/* MotherHaven API Documentation Styles */
/* Dark theme with API endpoint styling */
/* CSS Custom Properties - Dark Theme */
:root {
--bg-primary: #0a0a0b;
--bg-secondary: #111113;
--bg-tertiary: #1a1a1d;
--text-primary: #e8e8ed;
--text-secondary: #7a7a85;
--text-muted: #4a4a55;
--border-primary: #2a2a30;
--border-secondary: #3a3a40;
--accent-green: #22c55e;
--accent-blue: #3b82f6;
--accent-orange: #f97316;
--accent-red: #ef4444;
--accent-purple: #a855f7;
--spacing-xs: 4px;
--spacing-sm: 8px;
--spacing-md: 16px;
--spacing-lg: 24px;
--spacing-xl: 32px;
--spacing-2xl: 48px;
--radius-sm: 4px;
--radius-md: 8px;
--radius-lg: 12px;
--font-mono: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;
--font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
}
/* Reset and Base Styles */
*, *::before, *::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html {
font-size: 16px;
scroll-behavior: smooth;
}
body {
font-family: var(--font-sans);
background-color: var(--bg-primary);
color: var(--text-primary);
line-height: 1.6;
min-height: 100vh;
}
/* Typography */
h1, h2, h3, h4, h5, h6 {
color: var(--text-primary);
font-weight: 600;
line-height: 1.3;
}
h1 {
font-size: 2.5rem;
margin-bottom: var(--spacing-lg);
}
h2 {
font-size: 1.75rem;
margin-bottom: var(--spacing-md);
}
h3 {
font-size: 1.25rem;
margin-bottom: var(--spacing-sm);
}
p {
color: var(--text-secondary);
margin-bottom: var(--spacing-md);
}
a {
color: var(--accent-blue);
text-decoration: none;
transition: color 0.2s ease;
}
a:hover {
color: var(--accent-purple);
}
/* Layout */
.container {
max-width: 1200px;
margin: 0 auto;
padding: var(--spacing-lg);
}
/* Base Header */
.header {
background-color: var(--bg-secondary);
border-bottom: 1px solid var(--border-primary);
padding: var(--spacing-md) 0;
}
.header-content {
max-width: 1200px;
margin: 0 auto;
padding: 0 var(--spacing-lg);
display: flex;
justify-content: space-between;
align-items: center;
}
.header-title {
margin: 0;
font-size: 1.5rem;
}
.header-title a {
color: var(--text-primary);
text-decoration: none;
}
.header-title a:hover {
color: var(--accent-blue);
}
.header-nav {
display: flex;
gap: var(--spacing-lg);
}
.nav-link {
color: var(--text-secondary);
font-size: 0.9375rem;
transition: color 0.2s ease;
}
.nav-link:hover {
color: var(--text-primary);
}
/* Main Content */
.main-content {
min-height: calc(100vh - 200px);
}
/* Footer */
.footer {
background-color: var(--bg-secondary);
border-top: 1px solid var(--border-primary);
padding: var(--spacing-xl);
text-align: center;
margin-top: var(--spacing-2xl);
}
.footer-content p {
color: var(--text-muted);
font-size: 0.875rem;
margin: 0;
margin-bottom: var(--spacing-xs);
}
.footer-version {
color: var(--text-muted) !important;
font-size: 0.75rem !important;
}
/* Header */
.docs-header {
background-color: var(--bg-secondary);
border-bottom: 1px solid var(--border-primary);
padding: var(--spacing-xl) 0;
text-align: center;
}
.docs-header h1 {
color: var(--text-primary);
font-size: 2.5rem;
margin-bottom: var(--spacing-sm);
}
.docs-header .subtitle {
color: var(--text-secondary);
font-size: 1.125rem;
}
.docs-header .version-badge {
display: inline-block;
background-color: var(--accent-blue);
color: white;
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: 0.875rem;
font-weight: 600;
margin-top: var(--spacing-md);
}
/* Navigation */
.docs-nav {
background-color: var(--bg-secondary);
border-bottom: 1px solid var(--border-primary);
position: sticky;
top: 0;
z-index: 100;
}
.docs-nav ul {
list-style: none;
display: flex;
flex-wrap: wrap;
gap: var(--spacing-sm);
padding: var(--spacing-md);
max-width: 1200px;
margin: 0 auto;
justify-content: center;
}
.docs-nav li a {
display: block;
padding: var(--spacing-xs) var(--spacing-md);
color: var(--text-secondary);
border-radius: var(--radius-sm);
font-size: 0.875rem;
transition: all 0.2s ease;
}
.docs-nav li a:hover {
background-color: var(--bg-tertiary);
color: var(--text-primary);
}
/* Main Content */
.docs-content {
padding: var(--spacing-2xl) 0;
}
/* API Category */
.api-category {
margin-bottom: var(--spacing-2xl);
scroll-margin-top: 80px;
}
.api-category-title {
display: flex;
align-items: center;
gap: var(--spacing-sm);
color: var(--text-primary);
font-size: 1.5rem;
font-weight: 600;
margin-bottom: var(--spacing-lg);
padding-bottom: var(--spacing-sm);
border-bottom: 2px solid var(--border-primary);
}
.api-category-title::before {
content: '';
width: 4px;
height: 24px;
background-color: var(--accent-blue);
border-radius: var(--radius-sm);
}
/* API Endpoint Card */
.api-endpoint {
background-color: var(--bg-secondary);
border: 1px solid var(--border-primary);
border-radius: var(--radius-md);
margin-bottom: var(--spacing-md);
overflow: hidden;
transition: border-color 0.2s ease;
}
.api-endpoint:hover {
border-color: var(--border-secondary);
}
.api-endpoint-header {
display: flex;
align-items: center;
gap: var(--spacing-md);
padding: var(--spacing-md);
background-color: var(--bg-tertiary);
border-bottom: 1px solid var(--border-primary);
}
/* HTTP Method Badges */
.api-method {
display: inline-block;
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-family: var(--font-mono);
font-size: 0.75rem;
font-weight: 700;
text-transform: uppercase;
color: white;
min-width: 60px;
text-align: center;
}
.api-method.get {
background-color: var(--accent-green);
}
.api-method.post {
background-color: var(--accent-blue);
}
.api-method.put {
background-color: var(--accent-orange);
}
.api-method.patch {
background-color: var(--accent-purple);
}
.api-method.delete {
background-color: var(--accent-red);
}
/* API Path */
.api-path {
font-family: var(--font-mono);
font-size: 0.9375rem;
color: var(--text-primary);
word-break: break-all;
}
a.api-path {
color: var(--accent-blue);
text-decoration: underline;
text-decoration-style: dotted;
text-underline-offset: 3px;
}
a.api-path:hover {
color: var(--accent-purple);
text-decoration-style: solid;
}
/* API Description */
.api-description {
padding: var(--spacing-md);
color: var(--text-secondary);
font-size: 0.9375rem;
margin: 0;
}
/* API Response Example */
.api-response-example {
padding: var(--spacing-md);
border-top: 1px solid var(--border-primary);
background-color: var(--bg-primary);
}
.api-response-example strong {
display: block;
color: var(--text-secondary);
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.05em;
margin-bottom: var(--spacing-sm);
}
/* Code Blocks */
pre, code {
font-family: var(--font-mono);
}
pre {
background-color: var(--bg-secondary);
border: 1px solid var(--border-primary);
border-radius: var(--radius-sm);
padding: var(--spacing-md);
overflow-x: auto;
font-size: 0.8125rem;
line-height: 1.5;
color: var(--text-primary);
}
code {
background-color: var(--bg-tertiary);
padding: 2px 6px;
border-radius: var(--radius-sm);
font-size: 0.875em;
color: var(--accent-purple);
}
pre code {
background: none;
padding: 0;
color: inherit;
}
/* Parameters Section */
.api-parameters {
padding: var(--spacing-md);
border-top: 1px solid var(--border-primary);
}
.api-parameters strong {
display: block;
color: var(--text-secondary);
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.05em;
margin-bottom: var(--spacing-sm);
}
.api-parameters ul {
list-style: none;
margin: 0;
padding: 0;
}
.api-parameters li {
display: flex;
align-items: flex-start;
gap: var(--spacing-sm);
padding: var(--spacing-xs) 0;
font-size: 0.875rem;
}
.param-name {
font-family: var(--font-mono);
color: var(--accent-blue);
font-weight: 500;
}
.param-type {
color: var(--text-muted);
font-size: 0.75rem;
}
.param-required {
color: var(--accent-red);
font-size: 0.75rem;
font-weight: 600;
}
.param-description {
color: var(--text-secondary);
}
/* Footer */
.docs-footer {
background-color: var(--bg-secondary);
border-top: 1px solid var(--border-primary);
padding: var(--spacing-xl);
text-align: center;
margin-top: var(--spacing-2xl);
}
.docs-footer p {
color: var(--text-muted);
font-size: 0.875rem;
margin: 0;
}
/* Utility Classes */
.text-muted {
color: var(--text-muted);
}
.text-secondary {
color: var(--text-secondary);
}
.text-success {
color: var(--accent-green);
}
.text-danger {
color: var(--accent-red);
}
/* Scrollbar Styling */
::-webkit-scrollbar {
width: 8px;
height: 8px;
}
::-webkit-scrollbar-track {
background: var(--bg-primary);
}
::-webkit-scrollbar-thumb {
background: var(--border-secondary);
border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
background: var(--text-muted);
}
/* Responsive */
@media (max-width: 768px) {
.container {
padding: var(--spacing-md);
}
.docs-header h1 {
font-size: 1.75rem;
}
.docs-nav ul {
flex-direction: column;
align-items: center;
}
.api-category-title {
font-size: 1.25rem;
}
.api-endpoint-header {
flex-direction: column;
align-items: flex-start;
gap: var(--spacing-sm);
}
.api-method {
min-width: auto;
}
pre {
font-size: 0.75rem;
}
}
@media (max-width: 480px) {
html {
font-size: 14px;
}
.docs-header {
padding: var(--spacing-lg) 0;
}
.container {
padding: var(--spacing-sm);
}
}