/* ========================= */
/* CAROUSEL SECTION */
/* ========================= */
#carousel {
    position: relative;
    text-align: center;
    padding: var(--section-padding);
    background: var(--section-light-bg);
    overflow: hidden;
}

#carousel-title,
#carousel h2 {
    color: var(--section-light-text);
    font-family: var(--font-heading);
    /*font-size: clamp(1.7rem, 4vw, 2.6rem);*/
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
    position: relative;
    z-index: 2;
}


/* ========================= */
/* CAROUSEL */
/* ========================= */
.carousel {
    --item-width: min(72vw, 600px);
    --item-height: min(48vw, 395px);
    --side-offset: min(31vw, 430px);
    padding-bottom: 90px;
    position: relative;
    width: 100%;
    height: clamp(420px, 58vw, 720px);
    margin: 0 auto;
    overflow: hidden;
}


/* ========================= */
/* ITEMS */
/* ========================= */
.carousel-item {
    position: absolute;
    top: 50%;
    left: 50%;
    width: var(--item-width);
    height: var(--item-height);
    border-radius: 22px;
    overflow: hidden;
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.7);
    transition:
        transform 0.38s ease,
        opacity 0.28s ease,
        filter 0.28s ease;
}

.carousel-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 22px;
    box-shadow: var(--shadow-soft);
}


/* ========================= */
/* STATES */
/* ========================= */
.carousel-item.center {
    z-index: 10;
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.08);
}

.carousel-item.left {
    z-index: 5;
    opacity: 0.45;
    transform: translate(calc(-50% - var(--side-offset)), -50%) scale(0.78);
}

.carousel-item.right {
    z-index: 5;
    opacity: 0.45;
    transform: translate(calc(-50% + var(--side-offset)), -50%) scale(0.78);
}

.carousel-item.hidden {
    opacity: 0;
    pointer-events: none;
}


/* ========================= */
/* NAVIGATION */
/* ========================= */
.carousel-nav {
    position: absolute;
    top: 50%;
    z-index: 30;

    width: 46px;
    height: 46px;

    border: none;
    border-radius: 50%;

    background: var(--section-light-accent);
    box-shadow: var(--shadow-soft);

    cursor: pointer;
    transform: translateY(-50%);

    display: flex;
    align-items: center;
    justify-content: center;

    transition:
        transform 0.25s ease,
        background 0.25s ease,
        box-shadow 0.25s ease;
}

.carousel-nav.prev {
    left: calc(50% - (var(--item-width) / 2) + 22px);
}

.carousel-nav.next {
    right: calc(50% - (var(--item-width) / 2) + 22px);
}

.carousel-nav::before {
    content: "";
    width: 12px;
    height: 12px;
    border-top: 2.5px solid var(--white);
    border-right: 2.5px solid var(--white);
}

.carousel-nav.prev::before {
    transform: rotate(-135deg);
}

.carousel-nav.next::before {
    transform: rotate(45deg);
}

.carousel-nav:hover {
    background: var(--section-light-hover);
    box-shadow: var(--shadow-hover);
    transform: translateY(-50%) scale(1.06);
}

.carousel-nav:active {
    transform: translateY(-50%) scale(0.95);
}


/* ========================= */
/* SHADOW */
/* ========================= */
.carousel::after {
    content: "";
    position: absolute;

    left: 50%;
    top: calc(50% + (var(--item-height) * 0.54) + clamp(14px, 2vw, 26px));

    width: clamp(260px, 58vw, 560px);
    height: clamp(18px, 2.8vw, 30px);

    background:
        radial-gradient(
            ellipse at center,
            rgba(0, 0, 0, 0.20) 0%,
            rgba(0, 0, 0, 0.13) 35%,
            rgba(0, 0, 0, 0.06) 60%,
            rgba(0, 0, 0, 0) 100%
        );

    filter: blur(clamp(8px, 1.4vw, 14px));

    transform: translateX(-50%);
    pointer-events: none;
    z-index: 1;
}

.carousel {
    overflow: visible;
}


/* ========================= */
/* CONTACT BUTTON */
/* ========================= */
.contact-me-btn {
    position: relative;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 30px;
    padding: 10px 18px;
    background: var(--section-light-accent);
    color: var(--white);
    border-radius: 999px;
    box-shadow: var(--shadow-soft);
    cursor: pointer;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.contact-me-btn:hover {
    transform: translateY(-2px);
    background: var(--section-light-hover);
    box-shadow: var(--shadow-hover);
}

.contact-icon-paw {
    display: inline-block;
    width: 18px;
    height: 18px;
    background-image: url("/images/paw.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.25s ease;
}

.contact-me-btn:hover .contact-icon-paw {
    transform: translateX(6px);
}
