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

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

.floorplan {
  display: grid;
  grid-template-columns: repeat(10, 50px);
  grid-template-rows: repeat(10, 50px);
  gap: 2px;
  background-color: #ddd;
  padding: 5px;
  border: 3px solid #000;
  width: max-content;
}

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

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

/* Grid placement per room - matching paper layout */

.cinema-room {
  grid-column: 1 / span 6;
  grid-row: 1 / span 6;
}

.kitchen {
  grid-column: 7 / span 3;
  grid-row: 1 / span 2;
}

.downstairs-office {
  grid-column: 1 / span 3;
  grid-row: 7 / span 3;
}

.chill-out {
  grid-column: 1 / span 3;
  grid-row: 10 / span 3;
}

.guest-bathroom {
  grid-column: 7 / span 3;
  grid-row: 7 / span 3;
}

.guest-bedroom {
  grid-column: 7 / span 3;
  grid-row: 10 / span 3;
}

/* Door placement (approximate for demo) */

.cinema-room .door {
  bottom: 4px;
  right: 4px;
}

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

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

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

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

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