:root {
    --correct: #0f8f6e;
    --wrong: #b2574f;
}

body {
    min-height: 100svh;
    display: grid;
    justify-items: center;
    align-content: start;
    padding-top: calc(var(--safe-top) + var(--space-4));
    padding-right: calc(var(--safe-right) + var(--space-3));
    padding-bottom: calc(var(--safe-bottom) + var(--space-2));
    padding-left: calc(var(--safe-left) + var(--space-3));
}

.ms-app {
    width: min(100%, 760px);
    margin-top: var(--space-5);
}

.ms-card h1 {
    margin: 0 0 var(--space-2);
    font-size: clamp(24px, 3.6vw, 34px);
    line-height: 1.1;
}

.status {
    min-height: 1.3em;
    margin-bottom: var(--space-2);
    color: var(--text-subtle);
    font-size: 14px;
}

.status.status-win {
    color: var(--correct);
}

.status.status-loss {
    color: var(--wrong);
}

.controls {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: var(--space-1);
    margin-bottom: var(--space-2);
}

.control-field {
    display: grid;
    gap: 6px;
    font-size: 13px;
    color: var(--text-subtle);
}

.control-select,
.control-btn {
    border: 1px solid var(--border);
    background: transparent;
    color: var(--ink);
    min-height: 40px;
    padding: var(--space-1) var(--space-2);
    font: inherit;
}

.control-select {
    min-width: 128px;
}

.control-btn {
    cursor: pointer;
}

.control-btn:hover,
.control-select:hover {
    border-color: var(--border-strong);
    background: rgba(16, 24, 40, 0.05);
}

.stats {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
    color: var(--text-subtle);
    font-size: 14px;
    font-variant-numeric: tabular-nums;
}

.board-wrap {
    width: 100%;
    overflow-x: hidden;
}

.ms-board {
    --cols: 12;
    display: grid;
    grid-template-columns: repeat(var(--cols), minmax(0, 1fr));
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    gap: 2px;
    border: 1px solid var(--border);
    background: var(--border);
    padding: 2px;
    touch-action: manipulation;
    -webkit-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
}

.ms-cell {
    border: 1px solid var(--border);
    background: #e7ecea;
    color: var(--ink);
    aspect-ratio: 1 / 1;
    min-height: 0;
    min-width: 0;
    font: inherit;
    font-size: clamp(12px, 2.2vw, 18px);
    line-height: 1;
    font-weight: 700;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    -webkit-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
}

.ms-cell:hover:not(:disabled):not(.revealed) {
    border-color: var(--border-strong);
}

.ms-cell.revealed {
    background: #f7f8f8;
    border-color: rgba(16, 24, 40, 0.14);
    cursor: default;
}

.ms-cell.flagged {
    color: var(--wrong);
}

.ms-cell.mine {
    background: rgba(178, 87, 79, 0.18);
    border-color: var(--wrong);
    color: #8f463f;
}

.ms-cell.mine.detonated {
    background: var(--wrong);
    color: #fff7f6;
}

.ms-cell.bad-flag {
    background: rgba(178, 87, 79, 0.08);
    color: var(--wrong);
}

.ms-cell.number-1 { color: #1f4fcb; }
.ms-cell.number-2 { color: #0f8f6e; }
.ms-cell.number-3 { color: #b2574f; }
.ms-cell.number-4 { color: #7e3db8; }
.ms-cell.number-5 { color: #8f463f; }
.ms-cell.number-6 { color: #0f7c7a; }
.ms-cell.number-7 { color: #334155; }
.ms-cell.number-8 { color: #5f6b7a; }

.ms-flag-popup {
    position: fixed;
    z-index: 1200;
    pointer-events: none;
    font-size: clamp(24px, 6vw, 32px);
    font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
    line-height: 1;
    transform: translate(-50%, -65%);
    text-shadow: 0 2px 7px rgba(16, 24, 40, 0.24);
    will-change: transform, opacity;
    animation: ms-flag-pop 0.55s ease-out forwards;
}

.ms-flag-popup.mouse {
    font-size: clamp(22px, 2vw, 28px);
}

@keyframes ms-flag-pop {
    0% {
        opacity: 0;
        transform: translate(-50%, -35%) scale(0.78);
    }

    20% {
        opacity: 1;
    }

    100% {
        opacity: 0;
        transform: translate(-50%, -130%) scale(1);
    }
}

#board,
#board * {
    -webkit-user-select: none !important;
    user-select: none !important;
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
}

@media (max-width: 540px) {
    body {
        padding-top: calc(var(--safe-top) + var(--space-2));
        padding-right: calc(var(--safe-right) + var(--space-2));
        padding-bottom: calc(var(--safe-bottom) + var(--space-1));
        padding-left: calc(var(--safe-left) + var(--space-2));
    }

    .ms-app {
        margin-top: calc(var(--space-5) + var(--space-2));
    }

    .controls {
        gap: 6px;
    }

    .control-select,
    .control-btn {
        min-height: 38px;
        padding: 8px 10px;
    }

}
