

/* Reset and Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    line-height: 1.6;
    color: var(--text-color);
    background-color: var(--background-color);
    font-size: var(--fs-0);
    transition: background-color var(--dur-theme) var(--ease-standard), color var(--dur-theme) var(--ease-standard);
}

/* Global helper to avoid body scroll when modals are open */
body.no-scroll { overflow: hidden; }

/* Skip link - Moved to utilities.css */

/* Focus styles */
:focus-visible {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

/* Container - Moved to utilities.css */





/* CTA Buttons - Moved to buttons.css */

/* Buttons - Moved to buttons.css */

/* Warnings and errors (CSP-safe) */
.warning-banner {
    background: var(--status-hold);
    color: #fff;
    padding: 10px 16px;
    border-radius: 4px;
    margin: 0 0 20px 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.warning-banner .warning-close {
    background: none; border: none; color: #fff; cursor: pointer; font-size: 20px;
}
.error-message { text-align: center; padding: 40px; background: var(--modal-bg); border-radius: 8px; margin-top: 20px; }
.error-message h2 { color: var(--status-hold); margin-bottom: 16px; }
.error-message p { margin-bottom: 24px; }





/* Latest Space Section */
.latest-space {
    background-color: rgba(var(--background-color-rgb, 245, 245, 247), 0.85);
    backdrop-filter: blur(1px);
    margin-bottom: var(--space-7);
}







/* Add top margin to main content to prevent navbar overlap */
main {
    margin-top: 64px;
}



.api-docs .page-header {
    margin-bottom: var(--space-6);
    text-align: center;
}

.api-docs .page-header h1 {
    font-size: var(--fs-3);
    margin-bottom: var(--space-4);
    color: var(--text-color);
}

.api-docs .page-header p {
    color: var(--text-secondary);
    font-size: 1.1rem;
}

/* Basic container for Swagger UI */
.swagger-container {
    margin-top: var(--space-5);
    background-color: var(--modal-bg);
    border-radius: var(--radius-card);
    border: 1px solid var(--modal-border);
    box-shadow: 0 2px 8px var(--modal-shadow);
    overflow: hidden;
}

/* Swagger UI Styles */
.swagger-ui .info {
    padding: 30px;
    background-color: var(--modal-bg);
    border-radius: var(--radius-card);
    margin: var(--space-5) 0;
    border: 1px solid var(--modal-border);
}

/* Swagger wrapper helpers (CSP-safe) */
.swagger-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--modal-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--modal-bg)
}
.swagger-header h2 { margin: 0; font-size: 1.2rem; }
.swagger-body { padding: 10px 0; }

.swagger-ui .info h2.title {
    color: var(--text-color);
    font-family: 'Inter', sans-serif;
    font-size: 24px;
    margin-bottom: var(--space-4);
}

.swagger-ui .info .description {
    color: var(--text-color);
    font-family: 'Inter', sans-serif;
}

.swagger-ui .info .description p,
.swagger-ui .info .description li {
    color: var(--text-color);
    line-height: 1.6;
    margin-bottom: var(--space-3);
}

/* Improve list styling */
.swagger-ui .info .description ul {
    margin: var(--space-3) 0 var(--space-5) 24px;
    list-style-position: outside;
}

.swagger-ui .info .description ul li {
    margin-bottom: 8px;
    position: relative;
    padding-left: 4px;
}

/* Style nested lists */
.swagger-ui .info .description ul ul {
    margin-top: var(--space-2);
    margin-left: var(--space-5);
}

/* Headers in description */
.swagger-ui .info .description h3,
.swagger-ui .info .description h4 {
    color: var(--text-color);
    margin: var(--space-6) 0 var(--space-3);
    font-family: 'Inter', sans-serif;
    font-weight: 600;
}

/* Swagger UI Servers Section */
.swagger-ui .scheme-container {
    background-color: var(--modal-bg);
    box-shadow: none;
    border: none;
    margin: 0;
    padding: 0;
}

.swagger-ui .servers-wrapper {
    background-color: var(--modal-bg);
    border: 1px solid var(--modal-border);
    border-radius: var(--radius-card);
    margin: 20px 0;
    padding: var(--space-6);
}

.swagger-ui .servers > label {
    color: var(--text-color);
    font-family: 'Inter', sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 16px;
    display: block;
}

/* Swagger UI Select - Moved to forms.css */

.swagger-ui .server-description {
    color: var(--text-secondary);
    font-family: 'Inter', sans-serif;
    font-size: 0.9rem;
    margin-top: 8px;
    line-height: 1.5;
}

/* Swagger UI Filter Input - Moved to forms.css */



.swagger-ui .info {
    background-color: var(--swagger-bg);
    color: var(--swagger-text);
}

.swagger-ui .info .title,
.swagger-ui .info h1,
.swagger-ui .info h2,
.swagger-ui .info h3,
.swagger-ui .info h4,
.swagger-ui .info h5,
.swagger-ui .info h6 {
    color: var(--swagger-text);
}

.swagger-ui .opblock {
    background-color: var(--swagger-bg);
    border: 1px solid var(--swagger-border);
}

.swagger-ui .opblock .opblock-summary {
    border-bottom: 1px solid var(--swagger-border);
}

.swagger-ui .opblock .opblock-summary-description {
    color: var(--swagger-text);
}

.swagger-ui .opblock-tag {
    color: var(--swagger-text);
    border-bottom: 1px solid var(--swagger-border);
}

.swagger-ui .opblock .opblock-section-header {
    background-color: var(--swagger-bg);
    border-bottom: 1px solid var(--swagger-border);
}

.swagger-ui .opblock .tab-header .tab-item {
    color: var(--swagger-text);
}

.swagger-ui .opblock .opblock-description-wrapper p,
.swagger-ui .opblock .opblock-external-docs-wrapper p,
.swagger-ui .opblock .opblock-title_normal p {
    color: var(--swagger-text);
}

.swagger-ui .opblock .opblock-summary-method {
    background-color: var(--swagger-method-get);
}

.swagger-ui .opblock.opblock-get {
    border-color: var(--swagger-method-get);
}

.swagger-ui .opblock.opblock-post {
    border-color: var(--swagger-method-post);
}

.swagger-ui .opblock.opblock-delete {
    border-color: var(--swagger-method-delete);
}

.swagger-ui .opblock.opblock-put {
    border-color: var(--swagger-method-put);
}

.swagger-ui .model-box {
    background-color: var(--swagger-code-bg);
    color: var(--swagger-code-text);
}

.swagger-ui .model {
    color: var(--swagger-text);
}

/* Swagger UI Form Elements - Moved to forms.css */

.swagger-ui .parameter__name,
.swagger-ui .parameter__type {
    color: var(--swagger-text);
}

.swagger-ui table thead tr td,
.swagger-ui table thead tr th {
    color: var(--swagger-text);
    border-bottom: 1px solid var(--swagger-border);
}

.swagger-ui .response-col_status {
    color: var(--swagger-text);
}

.swagger-ui .responses-inner h4,
.swagger-ui .responses-inner h5 {
    color: var(--swagger-text);
}

.swagger-ui .scheme-container {
    background-color: var(--swagger-bg);
    box-shadow: none;
    border-bottom: 1px solid var(--swagger-border);
}





    .feature-card {
        padding: 24px;
    }

    .footer-content {
        grid-template-columns: 1fr;
        gap: 30px;
        padding: 0 20px;
    }
}

/* Responsive styles moved to component files - Phase 5.2 cleanup */



/* API Example Button - Moved to buttons.css */








.section-heading {
    text-align: center;
    font-size: 3rem;
    margin-bottom: 24px;
    color: var(--text-color);
}

/* Launches Grid */
.launches-grid-preview {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 320px)); /* Dynamic columns: fixed width, auto-fit for centering */
    justify-content: center; /* Centers columns horizontally */
    gap: var(--space-6); /* Consistent spacing */
    margin-bottom: var(--space-6);
    padding-top: var(--space-2);
    padding-bottom: var(--space-2);
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    overflow: visible; /* Prevent clipping hover effects */
}

/* Launches grid responsive styles moved to sections.css - Phase 5.2 cleanup */



/* News Grid - Horizontal scroll on mobile */
.news-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* Fixed 3 columns for news */
    gap: var(--space-6);
    overflow-x: auto; /* Enable horizontal scroll */
    scroll-snap-type: x proximity; /* Smooth snapping */
    padding-top: var(--space-2); /* Add top padding to prevent hover animation clipping */
    padding-bottom: var(--space-4); /* For scroll shadow if needed */
}

/* Sub-section headings in Latest in Space */
.latest-space h3 {
    font-size: 1.5rem;
    margin: 24px 0 16px 0;
    color: var(--text-color);
    font-weight: 600;
    text-align: center;
}

.latest-space h3:first-of-type {
    margin-top: 0;
}

/* Ensure card containers don't clip hover animations */
.launches-grid-preview,
.news-grid {
    overflow: visible;
}

.news-grid article {
    scroll-snap-align: start; /* Snap to card edges */
}

/* Launches and news grid responsive styles moved to sections.css - Phase 5.2 cleanup */


/* Removed conflicting hover rule - using the one in launches.css */
















/* Removed conflicting hover rule - using the one in launches.css */























