body {
    font-family: Arial, sans-serif;
    margin: 20px;
}

.container {
    display: flex;
    gap: 20px;
    max-width: 100%;
}

.left-column {
    min-width: 200px; /* Minimum width for inputs and ship counts */
    width: 200px; /* Fixed width to prevent excessive growth */
    display: flex;
    flex-direction: column;
    align-items: center;
}

.center-column {
    flex-grow: 1; /* Grow to fit grid */
    display: flex;
    flex-direction: column;
    align-items: center;
}

.right-column {
    flex-shrink: 1; /* Allow shrinking or pushing off-screen */
    min-width: 200px;
    max-width: 300px;
}

h2 {
    font-size: 18px;
    margin-bottom: 10px;
}

div {
    margin: 10px 0;
}

input {
    padding: 5px;
    margin: 5px;
    width: 150px;
}

button {
    padding: 10px 20px;
    cursor: pointer;
}

canvas {
    border: 1px solid black;
    margin-top: 10px;
}

#shipCounts {
    font-size: 16px;
    margin-top: 15px;
}

.ship-length {
    color: blue;
    text-decoration: underline;
    cursor: pointer;
}

.right-column ul {
    font-size: 14px;
    line-height: 1.5;
    padding-left: 20px;
}