/* Basic modern, readable typography with light/dark theme support */
:root{
  --bg:#0b1020;
  --surface:#0f172a;
  --muted:#94a3b8;
  --text:#e2e8f0;
  --card:#111827;
  --brand:#0ea5e9;
  --brand-contrast:#031926;
  --ring:rgba(14,165,233,.35);
}

[data-theme="light"]{
  --bg:#f8fafc;
  --surface:#ffffff;
  --muted:#475569;
  --text:#0f172a;
  --card:#f1f5f9;
  --brand:#0ea5e9;
  --brand-contrast:#e6f7ff;
  --ring:rgba(14,165,233,.25);
}

html,body{height:100%}
html{color-scheme:dark light}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.container{max-width:1000px;margin:0 auto;padding:0 20px}

.site-header{position:sticky;top:0;background:rgba(2,6,23,.6);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid rgba(148,163,184,.15);z-index:10}
[data-theme="light"] .site-header{background:rgba(255,255,255,.7)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.brand .logo{font-size:22px}
.brand-logo{height:26px;width:auto;display:block;flex:0 0 auto}
.brand .title{font-size:16px}
.nav{display:flex;gap:12px;flex:1 1 auto;justify-content:center;min-width:0}
.nav-link{color:var(--muted);text-decoration:none;padding:8px 10px;border-radius:8px}
.nav-link[aria-current="page"],.nav-link:hover{color:var(--text);background:rgba(148,163,184,.12)}
.theme-toggle{border:1px solid rgba(148,163,184,.25);background:transparent;color:var(--text);border-radius:10px;padding:8px 10px;cursor:pointer;flex:0 0 auto}
.theme-toggle:focus{outline:none;box-shadow:0 0 0 4px var(--ring)}
.menu-toggle{display:none;border:1px solid rgba(148,163,184,.25);background:transparent;color:var(--text);border-radius:10px;padding:8px 10px;cursor:pointer}
.menu-icon{width:18px;height:18px}

/* Layout */
.layout{display:block;min-height:calc(100vh - 64px)}
.sidebar{width:260px;background:var(--surface);border-right:1px solid rgba(148,163,184,.15);overflow-y:auto;overflow-x:hidden;position:fixed;top:64px;left:0;height:calc(100vh - 64px);z-index:9}
.main-content{flex:1;overflow-y:auto;margin-left:260px}
body, .layout, .main-content{overflow-x:hidden}

/* Sidebar */
.sidebar-header{padding:20px;border-bottom:1px solid rgba(148,163,184,.15)}
.search-container{position:relative}
.search-input{width:100%;max-width:224px;padding:10px 40px 10px 12px;border:1px solid rgba(148,163,184,.25);border-radius:8px;background:var(--bg);color:var(--text);font-size:14px}
.search-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--ring)}
/* Icon styling */
.search-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;width:16px;height:16px}
.theme-icon{width:16px;height:16px;transition:opacity 0.2s}
.theme-icon.light-icon{opacity:0}
.theme-icon.dark-icon{opacity:1}
[data-theme="light"] .theme-icon.light-icon{opacity:1}
[data-theme="light"] .theme-icon.dark-icon{opacity:0}

/* Improved content formatting */
.prose{line-height:1.75;max-width:none;font-size:16px}
.prose h1{font-size:36px;font-weight:700;margin:2em 0 1em;color:var(--text);border-bottom:2px solid var(--brand);padding-bottom:0.5em;letter-spacing:-0.02em}
.prose h2{font-size:28px;font-weight:600;margin:2em 0 0.8em;color:var(--text);letter-spacing:-0.01em;scroll-margin-top:80px}
.prose h3{font-size:22px;font-weight:600;margin:1.8em 0 0.6em;color:var(--text);scroll-margin-top:80px}
.prose h4{font-size:18px;font-weight:600;margin:1.5em 0 0.5em;color:var(--text);scroll-margin-top:80px}
.prose p{margin:1.25em 0;color:var(--text);line-height:1.7}
.prose hr{border:none;border-top:1px solid rgba(148,163,184,.2);margin:3em 0;height:0}
.prose blockquote{border-left:4px solid var(--brand);background:rgba(14,165,233,.08);padding:1em 1.5em;margin:1.5em 0;border-radius:0 8px 8px 0;font-style:italic}
.prose code{background:rgba(148,163,184,.15);padding:0.2em 0.5em;border-radius:4px;font-size:0.9em;color:var(--text);font-family:'SF Mono',Monaco,'Cascadia Code','Roboto Mono',Consolas,'Courier New',monospace;font-weight:500}
.prose pre{background:#0a0f1c;border:1px solid rgba(148,163,184,.2);padding:1.5em;border-radius:12px;overflow:auto;margin:1.5em 0;position:relative;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}
[data-theme="light"] .prose pre{background:#f8fafc;box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06)}
.prose pre code{background:none;padding:0;color:inherit;font-size:0.875em;line-height:1.6}
.prose a{color:var(--brand);text-decoration:none;border-bottom:1px solid transparent;transition:all 0.2s;font-weight:500}
.prose a:hover{border-bottom-color:var(--brand);color:#38bdf8}
.prose table{border-collapse:collapse;width:100%;margin:1.5em 0;border:1px solid rgba(148,163,184,.2);border-radius:8px;overflow:hidden;display:block;white-space:nowrap;overflow-x:auto;box-shadow:0 1px 3px 0 rgba(0,0,0,.1)}
.prose thead{display:table-header-group;background:rgba(148,163,184,.08)}
.prose tbody{display:table-row-group}
.prose tr{display:table-row;transition:background-color 0.15s}
.prose tbody tr:hover{background:rgba(148,163,184,.05)}
.prose th,.prose td{display:table-cell;padding:14px 18px;border-bottom:1px solid rgba(148,163,184,.1);white-space:nowrap;vertical-align:top}
.prose th{background:rgba(148,163,184,.1);font-weight:600;text-align:left;border-bottom:1px solid rgba(148,163,184,.2);color:var(--text);font-size:0.9em;text-transform:uppercase;letter-spacing:0.5px}
.prose td{color:var(--text)}
.prose ul, .prose ol{margin:1.25em 0;padding-left:1.75em}
.prose li{margin:0.5em 0;color:var(--text);line-height:1.7}
.prose li::marker{color:var(--brand)}
.prose ul li{list-style-type:disc}
.prose ol li{list-style-type:decimal}
.prose strong{font-weight:600;color:var(--text)}
.prose em{font-style:italic;color:var(--text)}

/* Table of Contents */
.toc{padding:20px}
.toc-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:12px;text-transform:uppercase;letter-spacing:0.5px}
.toc-list{list-style:none;padding:0;margin:0}
.toc-list ul{list-style:none;padding-left:16px;margin:4px 0}
.toc-list li{margin:2px 0}
.toc-link{display:block;padding:6px 8px;color:var(--muted);text-decoration:none;border-radius:6px;font-size:14px;line-height:1.4;transition:all 0.2s}
.toc-link:hover{color:var(--text);background:rgba(148,163,184,.1)}
.toc-link.active{color:var(--brand);background:rgba(14,165,233,.1)}

/* Search highlighting */
.search-highlight{background:rgba(255,235,59,.3);padding:1px 2px;border-radius:3px}

/* Accessibility improvements */
.prose a:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:2px}
.prose code:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.prose pre:focus-within{outline:2px solid var(--brand);outline-offset:2px}

/* Smooth transitions */
.prose *{transition:color 0.2s ease,background-color 0.2s ease,border-color 0.2s ease}

/* Enhanced visual separators */
.prose hr::after{content:'';display:block;height:1px;background:linear-gradient(to right,transparent,var(--brand),transparent);margin-top:1px}

/* Better code block line numbers support */
.prose pre[data-line-numbers]{counter-reset:line-number}
.prose pre[data-line-numbers] code::before{counter-increment:line-number;content:counter(line-number);display:inline-block;width:2em;padding-right:1em;margin-right:1em;color:var(--muted);text-align:right;border-right:1px solid rgba(148,163,184,.2)}

/* Content adjustments */
.content{padding:40px 0}

.site-footer{padding:24px 0;border-top:1px solid rgba(148,163,184,.15);margin-top:24px}
.muted{color:var(--muted)}

.notice{padding:12px 14px;border:1px dashed rgba(148,163,184,.4);border-radius:10px;background:rgba(148,163,184,.08);margin:12px 0}
[data-theme="light"] .notice{background:rgba(15,23,42,.04)}

/* Enhanced callout boxes */
.prose .callout{position:relative;padding:16px 20px;margin:1.5em 0;border-radius:8px;border-left:4px solid;background:rgba(148,163,184,.08);box-shadow:0 1px 3px 0 rgba(0,0,0,.1)}
.prose .callout-note{border-left-color:#0ea5e9;background:rgba(14,165,233,.08)}
.prose .callout-warning{border-left-color:#f59e0b;background:rgba(245,158,11,.08)}
.prose .callout-error{border-left-color:#ef4444;background:rgba(239,68,68,.08)}
.prose .callout-success{border-left-color:#10b981;background:rgba(16,185,129,.08)}
.prose .callout-info{border-left-color:#6366f1;background:rgba(99,102,241,.08)}
.prose .callout-title{font-weight:600;margin-bottom:8px;color:var(--text);font-size:0.95em}
.prose .callout-content{margin:0;color:var(--text);line-height:1.6}

/* Badge/Tag styling */
.prose .badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:0.75em;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-left:8px;vertical-align:middle}
.prose .badge-required{background:rgba(239,68,68,.15);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}
.prose .badge-optional{background:rgba(148,163,184,.15);color:var(--muted);border:1px solid rgba(148,163,184,.3)}
.prose .badge-new{background:rgba(16,185,129,.15);color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}
.prose .badge-deprecated{background:rgba(245,158,11,.15);color:#fcd34d;border:1px solid rgba(245,158,11,.3)}

/* Enhanced code syntax highlighting colors */
.prose pre{color:#e2e8f0}
.prose pre .keyword{color:#c792ea}
.prose pre .string{color:#c3e88d}
.prose pre .number{color:#f78c6c}
.prose pre .function{color:#82aaff}
.prose pre .comment{color:#546e7a;font-style:italic}
.prose pre .variable{color:#ffcb6b}
.prose pre .operator{color:#89ddff}
.prose pre .punctuation{color:#c792ea}

/* Better JSON syntax in code blocks */
.prose pre .json-key{color:#c792ea}
.prose pre .json-string{color:#c3e88d}
.prose pre .json-number{color:#f78c6c}
.prose pre .json-boolean{color:#ff5370}
.prose pre .json-null{color:#546e7a}

/* Enhanced table styling */
.prose table{font-size:0.9em}
.prose table tbody tr:nth-child(even){background:rgba(148,163,184,.03)}
[data-theme="light"] .prose table tbody tr:nth-child(even){background:rgba(15,23,42,.02)}
.prose table tbody tr:last-child td{border-bottom:none}

/* Improved list styling */
.prose ul ul, .prose ol ol, .prose ul ol, .prose ol ul{margin:0.5em 0}
.prose li p{margin:0.5em 0}
.prose li code{font-size:0.9em}

/* Enhanced blockquote */
.prose blockquote p:first-child{margin-top:0}
.prose blockquote p:last-child{margin-bottom:0}

/* Better heading anchors */
.prose h1, .prose h2, .prose h3, .prose h4{position:relative}
.prose h2:hover::before, .prose h3:hover::before, .prose h4:hover::before{content:'#';position:absolute;left:-24px;color:var(--muted);opacity:0.5;font-weight:400}
.prose h2:hover::before, .prose h3:hover::before, .prose h4:hover::before{display:block}

/* Enhanced markdown elements */
.prose mark{background:rgba(255,235,59,.4);padding:2px 4px;border-radius:3px;color:inherit}
.prose del{text-decoration:line-through;opacity:0.7}
.prose ins{text-decoration:underline;text-decoration-color:var(--brand)}

/* Better spacing for nested content */
.prose > *:first-child{margin-top:0}
.prose > *:last-child{margin-bottom:0}

/* Iframe styling for HTML doc */
.doc-frame-wrap{margin:20px 0;border-radius:12px;overflow:hidden;border:1px solid rgba(148,163,184,.2)}
.doc-frame{width:100%;height:80vh;min-height:600px;border:none;background:var(--surface)}

/* Enhanced scrollbar styling */
.prose pre::-webkit-scrollbar{height:8px;width:8px}
.prose pre::-webkit-scrollbar-track{background:rgba(148,163,184,.1);border-radius:4px}
.prose pre::-webkit-scrollbar-thumb{background:rgba(148,163,184,.3);border-radius:4px}
.prose pre::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.5)}
.prose table::-webkit-scrollbar{height:8px}
.prose table::-webkit-scrollbar-track{background:rgba(148,163,184,.1);border-radius:4px}
.prose table::-webkit-scrollbar-thumb{background:rgba(148,163,184,.3);border-radius:4px}
.prose table::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,.5)}

/* Print styles */
@media print{
  .site-header,.sidebar,.site-footer{display:none}
  .main-content{margin-left:0}
  .prose{max-width:100%}
  .prose pre{background:#f5f5f5;border:1px solid #ddd}
  .prose table{border:1px solid #ddd}
}

/* Mobile responsiveness */
@media (max-width:768px){
  .menu-toggle{display:inline-flex}
  .nav{display:none}
  .layout{display:flex;flex-direction:column}
  .sidebar{position:fixed;left:-100%;top:64px;width:80%;max-width:320px;height:calc(100vh - 64px);border-right:1px solid rgba(148,163,184,.15);transition:left .25s ease;box-shadow:2px 0 8px rgba(0,0,0,.1)}
  .sidebar.open{left:0}
  .sidebar-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(2px);display:none;z-index:8}
  .sidebar-backdrop.show{display:block}
  .main-content{flex:none;margin-left:0;padding:0}
  .sidebar-header{padding:16px}
  .toc{padding:16px}
  .content{padding:20px 0}
  .hero-title{font-size:26px}
  .doc-frame{height:70vh;min-height:500px}
  .prose{font-size:15px;padding:0 16px}
  .prose h1{font-size:28px;margin:1.5em 0 0.8em}
  .prose h2{font-size:24px;margin:1.5em 0 0.7em}
  .prose h3{font-size:20px;margin:1.3em 0 0.6em}
  .prose h4{font-size:18px;margin:1.2em 0 0.5em}
  .prose pre{padding:1em;font-size:0.85em;overflow-x:auto}
  .prose table{font-size:0.85em;display:block}
  .prose th,.prose td{padding:10px 12px}
  .prose blockquote{padding:0.8em 1.2em}
  .container{padding:0 16px}
}

/* Tablet responsiveness */
@media (max-width:1024px) and (min-width:769px){
  .sidebar{width:240px}
  .main-content{margin-left:240px}
  .prose{font-size:15px}
}

/* Authentication Flow Styles */
.auth-flow{
  margin:2.5em 0;
  padding:0;
}

.flow-step{
  position:relative;
  background:var(--card);
  border:1px solid rgba(148,163,184,.2);
  border-radius:12px;
  padding:24px;
  margin:0;
  box-shadow:0 2px 8px rgba(0,0,0,.1);
  transition:all 0.3s ease;
}

[data-theme="light"] .flow-step{
  box-shadow:0 1px 3px rgba(0,0,0,.08);
}

.flow-step:hover{
  border-color:var(--brand);
  box-shadow:0 4px 12px rgba(14,165,233,.15);
  transform:translateY(-2px);
}

.step-number{
  position:absolute;
  top:-16px;
  left:24px;
  width:36px;
  height:36px;
  background:var(--brand);
  color:var(--brand-contrast);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:18px;
  box-shadow:0 2px 8px rgba(14,165,233,.3);
  z-index:1;
}

.step-content{
  margin-top:8px;
}

.step-title{
  font-size:20px;
  font-weight:600;
  color:var(--text);
  margin:0 0 12px 0;
  display:flex;
  align-items:center;
  gap:8px;
}

.step-description{
  color:var(--muted);
  margin:0 0 20px 0;
  line-height:1.6;
  font-size:15px;
}

.step-description strong{
  color:var(--text);
  font-weight:600;
}

.flow-arrow{
  display:flex;
  justify-content:center;
  align-items:center;
  margin:16px 0;
  color:var(--brand);
  opacity:0.7;
  animation:pulse 2s ease-in-out infinite;
}

@keyframes pulse{
  0%,100%{opacity:0.7;transform:translateY(0)}
  50%{opacity:1;transform:translateY(4px)}
}

.dashboard-preview{
  background:var(--surface);
  border:1px solid rgba(148,163,184,.2);
  border-radius:8px;
  padding:16px;
  margin-top:12px;
}

.dashboard-header{
  margin-bottom:16px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(148,163,184,.15);
}

.dashboard-tab{
  display:inline-block;
  padding:8px 16px;
  background:var(--brand);
  color:var(--brand-contrast);
  border-radius:6px;
  font-weight:600;
  font-size:14px;
}

.dashboard-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.btn-secondary,.btn-primary{
  padding:10px 18px;
  border-radius:8px;
  font-size:14px;
  font-weight:500;
  border:none;
  cursor:pointer;
  transition:all 0.2s;
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.btn-secondary{
  background:var(--surface);
  color:var(--text);
  border:1px solid rgba(148,163,184,.3);
}

.btn-primary{
  background:var(--brand);
  color:var(--brand-contrast);
}

.code-block-wrapper{
  margin:16px 0;
  border-radius:8px;
  overflow:hidden;
  border:1px solid rgba(148,163,184,.2);
  background:var(--surface);
}

.code-header{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 16px;
  background:rgba(148,163,184,.08);
  border-bottom:1px solid rgba(148,163,184,.15);
}

.code-method{
  padding:4px 10px;
  background:var(--brand);
  color:var(--brand-contrast);
  border-radius:4px;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.5px;
}

.code-endpoint{
  color:var(--text);
  font-family:'SF Mono',Monaco,'Cascadia Code','Roboto Mono',Consolas,'Courier New',monospace;
  font-size:13px;
  font-weight:500;
}

.code-block-wrapper pre{
  margin:0;
  border-radius:0;
  border:none;
  background:#0a0f1c;
  padding:16px;
}

[data-theme="light"] .code-block-wrapper pre{
  background:#f8fafc;
}

.response-block{
  margin-top:16px;
  border-radius:8px;
  overflow:hidden;
  border:1px solid rgba(16,185,129,.3);
  background:var(--surface);
}

.response-header{
  padding:12px 16px;
  background:rgba(16,185,129,.15);
  border-bottom:1px solid rgba(16,185,129,.2);
  color:#6ee7b7;
  font-weight:600;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.5px;
}

.response-block pre{
  margin:0;
  border-radius:0;
  border:none;
  background:#0a0f1c;
  padding:16px;
}

[data-theme="light"] .response-block pre{
  background:#f8fafc;
}

.headers-info{
  padding:12px 16px;
  background:rgba(148,163,184,.05);
  border-bottom:1px solid rgba(148,163,184,.15);
  display:flex;
  flex-direction:column;
  gap:8px;
}

.header-item{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:13px;
}

.header-name{
  color:var(--muted);
  font-weight:600;
  min-width:120px;
  font-family:'SF Mono',Monaco,'Cascadia Code','Roboto Mono',Consolas,'Courier New',monospace;
}

.header-value{
  color:var(--text);
  font-family:'SF Mono',Monaco,'Cascadia Code','Roboto Mono',Consolas,'Courier New',monospace;
}

.auth-note{
  margin-top:24px;
  padding:16px 20px;
  background:rgba(14,165,233,.08);
  border-left:4px solid var(--brand);
  border-radius:8px;
  color:var(--text);
  line-height:1.6;
  font-size:14px;
}

.auth-note strong{
  color:var(--text);
  font-weight:600;
}

.auth-note code{
  background:rgba(148,163,184,.2);
  padding:2px 6px;
  border-radius:4px;
  font-size:0.9em;
}

/* Mobile responsiveness for auth flow */
@media (max-width:768px){
  .flow-step{
    padding:20px 16px;
  }
  
  .step-number{
    width:32px;
    height:32px;
    font-size:16px;
    top:-14px;
    left:16px;
  }
  
  .step-title{
    font-size:18px;
  }
  
  .dashboard-actions{
    flex-direction:column;
  }
  
  .btn-secondary,.btn-primary{
    width:100%;
    justify-content:center;
  }
  
  .code-header{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }
  
  .header-item{
    flex-direction:column;
    align-items:flex-start;
    gap:4px;
  }
  
  .header-name{
    min-width:auto;
  }
}


