/* --- File: experience-card.css --- */
/* Experience Card Elementor Widget Styles */

.aw-experience-card {
	position: relative;
	display: flex;
	flex-direction: column;
	border-radius: 20px;
	overflow: hidden;
	background-color: #e8f7f8;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.aw-experience-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
}

.aw-experience-card-link-wrapper {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
	text-decoration: none;
}

.aw-experience-card-image {
	width: 100%;
	height: 250px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.aw-experience-card-content-wrap {
	position: relative;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}


.aw-experience-card-info {
	padding: 20px;
	text-align: center;
	background-color: #e8f7f8; /* default light blue */
	flex-grow: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

.aw-experience-card-title {
	margin: 0;
	color: #1a2b3c;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.3;
}

/* Video Box Widget Styles */

.aw-video-box-wrap {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	display: block;
}

.aw-video-box-link {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
}

.aw-video-box {
	position: relative;
	width: 100%;
	height: 450px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	border-radius: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.aw-video-play-btn {
	background-color: #ffffff;
	color: #1a2b3c;
	width: 80px;
	height: 80px;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 24px;
	box-shadow: 0 10px 25px rgba(0,0,0,0.15);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	z-index: 5;
	position: relative; /* Ensure it respects z-index if needed */
}

.aw-video-box-wrap:hover .aw-video-play-btn {
	transform: scale(1.1);
	box-shadow: 0 15px 35px rgba(0,0,0,0.2);
}

.aw-video-play-btn i,
.aw-video-play-btn svg {
	display: block;
	width: 1em;
	height: 1em;
	margin: auto;
}

.aw-video-play-btn i {
	margin-left: 5px; /* Offset to center the play triangle optically */
}

/* Circle Carousel Widget Styles */
.aw-circle-carousel-wrapper {
	position: relative;
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.aw-circle-carousel-container {
	position: relative;
	width: 450px;
	height: 450px;
	max-width: 100%;
	margin: 0 auto;
}

.aw-dashed-circle {
	position: absolute;
	top: -20px;
	left: -20px;
	right: -20px;
	bottom: -20px;
	border: 1px dashed #bccad6;
	border-radius: 50%;
	z-index: 1;
}

.aw-circle-carousel-container {
	position: relative;
	margin: 0 auto;
	max-width: 100%;
	aspect-ratio: 1 / 1;
}

.aw-circle-carousel {
	position: absolute !important;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
	border-radius: 50% !important;
	/* overflow: visible to allow pagination inside but positioned outside */
	overflow: visible !important;
	z-index: 3;
	display: block !important;
}

/* Inner wrapper to keep the circular mask while allowing outer elements */
.aw-circle-carousel .swiper-wrapper {
	display: flex !important;
	width: 100% !important;
	height: 100% !important;
	position: relative;
	z-index: 1;
	border-radius: 50% !important;
	overflow: hidden;
}

.aw-circle-carousel .swiper-slide {
	position: relative;
	width: 100% !important;
	height: 100% !important;
	flex-shrink: 0;
	opacity: 0 !important;
	transition: opacity 0.5s ease-in-out;
}

.aw-circle-carousel .swiper-slide-active,
.aw-circle-carousel .swiper-slide-duplicate-active {
	opacity: 1 !important;
}

.aw-carousel-img {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	border-radius: 50% !important;
	display: block;
	box-sizing: border-box;
	border: 15px solid #fcdba1; /* Default/Fallback */
}

.aw-carousel-pagination {
	margin-top: 40px;
	display: flex;
	justify-content: center;
	width: 100%;
	min-height: 20px;
}

.aw-circle-carousel-wrapper .swiper-pagination {
	position: relative !important;
	bottom: auto !important;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 10;
	margin-top: 20px;
}

.aw-circle-carousel-wrapper .swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	background: #e6e6e6;
	opacity: 1;
	margin: 0 5px;
	transition: all 0.3s ease;
	cursor: pointer;
}

.aw-circle-carousel-wrapper .swiper-pagination-bullet-active {
	background: #00b4b6; /* Teal active color */
	width: 24px;
	border-radius: 4px;
}


/* --- File: testimonials.css --- */
.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-wrapper {
	position: relative !important;
	padding: 0 20px !important;
	max-width: 1200px !important;
	margin: 0 auto !important;
	overflow: hidden !important;
	box-sizing: border-box !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-carousel {
	padding: 20px 10px 80px !important;
	overflow: visible !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-card.aw-v2 {
	background: #ffffff !important;
	border-radius: 12px !important;
	padding: 40px !important;
	box-shadow: 0 10px 30px rgba(0,0,0,0.05) !important;
	height: 100% !important;
	display: flex !important;
	flex-direction: column !important;
	position: relative !important;
	transition: transform 0.3s ease !important;
	border: 1px solid #f0f0f0 !important;
	box-sizing: border-box !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-card.aw-v2:hover {
	transform: translateY(-5px) !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-quote {
	color: #00b4b6 !important;
	margin-bottom: 15px !important;
	display: block !important;
	line-height: 1 !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-quote svg {
	width: 50px !important;
	height: 50px !important;
	fill: currentColor !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-stars {
	display: flex !important;
	gap: 6px !important;
	margin-bottom: 25px !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-stars svg {
	width: 18px !important;
	height: 18px !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-content {
	font-size: 16px !important;
	line-height: 1.7 !important;
	color: #333333 !important;
	margin-bottom: 35px !important;
	flex-grow: 1 !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-read-more {
	display: inline-block !important;
	margin-left: 5px !important;
	color: #1a2b3c !important;
	font-weight: 700 !important;
	text-decoration: underline !important;
	font-size: 15px !important;
	cursor: pointer !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-read-more:hover {
	color: #00b4b6 !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-author {
	font-weight: 700 !important;
	font-size: 16px !important;
	color: #1a2b3c !important;
	margin-bottom: 25px !important;
	display: flex !important;
	align-items: center !important;
	text-transform: none !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-author::before {
	content: "" !important;
	width: 20px !important;
	height: 2px !important;
	background-color: #00b4b6 !important;
	margin-right: 12px !important;
	display: block !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-gallery {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 10px !important;
	margin-top: auto !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-gallery-item {
	width: calc(33.333% - 10px) !important;
	aspect-ratio: 1/1 !important;
	border-radius: 12px !important;
	overflow: hidden !important;
	cursor: pointer !important;
	box-shadow: 0 4px 10px rgba(0,0,0,0.1) !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-wrapper .swiper-slide {
	max-width: none !important;
	height: auto !important;
}

/* If only one image, make it larger */
.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-gallery:has(.aw-testimonial-gallery-item:only-child) .aw-testimonial-gallery-item {
	width: 120px !important;
	height: 120px !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonial-gallery-item img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
}

/* Swiper Pagination & Navigation */
.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-wrapper .swiper-pagination {
	bottom: -40px !important;
	display: flex !important;
	justify-content: center !important;
	align-items: center !important;
	gap: 10px !important;
	width: 100% !important;
	left: 0 !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-wrapper .swiper-pagination-bullet {
	width: 10px !important;
	height: 10px !important;
	background: #e0e0e0 !important;
	opacity: 1 !important;
	margin: 0 !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-wrapper .swiper-pagination-bullet-active {
	background: #00b4b6 !important;
	width: 25px !important;
	border-radius: 5px !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-nav {
	position: absolute !important;
	top: 50% !important;
	width: 100% !important;
	transform: translateY(-50%) !important;
	z-index: 100 !important;
	pointer-events: none !important;
	display: flex !important;
	justify-content: space-between !important;
	padding: 0 !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-prev,
.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-next {
	width: 50px !important;
	height: 50px !important;
	background: #ffffff !important;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	box-shadow: 0 4px 15px rgba(0,0,0,0.1) !important;
	cursor: pointer !important;
	pointer-events: auto !important;
	color: #333333 !important;
	transition: all 0.3s ease !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-prev:hover,
.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-next:hover {
	background: #00b4b6 !important;
	color: #ffffff !important;
}

.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-prev svg,
.elementor-widget-art_wine_testimonials_carousel .aw-testimonials-next svg {
	width: 24px !important;
	height: 24px !important;
}


/* --- File: experience-marketplace.css --- */
/* Experience Marketplace Styles */

.aw-marketplace-container {
    display: flex;
    gap: 30px;
    width: 100%;
    margin-top: 20px;
}

/* Sidebar Filters */
.aw-filters-sidebar {
    width: 300px;
    flex-shrink: 0;
    background: #f8f9fa;
    padding: 20px;
    border-radius: 15px;
}

.aw-filter-group {
    margin-bottom: 25px;
}

.aw-filter-label {
    font-weight: 600;
    margin-bottom: 10px;
    display: block;
    color: #333;
}

/* City Tabs */
.aw-city-tabs {
    display: flex;
    background: #e9ecef;
    padding: 5px;
    border-radius: 10px;
    gap: 5px;
}

.aw-city-tab {
    flex: 1;
    padding: 10px;
    text-align: center;
    cursor: pointer;
    border-radius: 8px;
    font-weight: 600;
    transition: all 0.3s ease;
}

.aw-city-tab.active {
    background: #00a8b5;
    color: #fff;
}

/* Time Chips */
.aw-time-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.aw-time-chip {
    padding: 8px 15px;
    border: 1px solid #00a8b5;
    border-radius: 20px;
    color: #00a8b5;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.3s ease;
}

.aw-time-chip.active {
    background: #00a8b5;
    color: #fff;
}

.aw-time-chip.disabled {
    border-color: #ccc;
    color: #ccc;
    cursor: not-allowed;
}

/* ArtWine Marketplace Premium UI Fixes */
:root {
    --aw-turquoise: #00a8b1;
    --aw-turquoise-light: #e1f8fa;
    --aw-gray-bg: #f5f6f7;
    --aw-text-dark: #333333;
    --aw-text-gray: #666666;
    --aw-white: #ffffff;
    --aw-radius: 12px;
    --aw-radius-pill: 50px;
    --aw-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.aw-marketplace-container {
    display: flex;
    gap: 30px;
    /* padding: 16px 24px; */
    max-width: 1400px;
    margin: 0 auto;
    font-family: 'Inter', sans-serif;
    align-items: flex-start;
}

/* Sidebar Styling */
.aw-marketplace-sidebar {
    flex: 0 0 320px;
    background: var(--aw-white);
    padding: 25px;
    border-radius: var(--aw-radius);
    box-shadow: var(--aw-shadow);
    height: fit-content;
    z-index: 10;
}

.aw-filter-section {
    margin-bottom: 25px;
    clear: both;
}

.aw-section-label {
    display: block;
    font-weight: 700;
    font-size: 16px;
    margin-bottom: 5px;
    color: var(--aw-text-dark);
}

.aw-sub-label {
    font-size: 13px;
    color: var(--aw-text-gray);
    margin-bottom: 12px;
}

.aw-sidebar-help {
    font-size: 13px;
    color: var(--aw-text-gray);
    line-height: 1.5;
    margin-top: 15px;
}

/* City Tabs */
.aw-city-tabs {
    display: flex;
    flex-wrap: wrap;
    background: #e9ecef;
    padding: 6px;
    border-radius: 12px;
    margin-bottom: 15px;
    gap: 6px;
}

.aw-city-tab {
    flex: 1 1 auto;
    text-align: center;
    white-space: nowrap;
    border: none;
    padding: 10px 12px;
    border-radius: 8px;
    background: transparent;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    color: #718096;
    font-size: 13px;
}

.aw-city-tab.active {
    background: #00a5b5;
    /* Turquoise active */
    color: var(--aw-white);
    box-shadow: 0 4px 10px rgba(0, 165, 181, 0.2);
}

.aw-city-tab:hover:not(.active) {
    background: rgba(0, 165, 181, 0.05);
    color: #00a5b5;
}

/* Select Styling - FIXED TEXT VISIBILITY */
.aw-select-wrapper select {
    width: 100%;
    height: 48px;
    padding: 0 15px;
    border-radius: 10px;
    border: 1px solid #cbd5e0;
    background: var(--aw-white);
    font-size: 14px;
    color: var(--aw-text-dark);
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: border-color 0.3s ease;
}

.aw-select-wrapper select:focus {
    border-color: #00a5b5;
    outline: none;
}

.aw-select-wrapper {
    position: relative;
}

.aw-select-wrapper::after {
    content: '▼';
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 10px;
    color: #999;
    pointer-events: none;
}

/* Flatpickr Visibility - FIXED INPUT HIDE */
#aw-selected-date {
    display: none !important;
}

.aw-calendar-inline {
    width: 100%;
    margin-top: 10px;
}

.flatpickr-calendar.inline {
    box-shadow: none !important;
    border: 1px solid #e2e8f0 !important;
    width: 100% !important;
    border-radius: 12px;
    margin-top: 10px;
}

/* Time Chips */
.aw-time-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.aw-time-chip {
    padding: 8px 18px;
    border: 1px solid #00a5b5;
    background: transparent;
    color: #00a5b5;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 8px;
}

.aw-time-chip.active {
    background: #00a5b5;
    color: var(--aw-white);
    border-color: #00a5b5;
}

.aw-time-chip.active:hover {
    background-color: #00636D !important;
    border-color: #00636D !important;
}

.aw-time-chip:hover:not(.active) {
    background: rgba(0, 165, 181, 0.05);
}

.aw-chip-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    font-size: 12px;
    line-height: 1;
    margin-left: 4px;
}

.aw-time-chip.active:hover .aw-chip-remove {
    background: rgba(255, 255, 255, 0.3);
}

.aw-time-placeholder {
    font-size: 12px;
    color: #999;
    font-style: italic;
}

/* Sidebar Actions */
.aw-filter-actions {
    display: block;
    margin-top: 25px;
}

.aw-btn-reset {
    width: 100%;
    padding: 12px;
    border: 1.5px solid #00a5b5 !important;
    background-color: #ffffff !important;
    color: #00a5b5 !important;
    border-radius: 10px;
    font-weight: 700;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.3s ease;
    text-align: center;
    box-sizing: border-box;
}

.aw-btn-reset:hover,
.aw-btn-reset:focus,
.aw-btn-reset:active {
    background-color: #f0fbff !important;
    border-color: #00636D !important;
    color: #00636D !important;
    outline: none !important;
}

/* Grid & Cards - FIXED LOADING HANG */
.aw-marketplace-main {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* Mobile Filter Toggle Styling */
.aw-mobile-filter-header {
    display: none;
    align-items: center;
    justify-content: space-between;
    padding: 15px 5px;
    margin-bottom: 5px;
}

.aw-mobile-grid-title {
    font-size: 20px !important;
    font-weight: 800;
    color: #334155;
    margin: 0 !important;
}

.aw-filter-toggle {
    width: 44px;
    height: 44px;
    background: rgba(0, 165, 181, 0.1);
    border: 1.5px solid #00a5b5;
    border-radius: 12px;
    color: #00a5b5;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    padding: 0;
}

.aw-filter-toggle:hover,
.aw-filter-toggle.active {
    background: #00a5b5 !important;
    color: #fff !important;
}

/* Collapsible Wrapper */
.aw-filters-collapsible {
    display: block;
}

@media (max-width: 767px) {
    .aw-mobile-filter-header {
        display: flex;
    }

    .aw-filters-collapsible {
        display: none;
        /* Hidden by default on mobile */
        padding-top: 15px;
        border-top: 1px solid #f1f5f9;
        margin-top: 5px;
    }

    .aw-filters-collapsible.is-open {
        display: block !important;
        animation: aw-fade-in 0.3s ease;
    }
}

@keyframes aw-fade-in {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.aw-marketplace-header {
    margin-bottom: 30px;
    padding-left: 5px;
}

.aw-marketplace-title {
    font-size: 20px !important;
    font-weight: 800;
    color: var(--aw-text-dark);
    margin: 0 0 8px 0;
    line-height: 1.2 !important;
    margin-bottom: 0px !important;
}

.aw-marketplace-subtitle {
    font-size: 14px;
    color: var(--aw-text-gray);
    margin: 0;
    line-height: 1.5;
}

.aw-marketplace-subtitle strong {
    color: var(--aw-text-dark);
    font-weight: 700;
}

.aw-experience-instances-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 25px;
}

.aw-grid-placeholder,
.aw-no-results {
    grid-column: 1 / -1;
    padding: 50px;
    text-align: center;
    font-size: 18px;
    color: #999;
}

.aw-event-card {
    background: var(--aw-white);
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.4s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    border: 1px solid rgba(0, 0, 0, 0.03);
}

.aw-event-card:hover:not(.is-sold-out) {
    transform: translateY(-8px);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.12);
}

.aw-event-card.is-sold-out {
    opacity: 0.7;
    filter: grayscale(0.4);
    pointer-events: none;
    cursor: not-allowed;
}

.aw-event-card.is-sold-out .aw-price-savings-box {
    background: #f1f5f9;
}

.aw-event-card.is-sold-out .aw-price-value {
    color: #94a3b8;
}

.aw-event-card-media {
    position: relative;
    aspect-ratio: 4/3;
    width: 100%;
}

.aw-event-card-img-bg {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;

    /* Rounded image inside padded card */
}

/* Badges exactly like screenshot */
.aw-card-badge-top-left {
    position: absolute;
    top: 10px;
    left: 10px;
    background: white;
    color: #1a1a1a;
    padding: 5px 10px;
    border-radius: 50px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.3px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    text-transform: uppercase;
    z-index: 3;
}

.aw-card-badge-top-right {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(255, 255, 255, 0.25);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #000000;
    padding: 5px 10px;
    border-radius: 50px;
    font-size: 11px;
    font-weight: 800;
    z-index: 3;
}

.aw-card-badge-top-right.is-low-stock {
    background: rgba(255, 59, 48, 0.9) !important;
    color: #ffffff !important;
    border-color: #ff3b30 !important;
}

.aw-card-badge-top-right.is-sold-out {
    background: #ff3b30 !important;
    color: #ffffff !important;
    border-color: #ff3b30 !important;
    font-weight: 800;
    box-shadow: 0 4px 12px rgba(255, 59, 48, 0.3);
}

.aw-card-link,
.aw-card-link:hover,
.aw-card-link:active,
.aw-card-link:focus,
.aw-card-link *,
.aw-card-link *:hover,
.aw-event-grid a,
.aw-event-grid a *,
.aw-event-card a,
.aw-event-card a *,
.aw-info-bar *,
.aw-price-savings-box * {
    text-decoration: none !important;
    text-decoration-line: none !important;
    border-bottom: 0 !important;
    border-bottom-style: none !important;
    box-shadow: none !important;
    outline: 0 !important;
}

.aw-card-link,
.aw-card-link:hover,
.aw-card-link:active,
.aw-card-link:focus,
.aw-card-link *,
.aw-card-link *:hover,
.aw-event-grid a,
.aw-event-grid a *,
.aw-event-card a,
.aw-event-card a *,
.aw-info-bar *,
.aw-price-savings-box * {
    text-decoration: none !important;
    text-decoration-line: none !important;
    border-bottom: 0 !important;
    border-bottom-style: none !important;
    box-shadow: none !important;
    outline: 0 !important;
}

.aw-event-card-content {
    padding: 8px 10px 20px 10px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.aw-event-card-title {
    font-size: 22px !important;
    font-weight: 800;
    line-height: 1.2 !important;
    margin: 0 0 15px 0;
    color: var(--aw-text-dark);
    transition: none !important;
}

.aw-card-link:hover .aw-event-card-title {
    color: var(--aw-text-dark) !important;
}

/* Consolidated Info Bar */
.aw-info-bar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    /* New wrap */
    gap: 10px 0;
    /* Vertical gap when wrapped */
    margin-bottom: 20px;
    border-top: 1px solid transparent;
}

.aw-info-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 400 !important;
    color: #4a5568 !important;
    flex: none;
}

.aw-info-item svg {
    color: #4a5568;
    flex-shrink: 0;
    opacity: 0.8;
}

.aw-info-separator {
    width: 1px;
    height: 14px;
    background: #e2e8f0;
    margin: 0 12px;
}

/* Price & Savings Box */
.aw-price-savings-box {
    background: #f0fbff;
    /* Soft cyan blue */
    border-radius: 15px;
    display: flex;
    align-items: center;
    padding: 15px 20px;
    gap: 0;
    margin-top: auto;
}

.aw-price-column {
    display: flex;
    flex-direction: column;

    flex: 0 0 auto;
}

.aw-price-label {
    font-size: 11px;
    color: #718096;
    font-weight: 500;
    margin-bottom: 2px;
}

.aw-price-value {
    font-size: 1.7rem;
    padding-right: 10px;
    font-weight: 800;
    color: #00a5b5;
    /* Turquoise highlight */
    line-height: 1;
}

.aw-price-separator {
    width: 1px;
    height: 40px;
    background: rgba(0, 165, 181, 0.15);
    margin-right: 20px;
}

.aw-savings-column {
    flex: 1;
    font-size: 11px;
    color: #4a5568;
    line-height: 1.4;
}

.aw-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
    height: 100%;
}

/* Skeleton / Loading State */
.aw-grid-loading {
    opacity: 0.5;
    pointer-events: none;
}

/* Empty State */
.aw-empty-state {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 80px 20px;
    background: #fcfdfe;
    border: 2px dashed #e2e8f0;
    border-radius: 24px;
    margin-top: 20px;
}

.aw-empty-icon {
    font-size: 50px;
    margin-bottom: 20px;
}

.aw-empty-title {
    font-size: 22px;
    font-weight: 700;
    color: var(--aw-text-dark);
    margin-bottom: 12px;
}

.aw-empty-text {
    font-size: 15px;
    color: var(--aw-text-gray);
    max-width: 420px;
    line-height: 1.6;
    margin-bottom: 30px;
}

.aw-btn-reset-small {
    background: var(--aw-turquoise);
    color: white;
    border: none;
    padding: 12px 25px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0, 168, 177, 0.2);
}

.aw-btn-reset-small:hover {
    background-color: #00636D !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(0, 99, 109, 0.3);
}

/* Flatpickr Customizations - HIGH FIDELITY OVERHAUL */
.flatpickr-calendar {
    box-shadow: none !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 20px !important;
    padding: 15px !important;
    background: #fff !important;
    width: 320px !important;
    font-family: inherit !important;
}

.flatpickr-months {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    margin-bottom: 15px !important;
}

.flatpickr-current-month {
    position: static !important;
    width: auto !important;
    padding: 0 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #334155 !important;
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
}

.flatpickr-month {
    height: auto !important;
    overflow: visible !important;
}

.flatpickr-prev-month,
.flatpickr-next-month {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    padding: 5px !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #64748b !important;
    transition: color 0.2s ease !important;
}

.flatpickr-prev-month {
    left: 10px !important;
}

.flatpickr-next-month {
    right: 10px !important;
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
    width: 14px !important;
    height: 14px !important;
    fill: currentColor !important;
}

.flatpickr-weekdays {
    height: auto !important;
    margin-bottom: 10px !important;
}

.flatpickr-weekday {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #64748b !important;
    text-transform: none !important;
}

.flatpickr-day {
    border-radius: 10px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: #334155 !important;
    margin: 2px !important;
    max-width: 38px !important;
    height: 38px !important;
    line-height: 38px !important;
    border: none !important;
    cursor: pointer !important;
}

.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: #cbd5e1 !important;
}

.flatpickr-day.today {
    background: rgba(0, 165, 181, 0.05) !important;
    color: #00a5b5 !important;
    font-weight: 700 !important;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: #00a5b5 !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(0, 165, 181, 0.25) !important;
    border-radius: 10px !important;
}

.flatpickr-day:hover:not(.selected) {
    background: #f1f5f9 !important;
}

@media (max-width: 1100px) {
    .aw-marketplace-container {
        flex-direction: column;
        gap: 20px;
        padding: 16px 2px !important;
        /* Optimized mobile padding */
    }


    .aw-filters-sidebar {
        width: 100%;
        padding: 15px;
        order: -1;
    }

    .aw-experience-instances-grid {
        grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
        gap: 15px;
    }
}

@media (max-width: 767px) {
    .aw-marketplace-title {
        font-size: 24px !important;
        margin-bottom: 10px !important;
        text-align: center;
    }

    .aw-marketplace-subtitle {
        text-align: center;
        margin-bottom: 25px !important;
    }

    .aw-experience-instances-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        padding: 0 5px;
    }

    .aw-city-tabs {
        flex-wrap: wrap;
        padding-bottom: 6px;
        justify-content: center;
    }

    .aw-city-tab {
        flex: 1 1 calc(50% - 10px);
        padding: 10px 12px;
    }

    .aw-filters-sidebar {
        border-radius: 0;
        margin: 0 0 20px 0;
        width: 100%;
    }
}

@media (max-width: 480px) {
    .aw-event-card-media {
        aspect-ratio: 4/3;
        height: auto;
    }

    .aw-event-card-content {
        padding: 20px 15px;
    }

    .aw-event-card-title {
        font-size: 18px !important;
        margin-bottom: 12px !important;
    }

    .aw-price-value {
        font-size: 28px !important;
    }

    .aw-info-bar {
        flex-wrap: wrap;
        gap: 8px 12px;
        margin-bottom: 15px;
    }

    .aw-info-separator {
        display: none;
    }

    .aw-info-item {
        font-size: 13px;
        gap: 6px;
    }

    .aw-btn-next-step {
        width: 100%;
        text-align: center;
        background-color: #00a5b5;
        color: white;
        border: none;
        padding: 12px;
        border-radius: 10px;
        font-weight: 700;
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .aw-btn-next-step:hover {
        background-color: #00636D !important;
    }

    /* Flatpickr center for mobile */
    .flatpickr-calendar {
        margin: 0 auto;
    }
}

@media (max-width: 375px) {
    .aw-experience-instances-grid {
        grid-template-columns: 1fr !important;
    }

    .aw-event-card-content {
        padding: 15px;
    }

    .aw-price-value {
        font-size: 28px;
    }
}

/* --- PW Gift Card Elementor Widget Styles --- */
.aw-gift-card-form-wrapper {
    background: #fff;
    padding: 25px;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
    font-family: inherit;
    color: #333;
}

.aw-gc-section-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #718096;
    margin: 25px 0 15px 0;
    border-bottom: 1px solid #e2e8f0;
    padding-bottom: 8px;
}

.aw-gift-card-form-wrapper .aw-gc-section-title:first-child {
    margin-top: 0;
}

.aw-gc-amount-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 12px;
    margin-bottom: 15px;
}

.aw-gc-amount-box {
    border: 2px solid #e2e8f0;
    border-radius: 12px;
    padding: 15px;
    text-align: center;
    cursor: pointer;
    position: relative;
    transition: all 0.2s ease;
    background: #fff;
}

.aw-gc-amount-box:hover {
    border-color: #cbd5e1;
    background: #f8fafc;
}

.aw-gc-amount-box.active {
    border-color: #00a5b5;
    background: #f0fbff !important;
}

.aw-gc-amount-box.recommended {
    border-color: #00a5b5;
    background: #fff;
}

.aw-gc-recommended-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: #00a5b5;
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 20px;
    letter-spacing: 0.5px;
    white-space: nowrap;
}

.aw-gc-box-price {
    font-size: 24px;
    font-weight: 800;
    color: #334155;
    margin-bottom: 4px;
    transition: color 0.2s ease;
}

.aw-gc-amount-box.active .aw-gc-box-price {
    color: #00a5b5;
}

.aw-gc-amount-box.custom .aw-gc-box-price {
    font-size: 16px;
    margin-top: 5px;
}

.aw-gc-box-subtitle {
    font-size: 11px;
    color: #64748b;
    line-height: 1.2;
}

.aw-gc-field-group {
    margin-bottom: 15px;
}

.aw-gc-label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #334155;
    margin-bottom: 8px;
}

.aw-gc-input-wrapper {
    position: relative;
}

.aw-gc-input,
.aw-gc-textarea {
    width: 100%;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    padding: 12px 15px;
    font-size: 14px;
    color: #334155;
    transition: all 0.2s;
    background: #fff;
    box-sizing: border-box;
}

.aw-gc-input:focus,
.aw-gc-textarea:focus {
    outline: none;
    border-color: #00a5b5;
    box-shadow: 0 0 0 3px rgba(0, 165, 181, 0.1);
}

.aw-gc-custom-amount-error,
.aw-gc-custom-amount-info {
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
}

.aw-gc-custom-amount-error {
    background-color: #fef2f2;
    border: 1px solid #fca5a5;
    color: #b91c1c;
}

.aw-gc-custom-amount-info {
    background-color: #f0f9ff;
    border: 1px solid #bae6fd;
    color: #0369a1;
}

.aw-gc-textarea {
    min-height: 100px;
    resize: vertical;
}

.aw-gc-qty-selector {
    display: inline-flex;
    align-items: center;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    overflow: hidden;
}

.aw-gc-qty-btn {
    background: #f1f5f9;
    border: none;
    width: 40px;
    height: 40px;
    font-size: 18px;
    color: #334155;
    cursor: pointer;
    transition: background 0.2s;
}

.aw-gc-qty-btn:hover {
    background: #e2e8f0;
}

.aw-gc-qty-input {
    width: 50px;
    height: 40px;
    border: none;
    border-left: 1px solid #cbd5e1;
    border-right: 1px solid #cbd5e1;
    text-align: center;
    font-size: 16px;
    font-weight: 600;
    color: #334155;
    background: #fff;
    -moz-appearance: textfield;
}

.aw-gc-qty-input::-webkit-outer-spin-button,
.aw-gc-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.aw-gc-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.aw-gc-counter {
    font-size: 11px;
    color: #94a3b8;
    margin: 5px 0 0 0;
}

.aw-gc-delivery-options {
    display: flex;
    gap: 10px;
}

.aw-gc-delivery-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    background: #fff;
    color: #475569;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.aw-gc-delivery-btn:hover {
    background: #f8fafc;
}

.aw-gc-delivery-btn.active {
    background: #00a5b5;
    border-color: #00a5b5;
    color: #fff;
}

.aw-gc-delivery-note {
    font-size: 13px;
    color: #64748b;
    margin: 10px 0 20px 0;
}

.aw-gc-submit-btn {
    width: 100%;
    background: #00a5b5;
    color: #fff;
    border: none;
    padding: 16px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0 4px 12px rgba(0, 165, 181, 0.2);
}

.aw-gc-submit-btn:hover:not(:disabled) {
    background: #008f9c;
    box-shadow: 0 6px 16px rgba(0, 165, 181, 0.3);
    transform: translateY(-1px);
}

.aw-gc-submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.aw-gc-footer-benefits {
    display: flex;
    justify-content: center;
    gap: 10px;
    font-size: 12px;
    color: #00a5b5;
    font-weight: 600;
    margin-top: 15px;
}

.aw-gc-footer-secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 11px;
    color: #64748b;
    margin-top: 8px;
}

.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.text-right {
    text-align: right;
}

@media (max-width: 600px) {
    .aw-gc-grid-2 {
        grid-template-columns: 1fr;
    }

    .aw-gc-delivery-options {
        flex-direction: column;
    }

    .aw-gc-amount-grid {
        grid-template-columns: 1fr 1fr;
    }
}

/* --- File: experience-booking.css --- */
/* Premium Event Booking Widget Styles */

:root {
    --aw-primary: #00a8b1;
    --aw-primary-hover: #008f96;
    --aw-bg-soft: #fcfdfe;
    --aw-border-light: rgba(0, 0, 0, 0.05);
    --aw-text-main: #333333;
    --aw-text-muted: #666666;
    --aw-accent-yellow: #fff9e6;
}

.aw-booking-container {
    max-width: 600px;
    margin: 0 auto;
    font-family: 'Outfit', 'Inter', sans-serif;
    color: var(--aw-text-main);
}

.aw-booking-title {
    font-size: 42px;
    font-weight: 800;
    margin-bottom: 15px;
    letter-spacing: -1px;
}

.aw-booking-short-desc {
    font-size: 16px;
    line-height: 1.6;
    color: var(--aw-text-muted);
    margin-bottom: 30px;
}

/* Info Bar */
.aw-booking-info-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 15px 20px;
    background: rgba(0, 168, 177, 0.03);
    border: 1px solid rgba(0, 168, 177, 0.08);
    border-radius: 12px;
    margin-bottom: 25px;
}

.aw-info-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
}

.aw-info-icon {
    font-size: 16px;
}

.aw-info-stock .low-stock {
    color: #e53e3e;
}

/* Benefits Box */
.aw-benefits-box {
    border: 1px solid var(--aw-border-light);
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 30px;
    background: white;
}

.aw-benefits-header {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    margin-bottom: 12px;
}

.aw-benefits-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.aw-benefits-list li {
    font-size: 14px;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--aw-text-muted);
}

.aw-check {
    color: #38a169;
    font-weight: bold;
}

/* Booking Card */
.aw-booking-card {
    background: white;
    border-radius: 16px;
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--aw-border-light);
    padding: 30px;
}

.aw-booking-guest-label {
    font-size: 12px;
    font-weight: 700;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 15px;
}

.aw-guest-selector {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 25px;
}

.aw-guest-btn {
    width: 44px;
    height: 44px;
    border: 1px solid #ddd;
    background: white;
    border-radius: 8px;
    font-size: 20px;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.aw-guest-btn:hover {
    border-color: var(--aw-primary);
    color: var(--aw-primary);
}

.aw-guest-count {
    font-size: 24px;
    font-weight: 700;
    min-width: 30px;
    text-align: center;
}

/* Discount Badge */
.aw-discount-badge {
    background: #e6fffa;
    color: #2c7a7b;
    padding: 10px 15px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 25px;
    display: inline-block;
}

/* Pricing Display */
.aw-pricing-display {
    margin-bottom: 30px;
}

.aw-price-main {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 15px;
}

.aw-old-price {
    font-size: 18px;
    color: #bbb;
    text-decoration: line-through;
}

.aw-current-price {
    font-size: 48px;
    font-weight: 800;
    color: var(--aw-primary);
    line-height: 1;
}

.aw-price-suffix {
    font-size: 14px;
    color: #888;
}

.aw-price-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 15px;
    border-top: 1px solid #f0f0f0;
    font-size: 15px;
}

.aw-total-amount {
    font-size: 20px;
    color: var(--aw-text-main);
}

/* Checkout Button */
.aw-btn-checkout {
    width: 100%;
    background: var(--aw-primary);
    color: white;
    border: none;
    padding: 18px;
    border-radius: 12px;
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
}

.aw-btn-checkout:hover {
    background: var(--aw-primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(0, 168, 177, 0.25);
}

/* Footer Info */
.aw-booking-footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-top: 25px;
    font-size: 13px;
    color: var(--aw-text-muted);
}

/* Responsive */
@media (max-width: 480px) {
    .aw-booking-title {
        font-size: 32px;
    }
    
    .aw-current-price {
        font-size: 38px;
    }
    
    .aw-booking-card {
        padding: 20px;
    }
}

/* Force Astra Container to 100% Width (Override theme constraints) */
@media (min-width: 922px) {
    .ast-container {
        max-width: 100% !important;
        width: 100% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    /* Ensure Elementor stretched sections work correctly within overridden container */
    .ast-container .elementor-section-stretched {
        left: 0 !important;
        width: 100% !important;
    }
}


/* --- File: checkout-premium.css --- */
/* 
   ArtWine Unified Checkout Premium Styles
   Designed for a 2-column layout with high-fidelity aesthetics.
*/

:root {
    --aw-turquoise: #00A5B5;
    --aw-dark: #0A0A0A;
    --aw-gray-text: #6B7280;
    --aw-border: #E5E7EB;
    --aw-bg-light: #F9FAFB;
    --aw-radius: 16px;
    --aw-shadow: 0px 4px 16px rgba(0, 0, 0, 0.05);
}

.aw-unified-checkout-container {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--aw-dark);
    margin: 40px auto;
    padding: 0 20px;
}

.aw-checkout-header {
    margin-bottom: 32px;
}

.aw-h1 {
    font-size: 32px !important;
    font-weight: 700 !important;
    line-height: 48px !important;
    margin-bottom: 4px !important;
    color: var(--aw-dark) !important;
}

.aw-subtitle {
    font-size: 15px;
    color: var(--aw-gray-text);
}

/* GRID LAYOUT */
.aw-unified-grid {
    display: grid;
    grid-template-columns: 420px 1fr;
    gap: 24px;
    align-items: start;
}

.aw-column-sidebar {
    position: sticky;
    top: 90px;
    z-index: 10;
}

@media (max-width: 768px) {
    .aw-unified-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
    .aw-column-sidebar {
        grid-row: 1 !important;
        margin-bottom: 20px !important;
        width: 100% !important;
        max-width: 100% !important;
    }
    .aw-column-main {
        grid-row: 2 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* TRUST BADGES MOBILE STACK */
    .aw-trust-badges {
        flex-direction: column !important;
        gap: 16px !important;
        text-align: center !important;
    }
    .aw-trust-badges .aw-v-divider {
        display: none !important;
    }
}






/* PREMIUM ERROR STYLES */
.aw-error-summary-box {
    background: #FEF2F2;
    border: 1px solid #FECACA;
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 24px;
    display: none;
}

.aw-error-summary-title {
    display: flex;
    align-items: center;
    gap: 12px;
    color: #991B1B;
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 8px;
}

.aw-error-summary-title::before {
    content: "!";
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    background: #DC2626;
    color: white;
    border-radius: 50%;
    font-size: 12px;
}

.aw-error-summary-list li {
    color: #991B1B;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 4px;
}

#artwine-checkout-node .form-row.woocommerce-invalid .aw-input,
#artwine-checkout-node .form-row.woocommerce-invalid input.input-text,
#artwine-checkout-node .form-row.woocommerce-invalid .input-text,
#artwine-checkout-node .aw-input.invalid,
.aw-unified-checkout-container .form-row.woocommerce-invalid .aw-input,
.aw-unified-checkout-container .form-row.woocommerce-invalid input.input-text,
.aw-unified-checkout-container .form-row.woocommerce-invalid .input-text,
.aw-unified-checkout-container .aw-input.invalid {
    border: 2px solid #DC2626 !important;
    background-color: #FEE2E2 !important;
    border-radius: 8px !important;
}

/* Force full width for name fields as well */
#artwine-checkout-node .form-row-first, 
#artwine-checkout-node .form-row-last,
#artwine-checkout-node .form-row-wide,
.aw-unified-checkout-container .form-row-first, 
.aw-unified-checkout-container .form-row-last,
.aw-unified-checkout-container .form-row-wide {
    width: 100% !important;
    float: none !important;
}

.aw-field-error-msg {
    color: #DC2626;
    font-size: 13px;
    font-weight: 700;
    margin-top: 8px;
    display: block;
}





/* CARDS */
.aw-checkout-card {
    background: white;
    border-radius: 16px;
    padding: 25px;
    margin-bottom: 24px;
    border: 1px solid #E5E7EB;
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.02);
}

.aw-card-title {
    font-size: 18px !important;
    font-weight: 600 !important;
    margin-bottom: 24px;
    color: #0A0A0A;
}

/* OPTIONAL BILLING SECTION */
.aw-optional-billing-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 15px 0;
    cursor: pointer;
    font-size: 14px;
    color: #374151;
    font-weight: 500;
}

.aw-optional-billing-header i {
    color: #6B7280;
}

/* SUMMARY STYLES */
.aw-summary-header {
    display: flex;
    gap: 12px;
    margin-bottom: 24px;
}

.aw-summary-thumb-wrapper img {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    object-fit: cover;
}

.aw-summary-header-meta h4 {
    font-size: 15px;
    font-weight: 600;
    margin: 0 0 2px 0;
}

.aw-summary-header-meta p {
    font-size: 13px;
    color: #6B7280;
    margin: 0;
}

.aw-summary-timedate {
    display: flex;
    gap: 12px;
    margin-top: 4px;
}

.aw-summary-timedate span {
    font-size: 13px;
    color: #6B7280;
    display: flex;
    align-items: center;
    gap: 4px;
}

.aw-summary-list {
    list-style: none;
    padding: 0;
    margin: 20px 0;
}

.aw-summary-item {
    display: flex;
    justify-content: space-between;
    margin-bottom: 12px;
    font-size: 14px;
    color: #374151;
}

.aw-item-subtext {
    font-size: 13px;
    color: var(--aw-turquoise);
    font-weight: 500;
    text-decoration: underline;
    margin-top: -8px;
    margin-bottom: 12px;
    display: block;
}

.aw-summary-item .price {
    font-weight: 500;
    color: #0A0A0A;
}

.aw-summary-totals {
    margin-top: 24px;
}

.aw-total-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.aw-total-row .label {
    font-size: 18px;
    font-weight: 600;
}

.aw-total-row .value {
    font-size: 32px;
    font-weight: 700;
    line-height: 1;
    color: var(--aw-turquoise);
}

.aw-tax-hint {
    display: block;
    text-align: right;
    font-size: 13px;
    color: #6B7280;
    margin-top: 4px;
}

.aw-divider {
    border: 0;
    border-top: 1px solid #E5E7EB;
    margin: 24px 0;
}

/* FORM STYLES */
.aw-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.aw-field-group.full-width {
    grid-column: span 2;
}

.aw-field-group label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 6px;
    color: #374151;
}

.aw-input {
    width: 100%;
    height: 44px;
    padding: 0 12px;
    border-radius: 12px;
    border: 1px solid var(--aw-border);
    font-size: 14px;
    transition: border-color 0.2s;
}

.aw-input:focus {
    outline: none;
    border-color: var(--aw-turquoise);
}

.aw-field-hint {
    font-size: 12px;
    color: var(--aw-gray-text);
    margin-top: 4px;
    display: block;
}

/* PAYMENT TABS */
.aw-payment-method-selector {
    display: flex;
    background: #F3F4F6;
    padding: 4px;
    border-radius: 10px;
    margin-bottom: 20px;
}

.aw-payment-tab {
    flex: 1;
    text-align: center;
    padding: 10px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    border-radius: 8px;
    color: var(--aw-gray-text);
    transition: all 0.2s;
}

.aw-payment-tab.active {
    background: white;
    color: var(--aw-dark);
    box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.05);
}

/* BUTTONS */
.aw-btn-confirm-final {
    width: 100%;
    height: 56px;
    background: var(--aw-turquoise);
    color: white;
    border: none;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 600;
    margin-top: 20px;
    cursor: pointer;
    box-shadow: 0px 4px 16px rgba(0, 165, 181, 0.3);
    transition: transform 0.2s, opacity 0.2s;
}

.aw-btn-confirm-final:hover {
    transform: translateY(-2px);
    opacity: 0.9;
}

.aw-btn-secondary {
    background: #F3F4F6;
    border: 1px solid var(--aw-border);
    padding: 8px 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    color: var(--aw-dark);
    cursor: pointer;
    transition: background 0.2s;
}

.aw-btn-secondary:hover {
    background: #E5E7EB;
}

/* TRUST BADGES */
.aw-trust-badges {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid #E5E7EB;
}

.aw-trust-badges .badge {
    font-size: 13px;
    color: #6B7280;
    display: flex;
    align-items: center;
    gap: 6px;
}

.aw-trust-badges .aw-v-divider {
    width: 1px;
    height: 14px;
    background: #E5E7EB;
}

/* HIDE NATIVE WOO UI (Carefully) */
form.checkout #place_order_native_hidden {
    display: none !important;
}

.aw-promo-field-wrapper {
    display: none;
    margin-top: 12px;
}

/** 
 * UI SECURITY FIX: Ensure standard WooCommerce sections 
 * dont overflow or float incorrectly.
 */
.aw-checkout-card#order_review {
    position: relative !important;
    float: none !important;
    width: 100% !important;
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.02) !important;
    display: block !important;
    clear: both !important;
}

.aw-payment-boxes.payment_methods.methods {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

#add_payment_method #payment, .woocommerce-cart #payment, .woocommerce-checkout #payment {
    background: transparent !important;
    border-radius: 0 !important;
}

.aw-payment-tab {
    user-select: none;
}

/* --- File: hero-experience.css --- */
/**
 * Hero Experience Elementor Widget Styles v3.5 (Fade Effect Support)
 */

.aw-hero-slider-main-container {
    width: 100% !important;
    position: relative !important;
    overflow: hidden !important;
    background: transparent !important;
}

.aw-hero-slider-main-container .swiper-wrapper {
    display: flex !important;
    width: 100% !important;
}

.aw-hero-slider-main-container .swiper-slide {
    width: 100% !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-sizing: border-box !important;
}

.aw-hero-slide-item {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 8rem 2rem !important;
    gap: 8rem !important;
    width: 100% !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    overflow: visible !important;
    box-sizing: border-box !important;
}

@media (max-width: 991px) {
    .aw-hero-slide-item {
        flex-direction: column !important;
        text-align: center !important;
        padding: 4rem 1.5rem !important;
        gap: 2.5rem !important;
        max-width: 100% !important;
    }
    .aw-hero-mobile-order-image_first .aw-hero-slide-item {
        flex-direction: column-reverse !important;
    }
    .aw-hero-mobile-order-text_first .aw-hero-slide-item {
        flex-direction: column !important;
    }
}

/* CONTENT CONTAINER */
.aw-hero-experience-content {
    flex: 1 1 50% !important;
    max-width: 600px;
    width: auto !important;
    position: relative;
    z-index: 10;
}

@media (max-width: 991px) {
    .aw-hero-experience-content {
        flex: 0 0 100% !important;
        width: 100% !important;
        max-width: 100%;
    }
}

.aw-hero-experience-title {
    font-size: 4.5rem;
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 1.5rem;
    letter-spacing: -0.02em;
}

@media (max-width: 767px) {
    .aw-hero-experience-title {
        font-size: 2.8rem;
    }
}

.aw-hero-experience-title span.highlight {
    position: relative;
    display: inline;
    /* Use inline to wrap text strictly */
    white-space: normal;
}

.aw-hero-experience-title span.highlight::after {
    content: '';
    position: absolute;
    bottom: 5px;
    /* Adjusted for better alignment with text base */
    left: -2%;
    /* Slightly less overshoot to avoid container clipping */
    width: 104%;
    height: 12px;
    background-color: #FBBF24;
    z-index: -1;
    opacity: 0.8;
    border-radius: 100% 10% 80% 5% / 10% 5% 10% 5%;
}

.aw-hero-experience-subtitle {
    font-size: 1.75rem;
    font-weight: 500;
    line-height: 1.4;
    margin-bottom: 2.5rem;
}

@media (max-width: 767px) {
    .aw-hero-experience-subtitle {
        font-size: 1.25rem;
    }
}

.aw-hero-experience-buttons {
    display: flex;
    gap: 1.25rem;
}

@media (max-width: 991px) {
    .aw-hero-experience-buttons {
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .aw-hero-experience-buttons {
        flex-direction: column;
        width: 100%;
        gap: 1rem !important;
    }
}

.aw-hero-btn {
    padding: 1.1rem 2rem;
    border-radius: 0.75rem;
    font-size: 1rem;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.3s ease;
    text-align: center;
    display: inline-block;
}

.aw-hero-btn-primary {}

.aw-hero-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.2);
}

.aw-hero-btn-outline {
    border-width: 2px;
    border-style: solid;
    background-color: transparent !important;
}

.aw-hero-btn-outline:hover {
    transform: translateY(-2px);
}

/* IMAGE RIGHT CONTAINER */
.aw-hero-experience-image-wrap {
    flex: 1 1 50% !important;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 700px;
    width: auto !important;
    overflow: visible !important;
    z-index: 5;
}

@media (max-width: 991px) {
    .aw-hero-experience-image-wrap {
        flex: 0 0 100% !important;
        width: 100% !important;
        max-width: 100%;
    }
}

.aw-hero-blob-bg {
    position: absolute;
    width: 125%;
    height: 125%;
    z-index: 1;
    pointer-events: none;
    transition: all 0.5s ease;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.aw-hero-blob-bg.primary {
    border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%;
    animation: blobMorph 10s infinite ease-in-out;
}

.aw-hero-blob-bg.secondary {
    width: 100%;
    height: 100%;
    z-index: 2;
    border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
    animation: blobMorph 12s infinite ease-in-out reverse;
    opacity: 0.5;
}

@keyframes blobMorph {

    0%,
    100% {
        border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%;
    }

    33% {
        border-radius: 60% 40% 40% 60% / 50% 60% 40% 60%;
    }

    66% {
        border-radius: 45% 55% 35% 65% / 45% 45% 65% 55%;
    }
}

.aw-hero-image-clip {
    position: relative;
    z-index: 5;
    width: 100%;
    max-width: 580px;
    aspect-ratio: 1/0.95;
    background-size: cover;
    background-position: center;
    border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
    box-shadow: 0 30px 80px -15px rgba(0,0,0,0.15);
    animation: heroImageFloat 6s infinite ease-in-out;
    transition: all 0.4s ease;
    box-sizing: border-box;
    border: 15px solid #C5A880; /* Fallback and default */
}

/* Overrides removed to favor Elementor Controls */
.aw-hero-style-ceramics .aw-hero-dashed-circle {
    width: 110%;
    height: 110%;
}

@keyframes heroImageFloat {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-10px);
    }
}

.aw-hero-dashed-circle {
    position: absolute;
    width: 105%;
    height: 105%;
    border: 2px dashed rgba(0, 165, 181, 0.4);
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
}

/* PAGINATION DOTS CENTERING */
.aw-hero-pagination-dots {
    position: absolute !important;
    bottom: 1.25rem !important;
    left: 0 !important;
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 0.5rem !important;
    z-index: 100 !important;
}

.aw-hero-pagination-dots .swiper-pagination-bullet {
    width: 0.625rem !important;
    height: 0.625rem !important;
    opacity: 1 !important;
    border-radius: 50% !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    margin: 0 !important;
}

.aw-hero-pagination-dots .swiper-pagination-bullet-active {
    width: 2rem !important;
    border-radius: 0.625rem !important;
}

/* EXTRA MOBILE OPTIMIZATIONS */
@media (max-width: 767px) {
    .aw-hero-slider-main-container {
        overflow: hidden !important;
    }

    .aw-hero-slide-item {
        padding: 3rem 1.25rem 5rem !important;
        /* Increased bottom padding for dots */
        gap: 1.5rem !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        box-sizing: border-box !important;
    }
    .aw-hero-mobile-order-image_first .aw-hero-slide-item {
        flex-direction: column-reverse !important;
    }
    .aw-hero-mobile-order-text_first .aw-hero-slide-item {
        flex-direction: column !important;
    }

    .aw-hero-experience-content {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        box-sizing: border-box !important;
    }

    .aw-hero-experience-title {
        font-size: 2.2rem !important;
        line-height: 1.2 !important;
        margin: 0 auto 1rem !important;
        width: 100% !important;
        display: block !important;
    }

    .aw-hero-experience-subtitle {
        font-size: 1.1rem !important;
        line-height: 1.5 !important;
        margin: 0 auto 2rem !important;
        padding: 0 1rem !important;
        box-sizing: border-box !important;
        width: 100% !important;
        display: block !important;
    }

    .aw-hero-experience-image-wrap {
        width: 100% !important;
        max-width: 100% !important;
        margin-bottom: 0.5rem !important;
    }

    .aw-hero-image-clip {
        max-width: 260px !important;
        width: 85% !important;
        aspect-ratio: 1/1 !important;
        margin: 0 auto !important;
    }

    .aw-hero-experience-buttons {
        width: 100% !important;
        flex-direction: column !important;
        gap: 0.85rem !important;
        padding: 0 !important;
        margin: 0 auto !important;
        align-items: center !important;
    }

    .aw-hero-btn {
        width: 100% !important;
        box-sizing: border-box !important;
        padding: 1.1rem !important;
    }

    .aw-hero-pagination-dots {
        bottom: 1.5rem !important;
    }
}

@media (max-width: 380px) {
    .aw-hero-experience-title {
        font-size: 1.8rem !important;
    }

    .aw-hero-image-clip {
        max-width: 220px !important;
    }
}

/* =======================================================
   Ceramics Clean Style Overrides
   ======================================================= */


.aw-hero-style-ceramics .aw-hero-slide-item {
    padding: 4rem 2rem !important;
    max-width: 1200px;
    margin: 0 auto;
    justify-content: center !important;
    gap: 6rem !important;
}

.aw-hero-style-ceramics .aw-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background-color: #F3EADF;
    padding: 8px 16px;
    border-radius: 50px;
    margin-bottom: 2rem;
}

.aw-hero-style-ceramics .aw-hero-badge-icon i,
.aw-hero-style-ceramics .aw-hero-badge-icon svg {
    font-size: 14px;
    color: #735E48;
}

.aw-hero-style-ceramics .aw-hero-badge-text {
    font-size: 14px;
    font-weight: 700;
    color: #735E48;
}

.aw-hero-style-ceramics .aw-hero-experience-title {
    font-size: 3.5rem;
    color: #1E293B;
    font-weight: 900;
    line-height: 1.1;
}

.aw-hero-style-ceramics .aw-hero-experience-title span.highlight {
    color: #C5A880;
}

/* Underline restored per user request */
.aw-hero-style-ceramics .aw-hero-experience-title span.highlight::after {
    display: block !important;
}

.aw-hero-style-ceramics .aw-hero-experience-subtitle {
    font-size: 1.1rem;
    color: #64748B;
    font-weight: 400;
    margin-bottom: 3rem;
}

.aw-hero-style-ceramics .aw-hero-experience-buttons {
    display: flex;
    gap: 1rem;
}

.aw-hero-style-ceramics .aw-hero-btn-primary {
    background-color: #00A5B5 !important;
    color: #ffffff !important;
    border-radius: 50px !important;
    padding: 12px 24px !important;
    font-size: 1rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.aw-hero-style-ceramics .aw-hero-btn-outline {
    background-color: transparent !important;
    color: #00A5B5 !important;
    border: 2px solid #00A5B5 !important;
    border-radius: 50px !important;
    padding: 12px 24px !important;
    font-size: 1rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.aw-hero-style-ceramics .aw-hero-experience-image-wrap {
    padding: 30px;
}

.aw-hero-style-ceramics .aw-hero-image-clip {
    box-shadow: 0 25px 60px rgba(0,0,0,0.1) !important;
}

.aw-hero-rating-card {
    position: absolute;
    bottom: 30px;
    right: -15px;
    background-color: #ffffff;
    padding: 10px 20px;
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
    display: flex;
    align-items: center;
    gap: 12px;
    z-index: 30;
}

.aw-hero-rating-star {
    font-size: 16px;
    color: #FBBF24;
}

.aw-hero-rating-data {
    display: flex;
    flex-direction: column;
    text-align: left;
}

.aw-hero-rating-val {
    font-size: 13px;
    font-weight: 700;
    color: #1E293B;
    line-height: 1.2;
}

.aw-hero-rating-desc {
    font-size: 11px;
    font-weight: 400;
    color: #64748B;
    line-height: 1.2;
}

@media (max-width: 991px) {
    .aw-hero-style-ceramics .aw-hero-slide-item {
        flex-direction: column !important;
        padding: 2rem 1.5rem !important;
    }
    .aw-hero-style-ceramics.aw-hero-mobile-order-image_first .aw-hero-slide-item {
        flex-direction: column-reverse !important;
    }
    .aw-hero-style-ceramics.aw-hero-mobile-order-text_first .aw-hero-slide-item {
        flex-direction: column !important;
    }

    .aw-hero-style-ceramics .aw-hero-experience-title {
        font-size: 2.5rem;
    }

    .aw-hero-style-ceramics .aw-hero-rating-card {
        bottom: 10px;
        left: 10px;
        padding: 8px 12px;
    }
}

/* --- File: experience-portal.css --- */
/**
 * Experience Portal v3 — Premium Boxed Design
 */

:root {
    --aw-primary: #00A5B5;
    --aw-primary-hover: #008f96;
    --aw-primary-soft: rgba(0, 165, 181, 0.06);
    --aw-tangerine: #FAA638;
    --aw-text-main: #475569;
    --aw-text-dark: #1E293B;
    --aw-text-muted: #64748B;
    --aw-text-light: #94A3B8;
    --aw-bg-body: #F8FAFC;
    --aw-white: #FFFFFF;
    --aw-border: #E2E8F0;
    --aw-shadow-sm: 0px 2px 4px rgba(0, 0, 0, 0.05);
    --aw-shadow-md: 0px 8px 32px rgba(0, 0, 0, 0.05);
    --aw-radius-lg: 24px;
    --aw-radius-md: 16px;
    --aw-radius-sm: 12px;
}

.aw-portal-wrapper {
    font-family: 'Inter', 'Outfit', sans-serif;
    color: var(--aw-text-dark);

    width: 100% !important;
    margin: 0 auto;
    padding: 32px;
    background: var(--aw-bg-body);
    box-sizing: border-box;
}

.aw-portal-container {
    display: flex;
    gap: 32px;
    align-items: flex-start;
}

.aw-gallery-empty {
    text-align: center;
    padding: 100px 20px;
    color: #94A3B8;
    font-size: 16px;
    border: 1px dashed #E2E8F0;
    border-radius: 16px;
    background: #FFF;
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
}

@media (max-width: 1024px) {
    .aw-portal-container {
        flex-direction: column;
    }

    .aw-portal-wrapper {
        padding: 16px;
    }
}

/* SIDEBAR */
.aw-portal-sidebar {
    flex: 0 0 300px;
    background: var(--aw-white);
    padding: 24px;
    border-radius: var(--aw-radius-lg);
    box-shadow: var(--aw-shadow-md);
    position: sticky;
    top: 20px;
}

.aw-sidebar-title {
    font-size: 20px;
    font-weight: 800;
    margin-bottom: 24px;
    color: var(--aw-text-dark);
}

.aw-sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.aw-nav-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 20px;
    border-radius: var(--aw-radius-md);
    background: transparent;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all 0.3s ease;
    width: 100%;
    text-align: left;
    position: relative;
}

.aw-nav-item:hover {
    background: #F1F5F9;
}

.aw-nav-item.is-active {
    background: var(--aw-primary-soft);
    border-color: rgba(0, 165, 181, 0.1);
}

.aw-nav-item.is-active::before {
    content: "";
    position: absolute;
    left: 0;
    top: 15%;
    bottom: 15%;
    width: 4px;
    background: var(--aw-primary);
    border-radius: 0 4px 4px 0;
}

.aw-nav-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #F1F5F9;
    border-radius: 12px;
    color: var(--aw-text-muted);
    flex-shrink: 0;
}

.aw-nav-item.is-active .aw-nav-icon {
    background: #CCFBF1;
    color: var(--aw-primary);
}

.aw-nav-label {
    font-size: 15px;
    font-weight: 600;
    color: var(--aw-text-main);
}

.aw-nav-item.is-active .aw-nav-label {
    color: var(--aw-primary);
}

/* MAIN CONTENT */
.aw-portal-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 32px;
    min-width: 0;
}

/* HERO */
.aw-portal-hero {
    border-radius: var(--aw-radius-lg);
    overflow: hidden;
    background: var(--aw-white);
    box-shadow: var(--aw-shadow-md);
}

.aw-hero-banner {
    width: 100%;
    height: 300px;
    /* Fixed height to fill width without growing too tall */
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    border-radius: 20px;
}

.aw-hero-overlay {
    padding: 40px;
    background: linear-gradient(90deg, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.1) 50%, transparent 100%);
    width: 60%;
    /* Only cover the text area */
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-radius: inherit;
}

.aw-hero-title {
    color: #FFF;
    font-size: 80px;
    font-weight: 800;
    margin-bottom: 8px;
    text-shadow: -7px 7px 14px rgb(0 0 0) !important;
}

.aw-hero-title-underline {
    width: 80px;
    height: 4px;
    background: var(--aw-tangerine);
}

.aw-hero-content {
    padding: 24px 40px;
}

.aw-hero-description {
    font-size: 15px;
    line-height: 1.6;
    color: var(--aw-text-muted);
}

/* MODE TOGGLE - REFINED MATCHING MOCKUP */
.aw-portal-mode-toggle {
    background: var(--aw-white);
    border-radius: 16px;
    padding: 20px;
    box-shadow: var(--aw-shadow-md);

}

.aw-portal-mode-toggle h4 {
    margin: 0 0 12px 0;
    font-size: 15px;
    font-weight: 700;
    color: var(--aw-text-dark);
}

.aw-toggle-options {
    display: flex;
    gap: 16px;
    margin-bottom: 24px;
}

.aw-toggle-card {
    flex: 1;
    display: flex;
    align-items: center;
    padding: 16px 24px;
    height: 45px;
    background: #FFF;
    border: 1.5px solid var(--aw-border);
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    gap: 16px;
    user-select: none;
}

.aw-toggle-card:hover {
    border-color: var(--aw-primary);
}

.aw-toggle-card.is-active {
    background: rgba(0, 165, 181, 0.04);
    border-color: var(--aw-primary);
}

.aw-toggle-card input[type="radio"] {
    display: none;
}

.aw-toggle-radio {
    width: 22px;
    height: 22px;
    border: 1.5px solid #CBD5E1;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: #FFF;
    box-sizing: border-box;
    position: relative;
}

.aw-toggle-card.is-active .aw-toggle-radio {
    border-color: var(--aw-primary);
    border-width: 2px;
}

.aw-toggle-card.is-active .aw-toggle-radio::after {
    content: "";
    width: 10px;
    height: 10px;
    background: var(--aw-primary);
    border-radius: 50%;
    display: block;
}

.aw-toggle-icon {
    font-size: 18px;
    color: #64748B;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    line-height: 1;
}

.aw-toggle-icon svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    fill: none;
    transition: all 0.2s ease;
}

.aw-toggle-card.is-active .aw-toggle-icon {
    color: var(--aw-primary);
}

/* Force FontAwesome to show if missing */
.aw-toggle-icon i {
    display: inline-block !important;
    font-family: "Font Awesome 5 Free", "FontAwesome" !important;
    font-weight: 900;
    font-style: normal;
}

.aw-toggle-text {
    font-size: 14px;
    font-weight: 600;
    color: var(--aw-text-dark);
    white-space: nowrap;
}

.aw-toggle-card:not(.is-active) .aw-toggle-text {
    color: #64748B;
}

.aw-toggle-card.is-active .aw-toggle-radio::after {
    content: "";
    position: absolute;

    background: var(--aw-primary);
    border-radius: 50%;
}

.aw-toggle-icon {
    font-size: 22px;
    color: var(--aw-text-muted);
}

.aw-toggle-card.is-active .aw-toggle-icon {
    color: var(--aw-primary);
}

.aw-toggle-header {
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 700;
    color: var(--aw-text-dark);
}

/* GLOBAL FILTERS ROW */
.aw-global-filters-row {
    display: flex;
    gap: 16px;
    margin-top: 8px;
    margin-bottom: 8px;
}

.aw-filter-box {
    flex: 1;
    height: 56px;
    background: #FFF;
    border: 1.5px solid #E2E8F0;
    border-radius: 12px;
    display: flex;
    align-items: center;
    padding: 0 16px;
    position: relative;
}

.aw-filter-box .aw-input-icon {
    color: var(--aw-primary);
}

.aw-location-box select {
    width: 100%;
    border: none;
    background: transparent;
    padding: 0 0 0 32px;
    font-size: 15px;
    font-weight: 700;
    color: var(--aw-text-dark);
    appearance: none;
    outline: none;
}

.aw-people-box {
    justify-content: space-between;
}

.aw-people-inner {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.aw-people-inner .aw-input-icon {
    position: static;
    transform: none;
    color: var(--aw-primary);
    display: flex;
    align-items: center;
}

.aw-people-inner .count {
    font-size: 15px;
    font-weight: 700;
    color: var(--aw-text-dark);
}

.aw-counter-controls {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0;
}

.aw-counter-controls button {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    border: 1px solid #E2E8F0;
    background: #FFF;
    color: #64748B;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.aw-counter-controls button:hover {
    background: #F8FAFC;
    color: var(--aw-primary);
}

/* ═══════════════════════════════════════════════════ */
/* FLOW CONTAINER: Controls visual order by mode       */
/* ═══════════════════════════════════════════════════ */

/* Unified single-card container for ALL modes */
.aw-flow-container {
    display: flex;
    flex-direction: column;
    background: #FFF;
    border-radius: var(--aw-radius-lg);
    border: 1.5px solid var(--aw-border);
    box-shadow: var(--aw-shadow-sm);
    padding: 24px;

}

/* Base styles for sections inside the unified container */
.aw-flow-container>section {
    transition: opacity 0.35s ease;
    background: transparent;
    border: none;
    box-shadow: none;
    border-radius: 0;
    margin-top: 0;
    padding: 0;
}

/* —— Mode: Artwork (default) —— */
.aw-flow-container[data-mode="artwork"] .aw-artwork-selector {
    order: 1;
}

.aw-flow-container[data-mode="artwork"] .aw-session-scheduler {
    order: 2;
    margin-top: 32px;
    border-top: 1px solid var(--aw-border);
}

.aw-flow-container[data-mode="artwork"] .aw-booking-selection {
    order: 3;
    /* padding-top: 32px;
    margin-top: 32px; */
    border-top: 1px solid var(--aw-border);
}

.aw-flow-container[data-mode="date"] .aw-session-scheduler {
    order: 1;
    display: none;
}

.aw-flow-container[data-mode="date"] .aw-session-scheduler.is-visible {
    display: block !important;
}

.aw-flow-container[data-mode="date"] .aw-artwork-selector {
    order: 2;
    margin-top: 40px;
    padding-top: 40px;
    border-top: 1px solid #F1F5F9;
}

.aw-flow-container[data-mode="date"] .aw-booking-selection {
    order: 3;
    margin-top: 40px;
    padding-top: 40px;
    border-top: 1px solid #F1F5F9;
}

.aw-session-scheduler {
    display: none;
}

.aw-session-scheduler.is-visible {
    display: block;
}


.aw-selector-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 24px;
    gap: 24px;
}

@media (max-width: 768px) {
    .aw-selector-header {
        flex-direction: column;
        align-items: flex-start;
    }
}

.aw-header-text h3,
#aw-gallery-main-title,
.aw-scheduler-title {
    font-size: 24px;
    font-weight: 800;
    color: var(--aw-text-dark, #1E293B);
    display: block !important;
}

.aw-section-subtitle,
#aw-gallery-secondary-title,
#aw-slots-title {
    font-size: 11px;
    font-weight: 700;
    color: #94A3B8;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    margin: 0 !important;
}

.aw-header-text p {
    font-size: 15px;
    color: var(--aw-text-muted);
    margin: 0;
}

#aw-active-date-display {
    color: var(--aw-text-dark, #1E293B);
    /* Make it black instead of primary color to match mockup */
    font-weight: 800;
}

#aw-gallery-secondary-header {
    margin: 0 0 24px 0;
    padding: 0;
}

#aw-gallery-secondary-header h4 {
    margin-top: 0;
}

.aw-gallery-secondary-note,
.aw-scheduler-note {
    font-size: 14px;
    color: #94A3B8;
    margin: 0 0 24px 0;
    line-height: 1.6;
}

.aw-header-search {

    align-self: flex-start;
}

.aw-search-container {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
}

.aw-search-container input {
    width: 100%;
    height: 48px;
    padding: 0 16px 0 44px !important;
    border: 1.5px solid #E2E8F0;
    border-radius: 12px;
    background: #F8FAFC;
    font-size: 14px;
    color: var(--aw-text-main);
    transition: all 0.2s;
    outline: none;
}

.aw-search-container input:focus {
    border-color: var(--aw-primary);
    background: #FFF;
    box-shadow: 0 0 0 4px rgba(0, 165, 181, 0.08);
}

.aw-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    color: #94A3B8;
    pointer-events: none;
    z-index: 5;
    display: block !important;
}

.aw-filter-chips {
    display: flex;
    gap: 10px;
    margin-bottom: 32px;
    flex-wrap: wrap;
}

.aw-chip {
    padding: 10px 22px;
    border-radius: 100px;
    background: #FFF;
    border: 1.5px solid #E2E8F0;
    color: #64748B;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.aw-chip:hover {
    border-color: var(--aw-primary-soft);
    color: var(--aw-primary);
}

.aw-chip.is-active {
    background: var(--aw-primary);
    color: #FFF;
    border-color: var(--aw-primary);
    box-shadow: 0 4px 12px rgba(0, 165, 181, 0.25);
}

/* SLIDER LAYOUT */
.aw-gallery-slider-container {
    position: relative;
    margin-bottom: 32px;
    padding: 0 10px;
}

.aw-artworks-gallery {
    overflow: hidden;
    padding: 10px 0 20px 0;
}

.swiper-wrapper {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
}

.swiper-slide {
    flex-shrink: 0;
    height: auto;
    position: relative;
    transition-property: transform;
}

.aw-artwork-card {
    background: var(--aw-white);
    border-radius: 12px;
    overflow: hidden;
    border: 1.5px solid #F1F5F9;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.aw-artwork-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.08);
}

.aw-artwork-card.is-selected {
    border: 2px solid #45AAB8;
}

.aw-artwork-card.is-agotado {
    opacity: 0.6;
    cursor: not-allowed;

}

.aw-artwork-card.is-agotado:hover {
    transform: none;
    box-shadow: var(--aw-shadow-sm);
}

.aw-card-image {
    aspect-ratio: 16/10;
    background-size: cover;
    background-position: center;
    position: relative;
}

/* BADGES */
.aw-card-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 6px 14px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    color: #FFF;
}

.aw-badge-limited {
    background: #F97316;
    /* Orange */
}

.aw-badge-session {
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
}

.aw-badge-agotado {
    background: #94A3B8;
    color: #FFF;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* SELECTION INDICATOR */
.aw-card-check {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 28px;
    height: 28px;
    background: var(--aw-primary);
    color: #FFF;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    opacity: 0;
    transform: scale(0.5);
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 4px 10px rgba(0, 165, 181, 0.3);
    z-index: 2;
}

.is-selected .aw-card-check {
    opacity: 1;
    transform: scale(1);
}

.aw-card-info {
    padding: 20px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.aw-card-title {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 6px 0;
    color: #1E293B;
}

.aw-card-footer {
    font-size: 14px;
    color: #94A3B8;
    font-weight: 400;
}

/* SLIDER NAVIGATION */
.aw-slider-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.aw-slider-nav.swiper-button-lock {
    display: none !important;
}

.aw-slider-nav {
    width: 44px;
    height: 44px;
    background: #FFF;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--aw-text-dark);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
    cursor: pointer;
    z-index: 10;
    transition: all 0.2s;
}

.aw-slider-nav:hover {
    background: var(--aw-primary);
    color: #FFF;
    transform: translateY(-50%) scale(1.1);
}

.aw-slider-nav svg {
    width: 22px;
    height: 22px;
}

.aw-nav-prev {
    left: -10px;
}

.aw-nav-next {
    right: -10px;
}

/* FOOTER BUTTON */
.aw-gallery-footer {
    display: flex;
    justify-content: center;
    margin-top: 24px;
}

.aw-btn-browse-all {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 16px;
    background: #FFF;
    border: 2px dashed #CBD5E1;
    border-radius: 16px;
    color: #64748B;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.aw-btn-browse-all:hover {
    border-color: var(--aw-primary);
    color: var(--aw-primary);
    background: rgba(0, 165, 181, 0.02);
}

.aw-btn-browse-all svg {
    color: #94A3B8;
    transition: color 0.2s;
}

.aw-btn-browse-all:hover svg {
    color: var(--aw-primary);
}

.aw-gallery-footer {
    margin-top: 16px;
}

.aw-btn-secondary {
    width: 100%;
    padding: 14px;
    border: 1.5px dashed var(--aw-border);
    background: transparent;
    border-radius: var(--aw-radius-sm);
    color: var(--aw-text-muted);
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

/* SCHEDULER CONTROLS ROW */
.aw-scheduler-title {
    font-size: 24px;
    font-weight: 800;
    margin: 0 0 8px 0 !important;
    color: var(--aw-text-dark);
}

.aw-scheduler-desc {
    font-size: 15px;
    color: var(--aw-text-muted);
    margin: 0 0 32px 0;
}

@media (max-width: 768px) {
    .aw-scheduler-controls {
        flex-direction: column;
    }
}

.aw-control-item {
    flex: 1;
    position: relative;
}

.aw-input-icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--aw-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    z-index: 5;
}

.aw-input-icon svg {
    width: 18px;
    height: 18px;
    stroke: #00A5B5;
    /* Teal icon */
    stroke-width: 2.5px;
}

.aw-control-item select,
.aw-people-counter {
    width: 100%;
    height: 54px;
    padding: 0 16px 0 48px;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    background: #FFF;
    font-size: 14px;
    font-weight: 600;
    color: #475569;
    cursor: pointer;
    appearance: none;
    transition: all 0.2s;
}

.aw-control-item select:focus,
.aw-people-counter:focus-within {
    border-color: #00A5B5;
    outline: none;
    box-shadow: 0 0 0 3px rgba(0, 165, 181, 0.08);
}

.aw-control-item select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394A3B8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 14px;
}

.aw-people-counter {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.aw-counter-controls {
    display: flex;
    gap: 12px;
}

.aw-counter-controls button {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid var(--aw-border);
    background: #FFF;
    color: var(--aw-text-muted);
    cursor: pointer;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* CALENDAR STRIP */
.aw-weekly-calendar {
    margin-bottom: 32px;
}

.aw-calendar-nav-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.aw-cal-arrows {
    display: flex;
    gap: 10px;
}

.aw-cal-nav {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--aw-border);
    background: #FFF;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--aw-primary);
    transition: all 0.2s ease;
    padding: 0;
}

.aw-cal-nav:hover {
    background: var(--aw-primary-soft);
    border-color: var(--aw-primary);
}

.aw-cal-nav svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
}

.aw-days-strip {
    flex: 1;
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 4px 0 12px;
}

/* CALENDAR EMPTY STATE */
.aw-calendar-empty {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 40px 24px;
    text-align: center;
    background: #F8FAFC;
    border: 2px dashed var(--aw-border);
    border-radius: var(--aw-radius-md);
}

.aw-calendar-empty svg {
    color: var(--aw-text-light);
    opacity: 0.6;
}

.aw-calendar-empty p {
    font-size: 15px;
    font-weight: 500;
    color: var(--aw-text-muted);
    margin: 0;
    line-height: 1.5;
}

.aw-calendar-empty p strong {
    color: var(--aw-primary);
    font-weight: 700;
}



.aw-cal-day {
    flex: 0 0 94px;
    height: 112px;
    background: #F1F5F9;
    border: 1px solid transparent;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}

.aw-cal-day.is-active {
    background: #45AAB8;
    box-shadow: 0 10px 15px -3px rgba(69, 170, 184, 0.3);
}

.aw-cal-day .day-name {
    font-size: 10px;
    font-weight: 700;
    color: #94A3B8;
    text-transform: uppercase;
    margin-bottom: 6px;
}

.aw-cal-day .day-number {
    font-size: 26px;
    font-weight: 800;
    color: #1E293B;
    line-height: 1;
}

.aw-cal-day .day-month {
    font-size: 10px;
    font-weight: 600;
    color: #94A3B8;
    margin-top: 4px;
}

.aw-cal-day.is-active .day-name,
.aw-cal-day.is-active .day-number,
.aw-cal-day.is-active .day-month {
    color: #FFF;
}

/* Availability dot */
.aw-cal-day::after {
    content: '';
    display: block;
    width: 4px;
    height: 4px;
    background: #45AAB8;
    border-radius: 50%;
    margin-top: 8px;
}

.aw-cal-day.is-active::after {
    background: #FFF;
}

.aw-cal-day.is-active .day-name,
.aw-cal-day.is-active .day-number,
.aw-cal-day.is-active .day-month {
    color: #FFF;
}

.aw-cal-day.is-disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* SLOTS AREA / EMPTY STATE */
.aw-time-slots-area {
    background: #F8FAFC;
    border-radius: var(--aw-radius-md);

    text-align: center;
    margin-bottom: 24px;
}

.aw-empty-slots {
    color: var(--aw-text-muted);
}

.aw-empty-slots .icon {
    font-size: 40px;
    display: block;
    margin-bottom: 16px;
    opacity: 0.4;
}

.aw-slots-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}

.aw-slot-pill {
    padding: 24px;
    background: #FFF;
    border: 1.5px solid var(--aw-border);
    border-radius: var(--aw-radius-md);
    cursor: pointer;
    text-align: left;
    position: relative;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.aw-slot-pill:hover {
    border-color: var(--aw-primary-300);
}

.aw-slot-pill.is-selected {
    border-color: var(--aw-primary);
    background: var(--aw-primary-soft);
}

.aw-slot-pill.is-selected::after {
    content: "✓";
    position: absolute;
    top: -10px;
    right: -10px;
    width: 24px;
    height: 24px;
    background: var(--aw-primary);
    color: #FFF;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 800;
    box-shadow: 0 4px 8px rgba(0, 165, 181, 0.3);
}

.aw-slot-time {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 800;
    font-size: 20px;
    color: var(--aw-text-dark);
}

.aw-slot-time svg {
    color: var(--aw-primary);
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.aw-slot-stock {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--aw-text-muted);
    font-weight: 600;
}

.aw-slot-stock svg {
    width: 16px;
    height: 16px;
    opacity: 0.8;
    color: var(--aw-primary);
    flex-shrink: 0;
}

/* GALLERY FOOTER BUTTON */
.aw-gallery-footer {
    display: flex;
    justify-content: center;
    margin-top: 32px;
}

.aw-btn-browse-all {
    width: 100%;
    padding: 16px;
    background: transparent;
    border: 1.5px dashed var(--aw-border);
    border-radius: var(--aw-radius-md);
    color: var(--aw-text-muted);
    font-size: 15px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    cursor: pointer;
    transition: all 0.2s;
}

.aw-btn-browse-all:hover {
    border-color: var(--aw-primary);
    color: var(--aw-primary);
    background: var(--aw-primary-soft);
}

.aw-btn-browse-all svg {
    opacity: 0.7;
}

/* FOOTER / CONTINUE BUTTON */
.aw-btn-booking {
    width: 100%;
    height: 64px;
    background: var(--aw-primary);
    color: #FFF;
    border: none;
    border-radius: var(--aw-radius-md);
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s;
}

.aw-btn-booking:disabled {
    background: #E2E8F0;
    color: #94A3B8;
    cursor: not-allowed;
}

.aw-btn-booking:not(:disabled):hover {
    background: var(--aw-primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 165, 181, 0.2);
}

.aw-notice {
    padding: 24px;
    border-radius: 12px;
    font-weight: 500;
    text-align: center;
}

.aw-notice-agotado {
    background: #FEF2F2;
    color: #991B1B;
    border: 1px solid #FEE2E2;
    margin: 20px 0;
}

.aw-slots-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
    margin-top: 16px;
    margin-bottom: 32px;
}

.aw-slot-pill {
    background: #FFF;
    border: 1px solid #E2E8F0;
    border-radius: 16px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
}

.aw-slot-pill.is-selected {
    border: 1.5px solid #45AAB8;
    background: #F0F9FA;
}

.aw-slot-pill.is-selected::after {
    content: '✓';
    position: absolute;
    top: -8px;
    right: -8px;
    background: #45AAB8;
    color: #FFF;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 800;
    border: 2px solid #FFF;
}

.aw-slot-time {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 18px;
    font-weight: 700;
    color: #1E293B;
}

.aw-slot-time svg {
    color: #45AAB8;
    width: 18px;
    height: 18px;
}

.aw-slot-stock {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: #64748B;
}

.aw-slot-stock svg {
    color: #94A3B8;
    width: 16px;
    height: 16px;
}

.aw-empty-slots {
    padding: 60px 40px;
    text-align: center;
    color: #94A3B8;
    background: #F8FAFC;
    border-radius: 20px;
    border: 2px dashed #E2E8F0;
}

.aw-empty-slots .icon {
    font-size: 32px;
    margin-bottom: 16px;
    display: block;
    opacity: 0.5;
}

/* ═══════════════════════════════════════════════════ */
/* MOBILE OPTIMIZATIONS — EXPERIENCE PORTAL V2         */
/* ═══════════════════════════════════════════════════ */

@media (max-width: 991px) {
    .aw-portal-wrapper {
        padding: 16px 10px;
        overflow: hidden;
    }

    .aw-portal-container {
        gap: 20px;
        width: 100%;
    }

    /* Transform sidebar to horizontal scroll on mobile */
    .aw-portal-sidebar {
        flex: none;
        width: 100%;
        margin: 0;
        border-radius: 0;
        padding: 15px 0;
        position: relative;
        top: 0;
        box-shadow: none;
        border-bottom: 1px solid var(--aw-border);
    }

    .aw-sidebar-title {
        display: none;
        /* Hide title in horizontal mobile menu */
    }

    .aw-sidebar-nav {
        flex-direction: row;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 5px;
        gap: 12px;
        scrollbar-width: none;
    }

    .aw-sidebar-nav::-webkit-scrollbar {
        display: none;
    }

    .aw-nav-item {
        flex: 0 0 auto;
        width: auto;
        padding: 10px 16px;
        gap: 10px;
        background: #F1F5F9;
    }

    .aw-nav-item.is-active::before {
        display: none;
    }

    .aw-nav-icon {
        width: 32px;
        height: 32px;
    }

    .aw-nav-label {
        font-size: 13px;
    }

    .aw-portal-main {
        flex: none !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        gap: 20px;
    }

    .aw-artworks-gallery {
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    .aw-hero-banner {
        height: 180px;
    }

    .aw-hero-overlay {
        padding: 20px;
    }

    .aw-hero-title {
        font-size: 24px;
    }

    .aw-hero-content {
        padding: 20px;
    }

    .aw-portal-mode-toggle {
        padding: 20px 15px;
    }

    .aw-toggle-options {
        flex-direction: column;
    }

    .aw-global-filters-row {
        flex-direction: column;
        gap: 12px;
    }

    .aw-toggle-card {
        height: 56px;
        padding: 16px 16px;
    }

    .aw-flow-container {
        padding: 20px 15px;
    }

    .aw-header-text h3,
    #aw-gallery-main-title,
    .aw-scheduler-title {
        font-size: 20px;
    }

    .aw-slots-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .aw-hero-banner {
        height: 150px;
    }

    .aw-hero-title {
        font-size: 20px;
    }



    .aw-cal-day {
        flex: 0 0 75px;
        height: 90px;
    }

    .aw-cal-day .day-number {
        font-size: 20px;
    }

    .aw-artwork-card .aw-card-info {
        padding: 15px;
    }

    .aw-card-title {
        font-size: 16px;
    }
}

/* MODAL SEGURO DE CANCELACIÓN */
.aw-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    padding: 20px;
}

.aw-modal-content {
    background: #FFF;
    width: 100%;
    max-width: 480px;
    border-radius: 24px;
    padding: 32px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
    animation: awModalFadeIn 0.3s ease-out;
}

@keyframes awModalFadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.aw-modal-header h3 {
    margin: 0 0 24px 0;
    font-size: 22px;
    font-weight: 800;
    color: #1E293B;
}

.aw-insurance-card {
    border: 1.5px solid #E2E8F0;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 24px;
    background: #F8FAFC;
    text-align: left;
}

.aw-insurance-info h4 {
    margin: 0 0 4px 0;
    font-size: 16px;
    font-weight: 700;
    color: #1E293B;
}

.aw-insurance-price {
    font-size: 15px;
    color: #64748B;
    font-weight: 600;
}

.aw-insurance-conditions {
    text-align: left;
}

.aw-insurance-conditions h5 {
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 700;
    color: #1E293B;
}

.aw-insurance-conditions ul {
    margin: 0;
    padding: 0 0 0 18px;
    list-style: disc;
}

.aw-insurance-conditions li {
    font-size: 13px;
    line-height: 1.5;
    color: #64748B;
    margin-bottom: 8px;
}

.aw-modal-footer {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 32px;
}

.aw-btn-primary {
    width: 100%;
    height: 52px;
    background: #00A5B5;
    color: #FFF;
    border: none;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
}

.aw-btn-primary:hover {
    background: #008F9B;
    transform: translateY(-2px);
}

.aw-btn-link {
    background: none;
    border: none;
    color: #64748B;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
}

/* ═══════════════════════════════════════════════════ */
/* PAST CREATIONS SECTION — EXPERIENCE PORTAL V2       */
/* ═══════════════════════════════════════════════════ */

.aw-past-creations-section {
    width: 100%;
    margin-top: 50px;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    padding-top: 40px;
    text-align: left;
    clear: both;
}

.aw-past-creations-title {
    font-family: 'Outfit', 'Inter', sans-serif;
    font-size: 26px;
    font-weight: 700;
    color: #1E293B;
    margin: 0 0 8px 0;
    line-height: 1.2;
}

.aw-past-creations-subtitle {
    font-family: 'Inter', sans-serif;
    font-size: 15px;
    color: #64748B;
    margin: 0 0 24px 0;
}

.aw-past-creations-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    width: 100%;
}

.aw-past-creation-item {
    overflow: hidden;
    position: relative;
    border-radius: 20px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.03);
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s ease;
}

.aw-past-creation-item img {
    width: 100%;
    display: block;
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 20px;
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

/* Hover premium micro-interactions */
.aw-past-creation-item:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1);
}

.aw-past-creation-item:hover img {
    transform: scale(1.06);
}

/* Responsive adjustments */
@media (max-width: 991px) {
    .aw-past-creations-section {
        padding-left: 15px;
        padding-right: 15px;
        margin-top: 40px;
    }
}

@media (max-width: 768px) {
    .aw-past-creations-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 12px;
    }

    .aw-past-creations-title {
        font-size: 20px;
    }

    .aw-past-creations-subtitle {
        font-size: 13px;
        margin-bottom: 16px;
    }
}

@media (max-width: 480px) {
    .aw-past-creations-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

/* ALL PAINTINGS MODAL STYLES */
.aw-all-paintings-modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(15, 23, 42, 0.5) !important;
    backdrop-filter: blur(8px) !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 99999999 !important;
    padding: 20px !important;
    box-sizing: border-box !important;
}

.aw-all-paintings-content {
    background: #FFFFFF !important;
    border-radius: 24px !important;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15) !important;
    max-width: 1100px !important;
    width: 95% !important;
    max-height: 90vh !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 32px !important;
    box-sizing: border-box !important;
    animation: awModalFadeIn 0.3s ease-out !important;
}

.aw-all-paintings-content .aw-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    position: relative;
    border: none;
    background: transparent;
    padding: 0;
}

.aw-all-paintings-content .aw-modal-header h3 {
    font-size: 24px;
    font-weight: 800;
    color: #1E293B;
    margin: 0;
}

.aw-modal-close {
    background: transparent;
    border: none;
    font-size: 28px;
    color: #94A3B8;
    cursor: pointer;
    line-height: 1;
    padding: 0;
    transition: color 0.2s;
}

.aw-modal-close:hover {
    color: #1E293B;
}

.aw-all-paintings-content .aw-modal-body {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    flex: 1;
}

.aw-modal-controls-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.aw-modal-filter-chips {
    margin-bottom: 0 !important;
}

.aw-modal-search {
    width: 300px;
    align-self: center;
}

.aw-modal-results-count {
    font-size: 14px;
    color: #94A3B8;
    margin-bottom: 20px;
    font-weight: 600;
}

.aw-modal-grid-container {
    overflow-y: auto;
    flex: 1;
    padding-right: 8px;
    margin-right: -8px;
}

.aw-modal-paintings-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    padding: 4px;
}

.aw-modal-paintings-grid .aw-artwork-card {
    display: flex;
    flex-direction: column;
    background: var(--aw-white);
    border-radius: 12px;
    overflow: hidden;
    border: 1.5px solid #F1F5F9;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
}

.aw-modal-paintings-grid .aw-artwork-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.08);
}

.aw-modal-paintings-grid .aw-artwork-card.is-selected {
    border: 2px solid #45AAB8;
}

.aw-modal-paintings-grid .aw-artwork-card.is-agotado {
    opacity: 0.6;
    cursor: not-allowed;
}

.aw-modal-paintings-grid .aw-artwork-card.is-agotado:hover {
    transform: none;
    box-shadow: var(--aw-shadow-sm);
}

@media (max-width: 1024px) {
    .aw-modal-paintings-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .aw-modal-paintings-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .aw-modal-controls-row {
        flex-direction: column;
        align-items: stretch;
    }

    .aw-modal-search {
        width: 100%;
    }
}

@media (max-width: 480px) {
    .aw-modal-paintings-grid {
        grid-template-columns: 1fr;
    }

    .aw-all-paintings-content {
        padding: 20px;
        max-height: 95vh;
    }
}

/* --- File: ceramics.css --- */
/**
 * ArtWine Ceramics Theme Styles
 */

.aw-ceramics-quote-container {
    max-width: 60rem;
    margin: 4em auto;
    padding: 0 5%;
    position: relative;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.aw-ceramics-quote-text {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.4;
    color: #334155;
    margin: 0;
    position: relative;
    z-index: 2;
}

.aw-ceramics-quote-icon {
    width: 2.5rem;
    height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #D4A373;
    /* Default Ocre */
    transition: transform 0.3s ease;
    vertical-align: baseline;
}

.aw-ceramics-quote-icon svg {
    width: 100%;
    height: auto;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.5;
}

.aw-ceramics-quote-icon.start {
    margin-right: 10px;
    position: relative;
}

.aw-ceramics-quote-icon.end {
    margin-left: 10px;
    position: relative;
}

/* --- PATHS SELECTION WIDGET --- */
.aw-ceramics-paths-wrap {
    width: 100%;
    margin: 5rem 0;
    padding: 6rem 0;
    position: relative;
}

.aw-ceramics-paths-inner-container {
    display: flex;
    width: 100%;
    position: relative;
    z-index: 5;
    /* justify-content handled by Elementor live control */
}

.aw-ceramics-paths-inner {
    position: relative;
    width: 100%;
    /* max-width handled by Elementor live control */
}

.aw-ceramics-paths-header {
    margin-bottom: 3.5rem;
}

.aw-ceramics-paths-title {
    font-size: 3.5rem;
    font-weight: 900;
    margin-bottom: 1.25rem;
    line-height: 1.1;
}

.aw-ceramics-paths-subtitle {
    font-size: 1.75rem;
    line-height: 1.4;
}

.aw-highlight-underline {
    position: relative;
    display: inline;
}

.aw-highlight-underline {
    position: relative;
    display: inline-block;
}

.aw-highlight-underline::after {
    content: '';
    position: absolute;
    bottom: 0.1rem;
    left: 0;
    width: 100%;
    height: 0.4rem;
    background-color: #D4A373;
    z-index: -1;
    opacity: 0.8;
}

.aw-ceramics-paths-grid {
    display: grid;
    gap: 2.5rem;
    align-items: stretch;
}

.aw-ceramics-path-card {
    border: none;
    display: flex;
    flex-direction: column;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    height: 100%;
}

.aw-card-icon {
    border-radius: 0.75rem;
    margin-bottom: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.aw-card-icon img {
    object-fit: contain;
}

.aw-card-title {
    font-size: 1.2rem;
    font-weight: 900;
    margin-bottom: 1rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.aw-card-desc {
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 2rem;
    flex-grow: 1;
}

.aw-card-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem 1.75rem;
    border-radius: 0.75rem;
    text-decoration: none;
    transition: all 0.3s ease;
    width: fit-content;
    font-weight: 700;
}

.aw-card-btn span.arrow {
    font-size: 1.1rem;
    transition: transform 0.3s ease;
}

.aw-card-btn:hover span.arrow {
    transform: translateX(5px);
}

/* Background Decorations */
.aw-ceramics-paths-circle-decoration {
    position: absolute;
    z-index: 1;
    pointer-events: none;
    transform: translateY(-50%);
}

/* Circle decoration position and size are handled by Elementor sliders */

.aw-ceramics-paths-circle-decoration svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.aw-ceramics-paths-circle-decoration svg circle {
    stroke-dasharray: 6 10;
    stroke-width: 1.5;
    stroke-linecap: round;
    fill: none;
}

@media (max-width: 767px) {
    .aw-ceramics-paths-wrap {
        border-radius: 0 80px 0 0;
        padding: 60px 0;
    }
}


/* --- CERAMICS INFO WIDGET (Blobs) --- */
.aw-ceramics-info-wrap {
    display: flex;
    align-items: center;
    gap: 5rem;
    padding: 4rem 0;
}

.aw-ceramics-info-media {
    position: relative;
    width: 50%;
    flex-shrink: 0;
    aspect-ratio: 1 / 1;
}

.aw-blob-layer {
    position: absolute;
    width: 100%;
    height: 100%;
    transition: all 0.5s ease;
}

.aw-blob-1 {
    z-index: 3;
    border-radius: 67% 33% 47% 53% / 37% 48% 52% 63%;
    opacity: 0.9;
}

.aw-blob-2 {
    z-index: 1;
    border-radius: 30% 70% 70% 30% / 49% 37% 63% 51%;
    transform: scale(1.1) rotate(-8deg);
}

.aw-blob-dash {
    z-index: 2;
    border: 1.5px dashed #334155;
    border-radius: 50% 50% 50% 50% / 40% 60% 40% 60%;
    transform: scale(1.12) rotate(4deg);
    background: transparent;
    opacity: 0.4;
}

.aw-info-image-container {
    position: relative;
    z-index: 4;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: 67% 33% 47% 53% / 37% 48% 52% 63%;
}

.aw-info-image-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.aw-ceramics-info-content {
    flex-grow: 1;
}

.aw-info-title {
    font-size: 3rem;
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 2rem;
}

.aw-info-desc {
    font-size: 1.125rem;
    line-height: 1.6;
    margin-bottom: 2.5rem;
}

.aw-info-desc>div {
    margin-bottom: 1rem;
}

.aw-info-desc>div:last-child {
    margin-bottom: 0;
}

.aw-info-list-title {
    font-size: 1.5rem;
    font-weight: 800;
    margin-bottom: 1.5rem;
    text-transform: none;
}

.aw-info-list {
    display: flex;
    flex-direction: column;
}

.aw-info-item {
    display: flex;
    align-items: center;

}

.aw-info-item-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
}

.aw-info-item-icon i,
.aw-info-item-icon svg {
    font-size: 1.125rem;
}

.aw-info-item-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: inherit;
}

.aw-info-item-text {
    font-size: 1.05rem;
    font-weight: 600;
}

@media (max-width: 1024px) {
    .aw-ceramics-info-wrap {
        gap: 2.5rem;
    }

    .aw-info-title {
        font-size: 2.4rem;
    }
}

@media (max-width: 767px) {
    .aw-ceramics-info-wrap {
        flex-direction: column;
    }

    .aw-ceramics-info-media {
        margin: 0 auto 40px;
        max-width: 300px;
        /* Evita que crezca demasiado en pantallas grandes móviles */
    }
}

/* --- CERAMICS MEETING WIDGET ("El encuentro") --- */
.aw-ceramics-meeting-wrap {
    position: relative;
    width: 100%;
    overflow: hidden;
    background-color: #F9F6F0;
}

.aw-meeting-inner-container {
    position: relative;
    z-index: 5;
    max-width: 1200px;
    margin: 0 auto;
}

.aw-meeting-header {
    margin-bottom: 4rem;
}

.aw-meeting-title {
    font-size: 3.5rem;
    font-weight: 900;
    color: #2D3E4E;
}

/* Background Decorations Meeting */
.aw-meeting-blob {
    position: absolute;
    top: 0;
    left: 100%;
    width: 60%;
    height: 100%;
    background: #DFEBE8;
    border-top-right-radius: 280px;
    border-bottom-right-radius: 50px;
    transform: rotate(180deg);
    transform-origin: top left;
    z-index: 1;
    pointer-events: none;
}

.aw-meeting-dash-circle {
    position: absolute;
    bottom: 2rem;
    left: -5rem;
    width: 18rem;
    height: 18rem;
    z-index: 2;
}

.aw-meeting-dash-circle svg circle {
    fill: none;
    stroke-dasharray: 6 10;
    stroke-width: 1.5;
    stroke: rgba(0, 0, 0, 0.1);
}

/* CARDS GRID */
.aw-meeting-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.5rem;
    margin-bottom: 3rem;
}

.aw-meeting-card {
    background-color: #FFFFFF;
    border-radius: 15px;
    padding: 2.5rem;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
    transition: all 0.3s ease;
    border: 1px solid rgba(0, 0, 0, 0.01);
}

.aw-meeting-card:hover {
    transform: translateY(-8px);
}

.aw-meeting-card-icon {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2rem;
    overflow: hidden;
}

.aw-meeting-card-icon i,
.aw-meeting-card-icon svg {
    font-size: 1.5rem;
}

.aw-meeting-card-title {
    font-size: 1.15rem;
    font-weight: 900;
    color: #2D3E4E;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.aw-meeting-card-desc {
    font-size: 1rem;
    color: #7A7A7A;
    line-height: 1.6;
    margin-bottom: 2rem;
    flex-grow: 1;
}

.aw-meeting-card-btn {
    background-color: #00A8B5;
    /* Turquesa */
    color: #FFFFFF;
    padding: 0.8rem 1.8rem;
    border-radius: 0.75rem;
    font-weight: 800;
    text-decoration: none;
    width: fit-content;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    transition: background 0.3s ease;
}

/* SECTION INCLUYE */
.aw-meeting-includes-wrap {
    background-color: #FFFFFF;
    border-radius: 15px;
    padding: 3.5rem 4rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03);
    display: flex;
    flex-direction: row;
    align-items: center;
    border: 1px solid rgba(0, 0, 0, 0.01);
}

.aw-inc-left-col {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.25rem;
    flex-shrink: 0;
    margin-right: 2rem;
}

.aw-inc-icon {
    width: 3.5rem;
    height: 3.5rem;
    background-color: #E2EFEA;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.aw-inc-title {
    font-size: 1.15rem;
    font-weight: 900;
    color: #2D3E4E;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.aw-inc-right-col {
    flex-grow: 1;
}

.aw-inc-items {
    display: flex;
    flex-direction: row;
    width: 100%;
}

.aw-inc-item {
    flex: 1;
    padding: 0 2.5rem;
    font-size: 0.95rem;
    line-height: 1.5;
    color: #7A7A7A;
    border-left: 1px solid #DFEBE8;
    display: flex;
    align-items: center;
    min-height: 4.5rem;
}

.aw-inc-item:first-child {
    border-left: none;
    padding-left: 0;
}

/* RESPONSIVE */
@media (max-width: 1024px) {
    .aw-meeting-cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .aw-meeting-title {
        font-size: 2.8rem;
    }
}

@media (max-width: 900px) {
    .aw-meeting-includes-wrap {
        flex-direction: column;
        align-items: flex-start;
        gap: 2rem;
    }

    .aw-inc-items {
        flex-wrap: wrap;
    }

    .aw-inc-item {
        flex: 1 1 50%;
        border-left: none;
        padding: 1rem 0;
        border-bottom: 1px solid #E2E8F0;
    }
}

@media (max-width: 767px) {
    .aw-meeting-cards-grid {
        grid-template-columns: 1fr;
    }

    .aw-inc-left-col {
        align-items: flex-start;
    }
}

/* --- File: expandable-search.css --- */
/* Floating Search Widget Fixes - High Specificity */
.elementor-widget-art_wine_expandable_search {
    overflow: visible !important;
}

/* DEBUG: Un-comment the line below if you want to see if the CSS is loading at all */
/* .aw-search-trigger { border: 2px solid red !important; } */

.elementor-widget-art_wine_expandable_search .aw-search-float-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible !important; /* Prevent clipping of the trigger or overlay */
    min-height: 44px;
    min-width: 44px;
}

.elementor-widget-art_wine_expandable_search .aw-search-trigger {
    width: 44px;
    height: 44px;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    z-index: 10;
    opacity: 1 !important;
    visibility: visible !important;
}

.elementor-widget-art_wine_expandable_search .aw-search-trigger:hover {
    background: rgba(255, 255, 255, 0.15);
    transform: scale(1.08);
}

.elementor-widget-art_wine_expandable_search .search-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.elementor-widget-art_wine_expandable_search .aw-search-trigger i,
.elementor-widget-art_wine_expandable_search .aw-search-trigger svg {
    width: 20px !important;
    height: 20px !important;
    font-size: 20px;
    fill: currentColor;
    display: inline-block;
    line-height: 1;
}

/* SEARCH OVERLAY - HIDDEN BY DEFAULT */
.elementor-widget-art_wine_expandable_search .aw-search-overlay {
    position: absolute;
    top: calc(100% + 20px);
    right: 0;
    width: 320px;
    backdrop-filter: blur(25px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 14px;
    padding: 12px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.7);
    
    /* Animation initial state */
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(-15px);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    z-index: 99999 !important;
}

/* ACTIVE STATE */
.elementor-widget-art_wine_expandable_search .aw-search-overlay.active {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0);
}

.elementor-widget-art_wine_expandable_search .search-input-wrap {
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 10px;
    padding: 2px 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: border-color 0.3s;
}

.elementor-widget-art_wine_expandable_search .search-input-wrap:focus-within {
    border-color: rgba(255, 255, 255, 0.3);
}

.elementor-widget-art_wine_expandable_search input[type="search"] {
    flex: 1;
    background: transparent !important;
    border: none !important;
    color: #fff !important;
    padding: 12px 0 !important;
    outline: none !important;
    font-size: 14px !important;
    box-shadow: none !important;
}

.elementor-widget-art_wine_expandable_search input[type="search"]::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.elementor-widget-art_wine_expandable_search .search-submit {
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 14px;
    opacity: 0.6;
    transition: opacity 0.3s, transform 0.3s;
    padding: 5px;
}

.elementor-widget-art_wine_expandable_search .search-submit:hover {
    opacity: 1;
    transform: scale(1.1);
}

.elementor-widget-art_wine_expandable_search .search-submit svg {
    width: 16px;
    height: 16px;
    fill: currentColor;
}

/* Pointer arrow */
.elementor-widget-art_wine_expandable_search .aw-search-overlay::before {
    content: '';
    position: absolute;
    top: -7px;
    right: 15px;
    width: 14px;
    height: 14px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    border-left: 1px solid rgba(255, 255, 255, 0.1);
    transform: rotate(45deg);
}

/* Fix for mobile/tablet where alignment might differ */
@media (max-width: 1024px) {
    .elementor-widget-art_wine_expandable_search .aw-search-overlay {
        right: -10px;
    }
    .elementor-widget-art_wine_expandable_search .aw-search-overlay::before {
        right: 25px;
    }
}

/* MOBILE SPECIFIC FIXES */
@media (max-width: 767px) {
    .elementor-widget-art_wine_expandable_search {
        z-index: 9999; /* Higher priority for the whole widget */
        display: block !important;
    }

    .elementor-widget-art_wine_expandable_search .aw-search-float-wrapper {
        min-height: 42px;
        min-width: 42px;
    }

    .elementor-widget-art_wine_expandable_search .aw-search-trigger {
        width: 42px;
        height: 42px;
        z-index: 10000; /* Ensure trigger is above theme bars */
    }

    /* Fixed overlay on mobile to prevent clipping by overflow:hidden containers */
    .elementor-widget-art_wine_expandable_search .aw-search-overlay {
        position: fixed;
        top: 20px !important;
        left: 20px !important;
        right: 20px !important;
        width: auto !important;
        margin: 0 !important;
        transform: translateY(-20px);
        box-shadow: 0 15px 50px rgba(0, 0, 0, 0.4);
    }

    .elementor-widget-art_wine_expandable_search .aw-search-overlay.active {
        transform: translateY(0);
    }

    /* Hide arrow on mobile as it won't align with fixed position */
    .elementor-widget-art_wine_expandable_search .aw-search-overlay::before {
        display: none;
    }

    /* Adjust search input for mobile */
    .elementor-widget-art_wine_expandable_search input[type="search"] {
        font-size: 16px !important; /* Prevent iOS zoom on focus */
    }
}


/* --- File: pw-gift-card-form.css --- */
:root {
    --aw-turquoise: #00a5b5;
    --aw-turquoise-hover: #008a99;
    --aw-turquoise-light: #f0fbfc;
    --aw-text-dark: #2d3748;
    --aw-text-gray: #718096;
    --aw-border: #e2e8f0;
    --aw-white: #ffffff;
    --aw-bg-soft: #f7fafc;
}

.aw-gift-card-form-widget {
    max-width: 100%;
    font-family: inherit;
    color: var(--aw-text-dark);
}

.aw-gc-field-group {
    margin-bottom: 24px;
}

.aw-gc-label {
    display: block;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 10px;
    color: var(--aw-text-dark);
}

.aw-gc-input-wrapper {
    position: relative;
}

.aw-gc-select, 
.aw-gc-input, 
.aw-gc-textarea {
    width: 100%;
    padding: 12px 16px;
    border: 1.5px solid var(--aw-border);
    border-radius: 12px;
    font-size: 15px;
    transition: all 0.3s ease;
    background: var(--aw-white);
    outline: none;
}

.aw-gc-select:focus, 
.aw-gc-input:focus, 
.aw-gc-textarea:focus {
    border-color: var(--aw-turquoise);
    box-shadow: 0 0 0 4px rgba(0, 165, 181, 0.1);
}

.aw-gc-textarea {
    min-height: 120px;
    resize: vertical;
}

/* Dropdown specific */
.aw-gc-amount-row {
    display: flex;
    align-items: center;
    gap: 15px;
}

.aw-gc-clear-btn {
    color: var(--aw-turquoise);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: color 0.2s;
}

.aw-gc-clear-btn:hover {
    color: var(--aw-turquoise-hover);
    text-decoration: underline;
}

.aw-gc-clear-btn:hover {
    color: var(--aw-turquoise-hover);
    text-decoration: underline;
}

/* Icon in input */
.aw-gc-icon-inside {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--aw-text-gray);
    pointer-events: none;
}


/* Counter */
.aw-gc-counter {
    margin-top: 6px;
    font-size: 12px;
    color: var(--aw-text-gray);
}

/* Summary Box */
.aw-gc-summary-box {
    background: var(--aw-bg-soft);
    border-radius: 16px;
    padding: 20px 24px;
    margin-bottom: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid var(--aw-border);
}

.aw-gc-summary-text {
    font-size: 18px;
    font-weight: 700;
    color: var(--aw-text-dark);
}

.aw-gc-summary-price {
    font-size: 22px;
    font-weight: 800;
    color: var(--aw-turquoise);
}

/* Submit Button */
.aw-gc-submit-btn {
    width: 100%;
    background: var(--aw-turquoise);
    color: var(--aw-white);
    border: none;
    padding: 20px;
    border-radius: 16px;
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 10px 25px rgba(0, 165, 181, 0.2);
}

.aw-gc-submit-btn:hover {
    background: var(--aw-turquoise-hover);
    transform: translateY(-2px);
    box-shadow: 0 15px 30px rgba(0, 165, 181, 0.3);
}

.aw-gc-submit-btn:disabled {
    background: var(--aw-text-gray);
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
    opacity: 0.6;
}

/* Responsive */
@media (max-width: 768px) {
    .aw-gc-summary-box {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    
    .aw-gc-submit-btn {
        padding: 16px;
        font-size: 16px;
    }
}


/* --- File: premium-widgets.css --- */
/* Premium Title Widget Styles */
.aw-premium-title-container {
    position: relative;
    display: inline-block;
    width: 100%;
}

.aw-premium-title {
    margin: 0;
    padding: 0;
    position: relative;
    display: inline-block;
}

.aw-highlighted-word {
    position: relative;
    display: inline-block;
    white-space: pre-wrap;
}

.aw-title-underline {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #00A5B5;
    z-index: -1;
    transform: translateY(2px);
    border-radius: 2px;
}

/* Premium FAQ Widget Styles */
.aw-premium-faq-container {
    width: 100%;
    max-width: 100%;
}

.aw-faq-item {
    border-bottom: 1px solid #E2E8F0;
    padding: 20px 0;
    transition: all 0.3s ease;
}

.aw-faq-item:last-child {
    border-bottom: none;
}

.aw-faq-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    user-select: none;
    gap: 20px;
}

.aw-faq-title-wrapper {
    display: flex;
    align-items: center;
    gap: 15px;
    flex: 1;
}

.aw-faq-number {
    font-size: 1.1em;
    font-weight: 700;
    color: #1A202C;
    min-width: 30px;
}

.aw-faq-question {
    font-size: 1.2em;
    font-weight: 600;
    color: #1A202C;
    margin: 0;
    transition: color 0.3s ease;
}

.aw-faq-icon {
    position: relative;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
}

.aw-faq-icon::before,
.aw-faq-icon::after {
    content: '';
    position: absolute;
    background-color: #64748B;
    transition: all 0.3s ease;
}

/* Horizontal line */
.aw-faq-icon::before {
    width: 14px;
    height: 2px;
}

/* Vertical line (the 'plus' part) */
.aw-faq-icon::after {
    width: 2px;
    height: 14px;
}

.aw-faq-item.is-active .aw-faq-icon::after {
    transform: rotate(90deg);
    opacity: 0;
}

.aw-faq-item.is-active .aw-faq-icon::before {
    background-color: #00A5B5;
}

.aw-faq-content {
    max-height: 0;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    opacity: 0;
}

.aw-faq-item.is-active .aw-faq-content {
    max-height: 1000px;
    opacity: 1;
    margin-top: 15px;
    padding-left: 45px;
    /* Offset for the number */
}

.aw-faq-answer {
    color: #4A5568;
    line-height: 1.6;
    margin: 0;
}

/* Premium List Widget Styles */
.aw-premium-list {
    display: flex;
    flex-direction: column;
}

.aw-premium-list-item {
    display: flex;
    align-items: center;
    background-color: #F0FDF4;
    /* Fallback */
    border-radius: 12px;
    padding: 15px 20px;
    transition: all 0.3s ease;
}

.aw-premium-list-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: #ccfbf1;
    /* Fallback */
    margin-right: 15px;
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.aw-premium-list-icon i,
.aw-premium-list-icon svg {
    color: #0d9488;
    /* Fallback */
    fill: #0d9488;
    /* Fallback */
    font-size: 16px;
    width: 16px;
    height: 16px;
}

.aw-premium-list-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.aw-premium-list-title {
    font-size: 16px;
    font-weight: 600;
    color: #1e293b;
    /* Fallback */
    line-height: 1.3;
    margin: 0;
}

.aw-premium-list-subtitle {
    font-size: 13px;
    font-weight: 400;
    color: #64748b;
    /* Fallback */
    margin-top: 4px;
    line-height: 1.4;
}

/* Premium Features Grid Widget */
.aw-features-grid-header {
    margin-bottom: 40px;
    text-align: center;
}

.aw-features-grid-main-title {
    font-size: 32px;
    font-weight: 800;
    color: #1e293b;
    margin: 0 0 10px 0;
    line-height: 1.2;
}

.aw-features-grid-main-subtitle {
    font-size: 16px;
    font-weight: 400;
    color: #64748b;
    margin: 0;
}

/* Highlighted Underline System */
.aw-highlighted-word {
    position: relative;
    display: inline-block;
    z-index: 1;
}

.aw-title-underline {
    position: absolute;
    bottom: 2px;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #F97316;
    z-index: -1;
    transform: translateY(2px);
    border-radius: 4px;
}

.aw-features-grid {
    display: grid;
    gap: 20px;
}

.aw-feature-card {
    background: #ffffff;
    border-radius: 16px;
    padding: 25px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border: 1px solid rgba(0, 0, 0, 0.02);
}

.aw-feature-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
}

.aw-feature-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    background-color: #E0F2FE;
    /* Fallback */
}

.aw-feature-card-icon i,
.aw-feature-card-icon svg {
    font-size: 18px;
    width: 18px;
    height: 18px;
    color: #0284C7;
    /* Fallback */
    fill: #0284C7;
    /* Fallback */
}

.aw-feature-card-title {
    font-size: 16px;
    font-weight: 700;
    color: #1e293b;
    margin-bottom: 8px;
    line-height: 1.2;
}

.aw-feature-card-subtitle {
    font-size: 13px;
    font-weight: 400;
    color: #64748b;
    line-height: 1.5;
}

@media (max-width: 768px) {
    .aw-features-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Premium CTA Banner Widget */
.aw-premium-cta-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 40px 50px;
    border-radius: 20px;
    background: linear-gradient(90deg, #d8eeea 0%, #f0f7f7 50%, #f5e4cd 100%);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.05);
    border: 1px solid rgba(0, 0, 0, 0.03);
    flex-wrap: wrap;
    gap: 20px;
}

.aw-premium-cta-content {
    flex: 1;
    min-width: 300px;
}

.aw-premium-cta-title {
    font-size: 28px;
    font-weight: 800;
    color: #1e293b;
    margin: 0 0 8px 0;
    line-height: 1.2;
}

.aw-premium-cta-subtitle {
    font-size: 15px;
    font-weight: 400;
    color: #64748b;
    margin: 0;
    line-height: 1.5;
}

.aw-premium-cta-action {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.aw-premium-cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background-color: #00A5B5;
    color: #ffffff;
    font-size: 15px;
    font-weight: 700;
    padding: 16px 32px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 8px 20px rgba(0, 165, 181, 0.3);
}

.aw-premium-cta-btn:hover {
    background-color: #008f9c;
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 12px 25px rgba(0, 165, 181, 0.4);
}

.aw-premium-cta-btn i {
    font-size: 14px;
}

@media (max-width: 768px) {
    .aw-premium-cta-banner {
        flex-direction: column;
        align-items: flex-start;
        padding: 30px;
    }

    .aw-premium-cta-action {
        width: 100%;
        justify-content: flex-start;
        margin-top: 10px;
    }
}

/* Premium Inline Benefits Widget */
.aw-inline-benefits {
    display: flex;
    flex-wrap: wrap;
    background-color: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 20px;
    padding: 25px 40px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
    align-items: center;
}

.aw-inline-benefit-item {
    display: flex;
    align-items: center;
}

.aw-inline-benefit-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #E0F2FE;
    /* Fallback */
    border-radius: 50%;
    margin-right: 12px;
}

.aw-inline-benefit-icon i,
.aw-inline-benefit-icon svg {
    color: #0284C7;
    /* Fallback */
    fill: #0284C7;
    /* Fallback */
}

.aw-inline-benefit-text {
    font-size: 15px;
    font-weight: 600;
    color: #1e293b;
    line-height: 1.3;
}

@media (max-width: 768px) {
    .aw-inline-benefits {
        flex-direction: column;
        align-items: flex-start;
        padding: 25px;
    }

    .aw-inline-benefit-item {
        width: 100%;
        margin-bottom: 12px;
    }

    .aw-inline-benefit-item:last-child {
        margin-bottom: 0;
    }
}

/* Premium Header */
.aw-premium-header {
    margin-bottom: 40px;
}

.aw-premium-main-title {
    font-size: 36px;
    font-weight: 800;
    color: #1e293b;
    margin: 0 0 10px 0;
    line-height: 1.2;
}

.aw-premium-main-subtitle {
    font-size: 16px;
    font-weight: 400;
    color: #64748b;
    margin: 0;
}

/* Premium Image Cards Widget */
.aw-image-cards-grid {
    display: grid;
    gap: 30px;
}

.aw-image-card {
    background-color: #ffffff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
    border: 1px solid rgba(0, 0, 0, 0.04);
    display: flex;
    flex-direction: column;
}

.aw-image-card-img-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
}

.aw-image-card-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.aw-image-card-placeholder {
    width: 100%;
    height: 100%;
    background-color: #f1f5f9;
}

.aw-image-card-badge {
    position: absolute;
    top: 15px;
    left: 15px;
    padding: 6px 12px;
    border-radius: 50px;
    font-size: 11px;
    font-weight: 800;
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.aw-image-card-content {
    padding: 30px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.aw-image-card-title {
    font-size: 22px;
    font-weight: 800;
    color: #1e293b;
    margin: 0 0 15px 0;
}

.aw-image-card-desc {
    font-size: 15px;
    color: #475569;
    line-height: 1.6;
    margin: 0 0 25px 0;
}

.aw-image-card-features {
    list-style: none;
    padding: 0;
    margin: 0 0 25px 0;
}

.aw-image-card-features li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 15px;
    color: #475569;
    margin-bottom: 12px;
    line-height: 1.4;
}

.aw-image-card-features li i,
.aw-image-card-features li svg {
    font-size: 18px;
    width: 18px;
    height: 18px;
    margin-top: 2px;
    flex-shrink: 0;
}

.aw-image-card-highlight {
    background-color: #F8FAFC;
    border-radius: 16px;
    padding: 18px 22px;
    display: flex;
    gap: 15px;
    margin-bottom: 25px;
    align-items: center;
}

.aw-highlight-icon {
    font-size: 20px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background-color: rgba(0, 0, 0, 0.05);
}

.aw-highlight-text strong {
    display: block;
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 2px;
}

.aw-highlight-text p {
    margin: 0;
    font-size: 14px;
    opacity: 0.9;
    line-height: 1.4;
}

.aw-image-card-link {
    font-size: 16px;
    font-weight: 700;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all 0.3s ease;
    margin-top: auto;
    border: none;
    outline: none;
}

/* Button Style */
.aw-image-card-link.aw-style-button {
    color: #ffffff;
    background-color: #00A5B5;
    padding: 16px 30px;
    border-radius: 50px;
    width: 100%;
    box-shadow: 0 4px 15px rgba(0, 165, 181, 0.2);
}

.aw-image-card-link.aw-style-button:hover {
    background-color: #008f9c;
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 165, 181, 0.3);
}

/* Text Style */
.aw-image-card-link.aw-style-text {
    color: #00A5B5;
    background-color: transparent;
    padding: 0;
    border-radius: 0;
    width: auto;
    justify-content: flex-start;
    box-shadow: none;
}

.aw-image-card-link.aw-style-text:hover {
    color: #008f9c;
    gap: 14px;
}

.aw-image-card-link i {
    font-size: 14px;
}

/* Premium Steps Grid Widget */
.aw-steps-grid {
    display: grid;
    gap: 30px;
    margin-bottom: 40px;
}

.aw-step-card {
    background-color: #ffffff;
    border-radius: 20px;
    padding: 40px 30px 30px;
    text-align: center;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04);
    border: 1px solid rgba(0, 0, 0, 0.04);
    position: relative;
    margin-top: 20px;
}

.aw-step-number {
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 40px;
    background-color: #F97316;
    color: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 800;
    box-shadow: 0 4px 15px rgba(249, 115, 22, 0.3);
}

.aw-step-icon {
    width: 60px;
    height: 60px;
    background-color: #E0F2FE;
    color: #0284C7;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px auto;
    font-size: 24px;
}

.aw-step-title {
    font-size: 18px;
    font-weight: 800;
    color: #1e293b;
    margin: 0 0 10px 0;
}

.aw-step-desc {
    font-size: 14px;
    color: #64748b;
    line-height: 1.5;
    margin: 0;
}

.aw-steps-action {
    text-align: center;
}

.aw-premium-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background-color: #00A5B5;
    color: #ffffff;
    font-size: 15px;
    font-weight: 700;
    padding: 16px 32px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 8px 20px rgba(0, 165, 181, 0.3);
}

.aw-premium-btn:hover {
    background-color: #008f9c;
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: 0 12px 25px rgba(0, 165, 181, 0.4);
}

/* Premium Masonry Gallery Widget */
.aw-masonry-gallery {
    column-count: 4;
    column-gap: 20px;
}

.aw-masonry-item {
    break-inside: avoid;
    margin-bottom: 20px;
}

.aw-masonry-item img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 15px;
}

/* Premium Split Banner Widget */
.aw-split-banner {
    display: flex;
    border-radius: 20px;
    overflow: hidden;
    background-color: #E8DCB8;
}

.aw-split-banner-content {
    flex: 1;
    padding: 40px 60px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.aw-split-banner-image {
    flex: 1;
    min-height: 400px;
}

.aw-split-banner-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.aw-split-banner-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background-color: #ffffff;
    padding: 8px 16px;
    border-radius: 50px;
    font-size: 12px;
    font-weight: 800;
    color: #433422;
    margin-bottom: 25px;
    align-self: flex-start;
}

.aw-split-banner-title {
    font-size: 42px;
    font-weight: 800;
    color: #433422;
    margin: 0 0 20px 0;
    line-height: 1.1;
}

.aw-split-banner-desc {
    font-size: 18px;
    font-weight: 400;
    color: #433422;
    margin: 0 0 40px 0;
    line-height: 1.5;
    opacity: 0.8;
}

.aw-split-banner-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background-color: #433422;
    color: #ffffff;
    font-size: 15px;
    font-weight: 700;
    padding: 16px 32px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s ease;
    align-self: flex-start;
}

.aw-split-banner-btn:hover {
    background-color: #2a2015;
    color: #ffffff;
}

/* Premium CTA Banner Centered Layout & Double Button */
.aw-premium-cta-banner.aw-layout-center {
    flex-direction: column;
    text-align: center;
    justify-content: center;
}

.aw-premium-cta-banner.aw-layout-center .aw-premium-cta-content {
    margin-bottom: 15px;
}

.aw-premium-cta-banner.aw-layout-center .aw-premium-cta-action {
    justify-content: center;
    margin-top: 10px;
    gap: 15px;
    flex-wrap: wrap;
}

.aw-premium-sec-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background-color: transparent;
    color: #ffffff;
    font-size: 15px;
    font-weight: 700;
    padding: 14px 30px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 2px solid rgba(255, 255, 255, 0.4);
}

.aw-premium-sec-btn:hover {
    border-color: #ffffff;
    background-color: rgba(255, 255, 255, 0.1);
}

@media (max-width: 768px) {
    .aw-premium-main-title {
        font-size: 28px;
    }

    .aw-image-cards-grid {
        grid-template-columns: 1fr !important;
    }

    .aw-steps-grid {
        grid-template-columns: 1fr !important;
    }

    .aw-masonry-gallery {
        column-count: 2 !important;
    }

    .aw-split-banner {
        flex-direction: column-reverse !important;
    }

    .aw-split-banner-content {
        padding: 20px 20px 30px 20px !important;
    }

    .aw-split-banner-title {
        font-size: 24px !important;
    }

    .aw-premium-cta-banner {
        padding: 30px 20px !important;
        flex-direction: column !important;
    }

    .aw-premium-cta-content {
        min-width: 100% !important;
        text-align: center !important;
    }

    .aw-premium-cta-title {
        font-size: 22px !important;
    }

    .aw-premium-cta-banner .aw-premium-cta-action {
        flex-direction: column;
        width: 100%;
        gap: 15px;
    }

    .aw-premium-btn,
    .aw-premium-sec-btn,
    .aw-split-banner-btn {
        width: 100%;
    }
}

/* Premium Horizontal Cards Widget */
.aw-horizontal-cards-grid {
    display: grid;
    gap: 30px;
    width: 100%;
}

.aw-horizontal-card {
    display: flex;
    background-color: #ffffff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
    border: 1px solid rgba(0, 0, 0, 0.03);
    transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.3s cubic-bezier(0.25, 1, 0.5, 1);
    width: 100%;
}

.aw-horizontal-card.aw-hover-lift:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
}

/* Direcciones de imagen */
.aw-horizontal-card.aw-img-left {
    flex-direction: row;
}

.aw-horizontal-card.aw-img-right {
    flex-direction: row-reverse;
}

.aw-horizontal-card-img-wrap {
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
    transition: width 0.3s ease;
    align-self: stretch;
}

.aw-horizontal-card-img-wrap img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100% !important;
    object-fit: cover !important;
    display: block;
    transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.aw-horizontal-card.aw-hover-zoom:hover .aw-horizontal-card-img-wrap img {
    transform: scale(1.05);
}

.aw-horizontal-card-placeholder {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #f1f5f9;
}

.aw-horizontal-card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 30px 40px;
}

.aw-horizontal-card-title {
    font-size: 24px;
    font-weight: 700;
    color: #1a202c;
    margin: 0 0 12px 0;
    line-height: 1.3;
}

.aw-horizontal-card-desc {
    font-size: 15px;
    color: #64748b;
    line-height: 1.6;
    margin: 0 0 25px 0;
}

.aw-horizontal-card-btn-wrap {
    display: flex;
    margin-top: auto;
}

.aw-horizontal-card-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none !important;
    padding: 12px 28px;
    border-radius: 50px;
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
    border: 2px solid #00a5b5;
    color: #00a5b5;
    background-color: transparent;
    cursor: pointer;
}

.aw-horizontal-card-btn:hover {
    background-color: #00a5b5;
    color: #ffffff;
}

@media (max-width: 768px) {
    .aw-horizontal-cards-grid {
        grid-template-columns: 1fr !important;
    }

    .aw-horizontal-card {
        flex-direction: column !important;
    }

    .aw-horizontal-card-img-wrap {
        width: 100% !important;
        height: 250px !important;
    }

    .aw-horizontal-card-content {
        padding: 30px 25px !important;
    }
}

/* Premium Masked Image Carousel Widget */
.aw-masked-carousel-outer-wrapper {
    position: relative;
    width: 100%;
}

.aw-masked-carousel-container {
    position: relative;
    display: block;
    width: 100%;
    margin: 0 auto;
}

/* Aspect Ratios on Container */
.aw-ratio-1-1.aw-masked-carousel-container {
    aspect-ratio: 1 / 1;
}

.aw-ratio-4-3.aw-masked-carousel-container {
    aspect-ratio: 4 / 3;
}

.aw-ratio-16-9.aw-masked-carousel-container {
    aspect-ratio: 16 / 9;
}

.aw-masked-carousel {
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    margin: 0 auto;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
}

.aw-masked-carousel .swiper-wrapper {
    display: flex;
    width: 100%;
    height: 100%;
}

.aw-masked-carousel .swiper-slide {
    flex-shrink: 0;
    width: 100% !important;
    height: 100% !important;
    position: relative;
    overflow: hidden;
}

.aw-masked-carousel-img {
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}

.aw-masked-carousel-link {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    outline: none;
}

/* Pagination Dots */
.aw-carousel-pagination {
    display: flex;
    justify-content: center;
    width: 100%;
}

.aw-carousel-pagination .swiper-pagination {
    position: static !important;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.aw-carousel-pagination .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.3s ease;
    margin: 0 !important;
}

.aw-carousel-pagination .swiper-pagination-bullet-active {
    width: 24px;
    border-radius: 4px;
}

/* Navigation Arrows */
.aw-masked-carousel .swiper-button-next,
.aw-masked-carousel .swiper-button-prev {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    transition: all 0.3s ease;
}

.aw-masked-carousel .swiper-button-next:after,
.aw-masked-carousel .swiper-button-prev:after {
    font-size: 16px;
    font-weight: bold;
}

.aw-masked-carousel .swiper-button-next {
    right: 15px;
}

.aw-masked-carousel .swiper-button-prev {
    left: 15px;
}

/* --- File: group-discount.css --- */
:root {
    --aw-discount-bg: #248286;
    /* Slightly darker teal for better white contrast */
    --aw-discount-card-bg: #FAFAFA;
    --aw-discount-accent: #FF8500;
    /* Vibrant orange matching the layout */
    --aw-discount-text-white: #FFFFFF;
    --aw-discount-text-dark: #1F2933;
    --aw-discount-text-muted: #4B5563;
    /* Darker gray (from 9CA3AF to 4B5563) for WCAG */
    --aw-discount-primary: #248286;
}

.aw-discount-banner {
    display: flex;
    background: #FFFFFF;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.05);

    margin: 40px auto;
    font-family: 'Inter', sans-serif;
    border: 1px solid #E2E8F0;
}

.aw-discount-info {
    flex: 0 0 520px;
    background: var(--aw-discount-bg);
    padding: 60px 40px;
    color: var(--aw-discount-text-white);
    display: flex;
    flex-direction: column;
    position: relative;
}

.aw-discount-header-group {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}

.aw-discount-icon-main {
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

.aw-discount-title {
    font-size: 26px;
    font-weight: 800;
    margin: 0;
    line-height: 1.15;
    letter-spacing: 0.22px;
}

.aw-discount-desc {
    font-size: 14.5px;
    line-height: 1.6;
    color: #FFFFFF !important;
    /* Pure white for maximum contrast */
    margin: 0 0 35px 0;
    font-weight: 500;
}

.aw-discount-tagline {
    margin-top: auto;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: #FFFFFF !important;
    font-weight: 600;
}

/* Tiers Section */
.aw-discount-tiers {
    flex: 1;
    display: flex;
    padding: 40px 30px;
    gap: 24px;
    background: #FFF;
    align-items: center;
}

.aw-discount-tier-card {
    flex: 1;
    background: var(--aw-discount-card-bg);
    border-radius: 14px;
    padding: 24px 16px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.aw-discount-tier-card.is-best-value {
    background: #FFFFFF;
    border: 2px solid var(--aw-discount-primary);
}

.aw-tier-icon-circle {
    width: 32px;
    height: 32px;
    background: #E9EEF2;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
    color: #94A3B8;
    margin-bottom: 12px;
    position: relative;
}

.aw-discount-tier-card:nth-child(2) .aw-tier-icon-circle {
    background: #EBF5F6;
    color: var(--aw-discount-primary);
}

.aw-discount-tier-card.is-best-value .aw-tier-icon-circle {
    background: var(--aw-discount-primary);
    color: #FFF;
}

.aw-discount-tier-card.is-best-value .aw-tier-icon-circle::after {
    display: none;
}

.aw-tier-icon-circle::after {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 50%;
    width: 1px;
    height: 10px;
    background: #E2E8F0;
}

.aw-tier-people {
    font-size: 15px;
    font-weight: 700;
    color: var(--aw-discount-text-dark);
    margin: 8px 0 4px 0;
}

.aw-tier-save {
    font-size: 12.5px;
    color: var(--aw-discount-text-muted);
    margin-bottom: 12px;
    font-weight: 500;
}

.aw-tier-badge {
    background: rgba(47, 164, 169, 0.1);
    color: var(--aw-discount-primary);
    padding: 8px 0;
    width: 100%;
    max-width: 92px;
    border-radius: 10px;
    font-weight: 800;
    font-size: 18px;
    line-height: 1.5;
}

.aw-discount-tier-card.is-best-value .aw-tier-badge {
    background: var(--aw-discount-primary);
    color: #FFF;
}

.aw-best-value-tag {
    display: inline-block;
    background: var(--aw-discount-accent);
    color: #FFF;
    font-size: 10px;
    font-weight: 800;
    padding: 4px 12px;
    border-radius: 20px;
    margin: 6px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    line-height: 1;
}

/* Mobile Responsiveness */
@media (max-width: 1024px) {
    .aw-discount-banner {
        flex-direction: column;
        margin: 20px auto;
        max-width: 90%;
    }

    .aw-discount-info {
        flex: 0 0 auto;
        padding: 40px;
        text-align: center;
        align-items: center;
    }

    .aw-discount-icon-main {
        margin-left: auto;
        margin-right: auto;
    }

    .aw-discount-tagline {
        justify-content: center;
    }

    .aw-discount-header-group {
        justify-content: center;
    }
}

@media (max-width: 768px) {
    .aw-discount-info {
        padding: 30px 20px;
    }

    .aw-discount-title {
        font-size: 22px;
    }

    .aw-discount-tiers {
        padding: 20px 12px;
        gap: 8px !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        justify-content: space-between;
    }

    .aw-discount-tier-card {
        flex: 1 1 33.333% !important;
        min-width: 0 !important;
        padding: 16px 8px !important;
    }

    .aw-tier-people {
        font-size: 13px !important;
        margin: 6px 0 2px 0 !important;
    }

    .aw-tier-save {
        font-size: 10px !important;
        margin-bottom: 8px !important;
    }

    .aw-tier-badge {
        font-size: 14px !important;
        padding: 6px 0 !important;
        max-width: 70px !important;
    }

    .aw-best-value-tag {
        font-size: 8px !important;
        padding: 2px 6px !important;
        margin: 4px 0 !important;
    }

    .aw-tier-icon-circle {
        width: 28px !important;
        height: 28px !important;
        font-size: 11px !important;
        margin-bottom: 8px !important;
    }

    .aw-tier-icon-circle::after {
        height: 8px !important;
        bottom: -8px !important;
    }
}

@media (max-width: 480px) {
    .aw-discount-banner {
        margin: 10px;
        border-radius: 16px;
    }

    .aw-discount-info {
        padding: 24px 16px;
    }

    .aw-discount-title {
        font-size: 20px;
    }

    .aw-discount-desc {
        font-size: 13px;
        margin: 0 0 20px 0;
    }

    .aw-discount-tiers {
        padding: 16px 8px;
        gap: 6px !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
    }

    .aw-discount-tier-card {
        flex: 1 1 33.333% !important;
        width: auto !important;
        min-width: 0 !important;
        padding: 12px 4px !important;
        border-radius: 10px !important;
    }

    .aw-tier-people {
        font-size: 11px !important;
        margin: 4px 0 2px 0 !important;
    }

    .aw-tier-save {
        font-size: 9px !important;
        margin-bottom: 6px !important;
        line-height: 1.1;
    }

    .aw-tier-badge {
        font-size: 13px !important;
        padding: 4px 0 !important;
        max-width: 60px !important;
        border-radius: 6px !important;
    }

    .aw-best-value-tag {
        font-size: 7.5px !important;
        padding: 1px 4px !important;
        margin: 3px 0 !important;
    }

    .aw-tier-icon-circle {
        width: 24px !important;
        height: 24px !important;
        font-size: 10px !important;
        margin-bottom: 6px !important;
    }

    .aw-tier-icon-circle::after {
        height: 6px !important;
        bottom: -6px !important;
    }
}

/* --- File: experience-media-grid.css --- */
/* Contenedor principal con Grid robusto */
.aw-media-grid {
    display: grid !important;
    grid-template-columns: 1.5fr 1fr !important;
    grid-template-rows: repeat(2, 1fr) !important;
    gap: 30px !important;
    margin: 40px 0;
    width: 100% !important;
    font-family: 'Inter', sans-serif;
}

/* Base de todas las tarjetas */
.aw-media-card {
    position: relative !important;
    border-radius: 30px !important;
    height: 100% !important;
    width: 100% !important;
    overflow: hidden !important;
    color: #FFFFFF !important;
    background-size: cover;
    background-position: center;
    text-decoration: none !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    transition: transform 0.3s ease !important;
    z-index: 1;
}

.aw-media-card:hover {
    transform: translateY(-5px) !important;
}

/* Tarjeta Grande (Izquierda) */
.aw-media-card-large {
    grid-row: span 2 !important;
    grid-column: 1 !important;
    min-height: 500px !important;
}

/* Tarjetas Pequeñas (Derecha) */
.aw-media-card-small {
    grid-column: 2 !important;
    min-height: 235px !important;
}

/* Forzar que las dos filas sean iguales incluso con contenido dispar */
.aw-media-grid > .aw-media-card-small:nth-child(2) {
    grid-row: 1 !important;
}
.aw-media-grid > .aw-media-card-small:nth-child(3) {
    grid-row: 2 !important;
}

/* Capa de degradado (Overlay) */
.aw-media-card::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.2) 50%, rgba(0, 0, 0, 0) 100%) !important;
    z-index: 1 !important;
}

.aw-media-card-large::before {
    background: rgba(0, 0, 0, 0.1) !important; /* Más claro para el video como en el ejemplo */
}

/* Botón de Play (Squircle Blanco + Triángulo Negro) */
.aw-video-play-btn {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 76px !important;
    height: 52px !important;
    background: #FFFFFF !important;
    border-radius: 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 5 !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3) !important;
    cursor: pointer !important;
}

.aw-video-play-btn::after {
    content: '' !important;
    width: 0 !important;
    height: 0 !important;
    border-top: 10px solid transparent !important;
    border-bottom: 10px solid transparent !important;
    border-left: 18px solid #000000 !important;
    margin-left: 4px !important;
}

/* Contenido de texto */
.aw-media-card-content {
    position: relative !important;
    z-index: 2 !important;
    padding: 30px !important;
    width: 100% !important;
}

.aw-media-card-title {
    font-size: 32px !important;
    font-weight: 800 !important;
    margin: 0 0 12px 0 !important;
    line-height: 1.1 !important;
    color: #FFFFFF !important;
}

.aw-media-card-desc {
    font-size: 15px !important;
    line-height: 1.4 !important;
    opacity: 0.9 !important;
    margin-bottom: 20px !important;
    max-width: 320px !important;
    color: #FFFFFF !important;
}

.aw-media-card-link {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #FFFFFF !important;
    text-decoration: none !important;
}

.aw-media-card-link span {
    transition: transform 0.3s ease !important;
}

.aw-media-card:hover .aw-media-card-link span {
    transform: translateX(5px) !important;
}

/* Ajustes para Móvil */
@media (max-width: 991px) {
    .aw-media-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        grid-template-rows: auto auto !important;
        gap: 16px !important;
    }

    .aw-media-card-large {
        grid-column: span 2 !important;
        grid-row: 1 !important;
        min-height: 280px !important;
        height: auto !important;
        aspect-ratio: 16 / 10 !important;
    }

    .aw-media-card-small {
        grid-column: auto !important;
        min-height: 200px !important;
        height: auto !important;
        aspect-ratio: 1 / 1 !important;
    }

    .aw-media-grid > .aw-media-card-small:nth-child(2) {
        grid-column: 1 !important;
        grid-row: 2 !important;
    }

    .aw-media-grid > .aw-media-card-small:nth-child(3) {
        grid-column: 2 !important;
        grid-row: 2 !important;
    }

    .aw-media-card-content {
        padding: 20px !important;
    }

    .aw-media-card-title {
        font-size: 22px !important;
    }

    .aw-media-card-desc {
        font-size: 13px !important;
        line-height: 1.35 !important;
        margin-bottom: 15px !important;
    }
}

@media (max-width: 480px) {
    .aw-media-grid {
        gap: 12px !important;
    }

    .aw-media-card {
        border-radius: 20px !important;
    }

    .aw-media-card-large {
        min-height: 200px !important;
        aspect-ratio: 16 / 10 !important;
    }

    .aw-media-card-small {
        min-height: 150px !important;
        aspect-ratio: 1 / 1 !important;
    }

    .aw-media-card-content {
        padding: 12px !important;
    }

    .aw-media-card-title {
        font-size: 16px !important;
        margin-bottom: 4px !important;
    }

    .aw-media-card-desc {
        font-size: 10px !important;
        line-height: 1.25 !important;
        margin-bottom: 8px !important;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .aw-media-card-link {
        font-size: 10px !important;
        gap: 4px !important;
    }

    .aw-video-play-btn {
        width: 60px !important;
        height: 42px !important;
        border-radius: 12px !important;
    }

    .aw-video-play-btn::after {
        border-top: 8px solid transparent !important;
        border-bottom: 8px solid transparent !important;
        border-left: 14px solid #000000 !important;
        margin-left: 3px !important;
    }
}

/* ==========================================================================
   Popup del Video (Modal Lightbox)
   ========================================================================== */
.aw-video-lightbox {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(15, 23, 42, 0.9); /* Slate-900 translúcido */
    backdrop-filter: blur(10px); /* Desenfoque de fondo premium */
    -webkit-backdrop-filter: blur(10px);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.aw-video-lightbox.is-active {
    opacity: 1;
    pointer-events: auto;
}

.aw-video-lightbox-content {
    position: relative;
    width: 90%;
    max-width: 1000px;
    aspect-ratio: 16 / 9;
    background: #000000;
    border-radius: 20px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transform: scale(0.9);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    overflow: visible;
}

.aw-video-lightbox.is-active .aw-video-lightbox-content {
    transform: scale(1);
}

.aw-video-lightbox-iframe-wrapper {
    width: 100%;
    height: 100%;
    border-radius: 20px;
    overflow: hidden;
}

.aw-video-lightbox-close {
    position: absolute;
    top: -50px;
    right: 0;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    color: #FFFFFF;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    z-index: 100000;
}

.aw-video-lightbox-close:hover {
    background: #FFFFFF;
    color: #0f172a;
    transform: rotate(90deg);
}

/* Cursor pointer y estilos para la tarjeta con video */
.aw-media-card-large[data-video-url] {
    cursor: pointer;
}

.aw-media-card-large[data-video-url]:hover .aw-video-play-btn {
    transform: translate(-50%, -50%) scale(1.1) !important;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.4) !important;
}

.aw-video-play-btn {
    transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.3s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

@media (max-width: 768px) {
    .aw-video-lightbox-close {
        top: 15px;
        right: 15px;
        background: rgba(0, 0, 0, 0.5);
    }
}

/* --- File: experience-steps-grid.css --- */
.aw-exp-steps-container {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 24px !important;
    margin: 30px auto;
    width: 100% !important;
    font-family: 'Inter', sans-serif;
}

.aw-exp-step-card {
    display: flex !important;
    flex-direction: row !important;
    background: #EBF5F6;
    border-radius: 20px;
    overflow: hidden;
    height: 100% !important;
    align-items: stretch !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
}

.aw-exp-step-img-wrap {
    flex: 0 0 42% !important;
    position: relative !important;
    overflow: hidden !important;
}

.aw-exp-step-img-wrap img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.aw-exp-step-placeholder {
    width: 100% !important;
    height: 100% !important;
    background: #E2E8F0 !important;
}

.aw-exp-step-content {
    flex: 1 !important;
    padding: 24px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
}

.aw-exp-step-number {
    background: #F89A24;
    color: #FFFFFF;
    font-size: 16px;
    font-weight: 800;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 12px;
    line-height: 1;
}

.aw-exp-step-desc {
    font-size: 15px;
    line-height: 1.4;
    color: #1F2933;
    margin: 0 !important;
    font-weight: 600;
}

/* Responsivo */
@media (max-width: 991px) {
    .aw-exp-steps-container {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 16px !important;
    }
    
    .aw-exp-step-content {
        padding: 20px 16px !important;
    }

    .aw-exp-step-desc {
        font-size: 14px;
    }
}

@media (max-width: 768px) {
    .aw-exp-steps-container {
        grid-template-columns: 1fr !important; /* Stack vertically, but cards remain row flex */
        gap: 16px !important;
    }

    .aw-exp-step-card {
        flex-direction: row !important; /* Force side-by-side */
    }

    .aw-exp-step-img-wrap {
        flex: 0 0 40% !important;
    }

    .aw-exp-step-content {
        padding: 16px 20px !important;
    }
}

@media (max-width: 480px) {
    .aw-exp-step-img-wrap {
        flex: 0 0 38% !important;
    }

    .aw-exp-step-content {
        padding: 14px 12px !important;
    }

    .aw-exp-step-number {
        width: 28px !important;
        height: 28px !important;
        font-size: 14px;
        margin-bottom: 8px !important;
        border-radius: 6px !important;
    }

    .aw-exp-step-desc {
        font-size: 12.5px;
        line-height: 1.3;
    }

    .aw-exp-step-card {
        border-radius: 16px !important;
    }
}


/* --- File: ceramics-sections.css --- */
/**
 * Ceramics Experience Sections Styles
 */

/* 1. Info Highlights */
.aw-ceramics-highlights {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin: 40px 0;
}

.aw-highlight-card {
    background: #FFFFFF;
    border-radius: 16px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.04);
    border: 1px solid #F1F5F9;
    transition: transform 0.3s ease;
}

.aw-highlight-card:hover {
    transform: translateY(-4px);
}

.aw-highlight-icon {
    width: 48px;
    height: 48px;
    background: #FAF5EF;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.aw-highlight-icon i {
    font-size: 20px;
    color: #C2A278;
}

.aw-highlight-info {
    display: flex;
    flex-direction: column;
}

.aw-highlight-title {
    font-size: 16px;
    font-weight: 700;
    color: #0F172A;
    margin: 0;
}

.aw-highlight-subtitle {
    font-size: 13px;
    color: #64748B;
    margin: 2px 0 0 0;
}

/* 2. Experience Features */
.aw-experience-features-section {
    margin: 60px 0;
}

.aw-section-title {
    font-size: 28px;
    font-weight: 800;
    color: #0F172A;
    margin-bottom: 32px;
}

.aw-features-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.aw-feature-item {
    background: #FFFFFF;
    border-radius: 12px;
    padding: 20px 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    border: 1px solid #F1F5F9;
    box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.02);
}

.aw-feature-icon {
    width: 32px;
    height: 32px;
    background: #E0F2F1;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.aw-feature-icon i {
    font-size: 14px;
    color: #00897B;
}

.aw-feature-text {
    font-size: 15px;
    font-weight: 600;
    color: #334155;
}

/* 3. Testimonials */
.aw-testimonials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin: 60px 0;
}

.aw-testimonial-card {
    background: #FFFFFF;
    border-radius: 16px;
    padding: 32px;
    border: 1px solid #F1F5F9;
    box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.04);
}

.aw-testimonial-stars {
    display: flex;
    gap: 4px;
    margin-bottom: 16px;
}

.aw-testimonial-stars i {
    color: #FBBF24;
    font-size: 14px;
}

.aw-testimonial-text {
    font-size: 15px;
    color: #475569;
    line-height: 1.6;
    margin-bottom: 20px;
    font-style: italic;
}

.aw-testimonial-author {
    font-size: 14px;
    font-weight: 700;
    color: #0F172A;
}

/* 4. CTA Banner */
.aw-ceramics-cta-banner {
    background: #00A5B5;
    border-radius: 24px;
    padding: 60px 40px;
    text-align: center;
    color: #FFFFFF;
    margin: 80px 0;
    position: relative;
    overflow: hidden;
}

.aw-cta-title {
    font-size: 36px;
    font-weight: 800;
    margin: 0 0 12px 0;
    letter-spacing: -0.02em;
}

.aw-cta-subtitle {
    font-size: 18px;
    opacity: 0.9;
    margin: 0 0 32px 0;
}

.aw-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #FFFFFF;
    color: #00A5B5;
    padding: 16px 32px;
    border-radius: 30px;
    font-size: 16px;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.1);
}

.aw-cta-btn:hover {
    transform: scale(1.05);
    box-shadow: 0px 8px 24px rgba(0, 0, 0, 0.15);
    background: #F8FAFC;
}

/* 5. Gallery */
.aw-experience-gallery-section {
    margin: 60px 0;
}

.aw-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.aw-gallery-item {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    width: 100%;
}

.aw-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.aw-gallery-item:hover img {
    transform: scale(1.05);
}

.aw-gallery-item.has-more .aw-gallery-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #FFFFFF;
    gap: 8px;
    cursor: pointer;
}

.aw-gallery-overlay i {
    font-size: 24px;
}

.aw-gallery-overlay span {
    font-size: 14px;
    font-weight: 700;
}

/* Responsive overrides: Let Elementor's column count control layout while ensuring base rules are beautiful */
.aw-gallery-item {
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
    background: #eeeeee;
    transition: all 0.3s ease;
}

/* Gallery Trigger (Ver más) Overlay */
.aw-gallery-trigger {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    backdrop-filter: blur(4px);
    z-index: 2;
}

.aw-gallery-trigger i {
    font-size: 24px;
    margin-bottom: 8px;
    color: #ffffff;
}

.aw-gallery-trigger span {
    font-size: 14px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.aw-gallery-trigger:hover {
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(6px);
}

/* Lightbox Modal Premium (Glassmorphism + Responsive controls) */
.aw-gallery-lightbox {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(15, 23, 42, 0.75); /* Sleek dark slate */
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1), visibility 0.4s;
}

.aw-gallery-lightbox.is-active {
    opacity: 1;
    visibility: visible;
}

.aw-lightbox-content {
    position: relative;
    max-width: 85%;
    max-height: 80%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.aw-lightbox-image-wrapper {
    overflow: hidden;
    border-radius: 20px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.03);
    display: flex;
    align-items: center;
    justify-content: center;
}

.aw-lightbox-image {
    max-width: 100%;
    max-height: 75vh;
    object-fit: contain;
    display: block;
    user-select: none;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    transform: scale(0.95);
}

.aw-gallery-lightbox.is-active .aw-lightbox-image {
    transform: scale(1);
}

/* Lightbox Controls */
.aw-lightbox-close,
.aw-lightbox-arrow {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    backdrop-filter: blur(8px);
    border-radius: 50%;
    z-index: 10;
}

.aw-lightbox-close {
    position: absolute;
    top: -60px;
    right: 0;
    width: 48px;
    height: 48px;
    font-size: 18px;
}

.aw-lightbox-close:hover {
    background: rgba(239, 68, 68, 0.2);
    border-color: rgba(239, 68, 68, 0.4);
    color: #ef4444;
    transform: rotate(90deg);
}

.aw-lightbox-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 56px;
    height: 56px;
    font-size: 20px;
}

.aw-lightbox-arrow.prev {
    left: -80px;
}

.aw-lightbox-arrow.next {
    right: -80px;
}

.aw-lightbox-arrow:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.3);
    transform: translateY(-50%) scale(1.08);
}

/* Responsive */
@media (max-width: 1200px) {
    .aw-lightbox-content {
        max-width: 90%;
    }
    .aw-lightbox-arrow.prev {
        left: -30px;
    }
    .aw-lightbox-arrow.next {
        right: -30px;
    }
    .aw-lightbox-arrow {
        width: 48px;
        height: 48px;
        font-size: 18px;
    }
}

@media (max-width: 768px) {
    .aw-gallery-item {
        width: 100%;
    }
    
    .aw-cta-title {
        font-size: 28px;
    }
    
    .aw-ceramics-cta-banner {
        padding: 40px 24px;
    }

    .aw-lightbox-close {
        top: -55px;
        right: 0px;
        width: 40px;
        height: 40px;
    }
    .aw-lightbox-arrow {
        position: fixed;
        bottom: 30px;
        top: auto;
        transform: none;
    }
    .aw-lightbox-arrow.prev {
        left: calc(50% - 60px);
    }
    .aw-lightbox-arrow.next {
        right: calc(50% - 60px);
    }
    .aw-lightbox-arrow:hover {
        transform: scale(1.05);
    }
}


/* --- File: experience-locations-grid.css --- */
.aw-locations-section {
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
    font-family: 'Inter', 'Outfit', sans-serif;
}

.aw-locations-header {
    text-align: center;
    margin-bottom: 50px;
}

.aw-locations-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background-color: #E0F7F9;
    color: #1DB3BC;
    padding: 8px 16px;
    border-radius: 50px;
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: capitalize;
    margin-bottom: 20px;
}

.aw-locations-title {
    font-size: 2.5rem;
    color: #111827;
    margin: 0 0 15px;
    font-weight: 700;
}

.aw-locations-subtitle {
    font-size: 1.1rem;
    color: #6B7280;
    max-width: 700px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Grid Layout */
.aw-locations-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

/* Card Styling */
.aw-location-card {
    background: #FFFFFF;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.aw-location-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.aw-location-image-wrapper {
    position: relative;
    height: 220px;
    overflow: hidden;
}

.aw-location-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.aw-location-card:hover .aw-location-image-wrapper img {
    transform: scale(1.05);
}

.aw-location-card-badge {
    position: absolute;
    top: 15px;
    left: 15px;
    background: #FFFFFF;
    color: #1DB3BC;
    padding: 6px 12px;
    border-radius: 50px;
    font-size: 0.7rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    gap: 6px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}

.aw-location-card-content {
    padding: 25px;
}

.aw-location-card-title {
    font-size: 1.4rem;
    color: #111827;
    margin: 0 0 8px;
    font-weight: 700;
}

.aw-location-card-info {
    font-size: 0.95rem;
    color: #6B7280;
    margin-bottom: 20px;
}

.aw-location-card-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #1DB3BC;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    transition: gap 0.2s ease;
}

.aw-location-card-link:hover {
    gap: 15px;
}

.aw-location-card-link svg {
    transition: transform 0.2s ease;
}

/* Responsive */
@media (max-width: 1024px) {
    .aw-locations-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .aw-locations-grid {
        grid-template-columns: 1fr;
    }
    .aw-locations-title {
        font-size: 2rem;
    }
}


/* --- File: studio-locations-tabs.css --- */
.aw-studio-tabs-section {
    max-width: 1200px;
    margin: 60px auto;
    padding: 0 20px;
    font-family: 'Inter', 'Outfit', sans-serif;
}

.aw-studio-tabs-header {
    text-align: center;
    margin-bottom: 50px;
}

.aw-studio-tabs-title {
    font-size: 2.5rem;
    color: #111827;
    margin: 0 0 10px;
    font-weight: 700;
}

.aw-studio-tabs-subtitle {
    font-size: 1.1rem;
    color: #6B7280;
}

/* Container Layout */
.aw-studio-tabs-container {
    display: flex;
    gap: 40px;
    align-items: flex-start;
}

.aw-studio-cards-column {
    flex: 0 0 400px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.aw-studio-content-column {
    flex: 1;
    min-height: 500px;
}

/* Card Styling */
.aw-studio-tab-card {
    background: #FFFFFF;
    border: 1.5px solid #F3F4F6;
    border-radius: 16px;
    padding: 25px;
    display: flex;
    gap: 20px;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    box-shadow: 0 2px 10px rgba(0,0,0,0.02);
}

.aw-studio-tab-card:hover {
    border-color: #E5E7EB;
    transform: translateX(5px);
}

.aw-studio-tab-card.is-active {
    border-color: #1DB3BC;
    box-shadow: 0 10px 25px rgba(29, 179, 188, 0.1);
}

.aw-studio-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: #F0FDFA;
    color: #1DB3BC;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.aw-studio-tab-card.is-active .aw-studio-card-icon {
    background-color: #1DB3BC;
    color: #FFFFFF;
}

.aw-studio-card-info {
    flex: 1;
}

.aw-studio-card-name {
    font-size: 1.25rem;
    color: #111827;
    margin: 0 0 5px;
    font-weight: 700;
}

.aw-studio-card-address {
    font-size: 0.95rem;
    color: #4B5563;
    margin: 0 0 10px;
    line-height: 1.4;
}

.aw-studio-card-desc {
    font-size: 0.9rem;
    color: #6B7280;
    margin: 0 0 15px;
    line-height: 1.5;
}

.aw-studio-card-maps {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #1DB3BC;
    text-decoration: none !important;
    font-size: 0.85rem;
    font-weight: 600;
    transition: all 0.2s ease;
}

.aw-studio-card-maps:hover {
    color: #00A5B5;
    gap: 12px;
}

/* Content Area */
.aw-studio-content-wrapper {
    background-color: #F9FAFB;
    border-radius: 24px;
    padding: 40px;
    min-height: 500px;
    position: relative;
    border: 1px solid rgba(0,0,0,0.03);
}

.aw-studio-content-pane {
    display: none;
    animation: awFadeIn 0.4s ease forwards;
}

.aw-studio-content-pane.is-active {
    display: block;
}

.aw-studio-template-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 400px;
    color: #9CA3AF;
    font-style: italic;
    text-align: center;
}

@keyframes awFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 1024px) {
    .aw-studio-tabs-container {
        flex-direction: column;
    }
    .aw-studio-cards-column {
        flex: 1;
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .aw-studio-cards-column {
        grid-template-columns: 1fr;
    }
    .aw-studio-content-wrapper {
        padding: 20px;
    }
}


/* --- File: single-category-booking.css --- */
/**
 * Single Category Booking Widget Styles — Clean & Fully Responsive
 */

/* 1. Main Wrapper */
.elementor-widget-artwine_single_category_booking .aw-single-portal-wrapper {
    font-family: 'Inter', 'Outfit', sans-serif !important;
    color: #1E293B !important;
    max-width: 100% !important;
    margin: 40px auto !important;
    padding: 40px !important;
    background: #FFFFFF !important;
    border-radius: 24px !important;
    box-sizing: border-box !important;
    box-shadow: 0px 8px 32px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid #F1F5F9 !important;
}

.aw-filter-label {
    margin: 0 !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-portal-container {
    display: flex !important;
    flex-direction: column !important;
    gap: 32px !important;
}

/* 2. Header Text */
.elementor-widget-artwine_single_category_booking .aw-single-portal-title {
    font-size: 32px !important;
    font-weight: 700 !important;
    color: #0F172A !important;
    margin: 0 !important;
    letter-spacing: -0.02em !important;
    text-align: left !important;
    line-height: 1.2 !important;
}

.elementor-widget-artwine_single_portal_subtitle {
    font-size: 16px !important;
    color: #64748B !important;
    margin-top: 8px !important;
}

/* 3. Filters Row */
.elementor-widget-artwine_single_category_booking .aw-single-filters-row {
    display: flex !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    align-items: center !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-filter-item {
    display: flex !important;
    align-items: center !important;
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 12px !important;
    padding: 0 16px !important;
    height: 52px !important;
    box-sizing: border-box !important;
    position: relative !important;
    gap: 10px !important;
    transition: all 0.2s ease !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-filter-item:hover {
    border-color: #CBD5E1 !important;
}

.elementor-widget-artwine_single_category_booking .aw-filter-icon {
    color: #94A3B8 !important;
    font-size: 16px !important;
    width: 20px !important;
    text-align: center !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-select {
    background: transparent !important;
    border: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #1E293B !important;
    cursor: pointer !important;
    outline: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    padding: 0 30px 0 0 !important;
    height: 100% !important;
    width: 100% !important;
    position: relative !important;
    z-index: 2 !important;
}

.elementor-widget-artwine_single_category_booking .aw-filter-arrow {
    position: absolute !important;
    right: 16px !important;
    color: #94A3B8 !important;
    font-size: 10px !important;
    pointer-events: none !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-people-controls {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-people-controls button {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 6px !important;
    width: 26px !important;
    height: 26px !important;
    font-size: 16px !important;
    color: #475569 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-people-count {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #0F172A !important;
    min-width: 20px !important;
    text-align: center !important;
}

/* 4. Calendar Slider */
.elementor-widget-artwine_single_category_booking .aw-single-calendar-section {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    position: relative !important;
    width: 100% !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-slider-nav {
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #475569 !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    font-size: 14px !important;
    box-shadow: 0px 2px 8px rgba(0, 0, 0, 0.05) !important;
    transition: all 0.2s ease !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-slider-nav:hover {
    background: #F8FAFC !important;
    color: #00A5B5 !important;
    border-color: #CBD5E1 !important;
    box-shadow: 0px 4px 12px rgba(0, 165, 181, 0.1) !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-days-strip {
    flex: 1 !important;
    min-width: 0 !important;
    display: flex !important;
    gap: 12px !important;
    overflow-x: auto !important;
    padding: 8px 0 !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
    scroll-behavior: smooth !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-days-strip::-webkit-scrollbar {
    display: none !important;
}

.elementor-widget-artwine_single_category_booking .aw-cal-day {
    flex: 0 0 80px !important;
    height: 110px !important;
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    position: relative !important;
    z-index: 1 !important;
}

.aw-empty-calendar {
    width: 100% !important;
    padding: 40px 20px !important;
    text-align: center !important;
    background: #F8FAFC !important;
    border: 1px dashed #E2E8F0 !important;
    border-radius: 16px !important;
    color: #94A3B8 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

.aw-select-date-message {
    width: 100% !important;
    padding: 30px 20px !important;
    text-align: center !important;
    background: #F8FAFC !important;
    border: 1px dashed #E2E8F0 !important;
    border-radius: 16px !important;
    color: #94A3B8 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    box-sizing: border-box !important;
}

.elementor-widget-artwine_single_category_booking .aw-cal-day.is-disabled {
    background: #F8FAFC !important;
    border-color: #F1F5F9 !important;
    opacity: 0.6 !important;
    cursor: not-allowed !important;
}

.elementor-widget-artwine_single_category_booking .aw-cal-day.is-active {
    border: 2px solid #00A5B5 !important;
    box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.08) !important;
}

.elementor-widget-artwine_single_category_booking .aw-cal-day .day-name {
    font-size: 11px !important;
    font-weight: 600 !important;
    color: #64748B !important;
    text-transform: uppercase !important;
    margin-bottom: 4px !important;
}

.elementor-widget-artwine_single_category_booking .aw-cal-day .day-number {
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #0F172A !important;
}

.elementor-widget-artwine_single_category_booking .aw-cal-day .day-month {
    font-size: 11px !important;
    font-weight: 500 !important;
    color: #94A3B8 !important;
}

.elementor-widget-artwine_single_category_booking .aw-cal-dot {
    width: 6px !important;
    height: 6px !important;
    background: #00A5B5 !important;
    border-radius: 50% !important;
    margin-top: 8px !important;
}

/* 5. Slots */
.elementor-widget-artwine_single_category_booking .aw-single-slots-notice {
    font-size: 14px !important;
    color: #94A3B8 !important;
    margin: 20px 0 !important;
    line-height: 1.5 !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-slots-wrapper {
    display: flex !important;
    gap: 32px !important;
    align-items: flex-start !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-slots-grid {
    display: flex !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
    flex: 1 !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-pill {
    display: inline-flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    background: #FFFFFF !important;
    border: 1px solid #E2E8F0 !important;
    border-radius: 12px !important;
    padding: 16px 20px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    min-width: 160px !important;
    position: relative !important;
    box-sizing: border-box !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-pill.is-selected {
    border: 1px solid #00A5B5 !important;
    background: #F0F9FA !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-check-badge {
    position: absolute !important;
    top: -8px !important;
    right: -8px !important;
    width: 20px !important;
    height: 20px !important;
    background: #00A5B5 !important;
    color: #FFFFFF !important;
    border-radius: 50% !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 10px !important;
    box-shadow: 0px 2px 6px rgba(0, 165, 181, 0.3) !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-pill.is-selected .aw-slot-check-badge {
    display: flex !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-line {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-line i {
    color: #00A5B5 !important;
    font-size: 14px !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-time {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #0F172A !important;
}

.elementor-widget-artwine_single_category_booking .aw-slot-stock {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #64748B !important;
}

/* 5.1 Product Preview - Integrated Horizontal Card */
.aw-single-product-preview {
    display: flex;
    flex-direction: row !important;
    align-items: center !important;
    gap: 15px !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin-top: 15px !important;
    max-width: 100% !important;
    width: auto !important;
    animation: awFadeInUp 0.4s ease forwards !important;
    flex: none !important;
}

@keyframes awFadeInUp {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.aw-preview-image-wrap {
    flex: 0 0 100px !important;
    width: 100px !important;
    height: 100px !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: #F8FAFC !important;
    position: relative !important;
    cursor: zoom-in !important;
}

.aw-preview-image-wrap::after {
    content: '\f00e';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #FFFFFF;
    font-size: 18px;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 2;
}

.aw-preview-image-wrap:hover::after {
    opacity: 1;
}

.aw-preview-image-wrap::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 165, 181, 0.4);
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
}

.aw-preview-image-wrap:hover::before {
    opacity: 1;
}

.aw-preview-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.5s ease !important;
}

.aw-single-product-preview:hover .aw-preview-img {
    transform: scale(1.05) !important;
}

.aw-preview-info {
    padding: 0 10px !important;
    text-align: left !important;
    flex: 1 !important;
}

.aw-preview-label {
    display: block !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #00A5B5 !important;
    text-transform: uppercase !important;
    margin-bottom: 2px !important;
    letter-spacing: 0.05em !important;
}

.aw-preview-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #0F172A !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}

/* 7. Modal Lightbox */
.aw-preview-modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 99999 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 20px !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 0.3s ease !important;
}

.aw-preview-modal.is-active {
    opacity: 1 !important;
    visibility: visible !important;
}

.aw-preview-modal .aw-modal-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(15, 23, 42, 0.85) !important;
    backdrop-filter: blur(8px) !important;
    z-index: 1 !important;
}

.aw-preview-modal .aw-modal-content {
    position: relative !important;
    z-index: 10 !important;
    max-width: 85% !important;
    max-height: 85% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    transform: scale(0.9);
    animation: awModalScale 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) forwards !important;
}

@keyframes awModalScale {
    to { transform: scale(1); }
}

.aw-preview-modal .aw-modal-img {
    max-width: 100% !important;
    max-height: 90vh !important;
    border-radius: 12px !important;
    box-shadow: 0 20px 50px rgba(0,0,0,0.5) !important;
}

.aw-preview-modal .aw-modal-close {
    position: absolute !important;
    top: 30px !important;
    right: 30px !important;
    font-size: 40px !important;
    color: #FFFFFF !important;
    cursor: pointer !important;
    z-index: 3 !important;
    line-height: 1 !important;
    opacity: 0.7 !important;
    transition: opacity 0.3s ease !important;
}

.aw-preview-modal .aw-modal-close:hover {
    opacity: 1 !important;
}

/* 6. Footer Button */
.elementor-widget-artwine_single_category_booking .aw-single-btn-booking {
    width: 100% !important;
    background: #CBD5E1 !important;
    color: #FFFFFF !important;
    border: none !important;
    border-radius: 16px !important;
    height: 56px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: not-allowed !important;
    transition: all 0.3s ease !important;
}

.elementor-widget-artwine_single_category_booking .aw-single-btn-booking:not(:disabled) {
    background: #00A5B5 !important;
    cursor: pointer !important;
}

/* --- RESPONSIVE --- */

@media (max-width: 1024px) {
    .elementor-widget-artwine_single_category_booking .aw-single-portal-wrapper {
        padding: 30px !important;
    }
}

@media (max-width: 768px) {
    .elementor-widget-artwine_single_category_booking .aw-single-portal-wrapper {
        padding: 20px !important;
        margin: 20px auto !important;
        border-radius: 16px !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-single-portal-title {
        font-size: 26px !important;
        text-align: center !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-single-filter-item {
        flex: 1 1 calc(50% - 6px) !important;
        height: 48px !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-filter-people {
        flex: 1 1 100% !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-single-slider-nav {
        display: flex !important;
        width: 36px !important;
        height: 36px !important;
        font-size: 12px !important;
        color: #475569 !important;
        background: #FFFFFF !important;
        border: 1px solid #E2E8F0 !important;
        border-radius: 50% !important;
        box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.04) !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-cal-day {
        flex: 0 0 74px !important;
        height: 100px !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-single-slots-grid {
        justify-content: center !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-slot-pill {
        flex: 1 1 calc(50% - 8px) !important;
        min-width: 140px !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-single-slots-wrapper {
        flex-direction: column !important;
        gap: 0 !important;
    }

    .aw-single-product-preview {
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-single-slots-notice {
        text-align: center !important;
    }
}

@media (max-width: 480px) {
    .elementor-widget-artwine_single_category_booking .aw-single-filter-item {
        flex: 1 1 100% !important;
    }

    .elementor-widget-artwine_single_category_booking .aw-slot-pill {
        flex: 1 1 100% !important;
    }
}

/* --- File: product-gallery.css --- */
/* ArtWine Product Gallery Base Styles */
.aw-product-gallery {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.aw-gallery-main {
    width: 100%;
    margin-bottom: 20px;
    overflow: hidden;
    background: transparent !important;
}

.aw-gallery-main img {
    width: 100%;
    height: auto;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
    transition: opacity 0.3s ease;
    border-radius: inherit; /* Inherit from container */
}

.aw-gallery-thumbs {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 5px 2px 15px 2px;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.aw-gallery-thumbs::-webkit-scrollbar {
    display: none;
}

.aw-gallery-thumb {
    flex: 0 0 72px;
    height: 72px;
    cursor: pointer;
    overflow: hidden;
    transition: all 0.2s ease;
    border: 2px solid transparent;
    padding: 0;
    background: transparent;
}

.aw-gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: inherit; /* Inherit from container */
}

.aw-gallery-thumb.active {
    border-color: #00a5b5;
    box-shadow: 0 4px 12px rgba(0, 165, 181, 0.2);
}

.aw-gallery-thumb:hover:not(.active) {
    opacity: 0.8;
    transform: translateY(-2px);
}


