/* fence-calculator.css */

/* ===== Fence style chip icons ===== */
.evvy-fence-chip-row {
  flex-wrap: wrap;
}
.evvy-fence-chip-row .evvy-chip {
  min-width: 5.5rem;
  text-align: center;
}

/* ===== Gate inputs row ===== */
.evvy-gate-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  align-items: end;
}

/* ===== Shopping list table ===== */
.evvy-shopping-list {
  width: 100%;
  border-collapse: collapse;
  margin-top: 0.5rem;
  font-size: 0.875rem;
}
.evvy-shopping-list th {
  text-align: left;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--evvy-text-secondary, #666);
  padding: 0.375rem 0.5rem;
  border-bottom: 2px solid var(--evvy-border-color, #DEE2E6);
}
.evvy-shopping-list td {
  padding: 0.5rem 0.5rem;
  border-bottom: 1px solid var(--evvy-border-color, #DEE2E6);
  color: var(--evvy-text-primary, #333);
}
.evvy-shopping-list td:last-child,
.evvy-shopping-list th:last-child {
  text-align: right;
}
.evvy-shopping-list tr:last-child td {
  border-bottom: none;
}
.evvy-shopping-list .evvy-sl-category {
  font-weight: 600;
  color: var(--cluster-dark, #1D3354);
}

/* ===== Gate materials card ===== */
.evvy-gate-card {
  background: color-mix(in srgb, var(--cluster-dark) 5%, transparent);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 1rem 1.125rem;
  margin-top: 0.75rem;
}
.evvy-gate-card-title {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--cluster-dark, #1D3354);
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
.evvy-gate-items {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.375rem 1rem;
  font-size: 0.8125rem;
}
.evvy-gate-item-label {
  color: var(--evvy-text-secondary, #666);
}
.evvy-gate-item-value {
  font-weight: 600;
  text-align: right;
  color: var(--evvy-text-primary, #333);
}

/* ===== Post breakdown grid ===== */
.evvy-post-breakdown {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin-top: 0.75rem;
}
.evvy-post-type {
  text-align: center;
  padding: 0.625rem 0.375rem;
  border-radius: var(--evvy-radius, 8px);
  background: color-mix(in srgb, var(--cluster-dark) 5%, transparent);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
}
.evvy-post-type-count {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--cluster-dark, #1D3354);
  line-height: 1.2;
}
.evvy-post-type-label {
  font-size: 0.6875rem;
  color: var(--evvy-text-secondary, #666);
  margin-top: 0.125rem;
}

/* ===== Cost estimator (premium) ===== */
.evvy-cost-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 0.75rem;
}
.evvy-cost-total {
  grid-column: 1 / -1;
  text-align: center;
  padding: 0.875rem;
  background: color-mix(in srgb, var(--cluster-dark) 8%, transparent);
  border-radius: var(--evvy-radius-lg, 12px);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
}
.evvy-cost-total-value {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--cluster-dark, #1D3354);
}
.evvy-cost-total-label {
  font-size: 0.75rem;
  color: var(--evvy-text-secondary, #666);
  margin-top: 0.125rem;
}

/* ===== Slope callout ===== */
.evvy-slope-callout {
  background: color-mix(in srgb, var(--cluster-dark) 6%, transparent);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 0.875rem 1rem;
  margin-top: 0.75rem;
  font-size: 0.8125rem;
  color: var(--evvy-text-secondary, #666);
  line-height: 1.55;
}
.evvy-slope-callout strong {
  color: var(--evvy-text-primary, #333);
}

/* ===== Post diagram (premium) ===== */
.evvy-post-diagram {
  position: relative;
  width: 100%;
  min-height: 180px;
  margin-top: 0.75rem;
  border-radius: var(--evvy-radius-lg, 12px);
  background: color-mix(in srgb, var(--cluster-dark) 4%, transparent);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  overflow: hidden;
}
.evvy-post-diagram svg {
  width: 100%;
  height: 100%;
}

/* ===== Custom height input ===== */
.evvy-custom-height-wrap {
  display: none;
  margin-top: 0.5rem;
}
.evvy-custom-height-wrap.evvy-visible {
  display: block;
}

/* ===== Dark mode ===== */
[data-bs-theme="dark"] .evvy-gate-card {
  background: color-mix(in srgb, var(--cluster-dark) 12%, transparent);
}
[data-bs-theme="dark"] .evvy-post-type {
  background: color-mix(in srgb, var(--cluster-dark) 12%, transparent);
}
[data-bs-theme="dark"] .evvy-cost-total {
  background: color-mix(in srgb, var(--cluster-dark) 15%, transparent);
}
[data-bs-theme="dark"] .evvy-slope-callout {
  background: color-mix(in srgb, var(--cluster-dark) 12%, transparent);
}
[data-bs-theme="dark"] .evvy-post-diagram {
  background: color-mix(in srgb, var(--cluster-dark) 10%, transparent);
}
[data-bs-theme="dark"] .evvy-shopping-list td {
  color: var(--evvy-text-primary, #ccc);
}
[data-bs-theme="dark"] .evvy-shopping-list .evvy-sl-category {
  color: color-mix(in srgb, var(--cluster-dark) 100%, white 40%);
}
[data-bs-theme="dark"] .evvy-gate-card-title {
  color: color-mix(in srgb, var(--cluster-dark) 100%, white 40%);
}
[data-bs-theme="dark"] .evvy-post-type-count {
  color: color-mix(in srgb, var(--cluster-dark) 100%, white 40%);
}
[data-bs-theme="dark"] .evvy-cost-total-value {
  color: color-mix(in srgb, var(--cluster-dark) 100%, white 40%);
}

/* ===== Mobile ===== */
@media (max-width: 575.98px) {
  .evvy-gate-row {
    grid-template-columns: 1fr;
  }
  .evvy-post-breakdown {
    grid-template-columns: 1fr 1fr;
  }
  .evvy-gate-items {
    grid-template-columns: 1fr 1fr;
  }
  .evvy-cost-grid {
    grid-template-columns: 1fr;
  }
  .evvy-fence-chip-row .evvy-chip {
    min-width: 4.5rem;
    font-size: 0.75rem;
  }
}
