/* Merged tabs - put nav tabs inline with header */
.md-header__title {
    width: fit-content;
    min-width: 6rem;
}

.md-header__inner .md-tabs {
    position: absolute;
    left: 0;
    right: 0;
    z-index: inherit;
    background: transparent;
    pointer-events: none;
}

.md-header__inner .md-tabs .md-tabs__list {
    justify-content: center;
    pointer-events: auto;
}

@media screen and (min-width: 60em) and (max-width:76.234375em) {
    [data-md-toggle=search]:checked~.md-header .md-search__inner {
        width: 23rem;
    }
}

@media screen and (min-width: 76.25em) {
    [data-md-toggle=search]:checked~.md-header .md-search__inner {
        width: 33rem;
    }
}


/* Prevent scroll anchoring shifts on reload */
html {
    overflow-anchor: none;
}

/* Override mkdocs-material's aggressive font scaling */
@media screen and (min-width: 100em) {
    html {
        font-size: 125%;
    }
}

@media screen and (min-width: 125em) {
    html {
        font-size: 125%;
    }
}

/* Light theme */
[data-md-color-scheme="default"] {
    /* Warm light surfaces - darker = elevated, 12-step delta */
    --surface-base: #e4e4e6;
    --surface-container: #d8d8da;
    --surface-card: #ccccce;
    --nav-hover: #d2d2d4;
    --nav-pressed: #dedee0;

    /* Dark text on light */
    --text-high: rgba(0, 0, 0, 0.87);
    --text-medium: rgba(0, 0, 0, 0.60);
    --text-disabled: rgba(0, 0, 0, 0.38);

    /* Accent - Eden blue */
    --accent: #1a5276;

    /* Page backgrounds */
    --md-default-bg-color: var(--surface-container);
    --md-default-bg-color--light: var(--surface-card);
    --md-default-fg-color: var(--text-high);
    --md-default-fg-color--light: var(--text-medium);
    --md-default-fg-color--lighter: var(--text-medium);
    --md-default-fg-color--lightest: var(--text-disabled);

    --md-code-bg-color: var(--surface-card);
    --md-code-fg-color: var(--text-high);

    --md-accent-fg-color: var(--accent);
    --md-typeset-color: var(--text-high);
    --md-typeset-a-color: var(--accent);

    /* Shadows - subtle for light theme */
    --md-shadow-z1: 0 2px 4px rgba(0, 0, 0, 0.1);
    --md-shadow-z2: 0 4px 8px rgba(0, 0, 0, 0.15);
    --md-shadow-z3: 0 8px 16px rgba(0, 0, 0, 0.2);

    /* Light header/footer - lightest element */
    --md-primary-fg-color: #f0f0f2;
    --md-primary-fg-color--light: #f4f4f6;
    --md-primary-fg-color--dark: #ebebed;
    --md-primary-bg-color: rgba(0, 0, 0, 0.87);
    --md-primary-bg-color--light: rgba(0, 0, 0, 0.6);

    --md-footer-fg-color: rgba(0, 0, 0, 0.87);
    --md-footer-fg-color--light: rgba(0, 0, 0, 0.6);
    --md-footer-fg-color--lighter: rgba(0, 0, 0, 0.38);
    --md-footer-bg-color: #f0f0f2;
    --md-footer-bg-color--dark: #ebebed;
}

/* Dark theme */
[data-md-color-scheme="slate"] {
    /* Cool dark surfaces - 12-step delta */
    --surface-base: #121212;
    --surface-container: #1e1e1e;
    --surface-card: #2a2a2a;
    --nav-hover: #242424;
    --nav-pressed: #181818;

    /* Light text on dark */
    --text-high: rgba(255, 255, 255, 0.95);
    --text-medium: rgba(255, 255, 255, 0.70);
    --text-disabled: rgba(255, 255, 255, 0.38);

    /* Accent - Eden blue */
    --accent: #2e86ab;

    /* Page backgrounds */
    --md-default-bg-color: var(--surface-container);
    --md-default-bg-color--light: var(--surface-card);
    --md-default-fg-color: var(--text-high);
    --md-default-fg-color--light: var(--text-medium);
    --md-default-fg-color--lighter: var(--text-medium);
    --md-default-fg-color--lightest: var(--text-disabled);

    --md-code-bg-color: var(--surface-card);
    --md-code-fg-color: var(--text-high);

    --md-accent-fg-color: var(--accent);
    --md-typeset-color: var(--text-high);
    --md-typeset-a-color: var(--accent);

    /* Shadows - subtle for dark theme */
    --md-shadow-z1: 0 2px 4px rgba(0, 0, 0, 0.2);
    --md-shadow-z2: 0 4px 8px rgba(0, 0, 0, 0.25);
    --md-shadow-z3: 0 8px 16px rgba(0, 0, 0, 0.3);

    /* Dark header/footer */
    --md-primary-fg-color: #121212;
    --md-primary-fg-color--light: #1e1e1e;
    --md-primary-fg-color--dark: #0a0a0a;
    --md-primary-bg-color: rgba(255, 255, 255, 0.95);
    --md-primary-bg-color--light: rgba(255, 255, 255, 0.7);

    --md-footer-fg-color: rgba(255, 255, 255, 0.95);
    --md-footer-fg-color--light: rgba(255, 255, 255, 0.7);
    --md-footer-fg-color--lighter: rgba(255, 255, 255, 0.38);
    --md-footer-bg-color: #121212;
    --md-footer-bg-color--dark: #0a0a0a;
}


/* Hide sidebars on desktop only - mobile drawer still works for nav */
@media (min-width: 76.25em) {
    .md-sidebar--primary,
    .md-sidebar--secondary {
        display: none !important;
    }
}


/* Mobile drawer fixes - override mkdocs-material's hardcoded 242px */
@media (max-width: 76.1875em) {
    .md-sidebar--primary {
        width: 66vw !important;
        max-width: none !important;
        left: 0 !important;
        inset-inline-start: 0 !important;
        transform: translateX(-100%) !important;
        transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }

    [data-md-toggle="drawer"]:checked ~ .md-container .md-sidebar--primary {
        transform: translateX(0) !important;
    }
}

.md-nav--primary {
    /* Start below header, extend to bottom using dynamic viewport */
    top: var(--md-toolbar-height, 48px) !important;
    bottom: 0 !important;
    height: auto !important;
    width: 100% !important;
}

/* Hide sidebar title - logo is in header instead */
.md-nav--primary > .md-nav__title {
    display: none;
}

/* Mobile sidebar nav styling */
.md-nav--primary .md-nav__item {
    border: none;
}

.md-nav--primary .md-nav__link {
    margin: 0;
    padding: 0.5rem 1rem;
    border-radius: 0;
    transition: background 0.15s ease;
    color: var(--text-high) !important;
}

.md-nav--primary .md-nav__link:hover {
    background: var(--nav-hover);
}

.md-nav--primary .md-nav__link:active {
    background: var(--nav-pressed);
}

.md-nav--primary .md-nav__link--active,
.md-nav--primary .md-nav__link--active:is(:focus, :hover) {
    background: color-mix(in srgb, var(--md-accent-fg-color) 15%, transparent);
    color: var(--text-high) !important;
}

.md-nav--primary .md-nav__link--active:hover {
    background: color-mix(in srgb, var(--md-accent-fg-color) 20%, transparent);
}

.md-nav--primary .md-nav__link--active:active {
    background: color-mix(in srgb, var(--md-accent-fg-color) 10%, transparent);
}


/* Overlay should also use dynamic positioning */
.md-overlay {
    top: var(--md-toolbar-height, 48px) !important;
    bottom: 0 !important;
    height: auto !important;
    z-index: 3 !important;
}

/* Lock scroll when drawer is open */
html:has(#__drawer:checked) {
    overflow: hidden !important;
}

html:has(#__drawer:checked) body {
    overflow: hidden !important;
    touch-action: none;
}

#__drawer:checked ~ .md-container .md-sidebar--primary {
    touch-action: auto;
    overscroll-behavior: contain;
}

/* Center content column */
.md-content {
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
}

.md-main__inner {
    margin-top: 0;
}

/* Body background matches theme */
body {
    background-color: var(--surface-base, #121212);
}

.md-container {
    background-color: var(--md-default-bg-color);
}

/* Header */
.md-header {
    background-color: var(--md-primary-fg-color);
    z-index: 102;
}


.md-header__social {
    display: flex;
    align-items: center;
    margin-left: auto;
    margin-right: 0.2rem;
}

.md-header__social .md-header__button {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.4rem;
    color: var(--md-primary-bg-color);
    opacity: 0.7;
    transition: opacity 0.2s ease;
}

.md-header__social .md-header__button:hover {
    opacity: 1;
}

.md-header__social .md-header__button svg {
    width: 1.2rem;
    height: 1.2rem;
    fill: currentColor;
}

/* Keep header visible when card is expanded */
body.card-expanded .md-header {
    position: fixed !important;
    top: 0 !important;
    transform: none !important;
    opacity: 1 !important;
    transition: none !important;
}

body.card-expanded .md-container {
    padding-top: var(--md-toolbar-height, 48px);
}

/* Search box */
.md-search__form {
    border-radius: 6px;
    background-color: var(--surface-card);
}

.md-search__input {
    color: var(--text-high);
}

.md-search__input::placeholder {
    color: var(--text-disabled);
}

.md-search__icon {
    color: var(--text-medium);
}

[data-md-toggle=search]:checked ~ .md-header .md-search__form {
    border-radius: 6px 6px 0 0;
    background-color: var(--md-default-bg-color);
}

[data-md-toggle=search]:checked ~ .md-header .md-search__input {
    color: var(--md-default-fg-color);
}

.md-search__output {
    border-radius: 0 0 6px 6px;
}

/* Footer */
.md-footer {
    background-color: var(--md-footer-bg-color);
}

.md-footer-meta {
    background-color: var(--md-footer-bg-color--dark);
}

/* Prevent footer from stacking on mobile */
.md-footer-meta__inner {
    flex-wrap: nowrap;
    gap: 0.5rem;
}

.md-copyright {
    font-size: 0.7rem;
}

@media (max-width: 768px) {
    .md-footer-meta__inner {
        flex-direction: row;
        justify-content: space-between;
        padding: 0.5rem 1rem;
    }

    .md-social {
        margin: 0;
    }
}

/* Rounded corners */
.md-typeset pre > code {
    border-radius: 6px;
}

.md-typeset .admonition,
.md-typeset details {
    border-radius: 6px;
}

/* Section headers */
.md-content h2 {
    text-align: center;
    font-weight: 500;
    font-size: 1.75rem;
    margin-bottom: 0.25rem;
}

.md-content h2 + hr {
    margin-top: 0.25rem;
}

/* Card grid */
.card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin: 1.5rem 0;
    position: relative;
    min-height: 580px;
    overflow-anchor: none;
}

.card {
    background: var(--surface-card, #2a2a2a);
    border-radius: 6px;
    overflow: hidden;
    box-shadow: var(--md-shadow-z1);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.3s ease, color 0.3s ease;
    overflow-anchor: none;
    display: flex;
    flex-direction: column;
    max-height: 380px;
    -webkit-tap-highlight-color: transparent;
}

.card:hover:not(.expanded):not(.collapsing) {
    transform: translateY(-2px);
    box-shadow: var(--md-shadow-z2);
}

.card:focus-visible {
    outline: 2px solid var(--md-accent-fg-color);
    outline-offset: 2px;
}

/* Card banner wrapper */
.card-banner-wrapper {
    position: relative;
    height: 144px;
    min-height: 144px;
    max-height: 144px;
    overflow: hidden;
}

.card-banner-wrapper picture {
    display: block;
    width: 100%;
    height: 144px;
    margin: 0;
    padding: 0;
}

.card-banner-wrapper img {
    display: block;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
}

/* Fallback for mkdocs wrapping img in p */
.card > p:first-child,
.card > p:first-child > img,
.card > p:first-child > picture,
.card > p:first-child > picture > img {
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
    height: 144px !important;
    min-height: 144px !important;
    max-height: 144px !important;
}

.card-banner {
    width: 100% !important;
    height: 144px !important;
    min-height: 144px !important;
    max-height: 144px !important;
    object-fit: cover !important;
    object-position: center center;
    display: block !important;
    flex-shrink: 0;
    margin: 0 !important;
    padding: 0 !important;
    border: none;
}

/* Banner gradient overlay - positioned at bottom of banner */
.card-banner-wrapper::after,
.card-banner-eden::after,
.card-banner-placeholder::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 60px;
    background: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.5));
    pointer-events: none;
}

.card-content {
    padding: 1rem 1.25rem 1.25rem;
    flex-grow: 1;
}

.card-content h3 {
    margin-top: 0;
    margin-bottom: 0.5rem;
    font-size: 1rem;
    color: var(--text-high);
}

.card-content h3 a {
    color: inherit;
    text-decoration: none;
}

.card-content p {
    margin-bottom: 0;
    color: var(--text-high);
}

/* Eden card special banner */
.card-banner-eden {
    position: relative;
    width: 100%;
    height: 144px !important;
    min-height: 144px !important;
    max-height: 144px !important;
    background-color: #3498db;
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 16px;
    margin: 0 !important;
    box-sizing: border-box;
    transition: height 0.25s ease 0.15s, min-height 0.25s ease 0.15s, max-height 0.25s ease 0.15s, padding 0.25s ease 0.15s;
}

.card-banner-eden img {
    height: 100%;
    width: auto;
}

.card-banner-eden + .card-year {
    margin: 0;
}

/* Fix Eden card content spacing - mkdocs may wrap year in p */
.card-banner-eden ~ p {
    margin: 0 !important;
    padding: 0 !important;
    display: contents;
}

/* Placeholder banner for NDA projects */
.card-banner-placeholder {
    position: relative;
    width: 100%;
    height: 144px !important;
    min-height: 144px !important;
    max-height: 144px !important;
    background:
        linear-gradient(to bottom, transparent 40%, rgba(0, 0, 0, 0.4)),
        linear-gradient(135deg, var(--surface-base) 0%, var(--surface-card) 100%);
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin: 0 !important;
    box-sizing: border-box;
    transition: height 0.25s ease 0.15s, min-height 0.25s ease 0.15s, max-height 0.25s ease 0.15s;
}

.card-banner-placeholder::after {
    content: "NDA";
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-disabled);
    letter-spacing: 0.2em;
}

.card-banner-placeholder .card-year {
    position: absolute;
    bottom: 0.375rem;
    right: 0.375rem;
}

.card-banner-placeholder ~ p {
    margin: 0 !important;
    padding: 0 !important;
    display: contents;
}

.card.expanded .card-banner-placeholder {
    height: 228px !important;
    min-height: 228px !important;
    max-height: 228px !important;
}

.card.collapsing .card-banner-placeholder {
    transition: height 0.25s ease, min-height 0.25s ease, max-height 0.25s ease;
}

/* Card expansion states */
.card {
    cursor: pointer;
    position: relative;
}

/* Card transitions */
.card {
    transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease, background 0.3s ease, color 0.3s ease;
}

/* Backdrop overlay */
.card-backdrop {
    position: fixed;
    top: var(--md-toolbar-height, 48px);
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 100;
    opacity: 0;
    transition: opacity 0.25s ease;
}

.card-backdrop.visible {
    opacity: 1;
}

.card-backdrop.fading {
    opacity: 0;
}

/* Placeholder to hold grid space */
.card-placeholder {
    visibility: hidden;
}

/* Expanded card modal */
.card.expanded,
.card.collapsing {
    max-height: none;
    border-radius: 6px;
    transition: top 0.25s ease, left 0.25s ease, width 0.25s ease, height 0.25s ease, box-shadow 0.25s ease;
    overflow: hidden;
}

/* Expanded banner height */
.card.expanded .card-banner-wrapper,
.card.expanded > p:first-child,
.card.expanded > p:first-child > img,
.card.expanded > p:first-child > picture,
.card.expanded > p:first-child > picture > img,
.card.expanded .card-banner {
    height: 228px !important;
    min-height: 228px !important;
    max-height: 228px !important;
    transition: height 0.25s ease 0.15s, min-height 0.25s ease 0.15s, max-height 0.25s ease 0.15s;
}

/* Per-image positioning overrides */
.card-banner--top-15 {
    object-position: center 15% !important;
}

.card.expanded .card-banner-eden {
    height: 228px !important;
    min-height: 228px !important;
    max-height: 228px !important;
}

/* Banner height during collapse - controlled by JS, just define transition */
.card.collapsing .card-banner-wrapper,
.card.collapsing > p:first-child,
.card.collapsing > p:first-child > img,
.card.collapsing > p:first-child > picture,
.card.collapsing > p:first-child > picture > img,
.card.collapsing .card-banner {
    transition: height 0.25s ease, min-height 0.25s ease, max-height 0.25s ease !important;
}

.card.collapsing .card-banner-eden {
    transition: height 0.25s ease, min-height 0.25s ease, max-height 0.25s ease, padding 0.25s ease !important;
}

.card.expanded .card-content,
.card.collapsing .card-content {
    flex: 1;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    scrollbar-color: transparent transparent;
    transition: scrollbar-color 0.3s ease;
}

.card.expanded .card-content:hover,
.card.collapsing .card-content:hover {
    scrollbar-color: var(--text-disabled) transparent;
}

.card.expanded .card-content::-webkit-scrollbar,
.card.collapsing .card-content::-webkit-scrollbar {
    width: 8px;
}

.card.expanded .card-content::-webkit-scrollbar-track,
.card.collapsing .card-content::-webkit-scrollbar-track {
    background: transparent;
}

.card.expanded .card-content::-webkit-scrollbar-thumb,
.card.collapsing .card-content::-webkit-scrollbar-thumb {
    background: transparent;
    border-radius: 4px;
    transition: background 0.3s ease;
}

.card.expanded .card-content:hover::-webkit-scrollbar-thumb,
.card.collapsing .card-content:hover::-webkit-scrollbar-thumb {
    background: var(--text-disabled);
}

.card.transitioning .card-content {
    overflow: hidden;
}

.card.collapsing .card-content {
    overflow-y: scroll;
}

.card.transitioning .card-content > *,
.card.collapsing .card-content > * {
    animation: fadeSlideOut 0.15s ease forwards;
}

.card-content > * {
    transition: opacity 0.15s ease;
}

.card.expanded:not(.transitioning) .card-content > h3,
.card.expanded:not(.transitioning) .card-content > p {
    animation: fadeSlideIn 0.2s ease forwards;
}


.card-details {
    display: none;
}

.card.expanded:not(.transitioning) .card-details {
    display: block;
    animation: fadeSlideIn 0.25s ease forwards;
}

.card.collapsing .card-details {
    display: block;
    opacity: 0;
}

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

@keyframes fadeSlideOut {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(-10px);
    }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.card-details h4 {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
    color: var(--text-high);
    font-size: 0.95rem;
}

.card-details ul {
    margin: 0;
    padding-left: 1.25rem;
    color: var(--text-high);
}

.card-details p {
    color: var(--text-high);
    margin-bottom: 0.75rem;
}

/* Remove p wrapper around close button */
.card > p:has(.card-close) {
    display: contents;
}

.card-year {
    position: absolute;
    bottom: 0.375rem;
    right: 0.375rem;
    padding: 0.25rem 0.6rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    font-weight: 500;
    z-index: 2;
    transition: background 0.3s ease, color 0.3s ease;
}

/* Year pills match hero skill pills */
[data-md-color-scheme="slate"] .card-year {
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
}

[data-md-color-scheme="default"] .card-year {
    background: rgba(255, 255, 255, 0.25);
    color: #fff;
}

.card-close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    line-height: 1;
    z-index: 10;
    padding: 0;
    margin: 0;
}

.card.expanded .card-close {
    display: flex;
}

.card-close:hover {
    background: rgba(0, 0, 0, 0.7);
}


/* Hero section */
.hero {
    position: relative;
    text-align: center;
    padding: 10rem 2rem 11rem;
    margin-top: -1rem;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    width: 100vw;
    background-size: cover;
    background-position: center;
}

/* Mobile hero fix */
@media (max-width: 768px) {
    .hero {
        padding: 6rem 1.5rem 7rem;
    }

    /* Prevent horizontal overflow from 100vw hero on mobile */
    .md-content {
        overflow-x: clip;
    }

}

/* Taller expanded cards on phones - match side margins (5% each) */
@media (max-width: 768px) and (aspect-ratio < 3/4) {
    .card.expanded {
        top: calc(var(--md-toolbar-height, 48px) + 5dvh) !important;
        bottom: 5dvh !important;
        height: auto !important;
    }
}

.hero::before,
.hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: opacity 0.5s ease;
}

.hero::before {
    background-image: url('../images/hero-dark.webp');
    background-color: rgba(0, 0, 0, 0.4);
    background-blend-mode: darken;
}

.hero::after {
    background-image: url('../images/hero-light.webp');
    background-color: rgba(0, 0, 0, 0.35);
    background-blend-mode: darken;
}

/* Dark mode - show dark hero */
[data-md-color-scheme="slate"] .hero::before {
    opacity: 1;
}

[data-md-color-scheme="slate"] .hero::after {
    opacity: 0;
}

/* Light mode - show light hero */
[data-md-color-scheme="default"] .hero::before {
    opacity: 0;
}

[data-md-color-scheme="default"] .hero::after {
    opacity: 1;
}

.hero > * {
    position: relative;
    z-index: 1;
}

.hero h1 {
    margin-bottom: 0.5rem;
    font-weight: 700;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.3);
}

.hero .subtitle {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
    text-shadow: 0 1px 6px rgba(0, 0, 0, 0.25);
}

.hero .tagline {
    font-size: 1rem;
    font-style: italic;
    max-width: 36rem;
    margin: 0 auto;
    text-shadow: 0 1px 6px rgba(0, 0, 0, 0.25);
}

.hero .skill {
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
    transition: background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
}

/* Dark mode hero text */
[data-md-color-scheme="slate"] .hero h1 {
    color: #fff;
}

[data-md-color-scheme="slate"] .hero .subtitle {
    color: rgba(255, 255, 255, 0.95);
}

[data-md-color-scheme="slate"] .hero .tagline {
    color: rgba(255, 255, 255, 0.85);
}

[data-md-color-scheme="slate"] .hero .skill {
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
}

/* Light mode hero text */
[data-md-color-scheme="default"] .hero h1 {
    color: #fff;
}

[data-md-color-scheme="default"] .hero .subtitle {
    color: rgba(255, 255, 255, 0.95);
}

[data-md-color-scheme="default"] .hero .tagline {
    color: rgba(255, 255, 255, 0.85);
}

[data-md-color-scheme="default"] .hero .skill {
    background: rgba(255, 255, 255, 0.25);
    color: #fff;
}

/* Skills list */
.skills {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin: 1.5rem 0;
}

.skill {
    background: var(--surface-card, #2a2a2a);
    color: var(--text-high);
    padding: 0.4rem 1rem;
    border-radius: 2rem;
    font-size: 0.9rem;
    transition: background 0.3s ease, color 0.3s ease;
}

/* Contact section */
.contact-intro {
    text-align: center;
    font-size: 1.1rem;
    margin-bottom: 1rem;
}

.contact-links {
    margin: 1rem 0 1.25rem;
}

.contact-links > p {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin: 0;
}

.contact-status {
    text-align: center;
    font-size: 0.95rem;
    color: var(--text-medium);
    font-style: italic;
    margin-top: 0.5rem;
}

.contact-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--surface-card);
    color: var(--text-high) !important;
    padding: 0.6rem 1.25rem;
    border-radius: 2rem;
    font-size: 0.95rem;
    text-decoration: none !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.contact-link:hover {
    transform: translateY(-2px);
    box-shadow: var(--md-shadow-z2);
}

[data-md-color-scheme="slate"] .contact-link:hover {
    background: #3a3a3a;
}

[data-md-color-scheme="default"] .contact-link:hover {
    background: #c0c0c2;
}

.contact-link:active {
    transform: translateY(0);
    box-shadow: var(--md-shadow-z1);
}

[data-md-color-scheme="slate"] .contact-link:active {
    background: #2a2a2a;
}

[data-md-color-scheme="default"] .contact-link:active {
    background: #b8b8ba;
}

/* Landing page */
.landing {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - var(--md-toolbar-height, 48px) - 100px);
    text-align: center;
    padding: 2rem;
}

/* Hide auto-generated title on landing page */
.md-content:has(.landing) h1 {
    display: none !important;
}

.md-typeset .landing-logo {
    width: 200px !important;
    height: 200px !important;
    max-width: none !important;
    max-height: none !important;
    margin-bottom: 1.5rem;
}


/* Theme-aware logo visibility - inverted for contrast */
[data-md-color-scheme="slate"] .landing-logo--light {
    display: block;
}

[data-md-color-scheme="slate"] .landing-logo--dark {
    display: none;
}

[data-md-color-scheme="default"] .landing-logo--light {
    display: none;
}

[data-md-color-scheme="default"] .landing-logo--dark {
    display: block;
}

.landing-tagline {
    font-size: 1.1rem;
    color: var(--text-medium);
    max-width: 400px;
    margin-top: 0;
    margin-bottom: 1.5rem;
}

.landing-error {
    font-size: 4rem;
    font-weight: 700;
    color: var(--text-high);
    margin: 0;
    line-height: 1;
}

.landing-error-message {
    font-size: 1.1rem;
    color: var(--text-medium);
    margin-top: 0.5rem;
    margin-bottom: 1.5rem;
}

.landing-links {
    display: flex;
    gap: 1rem;
}

.landing-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--accent);
    color: #fff !important;
    padding: 0.75rem 1.5rem;
    border-radius: 2rem;
    font-size: 1rem;
    font-weight: 500;
    text-decoration: none !important;
    transition: transform 0.1s ease, box-shadow 0.1s ease, filter 0.1s ease;
}

.landing-link:hover {
    transform: translateY(-1px);
    box-shadow: var(--md-shadow-z1);
    filter: brightness(1.1);
    transition: transform 0.1s ease, box-shadow 0.1s ease, filter 0.1s ease;
}

.landing-link:active {
    transform: translateY(0);
    box-shadow: none;
    filter: brightness(0.9);
}

/* Reduced motion for accessibility */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .card:hover:not(.expanded):not(.collapsing) {
        transform: none;
    }

    .contact-link:hover {
        transform: none;
    }
}

