/* =====================================================================
   Entrance
   ===================================================================== */

body.kiosk-locked,
body.kiosk-locked #bodyContent-wrapper {
    overflow: hidden;
}

body.kiosk-locked {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    background: var(--kiosk-bg);
    color: var(--kiosk-text);
}

body {
    background: var(--kiosk-bg);
    color: var(--kiosk-text);
}

.preloader { display: none !important; }

.kiosk-pre .experience__video-stack .experience__video,
.kiosk-pre .experience__video,
.kiosk-pre .experience__veil,
.kiosk-pre .experience__loader-emblem,
.kiosk-pre .experience__loader-number,
.kiosk-pre .experience__loader-label,
.kiosk-pre .experience__hero-eyebrow,
.kiosk-pre .experience__hero-title,
.kiosk-pre .experience__hero-subtitle,
.kiosk-pre .experience__hero-hint,
.kiosk-pre .experience__hero-arc {
    opacity: 0 !important;
}

.kiosk-pre .experience__loader-edge-fill { width: 0 !important; }


/* =====================================================================
   Experience
   ===================================================================== */

.experience {
    position: fixed;
    inset: 0;
    z-index: 50;
    background: var(--kiosk-bg);
    color: var(--kiosk-text);
    font-family: var(--font-immersive);
    overflow: hidden;
    isolation: isolate;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

.experience .experience__video-stack {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background: #000;
    isolation: isolate;
}

.experience .experience__video-stack .experience__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 58%;
    pointer-events: none;
    transform: translateZ(0);
    mix-blend-mode: normal;
    backface-visibility: hidden;
}

.experience .experience__video-stack .experience__video--loop {
    z-index: 0;
    opacity: 0;
}

.experience .experience__video-stack .experience__video--entrance {
    z-index: 1;
    opacity: 0;
}

.experience .experience__veil {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    opacity: 0;
    background:
        radial-gradient(ellipse 70% 90% at 50% 55%,
            transparent 0%,
            rgba(0, 0, 0, 0.35) 60%,
            rgba(0, 0, 0, 0.85) 100%),
        linear-gradient(to bottom,
            rgba(0, 0, 0, 0.6) 0%,
            rgba(0, 0, 0, 0.0) 28%,
            rgba(0, 0, 0, 0.0) 70%,
            rgba(0, 0, 0, 0.65) 100%);
    will-change: opacity;
}


/* =====================================================================
   Loader
   ===================================================================== */

.experience .experience__loader {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: grid;
    place-items: center;
    will-change: opacity, transform, filter;
}

.experience .experience__loader::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background: var(--kiosk-bg);
}

.experience .experience__loader-meter {
    position: relative;
    display: grid;
    place-items: center;
    --meter: 0;
}

.experience .experience__loader-meter > .experience__loader-emblem,
.experience .experience__loader-meter > .experience__loader-number {
    grid-row: 1;
    grid-column: 1;
}

.experience .experience__loader-meter > .experience__loader-emblem {
    z-index: 0;
}

.experience .experience__loader-meter > .experience__loader-number {
    position: relative;
    z-index: 1;
}

.experience .experience__loader-emblem {
    width: clamp(220px, min(90vmin, 92vw), 520px);
    max-width: 100%;
    margin: 0;
    aspect-ratio: 1;
    pointer-events: none;
    will-change: opacity, transform, filter;
}

.experience .experience__loader-emblem-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    opacity: calc(0.14 + var(--meter) * 0.82);
    filter:
        brightness(1.34)
        contrast(1.1)
        saturate(1.06)
        drop-shadow(0 0 44px rgba(0, 0, 0, 0.5))
        drop-shadow(0 0 26px rgba(72, 74, 80, 0.38))
        drop-shadow(0 0 1px rgba(255, 255, 255, 0.14));
}

/* =====================================================================
   Loader — %100 mikro nabız
   ===================================================================== */

.experience .experience__loader--peak .experience__loader-emblem {
    transform-origin: 50% 50%;
    animation: kiosk-loader-peak-emblem 0.74s forwards;
}

.experience .experience__loader--peak .experience__loader-number {
    transform-origin: 50% 55%;
    animation: kiosk-loader-peak-digits 0.74s forwards;
}

@keyframes kiosk-loader-peak-emblem {
    0% {
        transform: translateZ(0) scale(1);
        animation-timing-function: cubic-bezier(0.45, 0.02, 0.25, 1);
    }

    42% {
        transform: translateZ(0) scale(1.038);
        animation-timing-function: cubic-bezier(0.2, 0.85, 0.24, 1);
    }

    100% {
        transform: translateZ(0) scale(1);
    }
}

@keyframes kiosk-loader-peak-digits {
    0% {
        transform: translateZ(0) scale(1);
        animation-timing-function: cubic-bezier(0.45, 0.02, 0.25, 1);
        text-shadow:
            0 0 60px rgba(0, 0, 0, 0.45),
            0 0 24px rgba(90, 92, 98, 0.22);
    }

    44% {
        transform: translateZ(0) scale(1.022);
        animation-timing-function: cubic-bezier(0.2, 0.85, 0.24, 1);
        text-shadow:
            0 0 72px rgba(255, 255, 255, 0.09),
            0 0 64px rgba(0, 0, 0, 0.42),
            0 0 26px rgba(255, 115, 72, 0.1);
    }

    100% {
        transform: translateZ(0) scale(1);
        text-shadow:
            0 0 60px rgba(0, 0, 0, 0.45),
            0 0 24px rgba(90, 92, 98, 0.22);
    }
}

.experience .experience__loader-edge {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    z-index: 2;
    background: rgba(255, 255, 255, 0.06);
    overflow: hidden;
}

.experience .experience__loader-edge-fill {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0%;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.6) 30%,
        var(--ember) 80%,
        var(--ember-warm) 100%);
    box-shadow: 0 0 12px rgba(255, 90, 28, 0.4);
    will-change: width;
}

.experience .experience__loader-stack {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.6rem;
    text-align: center;
}

.experience .experience__loader-number {
    display: inline-flex;
    align-items: baseline;
    font-family: var(--font-immersive);
    font-weight: 700;
    font-size: clamp(7rem, 16vw, 14rem);
    line-height: 0.9;
    letter-spacing: -0.04em;
    color: var(--kiosk-text);
    text-shadow:
        0 0 60px rgba(0, 0, 0, 0.45),
        0 0 24px rgba(90, 92, 98, 0.22);
    font-variant-numeric: tabular-nums;
}

.experience .experience__loader-digit {
    display: inline-block;
    transition: color 0.5s ease, opacity 0.5s ease;
}

.experience .experience__loader-digit[data-d="h"] {
    color: rgba(255, 255, 255, 0.16);
}

.experience .experience__loader-number.is-three .experience__loader-digit[data-d="h"] {
    color: var(--kiosk-text);
}

.experience .experience__loader-label {
    font-family: var(--font-immersive);
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.55em;
    text-transform: uppercase;
    color: var(--kiosk-text-faint);
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.6);
    margin-top: 0;
}


/* =====================================================================
   Hero
   ===================================================================== */

.experience .experience__hero {
    position: absolute;
    inset: 0;
    z-index: 4;
    display: grid;
    grid-template-rows: auto 1fr auto;
    padding:
        clamp(7vh, 11vh, 14vh)
        clamp(1.6rem, 4vw, 3rem)
        clamp(4vh, 6vh, 7vh);
    align-items: center;
    justify-items: center;
    text-align: center;
    pointer-events: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    /* Konteyner üstünden mesafe — küçük = yay daha yukarı (subtitle’den uzak) */
    --hero-arc-offset-top: 22px;
}

.experience .experience__hero ::selection {
    background: transparent;
}

.experience .experience__hero-hint {
    grid-row: 3;
    align-self: end;
    justify-self: center;
    margin: 0;
    max-width: min(440px, 90vw);
    padding: 0 0.5rem;
    box-sizing: border-box;
    font-family: var(--font-immersive);
    font-size: clamp(0.6rem, 1.05vmin, 0.74rem);
    font-weight: 500;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: #ffffff;
    line-height: 1.5;
    text-wrap: balance;
    /* Güçlü shadow stack — videoda parlak alan üstünde bile okunabilirlik */
    text-shadow:
        0 1px 4px rgba(0, 0, 0, 0.95),
        0 2px 12px rgba(0, 0, 0, 0.75),
        0 0 28px rgba(0, 0, 0, 0.55);
    pointer-events: none;
    z-index: 5;
    will-change: opacity, transform;
}

.experience .experience__hero-text {
    grid-row: 1;
    display: grid;
    place-items: center;
    gap: 0.65rem;
    max-width: min(900px, 86vw);
    position: relative;
    z-index: 10;
    /* Başlık kutusu hit-test’i yutmasın; kaydırma tüm sahneye yayılsın */
    pointer-events: none;
}

.experience .experience__hero-text * {
    pointer-events: none;
}

.experience .experience__hero-eyebrow {
    font-family: var(--font-immersive);
    font-size: 0.66rem;
    font-weight: 600;
    letter-spacing: 0.48em;
    text-transform: uppercase;
    color: var(--kiosk-text-dim);
    line-height: 1;
    text-shadow:
        0 1px 4px rgba(0, 0, 0, 0.85),
        0 0 24px rgba(0, 0, 0, 0.45);
    will-change: opacity, transform;
}

.experience .experience__hero-title {
    font-family: var(--font-immersive);
    font-size: clamp(3.4rem, 7.2vw, 6.4rem);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.035em;
    color: var(--kiosk-text);
    margin: 0;
    text-shadow: 0 1px 30px rgba(0, 0, 0, 0.55);
    will-change: opacity, transform, filter;
}

.experience .experience__hero-subtitle {
    font-family: var(--font-immersive);
    font-size: clamp(0.92rem, 1.15vw, 1.05rem);
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.005em;
    color: var(--kiosk-text-dim);
    text-shadow:
        0 1px 6px rgba(0, 0, 0, 0.85),
        0 0 28px rgba(0, 0, 0, 0.55);
    max-width: 38ch;
    margin: 0.35rem auto 0;
    text-wrap: pretty;
    will-change: opacity, transform;
}


/* =====================================================================
   Hero arc gate (kiosk swipe)
   ===================================================================== */

.experience .experience__hero-arc {
    position: absolute;
    inset: 0;
    z-index: 6;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: var(--hero-arc-offset-top, 50px);
    padding-bottom: 0;
    box-sizing: border-box;
    /* Tam yüzey: SVG’nin altı/yanları da süpürme alsın */
    pointer-events: auto;
    touch-action: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    -webkit-touch-callout: none;
}

.experience .experience__hero-arc__svg {
    display: block;
    position: relative;
    width: 100%;
    max-width: 100%;
    height: auto;
    aspect-ratio: 1908 / 899;
    max-height: min(96vh, 920px);
    overflow: visible;
    /* none: bazı motorlarda alt grafiklere stroke hit hiç düşmüyor; track/meteor yine none */
    pointer-events: auto;
    touch-action: none;
    transform: translateY(-12px) translateZ(0);
    shape-rendering: auto;
    image-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
}

/* Path / textPath — sürüklerken metin veya kontur seçiminin yayı engellemesi */
.experience .experience__hero-arc__svg * {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    -webkit-touch-callout: none;
}

.experience .experience__hero-arc__track,
.experience .experience__hero-arc__meteor,
.experience .experience__hero-arc__hit {
    pointer-events: none;
}

.experience .experience__hero-arc__track {
    fill: none;
    stroke: rgba(255, 255, 255, 0.17);
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
    /* dash animasyonu GSAP inline style ile; attr+CSS çakışmasın */
}

/* Çizim öncesi: tamamen gizli → GSAP ile 100→0 smooth açılış */
.experience .experience__hero-arc:not(.experience__hero-arc--drawn) .experience__hero-arc__track {
    stroke-dasharray: 100;
    stroke-dashoffset: 100;
}

/* Çizim bitti: tam ince çizgi */
.experience .experience__hero-arc--drawn .experience__hero-arc__track {
    stroke-dasharray: none;
    stroke-dashoffset: 0;
}

/* Uç yumuşatma lekeleri: sadece path köşe bölgeleri, hit’e dokunmaz */
.experience .experience__hero-arc__corner-fade {
    pointer-events: none;
}

/* Tek meteor — stroke/dash animasyonu path-shimmer.css */
.experience .experience__hero-arc__meteor {
    fill: none;
    stroke: url("#experienceArcMeteorGrad");
    stroke-width: 1.65;
    filter: url("#experienceArcShimmerFilter");
    opacity: 0;
    visibility: hidden;
    animation: none;
}

/* Çizgi hazır ama ışıma henüz yok (tek karede sadece track + metin) */
.experience
    .experience__hero-arc--drawn:not(.experience__hero-arc--meteor-live)
    .experience__hero-arc__meteor {
    opacity: 0;
    visibility: hidden;
    animation: none !important;
}

/* Çizim + meteor: süpürme + opaklık path-shimmer--loop + --reveal */
.experience .experience__hero-arc--meteor-live .experience__hero-arc__meteor {
    opacity: 0;
    visibility: visible;
}

.experience .experience__hero-arc__hit {
    pointer-events: stroke;
    stroke: transparent;
    stroke-width: 48;
    stroke-linecap: round;
    stroke-linejoin: round;
    vector-effect: non-scaling-stroke;
    cursor: grab;
}

/* Kiosk: tıklama/odak turuncu çerçeve gösterme (scroll seçimde rahatsız ediyor) */
.experience .experience__hero-arc:focus,
.experience .experience__hero-arc:focus-visible,
.experience .experience__hero-arc:focus-within .experience__hero-arc__svg {
    outline: none;
    box-shadow: none;
}

.experience .experience__hero-arc:focus-visible .experience__hero-arc__svg {
    border-radius: 0;
}

.experience .experience__hero-arc--dragging .experience__hero-arc__hit {
    cursor: grabbing;
}

.experience .experience__hero-arc--busy .experience__hero-arc__meteor {
    animation: none;
    stroke-dasharray: 100 0;
    stroke-dashoffset: 0;
    opacity: 0.5;
    filter: url("#experienceArcShimmerFilter");
}

.experience .experience__hero-arc--busy {
    pointer-events: none !important;
}

.experience .experience__hero-arc__label {
    font-family: var(--font-immersive);
    font-size: clamp(7px, 1.15vmin, 10px);
    font-weight: 600;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    fill: rgba(255, 255, 255, 0.4);
    pointer-events: none;
    -webkit-user-select: none;
    user-select: none;
    text-rendering: geometricPrecision;
    opacity: 0;
}

.experience .experience__hero-arc--drawn .experience__hero-arc__label {
    opacity: 1;
}


/* =====================================================================
   Smoke
   ===================================================================== */

@keyframes kiosk-smoke-drift-a {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50%      { transform: translate(2%, -2%) scale(1.04); }
}

@keyframes kiosk-smoke-drift-b {
    0%, 100% { transform: translate(0, 0) scale(1.02); }
    50%      { transform: translate(-2%, 2%) scale(1); }
}

.smoke {
    position: fixed;
    inset: 0;
    z-index: 9999;
    pointer-events: none;
    opacity: 0;
    will-change: opacity;
    isolation: isolate;
    contain: layout style paint;
    transform: translateZ(0);
}

.smoke .smoke__frost {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: 0;
    background: radial-gradient(
        ellipse 100% 80% at 50% 45%,
        rgba(10, 10, 12, 0.22) 0%,
        rgba(8, 8, 10, 0.38) 100%
    );
}

.smoke .smoke__layer {
    position: absolute;
    inset: -10%;
    z-index: 1;
    will-change: transform;
    transform: translate3d(0, 0, 0);
    backface-visibility: hidden;
}

.smoke .smoke__layer--2 {
    z-index: 2;
}

.smoke .smoke__layer--3 {
    z-index: 3;
}

.smoke .smoke__blackout {
    position: absolute;
    inset: 0;
    z-index: 8;
    pointer-events: none;
    opacity: 0;
    background: #000;
}

.smoke .smoke__grain {
    position: absolute;
    inset: 0;
    z-index: 9;
    pointer-events: none;
    opacity: 0;
    background-image:
        repeating-linear-gradient(
            -12deg,
            transparent 0,
            transparent 98px,
            rgba(255, 255, 255, 0.02) 98px,
            rgba(255, 255, 255, 0.02) 100px
        ),
        radial-gradient(circle at 20% 30%, transparent 55%, rgba(0, 0, 0, 0.04) 100%),
        radial-gradient(circle at 80% 70%, transparent 52%, rgba(255, 255, 255, 0.02) 100%);
    mix-blend-mode: soft-light;
}

.smoke .smoke__layer--1 {
    background:
        radial-gradient(ellipse 70% 60% at 50% 50%,
            rgba(0, 0, 0, 0.92) 0%,
            rgba(0, 0, 0, 0.62) 44%,
            rgba(0, 0, 0, 0) 78%),
        radial-gradient(ellipse 80% 90% at 30% 60%,
            rgba(18, 18, 18, 0.5) 0%,
            transparent 72%);
    animation: kiosk-smoke-drift-a 18s ease-in-out infinite;
}

.smoke .smoke__layer--2 {
    background:
        radial-gradient(ellipse 62% 70% at 70% 40%,
            rgba(12, 12, 12, 0.78) 0%,
            transparent 66%),
        radial-gradient(ellipse 82% 50% at 30% 80%,
            rgba(8, 8, 8, 0.58) 0%,
            transparent 72%);
    animation: kiosk-smoke-drift-b 24s ease-in-out infinite reverse;
}

.smoke .smoke__layer--3 {
    background:
        linear-gradient(
            180deg,
            rgba(0, 0, 0, 0.48) 0%,
            rgba(0, 0, 0, 0) 34%,
            rgba(0, 0, 0, 0) 66%,
            rgba(0, 0, 0, 0.58) 100%
        );
}

.smoke.smoke--wiping .smoke__layer {
    animation: none !important;
}


/* =====================================================================
   Reduced motion
   ===================================================================== */

@media (prefers-reduced-motion: reduce) {
    .kiosk-pre .experience__video-stack .experience__video,
    .kiosk-pre .experience__video,
    .kiosk-pre .experience__veil,
    .kiosk-pre .experience__loader-emblem,
    .kiosk-pre .experience__loader-number,
    .kiosk-pre .experience__loader-label,
    .kiosk-pre .experience__hero-eyebrow,
    .kiosk-pre .experience__hero-title,
    .kiosk-pre .experience__hero-subtitle,
    .kiosk-pre .experience__hero-hint,
    .kiosk-pre .experience__hero-arc {
        opacity: 1 !important;
    }

    .experience .experience__loader,
    .experience .experience__loader-stack,
    .experience .experience__loader-emblem,
    .experience .experience__hero-text > *,
    .experience .experience__hero-hint,
    .experience .experience__hero-arc,
    .experience .experience__video-stack .experience__video,
    .experience .experience__video,
    .experience .experience__veil {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }

    .smoke .smoke__layer { animation: none !important; }

    .smoke .smoke__frost {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        background: rgba(4, 4, 6, 0.92) !important;
        opacity: 1 !important;
    }

    .smoke .smoke__grain { opacity: 0 !important; }

    .experience .experience__hero-arc__track {
        stroke-dasharray: none !important;
        stroke-dashoffset: 0 !important;
    }

    .experience .experience__hero-arc__corner-fade {
        opacity: 0 !important;
    }

    .experience .experience__hero-arc__label {
        opacity: 1 !important;
    }

    .experience .experience__hero-arc__meteor {
        animation: none !important;
        stroke-dasharray: 100 0 !important;
        stroke-dashoffset: 0 !important;
        opacity: 0.78 !important;
        filter: none !important;
    }

    .smoke .smoke__blackout {
        backdrop-filter: none !important;
        background: #000 !important;
    }

    .experience .experience__loader--peak .experience__loader-emblem,
    .experience .experience__loader--peak .experience__loader-number {
        animation: none !important;
        transform: none !important;
    }
}


/* =====================================================================
   Responsive
   ===================================================================== */

@media (max-width: 900px) {
    .experience .experience__loader-emblem { width: clamp(200px, min(88vmin, 94vw), 380px); }
    .experience .experience__loader-number { font-size: clamp(6rem, 22vw, 9rem); }
    .experience .experience__loader-label  { font-size: 0.58rem; letter-spacing: 0.45em; }

    .experience .experience__hero {
        padding: 10vh 1.4rem 5vh;
        --hero-arc-offset-top: clamp(16px, 3.5vh, 28px);
    }

    .experience .experience__hero-eyebrow { font-size: 0.6rem; letter-spacing: 0.4em; }
    .experience .experience__hero-title   { font-size: clamp(2.6rem, 9vw, 4rem); }
    .experience .experience__hero-subtitle { font-size: 0.92rem; max-width: 32ch; }

    .experience .experience__hero-arc__svg {
        max-height: min(94vh, 880px);
        transform: translateY(-10px) translateZ(0);
    }
}

@media (max-width: 560px) {
    .experience .experience__loader-emblem { width: clamp(180px, min(85vmin, 96vw), 300px); }

    .experience .experience__hero {
        padding: 9vh 1.2rem 4.5vh;
        --hero-arc-offset-top: clamp(14px, 3.2vh, 24px);
    }

    .experience .experience__hero-title { font-size: clamp(2.4rem, 11vw, 3.4rem); }
    .experience .experience__hero-subtitle { display: none; }

    .experience .experience__hero-hint {
        letter-spacing: 0.2em;
        font-size: clamp(0.56rem, 2.6vw, 0.66rem);
        padding-inline: 1.15rem;
    }

    .experience .experience__hero-arc__svg {
        max-height: min(92vh, 820px);
        transform: translateY(-8px) translateZ(0);
    }
}
