/* Android / touch controls + rotate-to-landscape prompt */

.mobile-orientation {
    position: fixed;
    inset: 0;
    z-index: 200000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 2rem;
    box-sizing: border-box;
    text-align: center;
    background: rgba(0, 0, 0, 0.92);
    color: #fff;
    font-family: var(--gta-menu-font, 'Arial Narrow', Arial, sans-serif);
}

.mobile-orientation[hidden] {
    display: none !important;
}

.mobile-orientation__art {
    width: min(72vw, 280px);
    max-height: 28vh;
    object-fit: cover;
    border-radius: 8px;
    border: 2px solid rgba(232, 197, 71, 0.45);
    opacity: 0.85;
}

.mobile-orientation__icon {
    width: 88px;
    height: 88px;
    border: 3px solid var(--gta-gold, #e8c547);
    border-radius: 12px;
    position: relative;
    animation: mobile-rotate-hint 2.2s ease-in-out infinite;
}

.mobile-orientation__icon::before {
    content: '';
    position: absolute;
    inset: 14px 22px;
    border-radius: 4px;
    background: linear-gradient(180deg, rgba(232, 197, 71, 0.35), rgba(232, 197, 71, 0.08));
}

.mobile-orientation__title {
    margin: 0;
    font-size: clamp(1.2rem, 4vw, 1.6rem);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-shadow: 2px 2px 0 #000;
    color: var(--gta-gold, #e8c547);
}

.mobile-orientation__text {
    margin: 0;
    max-width: 20rem;
    font-size: 0.92rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.78);
    text-shadow: 1px 1px 0 #000;
}

@keyframes mobile-rotate-hint {
    0%, 100% { transform: rotate(0deg); }
    40% { transform: rotate(-90deg); }
    60% { transform: rotate(-90deg); }
}

.mobile-controls {
    position: fixed;
    inset: 0;
    z-index: 45000;
    pointer-events: none;
}

.mobile-controls[hidden] {
    display: none !important;
}

.mobile-controls.is-active {
    pointer-events: auto;
}

.mobile-controls.is-active .mobile-joy-base,
.mobile-controls.is-active .mobile-btn,
.mobile-controls.is-active .mobile-arrow,
.mobile-controls.is-active .mobile-look-zone {
    pointer-events: auto;
}

.mobile-controls-hint {
    position: fixed;
    top: auto;
    bottom: max(4.5rem, calc(env(safe-area-inset-bottom, 0px) + 3.5rem));
    left: 50%;
    transform: translateX(-50%);
    z-index: 43800;
    max-width: min(92vw, 22rem);
    padding: 0.65rem 0.9rem;
    border: 1px solid rgba(232, 197, 71, 0.45);
    background: rgba(0, 0, 0, 0.72);
    font-family: var(--gta-menu-font, 'Arial Narrow', Arial, sans-serif);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-align: center;
    color: rgba(255, 255, 255, 0.88);
    text-shadow: 1px 1px 0 #000;
    opacity: 0;
    transition: opacity 0.35s ease;
    pointer-events: none;
}

.mobile-controls-hint.is-visible {
    opacity: 1;
}

.mobile-joy-base {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 128px;
    height: 128px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.22);
    background: rgba(0, 0, 0, 0.35);
    touch-action: none;
}

.mobile-joy-knob {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 54px;
    height: 54px;
    margin: -27px 0 0 -27px;
    border-radius: 50%;
    border: 2px solid rgba(232, 197, 71, 0.65);
    background: rgba(232, 197, 71, 0.28);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.45);
    pointer-events: none;
    transition: transform 0.05s linear;
}

.mobile-look-zone {
    position: absolute;
    right: 0;
    top: 0;
    width: 48%;
    bottom: 0;
    touch-action: none;
}

.mobile-walk-controls {
    position: absolute;
    left: max(1rem, env(safe-area-inset-left, 0px));
    bottom: max(1rem, env(safe-area-inset-bottom, 0px));
}

.mobile-drive-pad {
    position: absolute;
    left: max(1rem, env(safe-area-inset-left, 0px));
    bottom: max(1rem, env(safe-area-inset-bottom, 0px));
    width: 148px;
    height: 148px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, 1fr);
    gap: 0.35rem;
}

.mobile-drive-pad[hidden] {
    display: none !important;
}

.mobile-arrow {
    min-width: 0;
    min-height: 0;
    border: 2px solid rgba(255, 255, 255, 0.28);
    border-radius: 10px;
    background: rgba(0, 0, 0, 0.48);
    color: #fff;
    font-size: 1.15rem;
    font-weight: 700;
    text-shadow: 1px 1px 0 #000;
    touch-action: manipulation;
    user-select: none;
    -webkit-user-select: none;
}

.mobile-arrow--up { grid-column: 2; grid-row: 1; }
.mobile-arrow--left { grid-column: 1; grid-row: 2; }
.mobile-arrow--right { grid-column: 3; grid-row: 2; }
.mobile-arrow--down { grid-column: 2; grid-row: 3; }

.mobile-arrow:active,
.mobile-arrow.is-held {
    border-color: var(--gta-gold, #e8c547);
    background: rgba(232, 197, 71, 0.28);
}

.mobile-actions {
    position: absolute;
    right: max(0.75rem, env(safe-area-inset-right, 0px));
    bottom: max(0.75rem, env(safe-area-inset-bottom, 0px));
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.45rem;
    width: min(42vw, 210px);
}

.mobile-btn {
    min-height: 2.65rem;
    padding: 0.35rem 0.25rem;
    border: 2px solid rgba(255, 255, 255, 0.28);
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.48);
    color: #fff;
    font-family: var(--gta-menu-font, 'Arial Narrow', Arial, sans-serif);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-shadow: 1px 1px 0 #000;
    touch-action: manipulation;
    user-select: none;
    -webkit-user-select: none;
}

.mobile-btn:active,
.mobile-btn.is-held {
    border-color: var(--gta-gold, #e8c547);
    background: rgba(232, 197, 71, 0.28);
}

@media (min-width: 900px) and (pointer: fine) {
    .mobile-orientation,
    .mobile-controls,
    .mobile-controls-hint {
        display: none !important;
    }

    .gta-panel-note--mobile-only {
        display: none;
    }
}

@media (max-width: 899px), (pointer: coarse) {
    .gta-panel-note--mobile-only {
        display: block;
        border-left-color: var(--gta-gold, #e8c547);
    }
}
