body {
  font-family: Arial, sans-serif;
  background-color: #f5f5f5;
  padding: 20px;
}

h2 {
  text-align: center;
  margin-bottom: 20px;
}

.floorplan {
  position: relative;
  background-color: #ddd;
  padding: 10px;
  display: grid;
  grid-template-columns: repeat(12, 10px); /* Each 1m = 10px */
  grid-auto-rows: 10px;
  gap: 2px;
  width: max-content;
  border: 3px solid #333; /* Represents perimeter walls */
}

.room {
  position: relative;
  background-color: #fff;
  border: 1px solid #000;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 10px;
  padding: 2px;
  box-sizing: border-box;
}

.room .door {
  position: absolute;
  background-color: brown;
  color: white;
  font-size: 8px;
  padding: 1px 3px;
  border-radius: 2px;
}

/* Room sizes at 1:100 scale (1m = 10px) */
.cinema-room {
  grid-column: span 8;
  grid-row: span 8;
}

.kitchen {
  grid-column: 9 / span 4;
  grid-row: 1 / span 3;
}

.downstairs-office {
  grid-column: 1 / span 4;
  grid-row: 9 / span 4;
}

.chill-out {
  grid-column: 1 / span 4;
  grid-row: 13 / span 4;
}

.guest-bathroom {
  grid-column: 9 / span 4;
  grid-row: 9 / span 4;
}

.guest-bedroom {
  grid-column: 9 / span 4;
  grid-row: 13 / span 4;
}

/* Door placement (adjust as needed) */
.cinema-room .door {
  bottom: 2px;
  right: 2px;
}

.kitchen .door {
  bottom: 2px;
  right: 2px;
}

.downstairs-office .door {
  top: 2px;
  left: 50%;
  transform: translateX(-50%);
}

.chill-out .door {
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%);
}

.guest-bathroom .door {
  top: 2px;
  left: 50%;
  transform: translateX(-50%);
}

.guest-bedroom .door {
  bottom: 2px;
  left: 50%;
  transform: translateX(-50%);
}
