/* Horaire Chabbat Community Engine - front styles */

.hc-main { max-width: 960px; margin: 0 auto; padding: 1.5rem 1rem; }

.hc-breadcrumb { font-size: 0.85em; color: #6b6b6b; margin: 0 0 1rem 0; }
.hc-breadcrumb ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 0.4rem; }
.hc-breadcrumb li::after { content: "›"; margin-left: 0.4rem; color: #aaa; }
.hc-breadcrumb li:last-child::after { content: ""; }
.hc-breadcrumb a { color: inherit; text-decoration: underline dotted; }

.hc-last-update {
  font-size: 0.85em;
  color: #6b6b6b;
  margin: -0.4em 0 1.5em 0;
  font-style: italic;
}
.hc-last-update-label { font-weight: 500; }

.hc-sources {
  font-size: 0.85em;
  color: #555;
  border-top: 1px solid #eee;
  padding-top: 0.8rem;
  margin-top: 1.5rem;
}

.hc-disclaimer {
  background: #fafaf6;
  border-left: 3px solid #c8b46a;
  padding: 0.8rem 1rem;
  margin: 1.5rem 0;
  font-size: 0.95em;
}
.hc-disclaimer-link { margin: 0.4rem 0 0 0; font-size: 0.85em; }

.hc-fields { display: grid; grid-template-columns: max-content 1fr; gap: 0.4rem 1rem; }
.hc-fields dt { font-weight: 600; }
.hc-fields dd { margin: 0; }

.hc-children-grid {
  display: grid; gap: 1rem;
  grid-template-columns: repeat( auto-fit, minmax(220px, 1fr) );
  margin: 1.5rem 0;
}
.hc-card {
  display: block;
  padding: 1rem;
  border: 1px solid #ddd;
  border-radius: 6px;
  text-decoration: none;
  color: inherit;
  background: #fff;
}
.hc-card:hover { background: #fafafa; }
.hc-card h3 { margin: 0; font-size: 1rem; }

.hc-city-list, .hc-type-list, .hc-name-cats, .hc-name-roots {
  display: grid; gap: 0.4rem;
  grid-template-columns: repeat( auto-fit, minmax(180px, 1fr) );
  padding: 0;
  list-style: none;
}
.hc-name-letters {
  list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 0.4rem;
}
.hc-name-letters li a {
  display: inline-block; padding: 0.3rem 0.6rem; border: 1px solid #ddd; border-radius: 4px; text-decoration: none;
}

.hc-names-list { list-style: none; padding: 0; columns: 2; column-gap: 2rem; }
.hc-names-list li { break-inside: avoid; padding: 0.2rem 0; }
.hc-names-list .he { color: #555; margin-left: 0.4rem; }

.hc-zmanim th { text-align: left; padding-right: 1rem; font-weight: 500; }
.hc-zmanim td { font-variant-numeric: tabular-nums; }

.hc-events { width: 100%; border-collapse: collapse; }
.hc-events th, .hc-events td { padding: 0.4rem 0.6rem; border-bottom: 1px solid #eee; text-align: left; }

.hc-comments { margin-top: 2.5rem; border-top: 1px solid #eee; padding-top: 1.5rem; }
.hc-comment { padding: 0.8rem 0; border-bottom: 1px solid #f4f4f4; }
.hc-comment header { display: flex; gap: 1rem; align-items: baseline; font-size: 0.85em; color: #666; }
.hc-comment-author { font-weight: 600; color: #222; }
.hc-comment-form { margin-top: 1.5rem; }
.hc-comment-form label { display: block; margin: 0.6rem 0; }
.hc-comment-form input[type="text"],
.hc-comment-form input[type="email"],
.hc-comment-form input[type="number"],
.hc-comment-form textarea {
  width: 100%; padding: 0.5rem; box-sizing: border-box;
}
.hc-honeypot { position: absolute; left: -9999px; }
.hc-comment-disclaimer { font-size: 0.85em; color: #777; }

.hc-he-big { font-size: 2rem; direction: rtl; text-align: right; }
