@media (max-width: 920px) and (orientation: landscape) {

    html,
    body {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }

    #game-logs {
        display: none !important;
    }

    #game-screen {
        padding: 0.3rem;
        gap: 0.3rem;
        overflow-x: hidden;
        width: 100%;
        max-width: 100vw;
        margin: 0;
    }

    .game-header {
        width: 100%;
        padding: 0.5rem 0.8rem;
        margin: 0;
        border-radius: 0.8rem;
    }

    .game-board {
        grid-template-areas:
            ". top ."
            "left center right"
            ". bottom .";
        grid-template-columns: 180px 1fr 180px;
        grid-template-rows: auto 1fr auto;
        gap: 0.3rem;
        height: auto;
        min-height: 100vh;
        padding: 5px;
        overflow-x: hidden;
        max-width: 100vw;
        width: 100%;
        margin: 0;
    }

    .opponent-slot {
        align-items: center !important;
    }

    .opponent-slot.top {
        align-items: flex-end !important;
    }

    .opponent-slot.left .player-card {
        transform: rotate(90deg);
    }

    .opponent-slot.right .player-card {
        transform: rotate(-90deg);
    }

    .player-card {
        min-width: 90px;
        padding: 0.3rem;
        font-size: 0.65rem;
    }

    .opponent-hand {
        min-height: 35px;
        transform: scale(0.65);
        margin-top: 0 !important;
    }

    .card.mini {
        width: 35px !important;
        height: 55px !important;
    }

    .card {
        width: 60px;
        height: 90px;
        font-size: 1.8rem;
    }

    .hand .card {
        margin-left: -25px;
    }

    .center-area {
        gap: 1.5rem;
    }

    .player-area {
        padding-top: 0;
    }

    h1 {
        font-size: 1.8rem;
    }
}

/* Mobile Portrait - Dikey */
@media (max-width: 768px) and (orientation: portrait) {

    /* Reset & Base Layout */
    html,
    body {
        width: 100vw !important;
        max-width: 100vw !important;
        height: 100% !important;
        overflow-x: hidden !important;
        margin: 0 !important;
        padding: 0 !important;
        position: fixed;
        /* Prevent bouncy scrolling */

        /* Flex Center Globals */
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
    }

    /* Global Box Sizing to prevent width overflow */
    *,
    *:before,
    *:after {
        box-sizing: border-box !important;
    }

    /* Main App Wrapper */
    #app {
        width: 100% !important;
        max-width: 100vw !important;
        height: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        /* Center children */
        overflow: hidden;
    }

    /* Bootstrap Container Override */
    .container {
        width: 100% !important;
        max-width: 100vw !important;
        padding: 0 !important;
        margin: 0 auto !important;
    }

    body.game-active #app {
        /* Ensure app takes full width in game mode */
        width: 100% !important;
        align-items: center !important;
    }

    #game-screen {
        flex: 1;
        /* Take remaining height */
        width: 100% !important;
        max-width: 100vw !important;
        padding: 0 !important;
        margin: 0 auto !important;
        display: flex;
        flex-direction: column;
        align-items: center !important;
        overflow-x: hidden;
    }

    .game-header {
        width: 100% !important;
        padding: 0.5rem 0.8rem;
        margin: 0 !important;
        border-radius: 0 !important;
        border: none !important;
        box-sizing: border-box !important;
    }

    .game-board {
        display: grid !important;
        grid-template-areas:
            "left top right"
            "center center center"
            "bottom bottom bottom";
        grid-template-columns: 1fr 1fr 1fr;
        grid-template-rows: auto 1fr auto;
        width: 100% !important;
        flex: 1;
        margin: 0 auto !important;
        /* Center grid */
        padding: 5px 0 !important;
        /* Reduce side padding to 0 */
        box-sizing: border-box !important;
        border: none !important;
        align-items: flex-start;
        justify-items: center;
        /* Crucial for centering columns */
        gap: 0 !important;
    }

    /* 1v1'de rakip üstte */
    /* 1v1'de rakip üstte */
    .opponent-slot.top {
        grid-area: top;
        width: 100%;
        max-width: 100%;
        display: flex;
        justify-content: center !important;
        /* Force center */
        align-items: flex-start !important;
        padding-bottom: 0;
        margin: 0 auto !important;
        order: unset;
        z-index: 60;
    }

    .center-area {
        grid-area: center;
        order: unset;
        transform: none !important;
        display: flex !important;
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 20px;
        padding: 80px 0 20px 0 !important;
        width: 100% !important;
        max-width: 100vw !important;
        /* Cap to viewport */
        height: 100%;
        z-index: 10;
        margin: 0 auto !important;
        /* Force center */
    }

    .deck-pile {
        margin: 0 !important;
    }

    .player-area {
        grid-area: bottom;
        order: unset;
        transform: none !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
    }

    /* Enable side players in portrait */
    .opponent-slot.left,
    .opponent-slot.right {
        display: flex !important;
        position: relative !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
        width: 100% !important;
        min-width: 0 !important;
        /* Allow shrinking */
        height: auto !important;
        align-items: flex-start !important;
        justify-content: center;
        z-index: 60;
        overflow: visible !important;
        padding: 0 !important;
    }

    .opponent-slot.left {
        grid-area: left;
    }

    .opponent-slot.right {
        grid-area: right;
    }

    .opponent-slot {
        align-items: center !important;
        padding-top: 0;
    }

    /* Rotate side players */
    /* Container rotated, so width becomes height. */
    /* Rotate side players - RESET for side-by-side */
    .opponent-slot.left .player-card,
    .opponent-slot.right .player-card {
        transform: none !important;
        transform-origin: center top;
        width: 100% !important;
        max-width: 95%;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .player-card {
        min-width: unset;
        width: auto;
        padding: 0.4rem;
        font-size: 0.65rem;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    }

    .card {
        width: 55px;
        height: 82px;
        font-size: 1.6rem;
        border-width: 2px;
    }

    /* Fix color wheel overflow in mobile cards */
    .card .color-wheel {
        width: 35px !important;
        height: 35px !important;
        font-size: 0.8rem !important;
        /* Scale down text inside +4 */
        border-width: 2px !important;
    }

    .center-area {
        gap: 1rem;
        display: flex !important;
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        width: 100% !important;
        max-width: 100vw !important;
        margin: 0 auto !important;
        padding: 80px 0 20px 0 !important;
        transform: none !important;
        /* Remove legacy transforms */
    }

    .opponent-hand {
        min-height: 30px;
        transform: scale(0.65);
        margin-top: 0 !important;
    }

    .card.mini {
        width: 35px !important;
        height: 55px !important;
    }

    /* Tighter card overlap to fit more cards on screen */
    .hand .card {
        margin-left: var(--card-overlap, -5px) !important;
        /* Much wider spacing */
        margin-right: -5px !important;
        transform-origin: bottom center;
        flex-shrink: 0;
        /* Prevent squishing */
        transition: margin-left 0.3s ease;
        /* Smooth transition when drawing cards */
    }

    /* Shift center area cards slightly down */
    .center-area {
        padding-top: 80px !important;
        /* Push down further */
    }



    .player-area {
        grid-area: bottom;
        width: 100% !important;
        max-width: 100vw !important;
        padding: 0 !important;
        margin: 0 auto !important;
        overflow: hidden;
        /* Prevent page layout from breaking */
    }

    .hand {
        display: flex;
        justify-content: center;
        /* Default center */
        width: 100%;
        max-width: 100vw;
        /* Strict cap */
        overflow-x: auto;
        overflow-y: visible;
        padding: 60px 10px 10px 10px !important;
        /* Balanced padding */
        min-height: 140px;
        -webkit-overflow-scrolling: touch;
        box-sizing: border-box;
    }

    /* Reset margin for first card to prevent shift */
    .hand .card:first-child {
        margin-left: 0 !important;
    }

    /* When content overflows, ensure it doesn't push alignment */
    .hand::-webkit-scrollbar {
        height: 4px;
        /* Minimal scrollbar */
    }

    /* Ensure content inside doesn't shrink aggressively */
    .hand>* {
        flex-shrink: 0;
    }

    /* Kullanıcı kartları, isim ve bildirimler */
    .player-area {
        width: 100% !important;
        display: flex;
        flex-direction: column;
        align-items: center;
        padding-bottom: 15px !important;
        margin: 0 !important;
        transform: translateY(-100px) !important;
    }

    .player-status-bar {
        position: relative !important;
        top: 0 !important;
    }

    .hand {
        justify-content: center;
        width: 100%;
        padding: 0 10px !important;
        box-sizing: border-box !important;
        transform: translateY(30px) !important;
    }

    .my-name-wrapper {
        margin: 5px 0 !important;
    }
}

/* Mobil: Sol üst oyuncu skorları gizle */
#fixed-scoreboard {
    display: none !important;
}

/* Mobil: Oda numarası gizle */
.room-info {
    display: none !important;
}

/* Mobil: Sıra sende butonu mikro boyut */
.turn-badge {
    padding: 3px 8px;
    font-size: 0.55rem;
    border-radius: 15px;
    border-width: 1px;
    box-shadow: 0 0 8px rgba(255, 222, 0, 0.3);
}

/* Mobil: Kullanıcı kartlarındaki numaraları daha görünür yap */
.hand .card {
    font-size: 2.2rem;
    font-weight: 900;
    text-shadow:
        0 2px 4px rgba(0, 0, 0, 0.5),
        0 0 10px rgba(255, 255, 255, 0.3);
}

/* Az kart varken kartları daha net göster */
.hand {
    gap: 5px;
}

.hand .card:only-child,
.hand:has(.card:nth-child(-n+3):last-child) .card {
    margin-left: 0;
    font-size: 2.5rem;
}

/* Mobil: 1v1 oyunlarda rakip kartları */
.opponent-1v1 {
    min-width: 150px;
    padding: 0.5rem;
}

.opponent-1v1 .opponent-hand-1v1 {
    min-height: 80px;
}

.opponent-1v1 .opponent-hand-1v1 .card {
    width: 50px;
    height: 75px;
    font-size: 1.2rem;
}

.opponent-1v1 .opponent-hand-1v1 .card {
    margin-left: -20px !important;
}

.opponent-1v1 .opponent-hand-1v1 .card:first-child {
    margin-left: 0 !important;
}

.opponent-1v1 .opponent-hand-1v1 .uno-logo {
    font-size: 0.9rem;
}

/* Mobil: İsim badge'leri */
.player-name-badge {
    padding: 4px 10px;
    font-size: 0.7rem;
}

.turn-badge-inline {
    padding: 2px 8px;
    font-size: 0.55rem;
    border-width: 1px;
}

/* Landscape modunda da benzer düzenlemeler */
@media (max-width: 920px) and (orientation: landscape) {

    /* Mobil landscape: Sol üst oyuncu skorları gizle */
    #fixed-scoreboard {
        display: none !important;
    }

    /* Mobil landscape: Oda numarası gizle */
    .room-info {
        display: none !important;
    }

    /* Mobil landscape: Sıra sende butonu mikro boyut */
    .turn-badge {
        padding: 3px 8px;
        font-size: 0.55rem;
        border-radius: 15px;
        border-width: 1px;
        box-shadow: 0 0 8px rgba(255, 222, 0, 0.3);
    }

    /* Mobil landscape: Kullanıcı kartlarındaki numaraları daha görünür yap */
    .hand .card {
        font-size: 2rem;
        font-weight: 900;
        text-shadow:
            0 2px 4px rgba(0, 0, 0, 0.5),
            0 0 10px rgba(255, 255, 255, 0.3);
    }

    /* Mobil landscape: 1v1 oyunlarda rakip kartları */
    .opponent-1v1 {
        min-width: 180px;
        padding: 0.5rem;
    }

    .opponent-1v1 .opponent-hand-1v1 {
        min-height: 90px;
    }

    .opponent-1v1 .opponent-hand-1v1 .card {
        width: 55px;
        height: 82px;
        font-size: 1.3rem;
        margin-left: -22px !important;
    }

    .opponent-1v1 .opponent-hand-1v1 .card:first-child {
        margin-left: 0 !important;
    }

    /* Mobil landscape: İsim badge'leri */
    .player-name-badge {
        padding: 4px 10px;
        font-size: 0.7rem;
    }

    .turn-badge-inline {
        padding: 2px 8px;
        font-size: 0.55rem;
        border-width: 1px;
    }
}