/* ============================================
   PREMIUM API DOCS THEME
   Stripe / Vercel / Supabase inspired
   ============================================ */

/* --- CSS Custom Properties: Light Mode (default) --- */
:root,
[data-theme="light"] {
    --bg-primary:        #f8f9fb;
    --bg-secondary:      #ffffff;
    --bg-tertiary:       #f1f3f5;
    --bg-sidebar:        #fafbfc;
    --bg-sidebar-hover:  #f0f2f5;
    --bg-sidebar-active: #edf2ff;
    --bg-code:           #1e1e2e;
    --bg-right-panel:    #1a1b2e;
    --bg-input:          #ffffff;
    --bg-modal:          rgba(0,0,0,0.5);

    --text-primary:      #1a1a2e;
    --text-secondary:    #6b7280;
    --text-tertiary:     #9ca3af;
    --text-on-dark:      #e2e8f0;
    --text-code:         #e2e8f0;

    --accent:            #635bff;
    --accent-hover:      #4f46e5;
    --accent-light:      #818cf8;
    --accent-bg:         rgba(99,91,255,0.08);

    --border:            #e5e7eb;
    --border-light:      #f3f4f6;
    --border-focus:      #635bff;

    --method-get:        #10b981;
    --method-get-bg:     rgba(16,185,129,0.1);
    --method-post:       #3b82f6;
    --method-post-bg:    rgba(59,130,246,0.1);
    --method-put:        #f59e0b;
    --method-put-bg:     rgba(245,158,11,0.1);
    --method-delete:     #ef4444;
    --method-delete-bg:  rgba(239,68,68,0.1);

    --shadow-sm:         0 1px 2px rgba(0,0,0,0.04);
    --shadow-md:         0 4px 12px rgba(0,0,0,0.06);
    --shadow-lg:         0 8px 24px rgba(0,0,0,0.08);
    --shadow-xl:         0 12px 40px rgba(0,0,0,0.12);

    --radius-sm:         8px;
    --radius-md:         12px;
    --radius-lg:         16px;
    --radius-full:       9999px;

    --header-height:     56px;
    --sidebar-width:     280px;

    --font-sans:         'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-mono:         'JetBrains Mono', 'Fira Code', ui-monospace, SFMono-Regular, Menlo, monospace;

    --transition-fast:   150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-normal: 250ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow:   350ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* --- CSS Custom Properties: Dark Mode --- */
[data-theme="dark"] {
    --bg-primary:        #0f1117;
    --bg-secondary:      #1a1b2e;
    --bg-tertiary:       #252736;
    --bg-sidebar:        #13141f;
    --bg-sidebar-hover:  #1e1f31;
    --bg-sidebar-active: #1e2243;
    --bg-code:           #0d0e17;
    --bg-right-panel:    #0d0e17;
    --bg-input:          #1a1b2e;
    --bg-modal:          rgba(0,0,0,0.7);

    --text-primary:      #e2e8f0;
    --text-secondary:    #94a3b8;
    --text-tertiary:     #64748b;
    --text-on-dark:      #e2e8f0;
    --text-code:         #e2e8f0;

    --accent:            #818cf8;
    --accent-hover:      #a5b4fc;
    --accent-light:      #a5b4fc;
    --accent-bg:         rgba(129,140,248,0.12);

    --border:            #2d2e3f;
    --border-light:      #1e1f31;
    --border-focus:      #818cf8;

    --method-get:        #34d399;
    --method-get-bg:     rgba(52,211,153,0.12);
    --method-post:       #60a5fa;
    --method-post-bg:    rgba(96,165,250,0.12);
    --method-put:        #fbbf24;
    --method-put-bg:     rgba(251,191,36,0.12);
    --method-delete:     #f87171;
    --method-delete-bg:  rgba(248,113,113,0.12);

    --shadow-sm:         0 1px 2px rgba(0,0,0,0.2);
    --shadow-md:         0 4px 12px rgba(0,0,0,0.3);
    --shadow-lg:         0 8px 24px rgba(0,0,0,0.4);
    --shadow-xl:         0 12px 40px rgba(0,0,0,0.5);
}


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

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

html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body {
    margin: 0;
    padding: 0;
    background-color: var(--bg-primary) !important;
    color: var(--text-primary);
    font-family: var(--font-sans);
    transition: background-color var(--transition-normal), color var(--transition-normal);
}


/* ============================================
   CUSTOM HEADER BAR
   ============================================ */

#docs-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
    z-index: 1000;
    border-bottom: 1px solid var(--border);
    background: rgba(248,249,251,0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: background var(--transition-normal), border-color var(--transition-normal);
}

[data-theme="dark"] #docs-header {
    background: rgba(15,17,23,0.9);
}

.header-left {
    display: flex;
    align-items: center;
    gap: 12px;
}

.header-logo {
    height: 28px;
    width: auto;
}

.header-divider {
    width: 1px;
    height: 20px;
    background: var(--border);
}

.header-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: -0.01em;
    transition: color var(--transition-normal);
}

.header-version {
    font-size: 11px;
    font-weight: 500;
    color: var(--text-tertiary);
    background: var(--bg-tertiary);
    padding: 2px 8px;
    border-radius: var(--radius-full);
    letter-spacing: 0.02em;
    transition: background var(--transition-normal), color var(--transition-normal);
}

.header-right {
    display: flex;
    align-items: center;
    gap: 12px;
}


/* ============================================
   SEARCH TRIGGER BUTTON (in header)
   ============================================ */

.search-trigger {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px 7px 10px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-family: var(--font-sans);
    font-size: 13px;
    color: var(--text-tertiary);
    min-width: 240px;
    transition: all var(--transition-fast);
}

.search-trigger:hover {
    border-color: var(--border-focus);
    color: var(--text-secondary);
    box-shadow: var(--shadow-sm);
}

.search-trigger-icon {
    flex-shrink: 0;
    opacity: 0.5;
}

.search-trigger-text {
    flex: 1;
    text-align: left;
}

.search-trigger-shortcut {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 500;
    color: var(--text-tertiary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 1px 6px;
    line-height: 1.4;
}


/* ============================================
   THEME TOGGLE BUTTON
   ============================================ */

.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    cursor: pointer;
    color: var(--text-secondary);
    transition: all var(--transition-fast);
}

.theme-toggle:hover {
    border-color: var(--border-focus);
    color: var(--accent);
    background: var(--accent-bg);
}

[data-theme="light"] .theme-icon-light { display: none; }
[data-theme="light"] .theme-icon-dark  { display: block; }
[data-theme="dark"]  .theme-icon-light { display: block; }
[data-theme="dark"]  .theme-icon-dark  { display: none; }


/* ============================================
   SEARCH MODAL OVERLAY
   ============================================ */

.search-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2000;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 20vh;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-normal), visibility var(--transition-normal);
}

.search-modal.active {
    opacity: 1;
    visibility: visible;
}

.search-modal-backdrop {
    position: absolute;
    inset: 0;
    background: var(--bg-modal);
    backdrop-filter: blur(4px);
}

.search-modal-content {
    position: relative;
    width: 100%;
    max-width: 560px;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--border);
    overflow: hidden;
    transform: scale(0.98) translateY(-10px);
    transition: transform var(--transition-normal), background var(--transition-normal), border-color var(--transition-normal);
}

.search-modal.active .search-modal-content {
    transform: scale(1) translateY(0);
}

.search-modal-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
}

.search-modal-icon {
    flex-shrink: 0;
    color: var(--text-tertiary);
}

.search-modal-input {
    flex: 1;
    border: none !important;
    background: transparent !important;
    font-family: var(--font-sans);
    font-size: 16px !important;
    color: var(--text-primary) !important;
    outline: none !important;
    padding: 0 !important;
    box-shadow: none !important;
}

.search-modal-input::placeholder {
    color: var(--text-tertiary) !important;
}

.search-modal-esc {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 500;
    color: var(--text-tertiary);
    background: var(--bg-tertiary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 2px 8px;
}

.search-modal-results {
    display: none;
    max-height: 320px;
    overflow-y: auto;
    border-bottom: 1px solid var(--border);
}

.search-result-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 10px 20px;
    cursor: pointer;
    transition: background-color var(--transition-fast);
    border-bottom: 1px solid var(--border-light);
}

.search-result-item:last-child {
    border-bottom: none;
}

.search-result-item:hover,
.search-result-item.active {
    background-color: var(--accent-bg);
}

.search-result-text {
    font-size: 14px;
    color: var(--text-primary);
    line-height: 1.4;
    word-break: break-word;
}

.search-result-text strong {
    color: var(--accent);
    font-weight: 600;
}

.search-result-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.search-result-badge {
    flex-shrink: 0;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 2px 6px;
    border-radius: 4px;
    line-height: 1.4;
}

.search-badge-endpoint {
    background: var(--method-get-bg);
    color: var(--method-get);
}

.search-badge-parameter {
    background: var(--method-post-bg);
    color: var(--method-post);
}

.search-badge-field {
    background: var(--accent-bg);
    color: var(--accent);
}

.search-badge-description {
    background: var(--bg-tertiary);
    color: var(--text-secondary);
}

.search-result-section {
    font-size: 12px;
    color: var(--text-tertiary);
    line-height: 1.3;
    padding-left: 2px;
}

.search-result-empty {
    padding: 20px;
    text-align: center;
    color: var(--text-tertiary);
    font-size: 13px;
}

.search-modal-hint {
    padding: 24px 20px;
    color: var(--text-tertiary);
    font-size: 13px;
    text-align: center;
}


/* ============================================
   REDOC CONTAINER & WRAPPER
   ============================================ */

#redoc-container {
    margin-top: var(--header-height);
}

.redoc-wrap {
    font-family: var(--font-sans) !important;
    background-color: var(--bg-primary) !important;
    color: var(--text-primary) !important;
    transition: background-color var(--transition-normal), color var(--transition-normal);
}


/* ============================================
   SIDEBAR
   ============================================ */

.menu-content {
    background-color: var(--bg-sidebar) !important;
    border-right: 1px solid var(--border) !important;
    top: var(--header-height) !important;
    height: calc(100vh - var(--header-height)) !important;
    transition: background-color var(--transition-normal), border-color var(--transition-normal);
}

/* Hide ReDoc's built-in logo */
.menu-content > div:first-child {
    display: none !important;
}

/* Hide API version number (e.g. "1.0.0" with parentheses) in the title */
.api-info h1 span {
    display: none !important;
}

/* Sidebar search container */
.menu-content [role="search"] {
    padding: 16px 16px 12px !important;
    margin: 0 !important;
}

/* Sidebar search input */
.menu-content .search-input {
    width: 100% !important;
    margin: 0 !important;
    padding: 8px 12px 8px 36px !important;
    background: var(--bg-input) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    font-family: var(--font-sans) !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
}

.menu-content .search-input:focus {
    border-color: var(--border-focus) !important;
    box-shadow: 0 0 0 3px var(--accent-bg) !important;
    outline: none !important;
}

.menu-content .search-input::placeholder {
    color: var(--text-tertiary) !important;
}

/* Sidebar search icon */
.menu-content .search-icon {
    left: 28px !important;
}
.menu-content .search-icon path {
    fill: var(--text-tertiary) !important;
}

/* Sidebar scrollable area */
.menu-content .scrollbar-container {
    padding: 8px 0 !important;
}

/* Sidebar group headers (depth 0) */
.menu-content label.-depth0 {
    padding: 20px 20px 8px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: var(--text-tertiary) !important;
    background: transparent !important;
    cursor: default !important;
    opacity: 1 !important;
    border: none !important;
    border-bottom: none !important;
}

/* Sidebar category items (depth 1) */
.menu-content label.-depth1 {
    padding: 8px 20px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--text-secondary) !important;
    background: transparent !important;
    border-radius: 0 !important;
    margin: 0 !important;
    transition: color var(--transition-fast), background-color var(--transition-fast) !important;
}

.menu-content label.-depth1:hover {
    color: var(--text-primary) !important;
    background-color: var(--bg-sidebar-hover) !important;
}

/* Sidebar endpoint items (depth 2) */
.menu-content label.-depth2 {
    padding: 6px 20px 6px 24px !important;
    font-size: 12.5px !important;
    font-weight: 400 !important;
    color: var(--text-secondary) !important;
    background: transparent !important;
    transition: color var(--transition-fast), background-color var(--transition-fast) !important;
}

.menu-content label.-depth2:hover {
    color: var(--text-primary) !important;
    background-color: var(--bg-sidebar-hover) !important;
}

/* Active sidebar item */
.menu-content label.-depth1.active,
.menu-content label.-depth2.active,
.menu-content [class*="active"] label.-depth1,
.menu-content [class*="active"] label.-depth2 {
    color: var(--accent) !important;
    background-color: var(--bg-sidebar-active) !important;
    font-weight: 600 !important;
}

/* Sidebar method badges (small pills) */
.menu-content .operation-type {
    font-size: 9px !important;
    font-weight: 700 !important;
    padding: 2px 6px !important;
    border-radius: var(--radius-full) !important;
    line-height: 1 !important;
    height: 18px !important;
    width: 38px !important;
    max-width: 38px !important;
    min-width: 38px !important;
    text-align: center !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-right: 8px !important;
    vertical-align: middle !important;
}

.menu-content .operation-type.get    { background-color: var(--method-get-bg) !important;    color: var(--method-get) !important; }
.menu-content .operation-type.post   { background-color: var(--method-post-bg) !important;   color: var(--method-post) !important; }
.menu-content .operation-type.put    { background-color: var(--method-put-bg) !important;    color: var(--method-put) !important; }
.menu-content .operation-type.patch  { background-color: var(--method-put-bg) !important;    color: var(--method-put) !important; }
.menu-content .operation-type.delete { background-color: var(--method-delete-bg) !important; color: var(--method-delete) !important; }

/* Sidebar arrows */
.menu-content svg polygon {
    fill: var(--text-tertiary) !important;
}

/* Hide "API docs by Redocly" */
.menu-content a[href*="redocly.com"] {
    display: none !important;
}


/* ============================================
   MAIN CONTENT AREA
   ============================================ */

.api-content {
    background-color: var(--bg-primary) !important;
    transition: background-color var(--transition-normal);
}

/* Section dividers */
.redoc-wrap [data-section-id] {
    border-bottom: 1px solid var(--border) !important;
    transition: border-color var(--transition-normal);
}


/* ============================================
   HEADINGS
   ============================================ */

.redoc-wrap h1 {
    font-family: var(--font-sans) !important;
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    font-size: 2em !important;
    line-height: 1.2 !important;
    letter-spacing: -0.02em !important;
    margin-bottom: 16px !important;
}

.redoc-wrap h2 {
    font-family: var(--font-sans) !important;
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    font-size: 1.5em !important;
    line-height: 1.3 !important;
    letter-spacing: -0.01em !important;
    margin: 0 0 16px !important;
}

.redoc-wrap h3 {
    font-family: var(--font-sans) !important;
    color: var(--text-primary) !important;
    font-weight: 600 !important;
    font-size: 1.1em !important;
    letter-spacing: -0.005em !important;
}

.redoc-wrap h5 {
    font-family: var(--font-sans) !important;
    color: var(--text-primary) !important;
    font-weight: 600 !important;
}


/* ============================================
   MARKDOWN CONTENT
   ============================================ */

.redoc-markdown,
.redoc-wrap .redoc-markdown {
    color: var(--text-primary) !important;
    line-height: 1.7 !important;
}

.redoc-markdown p {
    margin-bottom: 16px !important;
}

.redoc-markdown code {
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
    color: var(--accent) !important;
    background: var(--accent-bg) !important;
    padding: 2px 6px !important;
    border-radius: 4px !important;
    border: none !important;
}

.redoc-markdown pre {
    background: var(--bg-code) !important;
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border) !important;
    padding: 20px !important;
    overflow-x: auto !important;
}

.redoc-markdown pre code {
    color: var(--text-code) !important;
    background: transparent !important;
    padding: 0 !important;
    border: none !important;
}

/* Links */
.redoc-wrap a {
    color: var(--accent) !important;
    text-decoration: none !important;
    transition: color var(--transition-fast) !important;
}

.redoc-wrap a:hover {
    color: var(--accent-hover) !important;
    text-decoration: underline !important;
}


/* ============================================
   ENDPOINT BLOCKS
   ============================================ */

/* Endpoint summary bar (dark header with method + path) */
.redoc-wrap [class*="sc-buTqWO"] {
    background: var(--bg-code) !important;
    border-radius: var(--radius-md) !important;
    padding: 12px 16px !important;
    margin-bottom: 16px !important;
    border: 1px solid var(--border) !important;
    transition: box-shadow var(--transition-fast) !important;
}

.redoc-wrap [class*="sc-buTqWO"]:hover {
    box-shadow: var(--shadow-md) !important;
}

/* Endpoint path text */
.redoc-wrap [class*="sc-jvKoal"] {
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
}

/* HTTP method badges (large, in content) */
.redoc-wrap [class*="sc-fQLpxn"] {
    border-radius: var(--radius-full) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    padding: 4px 12px !important;
    letter-spacing: 0.02em !important;
    font-family: var(--font-mono) !important;
}


/* ============================================
   PARAMETER TABLES
   ============================================ */

/* Property name text */
.redoc-wrap [class*="sc-fbQrwq"] {
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
    color: var(--text-primary) !important;
}

/* Type labels */
.redoc-wrap [class*="sc-bEjUoa"] {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    color: var(--text-secondary) !important;
}

/* Required marker */
.redoc-wrap [class*="sc-iIvHqT"] {
    color: var(--method-delete) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
}

/* Parameter detail cells */
.redoc-wrap [class*="sc-gGKoUb"] {
    border-bottom-color: var(--border) !important;
    padding: 14px 12px !important;
}

/* Parameter name cells */
.redoc-wrap [class*="sc-kCuUfV"] {
    border-left-color: var(--border) !important;
    padding: 14px 12px !important;
}

/* HTML description tables — inline, no card wrapper */
.redoc-markdown table,
.confluenceTable {
    border-collapse: collapse !important;
    border: none !important;
    width: auto !important;
    background-color: transparent !important;
}

.redoc-markdown table th {
    background: var(--bg-tertiary) !important;
    color: var(--text-primary) !important;
    font-weight: 600 !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
    padding: 12px 16px !important;
    border: 1px solid var(--border) !important;
}

.redoc-markdown table td,
.confluenceTd {
    padding: 12px 16px !important;
    border: 1px solid var(--border-light) !important;
    color: var(--text-primary) !important;
    background-color: transparent !important;
}

.highlight-grey.confluenceTd,
[data-highlight-colour="grey"] {
    background: var(--bg-tertiary) !important;
    color: var(--text-primary) !important;
}

.redoc-markdown table tr {
    transition: background-color var(--transition-fast) !important;
}

.redoc-markdown table tr:hover td {
    background: var(--bg-tertiary) !important;
}


/* ============================================
   CODE BLOCKS & RIGHT PANEL
   ============================================ */

/* Right panel backgrounds */
.redoc-wrap [class*="sc-evkzZa"],
.redoc-wrap [class*="sc-jwTyAe"],
.redoc-wrap [class*="sc-hjsuWn"] {
    background-color: var(--bg-right-panel) !important;
}

/* Code block panels */
.redoc-wrap [class*="sc-ciCoXh"] {
    background: var(--bg-code) !important;
    border-radius: var(--radius-md) !important;
}

/* Response tabs */
.redoc-wrap [class*="sc-cOpnSz"] > ul > li {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0 !important;
    padding: 8px 16px !important;
    margin: 0 4px !important;
    transition: all var(--transition-fast) !important;
}

/* Copy button */
.redoc-wrap [class*="sc-bbbBoY"] {
    opacity: 0 !important;
    transition: opacity var(--transition-fast) !important;
}

.redoc-wrap [class*="sc-cdmAjP"]:hover [class*="sc-bbbBoY"],
.redoc-wrap [class*="sc-bbbBoY"]:focus-within {
    opacity: 1 !important;
}

.redoc-wrap [class*="sc-bbbBoY"] > button {
    font-family: var(--font-mono) !important;
    font-size: 12px !important;
    color: var(--text-tertiary) !important;
    padding: 4px 10px !important;
    border-radius: var(--radius-sm) !important;
    transition: all var(--transition-fast) !important;
}

.redoc-wrap [class*="sc-bbbBoY"] > button:hover {
    color: var(--text-on-dark) !important;
    background: rgba(255,255,255,0.1) !important;
}

/* JSON viewer */
.redoc-wrap [class*="sc-fhfEft"] {
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
}


/* ============================================
   RESPONSE STATUS BUTTONS
   ============================================ */

.redoc-wrap [class*="sc-jIDBmd"] {
    border-radius: var(--radius-sm) !important;
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
    padding: 10px 16px !important;
    margin-bottom: 6px !important;
    transition: all var(--transition-fast) !important;
    border: 1px solid transparent !important;
}

.redoc-wrap [class*="sc-jIDBmd"]:hover {
    box-shadow: var(--shadow-sm) !important;
}


/* ============================================
   PATH BLOCK (custom class from OpenAPI descriptions)
   ============================================ */

.path-block {
    color: var(--text-primary) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    background: var(--bg-tertiary) !important;
    padding: 12px 16px !important;
    font-family: var(--font-mono) !important;
    font-size: 13px !important;
    width: 100%;
    text-align: left;
    outline: 0;
}


/* ============================================
   STATUS INDICATORS
   ============================================ */

.pending    { color: var(--text-secondary); }
.confirmed  { color: var(--method-get); }
.cancelled  { color: var(--method-delete); }


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

::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--text-tertiary);
}


/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Sidebar items transitions */
.menu-content [role="menuitem"] {
    transition: all var(--transition-fast) !important;
}


/* ============================================
   DARK MODE — REDOC INTERNAL OVERRIDES
   ============================================ */

[data-theme="dark"] .redoc-wrap {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .redoc-wrap h1,
[data-theme="dark"] .redoc-wrap h2,
[data-theme="dark"] .redoc-wrap h3,
[data-theme="dark"] .redoc-wrap h5 {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .redoc-markdown,
[data-theme="dark"] .redoc-wrap .redoc-markdown {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .redoc-markdown code {
    color: var(--accent) !important;
    background: var(--accent-bg) !important;
}

/* Dark mode sidebar text */
[data-theme="dark"] .menu-content label {
    color: var(--text-secondary) !important;
}

[data-theme="dark"] .menu-content label.-depth0 {
    color: var(--text-tertiary) !important;
}

[data-theme="dark"] .menu-content label:hover {
    color: var(--text-primary) !important;
}

/* Dark mode property names */
[data-theme="dark"] .redoc-wrap [class*="sc-fbQrwq"] {
    color: var(--text-primary) !important;
}

/* Dark mode descriptions */
[data-theme="dark"] .redoc-wrap [class*="sc-boKDdR"],
[data-theme="dark"] .redoc-wrap [class*="sc-fOOuSg"] {
    color: var(--text-secondary) !important;
}

/* Dark mode buttons */
[data-theme="dark"] .redoc-wrap button {
    color: var(--text-secondary) !important;
}

/* Dark mode section borders */
[data-theme="dark"] .redoc-wrap [data-section-id] {
    border-bottom-color: var(--border) !important;
}

/* Dark mode search input */
[data-theme="dark"] .menu-content .search-input {
    background: var(--bg-input) !important;
    color: var(--text-primary) !important;
    border-color: var(--border) !important;
}

/* Dark mode table — dark bg, light text */
[data-theme="dark"] .redoc-markdown table,
[data-theme="dark"] .confluenceTable {
    border: none !important;
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .redoc-markdown table tbody,
[data-theme="dark"] .redoc-markdown table thead,
[data-theme="dark"] .redoc-markdown table tr {
    background-color: var(--bg-secondary) !important;
}

[data-theme="dark"] .redoc-markdown table td,
[data-theme="dark"] .confluenceTd {
    color: var(--text-primary) !important;
    border-color: var(--border) !important;
    background-color: var(--bg-secondary) !important;
}

[data-theme="dark"] .confluenceTd *,
[data-theme="dark"] .confluenceTable td *,
[data-theme="dark"] .confluenceTable th * {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .redoc-markdown table th {
    color: var(--text-primary) !important;
    border-color: var(--border) !important;
    background: var(--bg-tertiary) !important;
}

[data-theme="dark"] .redoc-markdown table .highlight-grey,
[data-theme="dark"] .redoc-markdown table [data-highlight-colour="grey"],
[data-theme="dark"] .highlight-grey.confluenceTd {
    background: var(--bg-tertiary) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .highlight-grey.confluenceTd *,
[data-theme="dark"] [data-highlight-colour="grey"] * {
    color: var(--text-primary) !important;
}

/* Dark mode parameter borders */
[data-theme="dark"] .redoc-wrap [class*="sc-gGKoUb"] {
    border-bottom-color: var(--border) !important;
}

[data-theme="dark"] .redoc-wrap [class*="sc-kCuUfV"] {
    border-left-color: var(--border) !important;
}

/* Dark mode right panel */
[data-theme="dark"] .redoc-wrap [class*="sc-evkzZa"],
[data-theme="dark"] .redoc-wrap [class*="sc-jwTyAe"],
[data-theme="dark"] .redoc-wrap [class*="sc-hjsuWn"] {
    background-color: var(--bg-right-panel) !important;
}

/* Dark mode inline type references */
[data-theme="dark"] .redoc-wrap [class*="sc-dTWiOz"] {
    background: var(--accent-bg) !important;
    color: var(--accent) !important;
}

/* Dark mode endpoint URL display */
[data-theme="dark"] .redoc-wrap [class*="sc-xKhEK"] {
    background: var(--bg-tertiary) !important;
    border-color: var(--border) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .redoc-wrap [class*="sc-xKhEK"] > span {
    color: var(--text-secondary) !important;
}


/* ============================================
   MOBILE RESPONSIVE
   ============================================ */

@media screen and (max-width: 50rem) {
    #docs-header {
        padding: 0 16px;
    }

    .search-trigger {
        min-width: auto;
    }

    .search-trigger-text {
        display: none;
    }

    .search-trigger-shortcut {
        display: none;
    }

    .header-title {
        display: none;
    }

    .header-version {
        display: none;
    }

    .search-modal-content {
        margin: 0 16px;
    }
}
