/* Custom Swagger UI Theme for Faxiom API */
/* Clean white/black theme matching the Faxiom app design */

/* ========================================
   ROOT VARIABLES & GLOBAL STYLES
   ======================================== */

:root {
  /* Primary brand colors */
  --primary-color: #f97316;
  --primary-hover: #ea580c;
  --primary-light: #fff7ed;
  
  /* Status colors */
  --success-color: #22c55e;
  --success-bg: #f0fdf4;
  --warning-color: #f59e0b;
  --warning-bg: #fffbeb;
  --error-color: #ef4444;
  --error-bg: #fef2f2;
  --info-color: #3b82f6;
  --info-bg: #eff6ff;
  
  /* Background colors */
  --bg-primary: #ffffff;
  --bg-secondary: #f9fafb;
  --bg-tertiary: #f3f4f6;
  --bg-card: #ffffff;
  --bg-hover: #f9fafb;
  
  /* Text colors */
  --text-primary: #111827;
  --text-secondary: #4b5563;
  --text-muted: #9ca3af;
  --text-inverse: #ffffff;
  
  /* Border colors */
  --border-color: #e5e7eb;
  --border-light: #f3f4f6;
  --border-dark: #d1d5db;
  
  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  
  /* Radius */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --radius-xl: 12px;
}

/* ========================================
   BASE STYLES
   ======================================== */

body {
  background: var(--bg-secondary) !important;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  color: var(--text-primary) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.swagger-ui {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  color: var(--text-primary) !important;
}

.swagger-ui .wrapper {
  max-width: 1400px !important;
  padding: 0 24px !important;
}

/* ========================================
   TOP BAR / HEADER
   ======================================== */

.swagger-ui .topbar {
  background: var(--bg-primary) !important;
  padding: 16px 24px !important;
  border-bottom: 1px solid var(--border-color) !important;
  box-shadow: var(--shadow-sm) !important;
}

.swagger-ui .topbar .download-url-wrapper {
  display: flex;
  align-items: center;
  gap: 12px;
}

.swagger-ui .topbar .download-url-wrapper .download-url-button {
  background: var(--primary-color) !important;
  border: none !important;
  border-radius: var(--radius-md) !important;
  padding: 10px 20px !important;
  font-weight: 600 !important;
  color: var(--text-inverse) !important;
  transition: all 0.2s ease !important;
}

.swagger-ui .topbar .download-url-wrapper .download-url-button:hover {
  background: var(--primary-hover) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.swagger-ui .topbar input[type=text] {
  background: var(--bg-secondary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-md) !important;
  color: var(--text-primary) !important;
  padding: 10px 16px !important;
}

.swagger-ui .topbar input[type=text]:focus {
  border-color: var(--primary-color) !important;
  box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.15) !important;
  outline: none !important;
}

/* Hide the default Swagger logo */
.swagger-ui .topbar-wrapper .link {
  display: flex;
  align-items: center;
}

.swagger-ui .topbar-wrapper img[alt="Swagger UI"] {
  display: none !important;
}

.swagger-ui .topbar-wrapper .link::before {
  content: "Faxiom API";
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.025em;
}

/* ========================================
   INFO SECTION (Title, Description)
   ======================================== */

.swagger-ui .information-container {
  background: var(--bg-primary) !important;
  padding: 32px !important;
  margin: 24px 0 !important;
  border-radius: var(--radius-xl) !important;
  border: 1px solid var(--border-color) !important;
  box-shadow: var(--shadow-sm) !important;
}

.swagger-ui .info {
  margin: 0 !important;
}

.swagger-ui .info .title {
  font-size: 32px !important;
  font-weight: 800 !important;
  color: var(--text-primary) !important;
  letter-spacing: -0.025em !important;
  margin-bottom: 8px !important;
}

.swagger-ui .info .title small {
  background: var(--bg-tertiary) !important;
  color: var(--text-secondary) !important;
  padding: 4px 12px !important;
  border-radius: var(--radius-md) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  vertical-align: middle !important;
  margin-left: 12px !important;
}

.swagger-ui .info .title small pre {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  color: inherit !important;
  font-family: inherit !important;
}

.swagger-ui .info .description {
  font-size: 15px !important;
  line-height: 1.7 !important;
  color: var(--text-secondary) !important;
}

.swagger-ui .info .description p {
  margin: 12px 0 !important;
  color: var(--text-secondary) !important;
}

.swagger-ui .info .description h2 {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  margin: 24px 0 12px 0 !important;
  padding-bottom: 8px !important;
  border-bottom: 1px solid var(--border-color) !important;
}

.swagger-ui .info .description ul {
  margin: 12px 0 !important;
  padding-left: 0 !important;
  list-style: none !important;
}

.swagger-ui .info .description li {
  margin: 8px 0 !important;
  padding-left: 20px !important;
  position: relative !important;
}

.swagger-ui .info .description li::before {
  content: "•" !important;
  position: absolute !important;
  left: 0 !important;
  color: var(--primary-color) !important;
  font-weight: bold !important;
}

.swagger-ui .info .description strong {
  color: var(--text-primary) !important;
  font-weight: 600 !important;
}

.swagger-ui .info .description a {
  color: var(--primary-color) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
}

.swagger-ui .info .description a:hover {
  text-decoration: underline !important;
}

.swagger-ui .info .description ol {
  counter-reset: step-counter !important;
  list-style: none !important;
  padding-left: 0 !important;
}

.swagger-ui .info .description ol li {
  counter-increment: step-counter !important;
  padding-left: 32px !important;
  position: relative !important;
  margin: 10px 0 !important;
}

.swagger-ui .info .description ol li::before {
  content: counter(step-counter) !important;
  position: absolute !important;
  left: 0 !important;
  width: 22px !important;
  height: 22px !important;
  background: var(--primary-color) !important;
  color: var(--text-inverse) !important;
  border-radius: 50% !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.swagger-ui .info .description code {
  background: var(--bg-tertiary) !important;
  color: var(--primary-color) !important;
  padding: 2px 8px !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 13px !important;
}

/* ========================================
   SECTION TAGS (Expandable Groups)
   ======================================== */

.swagger-ui .opblock-tag-section {
  margin-bottom: 8px !important;
}

.swagger-ui .opblock-tag {
  background: var(--bg-primary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-lg) !important;
  padding: 16px 20px !important;
  margin: 0 !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--text-primary) !important;
  transition: all 0.2s ease !important;
}

.swagger-ui .opblock-tag:hover {
  background: var(--bg-hover) !important;
  border-color: var(--border-dark) !important;
}

.swagger-ui .opblock-tag small {
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--text-muted) !important;
  padding-left: 12px !important;
}

.swagger-ui .expand-operation svg,
.swagger-ui .opblock-tag svg {
  fill: var(--text-muted) !important;
  transition: fill 0.2s ease !important;
}

.swagger-ui .opblock-tag:hover svg {
  fill: var(--text-secondary) !important;
}

/* ========================================
   OPERATION BLOCKS (GET, POST, PUT, DELETE)
   ======================================== */

.swagger-ui .opblock {
  margin: 8px 0 !important;
  border-radius: var(--radius-lg) !important;
  border: 1px solid var(--border-color) !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.swagger-ui .opblock .opblock-summary {
  padding: 12px 16px !important;
  border: none !important;
}

.swagger-ui .opblock .opblock-summary-method {
  min-width: 70px !important;
  padding: 6px 12px !important;
  border-radius: var(--radius-md) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.025em !important;
}

/* GET - Blue */
.swagger-ui .opblock-get {
  background: var(--info-bg) !important;
  border-color: #bfdbfe !important;
}

.swagger-ui .opblock-get .opblock-summary-method {
  background: var(--info-color) !important;
  color: var(--text-inverse) !important;
}

.swagger-ui .opblock-get .opblock-summary {
  border-color: transparent !important;
}

/* POST - Green */
.swagger-ui .opblock-post {
  background: var(--success-bg) !important;
  border-color: #bbf7d0 !important;
}

.swagger-ui .opblock-post .opblock-summary-method {
  background: var(--success-color) !important;
  color: var(--text-inverse) !important;
}

/* PUT - Orange */
.swagger-ui .opblock-put {
  background: var(--warning-bg) !important;
  border-color: #fde68a !important;
}

.swagger-ui .opblock-put .opblock-summary-method {
  background: var(--warning-color) !important;
  color: var(--text-inverse) !important;
}

/* DELETE - Red */
.swagger-ui .opblock-delete {
  background: var(--error-bg) !important;
  border-color: #fecaca !important;
}

.swagger-ui .opblock-delete .opblock-summary-method {
  background: var(--error-color) !important;
  color: var(--text-inverse) !important;
}

/* PATCH - Purple */
.swagger-ui .opblock-patch {
  background: #faf5ff !important;
  border-color: #e9d5ff !important;
}

.swagger-ui .opblock-patch .opblock-summary-method {
  background: #a855f7 !important;
  color: var(--text-inverse) !important;
}

/* Operation path and description */
.swagger-ui .opblock .opblock-summary-path {
  color: var(--text-primary) !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}

.swagger-ui .opblock .opblock-summary-description {
  color: var(--text-secondary) !important;
  font-size: 13px !important;
}

/* Expanded operation body */
.swagger-ui .opblock-body {
  background: var(--bg-primary) !important;
  padding: 20px !important;
}

.swagger-ui .opblock-body pre {
  background: var(--bg-tertiary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-md) !important;
  color: var(--text-primary) !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
}

/* ========================================
   PARAMETERS & RESPONSES
   ======================================== */

.swagger-ui .parameters-col_description {
  color: var(--text-secondary) !important;
}

.swagger-ui .parameter__name {
  color: var(--text-primary) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
}

.swagger-ui .parameter__name.required::after {
  color: var(--error-color) !important;
}

.swagger-ui .parameter__type {
  color: var(--text-muted) !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 12px !important;
}

.swagger-ui .parameter__in {
  color: var(--text-muted) !important;
  font-size: 11px !important;
  font-style: normal !important;
}

.swagger-ui table tbody tr td {
  border-color: var(--border-color) !important;
  padding: 12px 16px !important;
}

.swagger-ui table thead tr th {
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  padding: 12px 16px !important;
}

/* Response codes */
.swagger-ui .responses-inner {
  padding: 16px !important;
}

.swagger-ui .response-col_status {
  color: var(--text-primary) !important;
  font-weight: 600 !important;
}

.swagger-ui .response-col_description {
  color: var(--text-secondary) !important;
}

/* ========================================
   BUTTONS
   ======================================== */

.swagger-ui .btn {
  border-radius: var(--radius-md) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  padding: 8px 16px !important;
  transition: all 0.2s ease !important;
}

.swagger-ui .btn.execute {
  background: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
  color: var(--text-inverse) !important;
}

.swagger-ui .btn.execute:hover {
  background: var(--primary-hover) !important;
  border-color: var(--primary-hover) !important;
}

.swagger-ui .btn.cancel {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

.swagger-ui .btn.cancel:hover {
  background: var(--bg-secondary) !important;
  border-color: var(--border-dark) !important;
  color: var(--text-primary) !important;
}

.swagger-ui .btn.authorize {
  background: var(--success-color) !important;
  border-color: var(--success-color) !important;
  color: var(--text-inverse) !important;
}

.swagger-ui .btn.authorize:hover {
  background: #16a34a !important;
  border-color: #16a34a !important;
}

.swagger-ui .btn-group {
  padding: 16px 0 !important;
}

/* Try it out button */
.swagger-ui .try-out__btn {
  background: transparent !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-secondary) !important;
  border-radius: var(--radius-md) !important;
  padding: 6px 12px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}

.swagger-ui .try-out__btn:hover {
  background: var(--bg-tertiary) !important;
  border-color: var(--border-dark) !important;
  color: var(--text-primary) !important;
}

.swagger-ui .try-out__btn.cancel {
  background: var(--error-bg) !important;
  border-color: #fecaca !important;
  color: var(--error-color) !important;
}

/* ========================================
   INPUTS & TEXTAREAS
   ======================================== */

.swagger-ui input[type=text],
.swagger-ui input[type=password],
.swagger-ui input[type=email],
.swagger-ui input[type=search],
.swagger-ui textarea,
.swagger-ui select {
  background: var(--bg-primary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-md) !important;
  color: var(--text-primary) !important;
  padding: 10px 12px !important;
  font-size: 14px !important;
  transition: all 0.2s ease !important;
}

.swagger-ui input:focus,
.swagger-ui textarea:focus,
.swagger-ui select:focus {
  border-color: var(--primary-color) !important;
  box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.15) !important;
  outline: none !important;
}

.swagger-ui textarea {
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
}

.swagger-ui select {
  appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M3 5l3 3 3-3'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  padding-right: 36px !important;
}

/* ========================================
   MODELS / SCHEMAS
   ======================================== */

.swagger-ui section.models {
  background: var(--bg-primary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-lg) !important;
  margin: 24px 0 !important;
}

.swagger-ui section.models h4 {
  color: var(--text-primary) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  padding: 16px 20px !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--border-color) !important;
}

.swagger-ui section.models .model-container {
  margin: 8px 0 !important;
  background: var(--bg-secondary) !important;
  border-radius: var(--radius-md) !important;
}

.swagger-ui .model-box {
  background: var(--bg-secondary) !important;
  border-radius: var(--radius-md) !important;
  padding: 16px !important;
}

.swagger-ui .model {
  color: var(--text-primary) !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 13px !important;
}

.swagger-ui .model-title {
  color: var(--text-primary) !important;
  font-weight: 600 !important;
}

.swagger-ui .model .property {
  color: var(--info-color) !important;
}

.swagger-ui .model .property.primitive {
  color: var(--success-color) !important;
}

/* ========================================
   AUTHORIZATION
   ======================================== */

.swagger-ui .auth-wrapper {
  background: var(--bg-primary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-lg) !important;
  padding: 20px !important;
}

.swagger-ui .auth-container {
  padding: 0 !important;
}

.swagger-ui .auth-container h4 {
  color: var(--text-primary) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  margin-bottom: 16px !important;
}

.swagger-ui .auth-container .wrapper {
  margin: 12px 0 !important;
}

.swagger-ui .auth-btn-wrapper {
  padding-top: 16px !important;
  border-top: 1px solid var(--border-color) !important;
  margin-top: 16px !important;
}

.swagger-ui .authorization__btn {
  fill: var(--text-muted) !important;
}

.swagger-ui .authorization__btn.locked {
  fill: var(--success-color) !important;
}

.swagger-ui .authorization__btn.unlocked {
  fill: var(--text-muted) !important;
}

/* ========================================
   RESPONSE CODES
   ======================================== */

.swagger-ui .responses-wrapper {
  padding: 0 !important;
}

.swagger-ui .responses-table {
  padding: 0 !important;
}

.swagger-ui .response-col_status {
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 13px !important;
}

.swagger-ui .response-col_links {
  color: var(--text-muted) !important;
}

/* ========================================
   CODE HIGHLIGHTING
   ======================================== */

.swagger-ui .highlight-code {
  background: var(--bg-tertiary) !important;
  border-radius: var(--radius-md) !important;
}

.swagger-ui .highlight-code > .microlight {
  background: transparent !important;
  color: var(--text-primary) !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
  padding: 16px !important;
}

/* JSON syntax highlighting */
.swagger-ui .microlight .string { color: var(--success-color) !important; }
.swagger-ui .microlight .number { color: var(--primary-color) !important; }
.swagger-ui .microlight .boolean { color: var(--info-color) !important; }
.swagger-ui .microlight .null { color: var(--error-color) !important; }

/* ========================================
   MARKDOWN RENDERING
   ======================================== */

.swagger-ui .markdown p,
.swagger-ui .renderedMarkdown p {
  color: var(--text-secondary) !important;
  margin: 8px 0 !important;
}

.swagger-ui .markdown code,
.swagger-ui .renderedMarkdown code {
  background: var(--bg-tertiary) !important;
  color: var(--primary-color) !important;
  padding: 2px 6px !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'JetBrains Mono', 'Fira Code', monospace !important;
  font-size: 12px !important;
}

/* ========================================
   LOADING STATES
   ======================================== */

.swagger-ui .loading-container {
  padding: 40px !important;
}

.swagger-ui .loading-container .loading {
  font-size: 14px !important;
  color: var(--text-muted) !important;
}

.swagger-ui .loading-container .loading::after {
  color: var(--primary-color) !important;
}

/* ========================================
   FILTER INPUT
   ======================================== */

.swagger-ui .filter-container {
  background: var(--bg-primary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-lg) !important;
  padding: 16px 20px !important;
  margin: 24px 0 !important;
}

.swagger-ui .filter-container .filter input {
  width: 100% !important;
  max-width: 400px !important;
}

/* ========================================
   SCROLLBAR STYLING
   ======================================== */

.swagger-ui ::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

.swagger-ui ::-webkit-scrollbar-track {
  background: var(--bg-secondary);
  border-radius: 4px;
}

.swagger-ui ::-webkit-scrollbar-thumb {
  background: var(--border-dark);
  border-radius: 4px;
}

.swagger-ui ::-webkit-scrollbar-thumb:hover {
  background: var(--text-muted);
}

/* ========================================
   SERVER DROPDOWN
   ======================================== */

.swagger-ui .servers > label {
  color: var(--text-secondary) !important;
  font-weight: 500 !important;
  font-size: 13px !important;
}

.swagger-ui .servers > label select {
  min-width: 300px !important;
}

.swagger-ui .servers-title {
  color: var(--text-primary) !important;
  font-weight: 600 !important;
}

/* ========================================
   COPY TO CLIPBOARD
   ======================================== */

.swagger-ui .copy-to-clipboard {
  background: var(--bg-tertiary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-md) !important;
  padding: 8px !important;
}

.swagger-ui .copy-to-clipboard button {
  background: transparent !important;
  border: none !important;
}

/* ========================================
   VERSION BADGE
   ======================================== */

.swagger-ui .info .title small.version-stamp {
  background: var(--primary-light) !important;
  color: var(--primary-color) !important;
  border: 1px solid var(--primary-color) !important;
}

/* ========================================
   TABS (Request Body, Responses)
   ======================================== */

.swagger-ui .tab li {
  color: var(--text-muted) !important;
  font-weight: 500 !important;
  padding: 8px 16px !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
}

.swagger-ui .tab li.active {
  color: var(--text-primary) !important;
  background: var(--bg-primary) !important;
}

.swagger-ui .tab li:first-of-type::after {
  display: none !important;
}

/* ========================================
   EXAMPLE VALUES
   ======================================== */

.swagger-ui .example {
  background: var(--bg-secondary) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: var(--radius-md) !important;
  padding: 12px !important;
}

/* ========================================
   DEPRECATION STYLING
   ======================================== */

.swagger-ui .opblock-deprecated {
  opacity: 0.6 !important;
  border-style: dashed !important;
}

.swagger-ui .opblock-deprecated .opblock-summary-method {
  background: var(--text-muted) !important;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */

@media (max-width: 768px) {
  .swagger-ui .wrapper {
    padding: 0 16px !important;
  }
  
  .swagger-ui .information-container {
    padding: 20px !important;
  }
  
  .swagger-ui .info .title {
    font-size: 24px !important;
  }
  
  .swagger-ui .opblock .opblock-summary-method {
    min-width: 60px !important;
    font-size: 11px !important;
  }
}
