/* Cafe Page Styles */

.cafe-content {
    padding: 0 var(--spacing-md) var(--spacing-2xl);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-lg);
}

.cafe-hero-image {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
}

.cafe-info-card {
    background: var(--color-white);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

.cafe-info-card__text {
    font-size: 14px;
    line-height: 1.6;
    color: var(--color-text-dark);
    margin-bottom: var(--spacing-md);
}

.cafe-info-card__text:last-child {
    margin-bottom: 0;
}

.cafe-info-card__price {
    font-weight: var(--font-weight-bold);
    color: var(--color-teal-primary);
}

.cafe-info-card__hours {
    display: inline-block;
    margin-top: var(--spacing-sm);
    padding: 4px 12px;
    background: var(--color-bg-light);
    border-radius: var(--radius-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-teal-dark);
}

/* Menu Slider Specifics */
.menu-slider-section {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.menu-slider-section__title {
    font-size: 16px;
    font-weight: var(--font-weight-bold);
    color: var(--color-teal-dark);
    padding-left: 4px;
}

.menu-hint {
    font-size: 12px;
    color: var(--color-text-gray);
    text-align: center;
    margin-top: -8px;
}

.slider__slide--zoomable {
    cursor: zoom-in;
}

/* Promo Section */
.promo-card {
    background: var(--gradient-teal);
    color: var(--color-white);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-md);
}

.promo-card__image {
    width: 100%;
    height: 150px;
    object-fit: cover;
}

.promo-card__content {
    padding: var(--spacing-lg);
}

.promo-card__title {
    font-size: 16px;
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-md);
    line-height: 1.4;
}

.promo-card__list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.promo-card__item {
    font-size: 13px;
    line-height: 1.5;
    padding-left: 16px;
    position: relative;
}

.promo-card__item::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--color-white);
}

/* Zoom Overlay Styles are now handled by JS for maximum reliability, 
   but we keep the class for potential CSS-only tweaks */
.zoom-overlay--active {
    display: flex !important;
}