/* Projects Page Specific Styles */

/* Light Mode Overrides */
.light-mode .projects-page__card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
}

.light-mode .projects-page__card:hover {
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

/* Navigation */
.projects-page__back-link {
    display: inline-flex;
    align-items: center;
    gap: var(--gap-sm, 0.5rem);
    color: var(--text-primary, #ffffff);
    text-decoration: none;
    margin-bottom: var(--gap-lg, 2rem);
    font-size: var(--text-base, 1rem);
    padding: clamp(0.5rem, 2vw, 0.75rem) clamp(0.75rem, 2vw, 1rem);
    border-radius: var(--radius-sm, 8px);
    transition: all 0.2s;
    min-height: 44px;
}

.projects-page__back-link:hover {
    color: var(--link-color, #ffffff);
    background: var(--bg-secondary, #111111);
}

.projects-page__back-link:focus-visible {
    outline: 2px solid var(--link-color, #ffffff);
    outline-offset: 2px;
}

/* Page Header */
.projects-page__title {
    font-size: clamp(1.75rem, 5vw, 2.5rem);
    font-weight: 700;
    color: var(--text-primary, #ffffff);
    margin-bottom: var(--gap-xl, 3rem);
    line-height: 1.2;
}

/* Projects Grid Layout */
.projects-page__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(1rem, 3vw, 1.5rem);
    margin-bottom: var(--gap-lg, 2rem);
    container-type: inline-size;
}

/* Mobile: Single column */
@media (max-width: 639px) {
    .projects-page__grid {
        grid-template-columns: 1fr;
    }
}

/* Project Cards */
.projects-page__card {
    background: var(--bg-secondary, #111111);
    border-radius: var(--radius-md, 12px);
    padding: clamp(1rem, 3vw, 1.5rem);
    border: 1px solid var(--border-color, #333333);
    transition: transform 0.2s, box-shadow 0.2s;
    min-height: 150px;
    container-type: inline-size;
    contain: layout style;
}

@media (hover: hover) {
    .projects-page__card:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4);
    }
}

.projects-page__card:active {
    transform: scale(0.98);
}

.projects-page__card-title {
    font-weight: 600;
    color: var(--text-primary, #ffffff);
    margin-bottom: clamp(0.375rem, 1.5vw, 0.5rem);
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    line-height: 1.3;
}

.projects-page__card-description {
    color: var(--text-muted, #888888);
    font-size: clamp(0.85rem, 2vw, 0.9rem);
    margin-bottom: clamp(0.5rem, 2vw, 0.75rem);
    line-height: 1.5;
}

@container (max-width: 300px) {
    .projects-page__card-description {
        font-size: 0.8rem;
    }
}

.projects-page__card-url {
    color: var(--text-muted, #888888);
    font-size: clamp(0.8rem, 1.8vw, 0.85rem);
    text-decoration: none;
    word-break: break-all;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.125rem 0;
    transition: opacity 0.2s;
}

.projects-page__card-url i {
    font-size: 0.9em;
}

.project-url {
    color: var(--link-color, #ffffff);
    font-size: clamp(0.8rem, 1.8vw, 0.85rem);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.125rem 0;
    transition: opacity 0.2s;
}

.project-url:hover {
    opacity: 0.8;
    text-decoration: underline;
}

/* Responsive Breakpoints */

/* Extra Small Screens (Phones) */
@media (max-width: 639px) {
    .projects-page__title {
        text-align: center;
    }

    .projects-page__back-link {
        width: 100%;
        justify-content: center;
    }
}

/* Micro Screens (Very Small Phones) */
@media (max-width: 480px) {
    .projects-page__card {
        padding: clamp(0.75rem, 3vw, 1.25rem);
    }

    .projects-page__card-title {
        font-size: 1rem;
    }

    .projects-page__card-description {
        font-size: 0.85rem;
    }
}

/* Touch-friendly adjustments */
@media (pointer: coarse) {
    .projects-page__card {
        min-height: 160px;
    }

    .projects-page__card-url {
        min-height: 44px;
        display: flex;
        align-items: center;
        padding: 0.5rem 0;
    }
}

/* High DPI Screens */
@media (-webkit-min-device-pixel-ratio: 2),
       (min-resolution: 192dpi) {
    .projects-page__card {
        border-width: 0.5px;
    }
}