/**
 * Langoo mobil kabuk — geçişler, kart cilası, güvenli alan.
 * Tema (mobil_tema/style.css) ile uyumlu; prefers-reduced-motion ve profil tercihi saygılı.
 */

:root {
    --langoo-mobil-ease: cubic-bezier(0.22, 1, 0.36, 1);
    --langoo-mobil-blur: 12px;
}

/* Sayfa girişi */
.langoo-mobil-main {
    animation: langooMobilMainIn 0.42s var(--langoo-mobil-ease) both;
}

@keyframes langooMobilMainIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Flash bildirimi */
.langoo-mobil-flash {
    animation: langooFlashPop 0.5s var(--langoo-mobil-ease) both;
}

@keyframes langooFlashPop {
    from {
        opacity: 0;
        transform: scale(0.98) translateY(-6px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* Üst bar hafif parlama */
.langoo-mobil-topbar {
    box-shadow: 0 4px 24px rgba(99, 102, 241, 0.18);
}

/* Bootstrap kartları — tema ile uyum */
.langoo-mobil-app .card-elevated {
    border-radius: 1.25rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow:
        0 4px 24px rgba(15, 23, 42, 0.06),
        0 0 0 1px rgba(99, 102, 241, 0.06);
    transition:
        transform 0.25s var(--langoo-mobil-ease),
        box-shadow 0.25s var(--langoo-mobil-ease);
}

.dark .langoo-mobil-app .card-elevated,
html.dark .langoo-mobil-app .card-elevated {
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
}

@media (hover: hover) {
    .langoo-mobil-app .card-elevated:hover {
        transform: translateY(-2px);
        box-shadow:
            0 12px 40px rgba(99, 102, 241, 0.12),
            0 0 0 1px rgba(99, 102, 241, 0.1);
    }
}

/* Butonlar — dokunma geri bildirimi */
.langoo-mobil-app .btn {
    transition:
        transform 0.15s ease,
        box-shadow 0.2s ease;
}

.langoo-mobil-app .btn:active {
    transform: scale(0.98);
}

.langoo-mobil-app .btn-primary,
.langoo-mobil-app .btn-outline-primary {
    box-shadow: 0 2px 12px rgba(99, 102, 241, 0.25);
}

/* İstatistik / rozet ızgarası — mobilde daha sıkı */
.langoo-mobil-app .row.g-3 {
    --bs-gutter-y: 0.75rem;
}

.langoo-mobil-app h1.h3,
.langoo-mobil-app .h3 {
    letter-spacing: -0.02em;
}

/* Alt sekme alanı — güvenli bölge */
.langoo-mobil-app .fixed.bottom-0 {
    padding-bottom: max(0.75rem, env(safe-area-inset-bottom));
}

.langoo-mobil-app .fixed.bottom-0 a:active {
    transform: scale(0.94);
}

/* Scroll sırasında içerik ortaya çıksın */
.langoo-mobil-reveal {
    opacity: 0;
    transform: translateY(12px);
    transition:
        opacity 0.5s var(--langoo-mobil-ease),
        transform 0.5s var(--langoo-mobil-ease);
}

.langoo-mobil-reveal.langoo-mobil-reveal--in {
    opacity: 1;
    transform: translateY(0);
}

/* Hareketi azalt */
@media (prefers-reduced-motion: reduce) {
    .langoo-mobil-main,
    .langoo-mobil-flash,
    .langoo-mobil-app .card-elevated,
    .langoo-mobil-app .btn {
        animation: none !important;
        transition: none !important;
    }

    .langoo-mobil-reveal {
        opacity: 1;
        transform: none;
    }
}

body[data-reduced-motion="1"] .langoo-mobil-main,
body[data-reduced-motion="1"] .langoo-mobil-flash,
body[data-reduced-motion="1"] .langoo-mobil-app .card-elevated {
    animation: none !important;
}

body[data-reduced-motion="1"] .langoo-mobil-reveal {
    opacity: 1;
    transform: none;
}

/* Auth sayfaları (layout_auth) */
.langoo-mobil-auth-page {
    animation: langooMobilAuthIn 0.5s var(--langoo-mobil-ease) both;
}

@keyframes langooMobilAuthIn {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .langoo-mobil-auth-page {
        animation: none;
    }
}

/* Ana sayfa / kütüphane kartları (Tailwind) */
.langoo-mobil-home-card {
    transition:
        transform 0.22s var(--langoo-mobil-ease),
        box-shadow 0.22s ease;
}

.langoo-mobil-home-card:active {
    transform: scale(0.98);
}

/* Splash logo */
.langoo-splash-logo {
    animation: langooSplashPulse 2.8s ease-in-out infinite;
}

@keyframes langooSplashPulse {
    0%,
    100% {
        transform: scale(1);
        filter: drop-shadow(0 8px 24px rgba(99, 102, 241, 0.35));
    }
    50% {
        transform: scale(1.05);
        filter: drop-shadow(0 12px 32px rgba(99, 102, 241, 0.5));
    }
}

@media (prefers-reduced-motion: reduce) {
    .langoo-splash-logo {
        animation: none;
    }
}

body[data-reduced-motion="1"] .langoo-splash-logo {
    animation: none;
}
