/* ============================================================
   Documentation LANDING page (GoDaddy-style API picker)
   ============================================================ */
.doc-band {
  border-bottom: 1px solid var(--gray-200);
  background: #fff;
  padding: 40px 0 34px;
}
.doc-band h1 { font-size: 38px; font-weight: 800; margin: 0; letter-spacing: -.02em; }

.doc-landing-wrap { background: var(--gray-50); padding: 40px 0 80px; min-height: calc(100vh - var(--header-h) - 360px); }
.doc-intro-card {
  max-width: 1040px; margin: 0 auto; background: #fff;
  border: 1px solid var(--gray-200); border-radius: 14px;
  box-shadow: var(--shadow-sm); padding: 40px 44px 48px;
}
.doc-intro-card h2 { font-size: 28px; font-weight: 800; margin: 0 0 14px; letter-spacing: -.01em; }
.doc-intro-card .intro { font-size: 16px; color: var(--gray-600); margin: 0 0 8px; max-width: 760px; }
.doc-intro-card .intro code {
  font-family: var(--mono); font-size: 13px; background: var(--gray-100);
  border: 1px solid var(--gray-200); padding: 2px 6px; border-radius: 5px; color: var(--op-navy);
}
.doc-intro-card hr { border: 0; border-top: 1px solid var(--gray-200); margin: 28px 0 34px; }

.api-button-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px 24px; justify-items: stretch; align-items: start;
}
@media (max-width: 860px) { .api-button-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .api-button-grid { grid-template-columns: 1fr; } }

.api-button {
  display: flex; align-items: center; justify-content: center;
  width: 100%; box-sizing: border-box;
  background: var(--op-navy); color: #fff; font-weight: 600; font-size: 15px;
  padding: 14px 20px; border-radius: 8px; text-align: center;
  transition: all .15s ease; border: 1px solid var(--op-navy);
}
.api-button:hover {
  background: var(--op-red); border-color: var(--op-red); color: #fff;
  transform: translateY(-2px); box-shadow: var(--shadow-md);
}
.api-button .count {
  margin-left: 9px; font-size: 11px; font-weight: 700; opacity: .7;
  background: rgba(255,255,255,.16); padding: 2px 7px; border-radius: 999px;
}

/* ============================================================
   XML API reference — command cards
   ============================================================ */
#xml-main { flex: 1 1 auto; overflow-y: auto; background: #fff; }
#xml-body { max-width: 1000px; margin: 0 auto; padding: 24px 28px 90px; }
#xml-body > .grp-title { font-size: 26px; font-weight: 800; color: var(--op-navy); margin: 0 0 4px; }
#xml-body > .grp-sub { color: var(--gray-500); font-size: 14.5px; margin: 0 0 22px; }

.xml-cmd { border: 1px solid var(--gray-200); border-radius: 10px; margin: 0 0 12px; overflow: hidden; background: #fff; }
.xml-cmd.open { box-shadow: var(--shadow-sm); }
.xml-cmd-head {
  display: flex; align-items: center; gap: 14px; padding: 12px 16px; cursor: pointer;
  background: rgba(9,178,87,.04); border-left: 4px solid #09B257; transition: background .12s ease;
}
.xml-cmd-head:hover { background: rgba(9,178,87,.09); }
.xml-cmd .badge {
  background: #09B257; color: #fff; font-family: var(--mono); font-weight: 700; font-size: 12px;
  padding: 5px 10px; border-radius: 6px; letter-spacing: .03em; flex-shrink: 0;
}
.xml-cmd .cmd-name { font-family: var(--mono); font-weight: 700; font-size: 15px; color: var(--op-navy); }
.xml-cmd .cmd-use { color: var(--gray-600); font-size: 13.5px; margin-left: auto; text-align: right; max-width: 52%; }
.xml-cmd .chev { flex-shrink: 0; transition: transform .18s ease; color: var(--gray-400); }
.xml-cmd.open .chev { transform: rotate(180deg); }

.xml-cmd-body { display: none; padding: 20px 20px 24px; border-top: 1px solid var(--gray-200); }
.xml-cmd.open .xml-cmd-body { display: block; }
.xml-cmd-body h4 {
  font-size: 12px; text-transform: uppercase; letter-spacing: .06em; color: var(--gray-500);
  margin: 22px 0 10px; font-weight: 700;
}
.xml-cmd-body h4:first-child { margin-top: 0; }
.xml-cmd-body .use-text { font-size: 15px; color: var(--gray-700); margin: 0; }

.pill-list { display: flex; flex-wrap: wrap; gap: 7px; }
.pill-list .pill {
  font-family: var(--mono); font-size: 12.5px; color: var(--op-navy);
  background: var(--gray-100); border: 1px solid var(--gray-200); padding: 4px 9px; border-radius: 6px;
}
.pill-list .pill .desc { color: var(--gray-500); font-family: var(--font); margin-left: 5px; }

.xml-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media (max-width: 720px) { .xml-cols { grid-template-columns: 1fr; } }

.code-tabs { display: flex; gap: 4px; margin: 4px 0 0; }
.code-tabs button {
  font: inherit; font-size: 13px; font-weight: 600; color: var(--gray-600);
  background: none; border: 0; border-bottom: 2px solid transparent; padding: 8px 12px; cursor: pointer;
}
.code-tabs button.active { color: var(--op-red); border-bottom-color: var(--op-red); }
.code-pane { display: none; }
.code-pane.active { display: block; }
.xml-code {
  background: var(--op-navy); color: #E6E9F0; border-radius: 8px; padding: 16px 18px; margin: 8px 0 0;
  overflow-x: auto; font-family: var(--mono); font-size: 13px; line-height: 1.65; white-space: pre;
  tab-size: 2;
}
.xml-code .t { color: #7EE7A8; }
.xml-code .a { color: #79C0FF; }
.xml-code .v { color: #FFD9A0; }
.xml-code .d { color: #6B7689; }
.src-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 18px; font-size: 13.5px; font-weight: 600; }

/* ============================================================
   Per-API REFERENCE page (Swagger UI, full width)
   ============================================================ */
.ref-topbar {
  border-bottom: 1px solid var(--gray-200); background: #fff;
  padding: 16px 0; position: sticky; top: var(--header-h); z-index: 50;
}
.ref-topbar .inner { max-width: 1100px; margin: 0 auto; padding: 0 28px; display: flex; align-items: center; gap: 14px; }
.ref-back { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; color: var(--gray-600); }
.ref-back:hover { color: var(--op-red); }
.ref-crumb { color: var(--gray-400); font-size: 14px; }
.ref-title { font-size: 18px; font-weight: 700; color: var(--op-navy); }
.ref-main { background: #fff; }

/* ============================================================
   Documentation page — GoDaddy-style layout + Openprovider theme
   Left sidebar of API groups + Swagger UI operation list.
   ============================================================ */

/* ---- Page shell: sidebar + main ---- */
.doc-layout {
  display: flex;
  height: calc(100vh - var(--header-h));
  overflow: hidden;
}

/* ---- Left sidebar ---- */
.doc-sidebar {
  width: 290px;
  flex-shrink: 0;
  border-right: 1px solid var(--gray-200);
  background: var(--gray-50);
  overflow-y: auto;
  padding: 22px 0 60px;
}
.doc-sidebar .ds-head { padding: 0 22px 14px; }
.doc-sidebar .ds-head h2 { font-size: 18px; margin: 0 0 4px; color: var(--op-navy); }
.doc-sidebar .ds-head p { margin: 0; font-size: 12.5px; color: var(--gray-500); }

.ds-search {
  margin: 6px 18px 16px; position: relative;
}
.ds-search input {
  width: 100%; padding: 9px 12px 9px 34px; font-size: 14px;
  border: 1px solid var(--gray-300); border-radius: 8px; background: #fff;
  font-family: var(--font); color: var(--ink); outline: none;
}
.ds-search input:focus { border-color: var(--op-red); box-shadow: 0 0 0 3px rgba(232,17,45,.12); }
.ds-search svg { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; stroke: var(--gray-400); fill: none; }

.ds-group { margin-bottom: 6px; }
.ds-group > .ds-group-label {
  display: block; padding: 8px 22px 6px; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; color: var(--gray-400);
}
.ds-group a {
  display: block; padding: 7px 22px; font-size: 14px; color: var(--gray-700);
  border-left: 3px solid transparent; cursor: pointer; transition: all .12s ease;
  overflow-wrap: anywhere;
}
.ds-group a:hover { background: #fff; color: var(--op-navy); }
.ds-group a.active { color: var(--op-red); border-left-color: var(--op-red); background: #fff; font-weight: 600; }
.ds-empty { padding: 10px 22px; color: var(--gray-400); font-size: 13px; }

@media (max-width: 880px) {
  .doc-sidebar { display: none; }
}

/* ---- Main (Swagger UI) ---- */
.doc-main { flex: 1 1 auto; overflow-y: auto; background: #fff; }
#swagger { max-width: 1100px; margin: 0 auto; padding: 8px 28px 80px; }

/* ---- Loading ---- */
#doc-loading {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  flex-direction: column; height: calc(100vh - var(--header-h)); color: var(--gray-500); width: 100%;
}
#doc-loading .spinner {
  width: 42px; height: 42px; border-radius: 50%;
  border: 4px solid var(--gray-200); border-top-color: var(--op-red);
  animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   Swagger UI overrides — Openprovider brand
   ============================================================ */
.swagger-ui, .swagger-ui .info, .swagger-ui .opblock-tag,
.swagger-ui .opblock .opblock-summary-path,
.swagger-ui select, .swagger-ui .parameter__name, .swagger-ui table {
  font-family: var(--font) !important;
}

/* Hide the default huge info header (we provide our own page chrome) */
.swagger-ui .information-container { display: none; }
.swagger-ui .scheme-container { display: none; }

/* Tag section headers */
.swagger-ui .opblock-tag {
  font-size: 22px; font-weight: 700; color: var(--op-navy);
  border-bottom: 1px solid var(--gray-200); padding: 18px 0 12px; margin: 18px 0 0;
}
.swagger-ui .opblock-tag small { color: var(--gray-500); font-weight: 400; }
.swagger-ui .opblock-tag:hover { background: transparent; }

/* Operation blocks */
.swagger-ui .opblock {
  border-radius: 10px; margin: 0 0 12px; box-shadow: none;
  border: 1px solid var(--gray-200);
}
.swagger-ui .opblock .opblock-summary { padding: 8px 14px; }
.swagger-ui .opblock .opblock-summary-method {
  border-radius: 6px; font-family: var(--mono); font-weight: 700; min-width: 80px;
}
.swagger-ui .opblock .opblock-summary-path { font-family: var(--mono); font-size: 14px; color: var(--op-navy); }
.swagger-ui .opblock .opblock-summary-description { color: var(--gray-600); font-size: 13.5px; }

/* Method accent colours (semantic — matches GoDaddy) kept, just soften borders */
.swagger-ui .opblock.opblock-get { background: rgba(20,104,184,.03); border-color: rgba(20,104,184,.35); }
.swagger-ui .opblock.opblock-get .opblock-summary-method { background: #1468B8; }
.swagger-ui .opblock.opblock-post { background: rgba(9,178,87,.04); border-color: rgba(9,178,87,.35); }
.swagger-ui .opblock.opblock-post .opblock-summary-method { background: #09B257; }
.swagger-ui .opblock.opblock-put { background: rgba(199,119,0,.04); border-color: rgba(199,119,0,.35); }
.swagger-ui .opblock.opblock-put .opblock-summary-method { background: #C77700; }
.swagger-ui .opblock.opblock-delete { background: rgba(232,17,45,.04); border-color: rgba(232,17,45,.35); }
.swagger-ui .opblock.opblock-delete .opblock-summary-method { background: var(--op-red); }

/* Buttons → Openprovider red */
.swagger-ui .btn.authorize { color: var(--op-red); border-color: var(--op-red); }
.swagger-ui .btn.authorize svg { fill: var(--op-red); }
.swagger-ui .btn.execute {
  background: var(--op-red); border-color: var(--op-red); color: #fff;
}
.swagger-ui .btn.execute:hover { background: var(--op-red-dark); }
.swagger-ui .topbar { display: none; }

/* Links */
.swagger-ui a { color: var(--op-red); }

/* "Try it out" toggle */
.swagger-ui .try-out__btn { border-color: var(--gray-300); color: var(--op-navy); }

/* Models */
.swagger-ui section.models { border-color: var(--gray-200); border-radius: 10px; }
.swagger-ui section.models h4 { color: var(--op-navy); }

/* Response & code blocks */
.swagger-ui .responses-inner { padding: 16px 0 0; }
.swagger-ui .microlight, .swagger-ui .highlight-code {
  font-family: var(--mono) !important;
}

/* Filter box (we hide Swagger's; we use our own sidebar search) */
.swagger-ui .filter-container { display: none; }
