﻿/* ──────────────────────────────────────────────
   ProTemplate1 • ARSENAL — asymmetric cards
   Respects: --primary-bg, --text-color, --accent, --accent-2
   ────────────────────────────────────────────── */

.pt1-arsenal {
    --_bg: var(--primary-bg, #0b1b2b);
    --_text: var(--text-color, #e7eef6);
    --_accent: var(--accent, #c96d36);
    --_accent2: var(--accent-2, #d88346);
    background: color-mix(in srgb, var(--_bg) 90%, #fff 10%);
    color: var(--_text);
    padding: clamp(42px, 6vw, 84px) 24px;
    position: relative;
}

.pt1-arsenal__inner {
    max-width: min(1280px, 94vw);
    margin: 0 auto;
}

.pt1-arsenal__title {
    font-weight: 900;
    font-size: clamp(2rem, 4.8vw, 3.2rem);
    line-height: 1.08;
    margin: 0 0 clamp(18px, 3vw, 32px);
    letter-spacing: .2px;
    position: relative;
    text-wrap: balance;
}

    .pt1-arsenal__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 to allow interesting spans */
.a-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0,1fr));
    gap: clamp(14px, 2.2vw, 24px);
}

/* Card */
.a-card {
    position: relative;
    padding: 20px 18px 18px 18px;
    border-radius: 16px;
    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);
    overflow: hidden;
    /* default span */
    grid-column: auto / span 4;
}

/* Accent wedge */
.a-card__accent {
    position: absolute;
    inset: 0 0 auto 0;
    height: 6px;
    width: 100%;
    background: linear-gradient(135deg, var(--_accent), var(--_accent2));
}

/* Titles / copy */
.a-card__title {
    margin: 8px 0 6px;
    font-weight: 800;
    letter-spacing: .2px;
    font-size: clamp(1.05rem, 1.8vw, 1.25rem);
}

.a-card__desc {
    margin: 0;
    color: color-mix(in srgb, var(--_text) 78%, transparent);
    line-height: 1.55;
    font-size: .98rem;
}

/* Asymmetric rhythm (repeats every 6) */
.a-grid > .a-card:nth-child(6n+1) {
    grid-column: span 6;
}

.a-grid > .a-card:nth-child(6n+2) {
    grid-column: span 3;
    transform: translateY(8px);
}

.a-grid > .a-card:nth-child(6n+3) {
    grid-column: span 3;
}

.a-grid > .a-card:nth-child(6n+4) {
    grid-column: span 4;
    transform: translateY(12px);
}

.a-grid > .a-card:nth-child(6n+5) {
    grid-column: span 4;
}

.a-grid > .a-card:nth-child(6n+6) {
    grid-column: span 4;
    transform: translateY(6px);
}

/* Hover polish (u-lift handles lift) */
.a-card:hover {
    box-shadow: 0 14px 34px rgba(0,0,0,.28), 0 0 18px color-mix(in srgb, var(--_accent) 35%, transparent);
}

/* Reveal states (works with global motion.js or local JS below) */
[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: blur(0);
        transform: none;
    }

/* Responsive */
@media (max-width: 1080px) {
    .a-grid {
        grid-template-columns: repeat(6, minmax(0,1fr));
    }

        .a-grid > .a-card {
            grid-column: auto / span 3 !important;
            transform: none !important;
        }
}

@media (max-width: 640px) {
    .a-grid {
        grid-template-columns: 1fr;
    }

        .a-grid > .a-card {
            grid-column: auto / span 1 !important;
        }
}
