/* Configurator Selection States */

/* All Selection Buttons - Rounded Edges */
.house-type-card,
.mobile-house-type-card,
.side-option,
.facade-style-card,
.door-type-card,
.door-type-btn,
.frame-color-btn,
.execution-card,
.material-card,
.green-roof-option,
.back-entrance-option,
.facade-breakthrough-option,
.common-dimension-btn,
.wood-color-btn-large,
.mobile-option-btn {
  border-radius: 10px;
}

/* Mobile House Type Card Base Styles */
.mobile-house-type-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.25rem;
  background: #F9F9F7;
  border: 2px solid #E8E8E8;
  cursor: pointer;
  transition: all 0.2s ease;
}

.mobile-house-type-card:hover {
  border-color: #9BA98C;
  background: #FFFFFF;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.mobile-house-type-card.selected {
  border-color: #E29427;
  background: #FFF9F0;
  box-shadow: 0 4px 16px rgba(226, 148, 39, 0.15);
}

/* Mobile House Type Icons - Smaller Size */
.mobile-house-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  margin: 0 auto 0.5rem;
  flex-shrink: 0;
  color: #697757;
}

.mobile-house-type-card.selected .mobile-house-icon {
  color: #E29427;
}

.mobile-house-icon svg {
  width: 100%;
  height: 100%;
}

/* Mobile House Info */
.mobile-house-info {
  text-align: center;
  width: 100%;
}

.mobile-house-name {
  font-size: 1rem;
  font-weight: 600;
  color: #2D3319;
  margin-bottom: 0.25rem;
}

.mobile-house-price {
  font-size: 0.875rem;
  color: #697757;
  font-weight: 500;
}

/* Responsive layout for smaller heights - horizontal layout */
@media (max-height: 1000px) {
  .mobile-house-type-card {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem !important;
    min-height: auto !important;
  }

  .mobile-house-icon {
    width: 60px !important;
    height: 60px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
  }

  .mobile-house-info {
    text-align: left !important;
    flex: 1 !important;
  }

  .mobile-house-name {
    font-size: 0.875rem !important;
  }

  .mobile-house-price {
    font-size: 0.75rem !important;
  }
}

@media (max-height: 850px) {
  .mobile-house-type-card {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 0.375rem !important;
    padding: 0.375rem 0.5rem !important;
    min-height: auto !important;
  }

  .mobile-house-icon {
    width: 45px !important;
    height: 45px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
  }

  .mobile-house-info {
    text-align: left !important;
    flex: 1 !important;
  }

  .mobile-house-name {
    font-size: 0.8125rem !important;
    line-height: 1.2 !important;
  }

  .mobile-house-price {
    font-size: 0.6875rem !important;
    line-height: 1.2 !important;
  }
}

@media (max-height: 800px) {
  .mobile-house-type-card {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 0.75rem !important;
    padding: 0.75rem !important;
    min-height: auto !important;
  }

  .mobile-house-icon {
    width: 50px !important;
    height: 50px !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
  }

  .mobile-house-info {
    text-align: left !important;
    flex: 1 !important;
  }

  .mobile-house-name {
    font-size: 0.875rem !important;
  }

  .mobile-house-price {
    font-size: 0.75rem !important;
  }
}

@media (max-height: 700px) {
  .mobile-house-type-card {
    padding: 0.5rem !important;
    gap: 0.5rem !important;
  }

  .mobile-house-icon {
    width: 40px !important;
    height: 40px !important;
  }

  .mobile-house-name {
    font-size: 0.8125rem !important;
  }

  .mobile-house-price {
    font-size: 0.6875rem !important;
  }
}

@media (max-height: 600px) {
  .mobile-house-type-card {
    padding: 0.375rem !important;
    gap: 0.375rem !important;
  }

  .mobile-house-icon {
    width: 32px !important;
    height: 32px !important;
  }

  .mobile-house-name {
    font-size: 0.75rem !important;
  }

  .mobile-house-price {
    font-size: 0.625rem !important;
  }
}

/* House Type Selection */
.house-type-card.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
  border-width: 2px;
}

/* Side Selection for Semi-detached */
.side-option.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

/* Facade Style Selection */
.facade-style-card.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

/* Door/Pui Selection */
.door-type-card.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

/* Material/Uitvoering Selection */
.execution-card {
  min-height: 100px !important;
  padding: 20px !important;
}

/* Standard button - very compact on mobile */
.execution-card-standard {
  min-height: 45px !important;
  padding: 8px 16px !important;
}

/* Luxury button - compact on mobile */
.execution-card-luxury {
  min-height: auto !important;
  padding: 12px 16px !important;
}

/* Luxury features - inline/horizontal layout on mobile */
.luxury-features-inline {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.25rem 0.75rem !important;
  margin: 0 !important;
  padding-left: 1rem !important;
}

.luxury-features-inline li {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.4 !important;
}

/* Desktop: vertical list layout */
@media (min-width: 1024px) {
  .luxury-features-inline {
    display: block !important;
    padding-left: 1.5rem !important;
  }

  .luxury-features-inline li {
    margin-bottom: 0.5rem !important;
    line-height: 1.6 !important;
  }

  .execution-card-standard {
    min-height: 80px !important;
    padding: 16px 20px !important;
  }

  .execution-card-luxury {
    min-height: 100px !important;
    padding: 20px !important;
  }
}

.execution-card.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

.material-card.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

/* Green Roof Selection */
.green-roof-option.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

/* Green Roof Button - New Style */
.green-roof-btn {
  width: 100%;
  min-height: 56px;
  border-radius: 8px;
  border: 2px solid #E5E5E5;
  background-color: #FFFFFF;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.green-roof-btn:hover {
  border-color: #D98F28;
  background-color: #FAFAFA;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}

.green-roof-btn.selected {
  border-color: #f48c06;
  background-color: #FFF9F0;
  box-shadow: 0 2px 8px rgba(244, 140, 6, 0.15);
}

.green-roof-label {
  font-weight: 500;
  font-size: 0.9375rem;
  color: #333;
}

.green-roof-btn .selection-indicator {
  width: 16px;
  height: 16px;
  border: 2px solid #E5E5E5;
  border-radius: 3px;
  background-color: #FFFFFF;
  flex-shrink: 0;
  position: relative;
}

.green-roof-btn.selected .selection-indicator {
  border-color: #f48c06;
  background-color: #f48c06;
}

/* Checkmark icon when selected */
.green-roof-btn.selected .selection-indicator::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* Back Entrance Button - Same Style as Green Roof */
.back-entrance-btn {
  width: 100%;
  min-height: 56px;
  border-radius: 8px;
  border: 2px solid #E5E5E5;
  background-color: #FFFFFF;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.back-entrance-btn:hover {
  border-color: #D98F28;
  background-color: #FAFAFA;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}

.back-entrance-btn.selected {
  border-color: #f48c06;
  background-color: #FFF9F0;
  box-shadow: 0 2px 8px rgba(244, 140, 6, 0.15);
}

.back-entrance-label {
  font-weight: 500;
  font-size: 0.9375rem;
  color: #333;
}

.back-entrance-btn .selection-indicator {
  width: 16px;
  height: 16px;
  border: 2px solid #E5E5E5;
  border-radius: 3px;
  background-color: #FFFFFF;
  flex-shrink: 0;
  position: relative;
}

.back-entrance-btn.selected .selection-indicator {
  border-color: #f48c06;
  background-color: #f48c06;
}

/* Checkmark icon when selected */
.back-entrance-btn.selected .selection-indicator::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* Achterom Info Text */
.achterom-info-container {
  text-align: left;
}

.achterom-requirement {
  margin-top: 0;
  margin-bottom: 0.75rem;
  font-size: 0.875rem;
  color: #555;
  text-align: left;
}

.achterom-info-heading {
  font-weight: 600;
  font-size: 0.9375rem;
  color: #333;
  margin-bottom: 0.25rem;
  text-align: left;
}

.achterom-info-text {
  font-size: 0.875rem;
  color: #555;
  line-height: 1.5;
  text-align: left;
}

/* Back Entrance Selection */
.back-entrance-option.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

/* Facade Breakthrough Selection */
.facade-breakthrough-option.selected {
  background-color: #DEE3D4;
  border-color: #697757 !important;
}

/* Mobile Options Grid - Side by Side Layout */
.mobile-options-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0.75rem !important;
}

@media (min-width: 1024px) {
  .mobile-options-grid {
    gap: 1rem !important;
  }
}

/* Mobile Option Buttons in Grid - Larger Size */
.mobile-options-grid .mobile-option-btn {
  min-height: 90px !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  text-align: center !important;
}

/* Extra compact for small viewport heights */
@media (max-height: 850px) {
  .mobile-options-grid .mobile-option-btn {
    min-height: 70px !important;
    padding: 12px !important;
    gap: 8px !important;
  }
}

@media (max-height: 700px) {
  .mobile-options-grid .mobile-option-btn {
    min-height: 60px !important;
    padding: 10px !important;
    gap: 6px !important;
  }
}

@media (min-width: 1024px) {
  .mobile-options-grid .mobile-option-btn {
    min-height: 140px !important;
    padding: 24px !important;
    gap: 16px !important;
  }
}

.mobile-options-grid .mobile-option-icon {
  font-size: 3rem !important;
  line-height: 1 !important;
}

.mobile-options-grid .mobile-option-icon.text-green-600 {
  color: #16a34a !important;
}

.mobile-options-grid .mobile-option-icon.text-gray-400 {
  color: #9ca3af !important;
}

/* Smaller icons for compact heights */
@media (max-height: 850px) {
  .mobile-options-grid .mobile-option-icon {
    font-size: 2.5rem !important;
  }
}

@media (max-height: 700px) {
  .mobile-options-grid .mobile-option-icon {
    font-size: 2rem !important;
  }
}

@media (min-width: 1024px) {
  .mobile-options-grid .mobile-option-icon {
    font-size: 4rem !important;
  }
}

.mobile-options-grid .mobile-option-label {
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  color: #1f2937 !important;
  line-height: 1.2 !important;
}

/* Smaller labels for compact heights */
@media (max-height: 850px) {
  .mobile-options-grid .mobile-option-label {
    font-size: 1rem !important;
  }
}

@media (max-height: 700px) {
  .mobile-options-grid .mobile-option-label {
    font-size: 0.875rem !important;
  }
}

@media (min-width: 1024px) {
  .mobile-options-grid .mobile-option-label {
    font-size: 1.25rem !important;
  }
}

/* Door Icon Preview */
.door-icon-preview svg {
  max-height: 80px;
  max-width: 100%;
  height: auto;
  width: auto;
}

/* Common Dimensions Grid Container */
.common-dimensions-section [data-configurator-target="commonDimensionsGrid"] {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0.75rem !important;
}

/* Common Dimension Buttons */
.common-dimension-btn {
  min-height: 80px;
  width: 100%;
}

.common-dimension-btn:hover {
  background-color: #f48c06 !important;
  border-color: #f48c06 !important;
  box-shadow: 0 4px 12px rgba(244, 140, 6, 0.3) !important;
}

.common-dimension-btn:hover span {
  color: white !important;
}

.common-dimension-btn:active {
  transform: scale(0.98);
}

/* Door Type Grid Container - Always 2 columns on desktop */
.door-type-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0.75rem !important;
}

/* Desktop: wider screens get more space */
@media (min-width: 1024px) {
  .door-type-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1rem !important;
  }
}

/* Door Type Selection - Compact Side-by-Side Layout */
.door-type-btn {
  min-height: 90px !important;
  padding: 8px !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-align: center;
  width: 100%;
}

/* Horizontal layout for small viewports */
@media (max-height: 1100px) {
  .door-type-btn {
    min-height: 55px !important;
    padding: 8px 10px !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    text-align: left !important;
  }
}

@media (min-width: 1024px) {
  .door-type-btn {
    min-height: 120px !important;
    padding: 12px !important;
    flex-direction: column !important;
    text-align: center !important;
  }
}

.door-preview-box-compact {
  width: 45px;
  height: 45px;
  border-radius: 6px;
  flex-shrink: 0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
  border: 1px solid rgba(0, 0, 0, 0.1);
  background: linear-gradient(to bottom, #e5e7eb 0%, #f3f4f6 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 5px;
  margin: 0 auto;
}

/* Smaller icon for horizontal layout */
@media (max-height: 1100px) {
  .door-preview-box-compact {
    width: 35px !important;
    height: 35px !important;
    margin: 0 !important;
  }
}

@media (min-width: 1024px) {
  .door-preview-box-compact {
    width: 55px;
    height: 55px;
    margin: 0 auto;
  }
}

.door-panel {
  flex: 1;
  height: 100%;
  background: linear-gradient(135deg, #ffffff 0%, #e5e7eb 100%);
  border: 1px solid #9ca3af;
  border-radius: 2px;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

.door-info-compact {
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
}

@media (max-height: 1100px) {
  .door-info-compact {
    gap: 2px;
    flex: 1;
  }
}

.door-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #1f2937;
  line-height: 1.2;
}

@media (max-height: 1100px) {
  .door-label {
    font-size: 0.8125rem;
    line-height: 1.3;
  }
}

@media (min-width: 1024px) {
  .door-label {
    font-size: 0.875rem;
  }
}

.door-elements {
  font-size: 0.6875rem;
  color: #6b7280;
  margin: 0;
  line-height: 1.2;
}

@media (max-height: 1100px) {
  .door-elements {
    font-size: 0.6875rem;
    line-height: 1.3;
  }
}

@media (min-width: 1024px) {
  .door-elements {
    font-size: 0.75rem;
  }
}

/* Frame Color Grid Container - Always 2 columns */
.frame-color-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0.75rem !important;
}

/* Desktop: wider screens get more space */
@media (min-width: 1024px) {
  .frame-color-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1rem !important;
  }
}

/* Frame Color Selection - Compact Layout */
.frame-color-btn {
  min-height: 70px !important;
  padding: 1rem 1.25rem !important;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.875rem;
  text-align: left;
  width: 100%;
  flex-wrap: nowrap;
}

/* Horizontal layout for small viewports */
@media (max-height: 1100px) {
  .frame-color-btn {
    min-height: 50px !important;
    padding: 8px 10px !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    text-align: left !important;
  }
}

@media (min-width: 1024px) {
  .frame-color-btn {
    min-height: 70px !important;
    padding: 1rem 1.25rem !important;
    flex-direction: row !important;
    text-align: left !important;
  }
}

.frame-color-preview {
  width: 45px;
  height: 45px;
  border-radius: 6px;
  flex-shrink: 0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
  border: 2px solid rgba(0, 0, 0, 0.1);
  margin: 0 auto;
}

/* Smaller preview for horizontal layout */
@media (max-height: 1100px) {
  .frame-color-preview {
    width: 32px !important;
    height: 32px !important;
    margin: 0 !important;
  }
}

@media (min-width: 1024px) {
  .frame-color-preview {
    width: 50px;
    height: 50px;
    margin: 0 auto;
  }
}

.frame-color-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
}

@media (max-height: 1100px) {
  .frame-color-info {
    gap: 1px;
    flex: 1;
  }
}

.frame-color-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #1f2937;
  line-height: 1.2;
}

@media (max-height: 1100px) {
  .frame-color-label {
    font-size: 0.8125rem;
    line-height: 1.3;
  }
}

@media (min-width: 1024px) {
  .frame-color-label {
    font-size: 0.875rem;
  }
}

.frame-color-desc {
  font-size: 0.6875rem;
  color: #6b7280;
  margin: 0;
  line-height: 1.2;
}

@media (max-height: 1100px) {
  .frame-color-desc {
    font-size: 0.6875rem;
    line-height: 1.3;
  }
}

@media (min-width: 1024px) {
  .frame-color-desc {
    font-size: 0.75rem;
  }
}

/* Wood Color Grid - Side by Side on Mobile */
.wood-color-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 0.75rem !important;
}

@media (min-width: 1024px) {
  .wood-color-grid {
    gap: 1rem !important;
  }
}

/* Wood Color Selection - Compact Mobile Buttons */
.wood-color-btn-compact {
  min-height: 80px !important;
  padding: 10px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 8px !important;
  width: 100%;
}

@media (min-width: 1024px) {
  .wood-color-btn-compact {
    min-height: 100px !important;
    padding: 14px !important;
  }
}

.wood-texture-preview-compact {
  width: 50px;
  height: 50px;
  border-radius: 8px;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  border: 1px solid rgba(0, 0, 0, 0.1);
}

@media (min-width: 1024px) {
  .wood-texture-preview-compact {
    width: 60px;
    height: 60px;
  }
}

.wood-color-info-compact {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* Wood Color Selection - Large Cards with Preview Images (legacy) */
.wood-color-btn-large {
  min-height: 110px !important;
  padding: 16px !important;
  gap: 16px !important;
}

.wood-texture-preview-large {
  width: 80px;
  height: 80px;
  border-radius: 8px;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  border: 1px solid rgba(0, 0, 0, 0.1);
}

/* Light Wood Texture - Natural beige/tan with vertical slats */
.texture-light-wood {
  background: linear-gradient(90deg,
    #d4b896 0%, #c9ad88 8%, #d4b896 16%,
    #d4b896 16%, #c9ad88 24%, #d4b896 32%,
    #d4b896 32%, #c9ad88 40%, #d4b896 48%,
    #d4b896 48%, #c9ad88 56%, #d4b896 64%,
    #d4b896 64%, #c9ad88 72%, #d4b896 80%,
    #d4b896 80%, #c9ad88 88%, #d4b896 96%
  );
  background-size: 100% 100%;
}

/* Dark Wood Texture - using actual image */
.texture-dark-wood {
  background-image: url("../images/configurator/zwart_vuren.png");
  background-size: cover;
  background-position: center;
}

.wood-color-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.wood-color-btn-large .mobile-option-label {
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  margin-bottom: 2px !important;
}

.wood-color-description {
  font-size: 0.8rem;
  color: #6b7280;
  margin: 0;
  line-height: 1.3;
}