/* Moreau documentation custom styles */

/* Enhanced card styling */
.sd-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border-radius: 12px !important;
}

.sd-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15) !important;
}

/* Framework-specific cards */
.sd-card-numpy {
    border-top: 4px solid #4dabcf !important;
    background: linear-gradient(180deg, rgba(77, 171, 207, 0.05) 0%, transparent 100%) !important;
}

.sd-card-pytorch {
    border-top: 4px solid #ee4c2c !important;
    background: linear-gradient(180deg, rgba(238, 76, 44, 0.05) 0%, transparent 100%) !important;
}

.sd-card-jax {
    border-top: 4px solid #5e35b1 !important;
    background: linear-gradient(180deg, rgba(94, 53, 177, 0.05) 0%, transparent 100%) !important;
}

.sd-card-cvxpy {
    border-top: 4px solid #f59e0b !important;
    background: linear-gradient(180deg, rgba(245, 158, 11, 0.05) 0%, transparent 100%) !important;
}

/* Card title styling */
.sd-card-title {
    font-weight: 600 !important;
    font-size: 1.1rem !important;
}

/* Grid spacing */
.sd-row {
    margin-bottom: 1rem;
}

/* Section dividers */
hr {
    margin: 2.5rem 0 !important;
    border: none !important;
    border-top: 1px solid var(--color-background-border) !important;
}

/* Better heading spacing */
h2 {
    margin-top: 2rem !important;
    margin-bottom: 1rem !important;
}

/* Border accent classes */
.sd-border-primary {
    border-left: 4px solid var(--color-brand-primary) !important;
}

.sd-border-secondary {
    border-left: 4px solid var(--color-foreground-muted) !important;
}

/* Feature cards */
.sd-card-feature {
    border-left: 3px solid var(--color-brand-primary) !important;
}

.sd-card-feature .sd-card-title {
    color: var(--color-brand-primary) !important;
}

/* Use case cards - compact pills */
.sd-card-usecase {
    background: var(--color-background-secondary) !important;
    border: none !important;
    padding: 0.5rem !important;
}

.sd-card-usecase .sd-card-title {
    font-size: 0.95rem !important;
    margin-bottom: 0.25rem !important;
}

.sd-card-usecase .sd-card-body {
    font-size: 0.85rem !important;
    color: var(--color-foreground-secondary) !important;
}

/* Buttons */
.sd-btn-primary {
    border-radius: 8px !important;
}

/* Dropdown styling */
details.sd-dropdown {
    border-radius: 8px !important;
}

/* Badge row centering */
p:has(> a > img[alt="PyPI"]) {
    text-align: center;
}

/* Sticky sidebar TOC */
.sidebar-scroll {
    position: sticky;
    top: 1rem;
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
}

/* Copy button feedback animation */
.copybtn {
    transition: all 0.2s ease;
}

.copybtn:hover {
    transform: scale(1.1);
}

.copybtn.success {
    animation: copied 0.4s ease;
}

@keyframes copied {
    0% { transform: scale(1); }
    50% { transform: scale(1.3); background-color: #22c55e; }
    100% { transform: scale(1); }
}

/* Code block language labels */
div[class*="highlight-"] {
    position: relative;
}

div.highlight-python::before {
    content: "python";
    position: absolute;
    right: 2.5rem;
    top: 0.3rem;
    font-size: 0.65rem;
    color: var(--color-foreground-muted);
    opacity: 0.6;
    font-family: var(--font-stack--monospace);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

div.highlight-bash::before {
    content: "bash";
    position: absolute;
    right: 2.5rem;
    top: 0.3rem;
    font-size: 0.65rem;
    color: var(--color-foreground-muted);
    opacity: 0.6;
    font-family: var(--font-stack--monospace);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Version badge in sidebar */
.sidebar-brand-text::after {
    content: "v0.1.0";
    display: inline-block;
    font-size: 0.65rem;
    background: var(--color-brand-primary);
    color: white;
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    margin-left: 0.5rem;
    vertical-align: middle;
    font-weight: 600;
}

/* Dark mode adjustments */
@media (prefers-color-scheme: dark) {
    .sd-card:hover {
        box-shadow: 0 12px 24px rgba(0, 0, 0, 0.4) !important;
    }

    .sd-card-numpy {
        background: linear-gradient(180deg, rgba(77, 171, 207, 0.1) 0%, transparent 100%) !important;
    }

    .sd-card-pytorch {
        background: linear-gradient(180deg, rgba(238, 76, 44, 0.1) 0%, transparent 100%) !important;
    }

    .sd-card-jax {
        background: linear-gradient(180deg, rgba(94, 53, 177, 0.1) 0%, transparent 100%) !important;
    }

    .sd-card-cvxpy {
        background: linear-gradient(180deg, rgba(245, 158, 11, 0.1) 0%, transparent 100%) !important;
    }

    .sd-card-usecase {
        background: var(--color-background-hover) !important;
    }
}
