/* ============================================================
   section-services.css — Sekcja kart usług (reusable partial)
   Używana na: index.php, uslugi.php
   AdresDoNajmu.pl
   ============================================================ */

/* ============================================================
   SERVICES SECTION — 4 karty z foto (aspect 1:1)
   ============================================================ */
.services-section {
    background: var(--color-surface-base);
    padding: var(--space-24) 0;
}

.services-section-title {
    font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
    font-weight: var(--font-weight-black);
    color: var(--color-primary);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: -0.01em;
    margin-bottom: var(--space-12);
}

@media (max-width: 768px) {
    .services-section {
        padding: var(--space-16) 0 var(--space-12);
    }
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-4);
    align-items: stretch;
}

/* AOS-обёртка вокруг карточки: ведёт себя как ячейка сетки */
.services-grid > [data-aos] {
    display: flex;
    flex-direction: column;
}
.services-grid > [data-aos] > .service-card {
    flex: 1;
    width: 100%;
}

.service-card {
    background: var(--color-surface-lowest);
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1.5px solid rgba(46, 16, 101, 0.15);
    display: flex;
    flex-direction: column;
    box-shadow:
        0 2px 0 rgba(46, 16, 101, 0.06),
        0 8px 24px -4px rgba(46, 16, 101, 0.12),
        0 24px 48px -8px rgba(46, 16, 101, 0.08),
        0 1px 0 rgba(255, 255, 255, 0.9) inset;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    position: relative;
    transform: translateY(0);
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow:
        0 2px 0 rgba(46, 16, 101, 0.08),
        0 16px 40px -4px rgba(46, 16, 101, 0.18),
        0 40px 80px -12px rgba(46, 16, 101, 0.12),
        0 1px 0 rgba(255, 255, 255, 0.9) inset;
}

.service-card-image {
    aspect-ratio: 7 / 8;
    overflow: hidden;
    background: var(--color-surface-low);
    display: block;
}

.service-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
    transition: transform var(--transition-slow);
}

.service-card:hover .service-card-img {
    transform: scale(1.04);
}

.service-card-body {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.service-card-title {
    font-size: var(--text-base);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    margin-bottom: var(--space-6);
    min-height: 3rem;
    line-height: 1.4;
    text-transform: none;
    flex-grow: 1;
}

.service-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: var(--space-4);
    border-top: 1px solid rgba(46, 16, 101, 0.08);
    gap: var(--space-2);
}

.service-card-actions {
    display: flex;
    gap: var(--space-2);
    flex-shrink: 0;
}

.service-card-price {
    display: flex;
    align-items: baseline;
    gap: 3px;
    font-size: 1.375rem;
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
    letter-spacing: -0.02em;
    line-height: 1;
}

.service-card-price::after {
    content: ' zł';
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    opacity: 0.7;
    letter-spacing: 0;
}

/* Stretched link — покрывает всю карточку, поверх изображения */
.service-card-link {
    position: absolute;
    inset: 0;
    z-index: 1;
}

/* Кнопка «Zamów» поверх stretched link */
.service-card-order {
    position: relative;
    z-index: 2;
}

/* Кнопки в карточках */
.service-card .btn-sm {
    padding: var(--space-2) var(--space-4);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    border-radius: var(--radius-lg);
    white-space: nowrap;
}

/* .btn-outline hover унаследован из global.css:
   hover → background: var(--color-primary), color: #fff */

@media (max-width: 1024px) {
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .services-grid {
        grid-template-columns: 1fr;
    }

    .service-card-footer {
        flex-wrap: wrap;
        gap: var(--space-3);
    }

    .service-card-actions {
        width: 100%;
        justify-content: flex-end;
    }
}