/**
 * Attractions styles
 * Styles for the attractions custom post type and listings
 */

/* Override container width for attractions page */
.attractions-container
.post-type-archive-attraction .site-main > .container
 {
    max-width: 80%;
    width: 80%;
    margin: 0 auto;
}


/* Reset any grid constraints */
.post-type-archive-attraction .attractions-list {
    display: flex;
    flex-direction: column;
    gap: var(--lubinik-spacing-lg);
    margin-top: var(--lubinik-spacing-lg);
    width: 100%;
}

/* Attractions Section */
.attractions-section {
    padding: var(--lubinik-spacing-lg) 0;
    max-width: 50%;
    margin: 0 auto;
}

.section-header {
    margin-bottom: var(--lubinik-spacing-lg);
    text-align: center;
}

/* Single Attraction Item */
.attraction-item {
    display: flex;
    background-color: var(--lubinik-attraction-primary-section-bg-color );
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    margin: 20px auto;
    width: 100%;
    box-sizing: border-box;
}

.attraction-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

/* Attraction Image */
.attraction-image {
    flex: 0 0 40%;
    max-width: 40%;
    position: relative;
    min-height: 350px;
    overflow: hidden;
}

.attraction-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}

/* Attraction Content */
.attraction-content {
    flex: 1;
    padding: var(--lubinik-spacing-md);
    display: flex;
    flex-direction: column;
}

.attraction-title {
    margin-top: 0;
    margin-bottom: var(--lubinik-spacing-sm);
    font-size: var(--lubinik-font-size-lg);
    color: var(--lubinik-attraction-title-color);
}

.attraction-title a {
    color: var(--lubinik-attraction-link-color);
    text-decoration: none;
    transition: color 0.3s ease;
}

.attraction-title a:hover {
    color: var(--lubinik-attraction-link-hover-color);
}

.attraction-excerpt {
    margin-bottom: var(--lubinik-spacing-md);
    color: var(--lubinik-attraction-description-color);
    line-height: 1.6;
}

/* Attraction Meta */
.attraction-meta {
    margin-top: auto;
    display: flex;
    align-items: center;
    gap: var(--lubinik-spacing-md);
    color: var(--lubinik-attraction-distance-color);
    font-size: var(--lubinik-font-size-sm);
}

.attraction-distance,
.attraction-category {
    display: flex;
    align-items: center;
    gap: var(--lubinik-spacing-xs);
}

.attraction-distance i,
.attraction-category i {
    color: var(--lubinik-attraction-distance-color);
}

/* No Attractions Message */
.no-attractions {
    text-align: center;
    padding: var(--lubinik-spacing-md);
    color: var(--lubinik-attraction-text-color);
    font-style: italic;
}

/* Attraction Gallery Slider */
.attraction-gallery-wrapper {
    margin-top: var(--lubinik-spacing-lg);
    padding: var(--lubinik-spacing-md) 0;
}

.attraction-extra-title {
    margin-bottom: var(--lubinik-spacing-md);
    font-size: var(--lubinik-font-size-md);
    color: var(--lubinik-attraction-title-color);
}

.attraction-gallery-slider {
    position: relative;
    margin: 0 -10px;
}

.attraction-gallery-slider .gallery-item {
    padding: 0 10px;
}

.attraction-gallery-slider img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    border-radius: 8px;
    transition: transform 0.3s ease;
}

.attraction-gallery-slider a:hover img {
    transform: scale(1.03);
}

/* Slick Slider Controls for Attraction Gallery */
.attraction-gallery-slider .slick-prev,
.attraction-gallery-slider .slick-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.8);
    color: var(--lubinik-attraction-link-color);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.attraction-gallery-slider .slick-prev {
    left: 15px;
}

.attraction-gallery-slider .slick-next {
    right: 15px;
}

.attraction-gallery-slider .slick-dots {
    bottom: -25px;
    list-style: none;
    display: flex;
    justify-content: center;
    padding: 0;
    margin: 0;
}

.attraction-gallery-slider .slick-dots li {
    margin: 0 5px;
}

.attraction-gallery-slider .slick-dots button {
    font-size: 0;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: rgba(0, 0, 0, 0.3);
    border: none;
    padding: 0;
    cursor: pointer;
}

/* Fix for duplicate dots - hide the default dot that Slick adds */
.attraction-gallery-slider .slick-dots button:before {
    display: none !important;
}

.attraction-gallery-slider .slick-dots li.slick-active button {
    background-color: var(--lubinik-attraction-link-color);
}

/* Video Wrapper */
.attraction-video-wrapper {
    margin-top: var(--lubinik-spacing-lg);
}

.responsive-video-embed {
    position: relative;
    padding-bottom: 56.25%; /* 16:9 ratio */
    height: 0;
    overflow: hidden;
    max-width: 100%;
    border-radius: 8px;
}

.responsive-video-embed iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}
