/**
 * UpLife — sabit iletişim rayı (minimal, hero sosyal kartlarıyla aynı dil)
 * Hero: alt bantta yukarı — slider kontrolleriyle çakışmaz.
 * Hero dışı: Tawk üstü (bottom stack style.css ile uyumlu); sağa daha yakın — margin hero’dan küçük; geçiş yumuşak.
 */

@property --rail-drawer-shift-y {
    syntax: '<length>';
    inherits: true;
    initial-value: -2.25rem;
}

.uplife-contact-rail {
    --rail-pad: 6px;
    --rail-btn: 42px;
    /* Panel: sağdan “açık”; dar kart — tipografi panelde sıkı kalsın */
    --rail-panel-w: min(252px, calc(100vw - 4.25rem));
    --rail-drawer-shift-y: -2.25rem;
    /* Tawk minimized üstü — style.css #tawkchat-minimized ile uyumlu */
    --rail-tawk-bottom: 32px;
    --rail-tawk-minimized-h: 72px;
    --rail-tawk-gap: 14px;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    /* Kapalıyken sayfa katmanında; Tawk ile çakışmayı konumla yönet. Açık panel: .is-open ile Tawk üstüne çıkar */
    z-index: 1040;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-end;
    padding-top: 0;
    padding-bottom: calc(var(--rail-tawk-bottom) + var(--rail-tawk-minimized-h) + var(--rail-tawk-gap));
    pointer-events: none;
    font-family: 'Poppins', system-ui, sans-serif;
    transition:
        padding-top 0.62s cubic-bezier(0.22, 1, 0.36, 1),
        padding-bottom 0.62s cubic-bezier(0.22, 1, 0.36, 1),
        --rail-drawer-shift-y 0.62s cubic-bezier(0.22, 1, 0.36, 1);
}

/*
 * Tawk embed çoğu kurulumda z-index ~999999 kullanır; drawer aynı fixed rail içinde kaldığı için
 * rail 1040 iken panel her zaman balonun altında kalır. Sadece panel açıkken yükselt.
 * (Mobil tam ekran menü: html.uplife-nav-mobile-open — rail zaten gizli.)
 */
.uplife-contact-rail.is-open {
    z-index: 1200000;
}

/*
 * Laptop / masaüstü (≥768): hero slider görünürken dikey ray, sağdaki kartlar + Tawk ile çakışmasın.
 * Aşağı kaydırınca --in-hero kalkar (uplife-contact-rail.js) → ray tekrar görünür.
 */
@media (min-width: 768px) {
    .uplife-contact-rail {
        transition:
            opacity 0.38s ease,
            visibility 0.38s ease,
            padding-top 0.62s cubic-bezier(0.22, 1, 0.36, 1),
            padding-bottom 0.62s cubic-bezier(0.22, 1, 0.36, 1),
            --rail-drawer-shift-y 0.62s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .uplife-contact-rail.uplife-contact-rail--in-hero:not(.is-open) {
        opacity: 0;
        visibility: hidden;
    }

    .uplife-contact-rail.uplife-contact-rail--in-hero.is-open {
        opacity: 1;
        visibility: visible;
    }
}

/* Hero: alt bantta ama yeterince yukarı — slider dots / CTA / overlay ile aynı hizada kavga etmesin */
.uplife-contact-rail--in-hero {
    padding-bottom: clamp(11rem, 36vh, 19rem);
    padding-top: clamp(4.75rem, 14vh, 9rem);
    /* Açık panel, hero’daki alt kontrollerden kaçsın */
    --rail-drawer-shift-y: -4.25rem;
}

.uplife-contact-rail__inner {
    position: relative;
    pointer-events: auto;
    display: flex;
    align-items: center;
    /* Aşağı/Tawk: sağ kenara yakın; hero’da biraz daha içeride (slider-nav) */
    margin-right: 28px;
    transform: translateY(0);
    transition:
        margin-right 0.62s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.62s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Hero: sağ üst sosyal kartların altına çek — rayın üstü çakışmasın */
.uplife-contact-rail--in-hero .uplife-contact-rail__inner {
    margin-right: 38px;
    transform: translateY(2rem);
}

/* Kabuk: frosted beyaz — slider sosyal kartlarıyla aynı his, ağır lacivert şerit yok */
.uplife-contact-rail__shell {
    position: relative;
    z-index: 1;
    width: calc(var(--rail-btn) + var(--rail-pad) * 2);
    padding: var(--rail-pad);
    box-sizing: border-box;
    background: rgba(255, 255, 255, 0.94);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-radius: 10px;
    box-shadow:
        0 10px 36px color-mix(in srgb, var(--color-secondary) 11%, transparent),
        0 2px 10px rgba(0, 0, 0, 0.05);
    transition:
        box-shadow 0.35s ease,
        margin 0.35s ease;
}

.uplife-contact-rail--in-hero .uplife-contact-rail__shell {
    box-shadow:
        0 12px 40px color-mix(in srgb, var(--color-secondary) 13%, transparent),
        0 3px 12px rgba(0, 0, 0, 0.06);
}

.uplife-contact-rail__buttons {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
}

.uplife-contact-rail__btn {
    width: var(--rail-btn);
    height: var(--rail-btn);
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    background: var(--tertiary-color-low);
    color: var(--color-primary-dark);
    transition:
        background 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

.uplife-contact-rail__btn i {
    font-size: 0.9rem;
    line-height: 1;
}

a.uplife-contact-rail__btn--survey {
    text-decoration: none;
    color: inherit;
    box-sizing: border-box;
}

.uplife-contact-rail__btn--survey i {
    font-size: 0.88rem;
}

.uplife-contact-rail__btn .fa-brands {
    font-family: 'Font Awesome 6 Brands', sans-serif;
    font-weight: 400;
}

.uplife-contact-rail__btn .fa-brands.fa-whatsapp {
    color: #128c4b;
}

.uplife-contact-rail__btn:hover {
    background: color-mix(in srgb, var(--color-primary) 12%, transparent);
    color: var(--color-primary);
    transform: translateY(-1px);
}

.uplife-contact-rail__btn:focus-visible {
    outline: 2px solid var(--color-primary-light);
    outline-offset: 2px;
}

.uplife-contact-rail__btn.is-active {
    background: var(--color-primary);
    color: var(--text-light);
    box-shadow: 0 6px 20px color-mix(in srgb, var(--color-primary) 28%, transparent);
}

.uplife-contact-rail__btn.is-active .fa-brands.fa-whatsapp {
    color: #fff;
}

.uplife-contact-rail__drawer {
    position: absolute;
    z-index: 2;
    /* Shell’den belirgin boşluk: panel daha sola “oturur”, çakışma azalır */
    right: calc(100% + 28px);
    top: 50%;
    transform: translateY(calc(-50% + var(--rail-drawer-shift-y))) translateX(10px);
    width: var(--rail-panel-w);
    max-height: min(68vh, 468px);
    opacity: 0;
    visibility: hidden;
    transition:
        opacity 0.26s ease,
        visibility 0.26s ease,
        /* Hero ↔ Tawk konumu ile aynı tempoda (küçük translateX açılışı da yumuşak) */
        transform 0.58s cubic-bezier(0.22, 1, 0.36, 1);
}

.uplife-contact-rail.is-open .uplife-contact-rail__drawer {
    opacity: 1;
    visibility: visible;
    transform: translateY(calc(-50% + var(--rail-drawer-shift-y))) translateX(0);
}

.uplife-contact-rail__drawer-inner {
    background: var(--card-bg);
    border-radius: 8px;
    box-shadow:
        0 20px 48px color-mix(in srgb, var(--color-secondary) 12%, transparent),
        0 6px 18px rgba(0, 0, 0, 0.04);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    max-height: min(68vh, 468px);
}

.uplife-contact-rail__panel {
    display: none;
    flex-direction: column;
    max-height: min(68vh, 468px);
}

.uplife-contact-rail__panel.is-visible {
    display: flex;
}

.uplife-contact-rail__panel-head {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    padding: 0.65rem 0.75rem 0.55rem;
    flex-shrink: 0;
    background: var(--tertiary-color-low);
}

.uplife-contact-rail__panel-icon {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: color-mix(in srgb, var(--color-primary) 8%, transparent);
    color: var(--color-primary-dark);
}

.uplife-contact-rail__panel-icon i {
    font-size: 0.68rem;
    line-height: 1;
}

.uplife-contact-rail__panel-icon .fa-brands.fa-whatsapp {
    color: #25d366;
}

.uplife-contact-rail__panel-titles {
    min-width: 0;
    flex: 1;
}

.uplife-contact-rail__panel-title {
    margin: 0;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    color: var(--section-dark-bg);
    line-height: 1.25;
}

.uplife-contact-rail__panel-sub {
    margin: 0.1rem 0 0;
    font-size: 0.625rem;
    font-weight: 500;
    letter-spacing: 0.035em;
    text-transform: uppercase;
    color: var(--secondary-color-dark);
    line-height: 1.35;
}

.uplife-contact-rail__panel-close {
    margin: -3px -3px 0 0;
    width: 26px;
    height: 26px;
    border: none;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.85);
    color: var(--secondary-color-dark);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition:
        background 0.2s ease,
        color 0.2s ease;
}

.uplife-contact-rail__panel-close i {
    font-size: 0.62rem;
    line-height: 1;
}

.uplife-contact-rail__panel-close:hover {
    background: var(--tertiary-color);
    color: var(--text-dark);
}

.uplife-contact-rail__panel-close:focus-visible {
    outline: 2px solid var(--color-primary-light);
    outline-offset: 2px;
}

.uplife-contact-rail__panel-body {
    padding: 0.45rem 0.75rem 0.7rem;
    overflow-y: auto;
    flex: 1;
    -webkit-overflow-scrolling: touch;
}

.uplife-contact-rail__field {
    margin-bottom: 0.5rem;
}

.uplife-contact-rail__field:last-child {
    margin-bottom: 0;
}

.uplife-contact-rail__label {
    display: block;
    font-size: 0.6rem;
    font-weight: 600;
    color: var(--secondary-color-dark);
    margin-bottom: 0.22rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.uplife-contact-rail__input,
.uplife-contact-rail__textarea {
    width: 100%;
    box-sizing: border-box;
    border: none;
    border-radius: 6px;
    background: var(--tertiary-color);
    font: inherit;
    font-size: 0.8125rem;
    color: var(--text-dark);
    padding: 0.38rem 0.55rem;
    box-shadow: 0 1px 8px color-mix(in srgb, var(--color-secondary) 4%, transparent);
    outline: none;
    transition: box-shadow 0.2s ease;
}

.uplife-contact-rail__input:focus,
.uplife-contact-rail__textarea:focus {
    box-shadow: 0 4px 18px color-mix(in srgb, var(--color-primary) 12%, transparent);
}

.uplife-contact-rail__textarea {
    min-height: 70px;
    resize: vertical;
}

.uplife-contact-rail__submit {
    width: 100%;
    margin-top: 0.35rem;
    padding: 0.48rem 0.75rem;
    border: none;
    border-radius: 6px;
    font: inherit;
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
    background: var(--color-primary);
    color: var(--text-light);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    box-shadow: 0 6px 18px color-mix(in srgb, var(--color-primary) 26%, transparent);
    transition:
        transform 0.2s ease,
        box-shadow 0.2s ease,
        background 0.2s ease;
}

.uplife-contact-rail__submit i {
    font-size: 0.72rem;
    line-height: 1;
}

.uplife-contact-rail__submit:hover {
    transform: translateY(-1px);
    background: var(--color-primary-dark);
    box-shadow: 0 10px 26px color-mix(in srgb, var(--color-primary) 34%, transparent);
}

.uplife-contact-rail__submit .fa-brands.fa-whatsapp {
    color: #fff;
}

.uplife-contact-rail__phone-list {
    display: flex;
    flex-direction: column;
    gap: 0.38rem;
}

.uplife-contact-rail__phone-card {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.48rem 0.55rem;
    border-radius: 6px;
    background: var(--tertiary-color);
    box-shadow: 0 2px 10px color-mix(in srgb, var(--color-secondary) 5%, transparent);
    text-decoration: none;
    color: inherit;
    transition:
        background 0.2s ease,
        box-shadow 0.2s ease;
}

.uplife-contact-rail__phone-card:hover {
    background: color-mix(in srgb, var(--color-primary) 8%, transparent);
    box-shadow: 0 4px 14px color-mix(in srgb, var(--color-secondary) 7%, transparent);
}

.uplife-contact-rail__phone-card:focus-visible {
    outline: 2px solid var(--color-primary-light);
    outline-offset: 2px;
}

.uplife-contact-rail__phone-card i {
    color: var(--color-primary);
    font-size: 0.72rem;
    line-height: 1;
    width: 1.1rem;
    flex-shrink: 0;
    text-align: center;
}

.uplife-contact-rail__phone-meta {
    display: flex;
    flex-direction: column;
    gap: 0.08rem;
    min-width: 0;
}

.uplife-contact-rail__phone-label {
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--secondary-color-dark);
}

.uplife-contact-rail__phone-num {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-dark);
}

.uplife-contact-rail__addr-text {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--text-dark-low);
}

@media (prefers-reduced-motion: reduce) {
    .uplife-contact-rail,
    .uplife-contact-rail__inner,
    .uplife-contact-rail__shell,
    .uplife-contact-rail__drawer,
    .uplife-contact-rail__btn {
        transition: none;
    }
}

@media (max-width: 767px) {
    :root {
        /* Tawk / sayfa altı boşluk ile hizalı — kabuk padding + min buton + pay */
        --uplife-mobile-contact-bar-total: calc(72px + env(safe-area-inset-bottom, 0px));
    }

    /* Uygulama tarzı alt iletişim çubuğu */
    .uplife-contact-rail {
        top: auto;
        left: 0;
        right: 0;
        bottom: 0;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-end;
        padding: 0;
        z-index: 1040;
        transition:
            transform 0.32s cubic-bezier(0.4, 0, 0.2, 1),
            opacity 0.28s ease;
    }

    .uplife-contact-rail--in-hero {
        padding-top: 0;
        --rail-drawer-shift-y: 0;
    }

    .uplife-contact-rail--in-hero .uplife-contact-rail__inner {
        margin-right: 0;
        transform: none;
    }

    .uplife-contact-rail__inner {
        position: relative;
        width: 100%;
        max-width: 100%;
        margin-right: 0;
        transform: none;
    }

    .uplife-contact-rail__shell {
        width: 100%;
        max-width: none;
        padding: 10px 12px calc(12px + env(safe-area-inset-bottom, 0px));
        border-radius: 18px 18px 0 0;
        border: 1px solid color-mix(in srgb, var(--tertiary-color-dark) 75%, transparent);
        border-bottom: none;
        background: linear-gradient(
            180deg,
            rgba(255, 255, 255, 0.98) 0%,
            color-mix(in srgb, var(--card-bg) 92%, var(--tertiary-color) 8%) 100%
        );
        box-shadow:
            0 -10px 40px color-mix(in srgb, var(--color-secondary) 14%, transparent),
            0 1px 0 rgba(255, 255, 255, 0.88) inset;
    }

    .uplife-contact-rail--in-hero .uplife-contact-rail__shell {
        box-shadow:
            0 -10px 40px color-mix(in srgb, var(--color-secondary) 14%, transparent),
            0 1px 0 rgba(255, 255, 255, 0.88) inset;
    }

    .uplife-contact-rail__buttons {
        flex-direction: row;
        align-items: stretch;
        justify-content: stretch;
        gap: 6px;
        width: 100%;
    }

    .uplife-contact-rail__btn {
        flex: 1 1 0;
        min-width: 0;
        width: auto;
        height: auto;
        min-height: 48px;
        border-radius: 11px;
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
    }

    .uplife-contact-rail__btn i {
        font-size: 1.08rem;
    }

    .uplife-contact-rail__btn:active {
        transform: scale(0.96);
    }

    /* Panel: barın hemen üstünde bottom-sheet */
    .uplife-contact-rail__drawer {
        position: absolute;
        right: auto;
        left: 8px;
        width: calc(100% - 16px);
        top: auto;
        bottom: 100%;
        margin-bottom: 8px;
        max-height: min(56vh, 400px);
        transform: translateY(12px) scale(0.98);
        transform-origin: bottom center;
    }

    .uplife-contact-rail.is-open .uplife-contact-rail__drawer {
        transform: translateY(0) scale(1);
    }

    .uplife-contact-rail__drawer-inner {
        border-radius: 14px;
        max-height: min(56vh, 400px);
        box-shadow:
            0 12px 40px color-mix(in srgb, var(--color-secondary) 14%, transparent),
            0 2px 12px rgba(0, 0, 0, 0.06);
    }

    /* Tam ekran mobil menü açıkken çubuğu gizle */
    html.uplife-nav-mobile-open .uplife-contact-rail {
        transform: translateY(110%);
        opacity: 0;
        pointer-events: none;
    }
}

@media (max-width: 767px) and (prefers-reduced-motion: reduce) {
    .uplife-contact-rail,
    .uplife-contact-rail__drawer,
    .uplife-contact-rail__btn {
        transition: none;
    }

    .uplife-contact-rail__btn:active {
        transform: none;
    }
}
