/* ============================================================
   FAB - Yüzen Butonlar (Quick Contact + Scroll Top)
   Modarenta Frontend
   ============================================================ */

/* Eski tekil FAB tanımları (kullanılmıyor) */
.ai-assistant-fab,
.quick-contact-fab {
    display: none;
}

/* ── Yüzen Buton Grubu ── */
.quick-fab-stack {
    position: fixed;
    right: 18px;
    bottom: 20px;
    z-index: var(--z-toast, 900);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
}

.quick-contact-menu {
    position: relative;
}

/* Ana toggle butonu + scroll-top butonu ortak stiller */
.quick-contact-menu__toggle,
.scroll-top-fab {
    width: 52px;
    height: 52px;
    border: 1px solid rgba(220, 212, 197, .92);
    border-radius: 18px;
    background: rgba(255, 252, 247, .94);
    color: #8a6220;
    box-shadow: 0 18px 40px rgba(24, 24, 27, .12);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, opacity .18s ease;
}

.quick-contact-menu__toggle:hover,
.scroll-top-fab:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 44px rgba(24, 24, 27, .16);
    border-color: rgba(184, 139, 57, .46);
}

.quick-contact-menu__toggle svg,
.scroll-top-fab svg,
.quick-contact-menu__item svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

/* Panel (açılır menü) */
.quick-contact-menu__panel {
    position: absolute;
    right: 0;
    bottom: calc(100% + 10px);
    display: flex;
    flex-direction: column;
    gap: 8px;
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px) scale(.96);
    transform-origin: bottom right;
    transition: opacity .18s ease, transform .18s ease;
}

.quick-contact-menu.is-open .quick-contact-menu__panel {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

/* Toggle aktif durumu */
.quick-contact-menu.is-open .quick-contact-menu__toggle {
    color: #fff;
    background: #b88b39;
    border-color: #b88b39;
}

/* ── Çalışma Saatleri Modal ── */
.hours-modal {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-toast, 900) + 10);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s ease;
}

.hours-modal.is-open {
    opacity: 1;
    pointer-events: auto;
}

.hours-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(22, 18, 15, .55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.hours-modal__dialog {
    position: relative;
    width: min(100%, 320px);
    background: rgba(255, 252, 247, .98);
    border-radius: 16px;
    box-shadow: 0 28px 72px rgba(15, 10, 5, .24);
    padding: 24px 22px 22px;
    transform: translateY(16px) scale(.97);
    transition: transform .22s ease;
}

.hours-modal.is-open .hours-modal__dialog {
    transform: translateY(0) scale(1);
}

.hours-modal__close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: none;
    background: rgba(220, 212, 197, .5);
    color: #7a6345;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .15s;
}
.hours-modal__close:hover { background: rgba(184, 139, 57, .2); color: #b88b39; }
.hours-modal__close svg { width: 14px; height: 14px; }

/* Bugün */
.hours-modal__today {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 0;
}

.hours-modal__today-meta {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.hours-modal__today-dayname {
    font-size: 22px;
    font-weight: 700;
    color: #3d2f1a;
    line-height: 1.1;
}

.hours-modal__today-date {
    font-size: 13px;
    color: #9c836a;
}

.hours-modal__today-badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    width: fit-content;
}

.hours-modal__today-badge.is-open  { background: rgba(21,128,61,.10); color: #15803d; }
.hours-modal__today-badge.is-closed { background: rgba(185,28,28,.09); color: #b91c1c; }

.hours-modal__next-open {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    color: #9c836a;
    background: rgba(184, 139, 57, .08);
    border: 1px solid rgba(184, 139, 57, .18);
    border-radius: 10px;
    padding: 5px 10px;
    width: fit-content;
}

.hours-modal__today-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
    animation: fab-pulse 2s ease-in-out infinite;
}

@keyframes fab-pulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: .35; }
}

.hours-modal__divider {
    height: 1px;
    background: rgba(220, 212, 197, .8);
    margin: 16px 0 12px;
}

/* Haftalık liste */
.hours-modal__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.hours-modal__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 13.5px;
    color: #7a6345;
    padding: 6px 8px;
    border-radius: 10px;
}

.hours-modal__row.is-today {
    background: rgba(184, 139, 57, .10);
    color: #3d2f1a;
    font-weight: 600;
}

.hours-modal__day { flex: 1; }

.hours-modal__time {
    font-variant-numeric: tabular-nums;
    font-size: 13px;
    color: #4a3b26;
}

.hours-modal__row.is-today .hours-modal__time { color: #b88b39; font-weight: 700; }

.hours-modal__closed { font-size: 13px; color: #b91c1c; }

.quick-contact-menu__item--hours { color: #b88b39; }

/* Panel içi butonlar */
.quick-contact-menu__item {
    height: 46px;
    padding: 0 16px 0 12px;
    gap: 10px;
    border: 1px solid rgba(220, 212, 197, .92);
    border-radius: 16px;
    background: rgba(255, 252, 247, .96);
    box-shadow: 0 14px 30px rgba(24, 24, 27, .10);
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    text-decoration: none;
    cursor: pointer;
    white-space: nowrap;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.quick-contact-menu__item:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 36px rgba(24, 24, 27, .14);
    border-color: rgba(184, 139, 57, .46);
}

.quick-contact-menu__label {
    font-size: 13px;
    font-weight: 500;
    color: #3d2f1a;
    letter-spacing: .01em;
}

.quick-contact-menu__item--instagram { color: #a53f7a; }
.quick-contact-menu__item--whatsapp  { color: #15803d; }
.quick-contact-menu__item--assistant { color: #9a6b17; }

/* Scroll-top — sadece scroll sonrası görünür */
.scroll-top-fab {
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
}

.scroll-top-fab.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

/* ── Mobil ── */
@media (max-width: 640px) {
    .quick-fab-stack { right: 14px; bottom: 16px; gap: 8px; }

    .quick-contact-menu__toggle,
    .scroll-top-fab {
        width: 48px;
        height: 48px;
        border-radius: 16px;
    }

    .quick-contact-menu__item {
        height: 42px;
        padding: 0 14px 0 10px;
        border-radius: 14px;
    }

    .quick-contact-menu__label {
        font-size: 12px;
    }

    .quick-contact-menu__hours {
        padding: 8px 12px;
        border-radius: 14px;
    }

    .quick-contact-menu__toggle svg,
    .scroll-top-fab svg,
    .quick-contact-menu__item svg {
        width: 18px;
        height: 18px;
    }
}
