/* ================================
   MOBILE RESPONSIVE STYLES
   ================================ */
@media (max-width: 768px) {
    /* Game popups on mobile */
    .game-popup {
        left: 10px;
        right: 10px;
        font-size: 16px; /* Slightly smaller on mobile */
    }

    footer {
        bottom: 10px;
        min-height: 160px; /* This is already min-height, good */

        .unit-panel .base-panel {
            align-items: flex-start;

            .unit-level {
                font-size: 32px;
                width: 60px;
                height: 60px;
                align-self: flex-start;
                margin-top: 0;
            }

            .unit-name {
                font-size: 24px;
                font-weight: bold;
            }

            > div:last-child > div {
                > span:first-child,
                > span:last-child {
                    font-size: 18px;
                }
            }
        }

        .tile-panel {
            display: none;

            .terrain-type {
                font-size: 18px;
            }

            .terrain-position {
                font-size: 16px;
            }
        }
    }

    header {
        font-size: 18px;

        .day-panel .day-display {
            font-size: 20px;
        }

        .day-panel .time-display {
            display: none;
        }

        .turn-panel .moves-display {
            font-size: 16px;
        }
    }

    .panel {
        font-size: 18px;
    }

    .control-panel {
        min-width: calc(100vw - 30px);
        max-width: calc(100vw - 30px);
        padding: 40px;

        label {
            font-size: 24px;
            margin-top: 20px;
        }

        button {
            padding: 20px 30px;
            font-size: 22px;
            width: 100%;
        }

        .panel-title {
            font-size: 28px;
        }

        .close-btn {
            font-size: 36px;
        }
    }

    aside .control-icon {
        width: 40px;
        height: 40px;
        font-size: 20px;
    }
}
