﻿/* ──────────────────────────────────────────────
   ProTemplate1 • Portfolio — asymmetric cards
   Respects: --primary-bg, --text-color, --accent, --accent-2
   ────────────────────────────────────────────── */

/* ProTemplate1 • Portfolio — section wash to match Arsenal */
.pt1-portfolio {
    --_bg: var(--primary-bg, #0b1b2b);
    --_text: var(--text-color, #e7eef6);
    --_accent: var(--accent, #c96d36);
    --_accent2: var(--accent-2, #d88346);
    /* was 92/8 — make it 90/10 to match Arsenal */
    background: color-mix(in srgb, var(--_bg) 90%, #fff 10%);
    color: var(--_text);
    padding: clamp(42px, 6vw, 84px) 24px;
}


.pt1-portfolio__inner {
    max-width: min(1280px, 94vw);
    margin: 0 auto;
}

.pt1-portfolio__title {
    font-weight: 900;
    font-size: clamp(2rem, 4.8vw, 3.2rem);
    line-height: 1.08;
    margin: 0 0 clamp(18px, 3vw, 32px);
    position: relative;
    text-wrap: balance;
}

    .pt1-portfolio__title::after {
        content: "";
        display: block;
        width: 72px;
        height: 4px;
        margin-top: 10px;
        border-radius: 999px;
        background: linear-gradient(135deg, var(--_accent), var(--_accent2));
    }

/* Grid (12-col for interesting spans) */
.pf-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0,1fr));
    gap: clamp(14px, 2.2vw, 24px);
}

/* Card */
.pf-card {
    background: color-mix(in srgb, var(--_bg) 86%, #fff 14%);
    border: 1px solid color-mix(in srgb, var(--_text) 14%, transparent);
    box-shadow: 0 10px 26px rgba(0,0,0,.22);
    border-radius: 16px;
    overflow: hidden;
    display: grid;
    grid-template-rows: auto 1fr;
    grid-column: auto / span 4; /* default span */
    position: relative;
}

/* Asymmetric rhythm (repeat every 6) */
.pf-grid > .pf-card:nth-child(6n+1) {
    grid-column: span 6;
}

.pf-grid > .pf-card:nth-child(6n+2) {
    grid-column: span 3;
    transform: translateY(8px);
}

.pf-grid > .pf-card:nth-child(6n+3) {
    grid-column: span 3;
}

.pf-grid > .pf-card:nth-child(6n+4) {
    grid-column: span 4;
    transform: translateY(12px);
}

.pf-grid > .pf-card:nth-child(6n+5) {
    grid-column: span 4;
}

.pf-grid > .pf-card:nth-child(6n+6) {
    grid-column: span 4;
    transform: translateY(6px);
}

/* Media */
.pf-media {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: color-mix(in srgb, var(--_bg) 75%, #fff 25%);
}

    .pf-media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
    }

    .pf-media::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(to bottom, rgba(0,0,0,.0), rgba(0,0,0,.15));
        pointer-events: none;
    }

/* Body */
.pf-body {
    padding: 14px 16px 16px;
}

.pf-title {
    margin: 0 0 6px;
    font-weight: 800;
    letter-spacing: .2px;
    font-size: clamp(1.05rem, 1.8vw, 1.25rem);
}

.pf-desc {
    margin: 0;
    color: color-mix(in srgb, var(--_text) 78%, transparent);
    font-size: .98rem;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.pf-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 10px 0 0;
    padding: 0;
    list-style: none;
}

    .pf-tags li {
        padding: .25rem .6rem;
        font-size: .72rem;
        border: 1px solid var(--_accent);
        border-radius: 12px;
        color: var(--_accent);
    }

/* Hover polish */
.pf-card:hover {
    box-shadow: 0 14px 34px rgba(0,0,0,.28), 0 0 18px color-mix(in srgb, var(--_accent) 35%, transparent);
}

/* Reveal hooks */
[data-reveal] {
    opacity: 0;
    filter: blur(6px);
    transform: translate3d(0,24px,0);
    transition: opacity .45s ease, transform .45s ease, filter .45s ease;
}

    [data-reveal].in {
        opacity: 1;
        filter: none;
        transform: none;
    }

/* Responsive */
@media (max-width: 1080px) {
    .pf-grid {
        grid-template-columns: repeat(6, minmax(0,1fr));
    }

        .pf-grid > .pf-card {
            grid-column: auto / span 3 !important;
            transform: none !important;
        }
}

@media (max-width: 640px) {
    .pf-grid {
        grid-template-columns: 1fr;
    }

        .pf-grid > .pf-card {
            grid-column: auto / span 1 !important;
        }
}
