:root {
  --navy: #0f1f3d;
  --navy-soft: #1c2f55;
  --gold: #a77324;
  --gold-soft: #d7b87a;
  --paper: #f7f1e6;
  --paper-dark: #eadbc3;
  --ink: #1d2733;
  --muted: #6b7280;
  --card: rgba(255, 252, 246, 0.94);
  --line: rgba(167,115,36,.25);
  --good: #1f7a4f;
  --warn: #a15c2a;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  color: var(--ink);
  font-family: Georgia, "Times New Roman", serif;
  background:
    radial-gradient(circle at 20% 5%, rgba(255,255,255,.9), transparent 35%),
    radial-gradient(circle at 80% 10%, rgba(215,184,122,.18), transparent 28%),
    linear-gradient(135deg, #fffaf0, var(--paper));
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .18;
  background-image:
    linear-gradient(90deg, rgba(167,115,36,.08) 1px, transparent 1px),
    linear-gradient(rgba(167,115,36,.06) 1px, transparent 1px);
  background-size: 44px 44px;
}

.page {
  width: min(1220px, calc(100% - 28px));
  margin: 0 auto;
  position: relative;
}

.topbar {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: flex-start;
  padding: 32px 8px 22px;
}

.brand h1 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(40px, 6vw, 68px);
  letter-spacing: .02em;
  line-height: .9;
  font-weight: 700;
}

.ornament-line {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  color: var(--gold);
}

.ornament-line span,
.results-heading span {
  width: 52px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}

.ornament-line p {
  margin: 0;
  font-size: 16px;
}

.nav {
  display: flex;
  gap: 28px;
  padding-top: 24px;
  font-size: 17px;
}

.nav a {
  color: var(--navy);
  text-decoration: none;
  padding: 8px 0;
  border-bottom: 2px solid transparent;
}

.nav a.active,
.nav a:hover {
  border-bottom-color: var(--gold);
}

.layout {
  display: grid;
  grid-template-columns: 210px 1fr;
  gap: 26px;
  align-items: start;
}

.side-card,
.info-card,
.hero-card,
.filter-card,
.calendar-card,
.yahrtzeit-card {
  border: 1px solid var(--line);
  background: var(--card);
  box-shadow: 0 14px 34px rgba(38, 30, 18, .08);
}

.side-card {
  border-radius: 16px;
  padding: 24px 18px;
  text-align: center;
  position: sticky;
  top: 18px;
}

.side-card h2 {
  margin: 0;
  color: var(--navy);
  font-size: 17px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.mini-ornament {
  color: var(--gold);
  margin: 10px 0 18px;
}

.calendar-icon {
  margin: 0 auto 18px;
  width: 54px;
  height: 52px;
  border: 2px solid var(--gold);
  border-radius: 8px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  padding: 10px 8px 8px;
  gap: 6px;
  position: relative;
}

.calendar-icon::before,
.calendar-icon::after {
  content: "";
  position: absolute;
  top: -8px;
  width: 6px;
  height: 14px;
  border: 2px solid var(--gold);
  border-radius: 999px;
  background: var(--paper);
}
.calendar-icon::before { left: 12px; }
.calendar-icon::after { right: 12px; }

.calendar-icon div {
  width: 5px;
  height: 5px;
  background: var(--gold);
  opacity: .65;
  border-radius: 50%;
}

.side-card p {
  font-size: 16px;
  line-height: 1.55;
}

button {
  font: inherit;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  background: var(--navy);
  color: white;
  padding: 11px 16px;
  box-shadow: 0 6px 14px rgba(15,31,61,.16);
}

button:hover { background: var(--navy-soft); }

.side-divider {
  height: 1px;
  margin: 28px 6px;
  background: linear-gradient(90deg, transparent, rgba(167,115,36,.45), transparent);
}

blockquote {
  margin: 0;
  color: var(--ink);
  font-style: italic;
  line-height: 1.5;
}

blockquote span {
  color: var(--gold);
  font-size: 28px;
}

blockquote cite {
  display: block;
  color: var(--gold);
  margin-top: 10px;
  font-style: normal;
}

.main-column { min-width: 0; }

.hero-card {
  min-height: 238px;
  border-radius: 18px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 340px;
  align-items: center;
  position: relative;
  background:
    radial-gradient(circle at 83% 35%, rgba(167,115,36,.14), transparent 28%),
    linear-gradient(90deg, rgba(255,252,246,.97) 0%, rgba(248,238,219,.94) 62%, rgba(250,243,230,.75) 100%);
}

.hero-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(167,115,36,.16);
  border-radius: 14px;
  pointer-events: none;
}

.hero-copy {
  text-align: center;
  padding: 24px;
  position: relative;
  z-index: 1;
}

.small-title {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 23px;
}

.small-title::before,
.small-title::after {
  content: "";
  width: 52px;
  height: 1px;
  background: var(--gold);
}

.hero-hebrew {
  direction: rtl;
  color: var(--navy);
  font-family: "Times New Roman", Georgia, serif;
  font-size: clamp(64px, 10vw, 104px);
  font-weight: 800;
  letter-spacing: .02em;
  margin-top: 8px;
}

.hero-english {
  color: var(--navy);
  font-size: 32px;
  margin-top: 2px;
}

.hero-art {
  height: 100%;
  position: relative;
  background:
    linear-gradient(90deg, rgba(255,252,246,.98) 0%, rgba(255,252,246,.42) 18%, rgba(255,252,246,0) 42%),
    url("assets/hero-books-candle.png") center right / cover no-repeat;
  overflow: hidden;
}

.books {
  position: absolute;
  right: 18px;
  top: 54px;
  width: 198px;
  height: 110px;
  transform: rotate(-3deg);
}

.book {
  position: absolute;
  right: 0;
  width: 178px;
  height: 34px;
  border-radius: 4px;
  background: linear-gradient(90deg, #0e1d36, #253b66 55%, #0a162c);
  color: var(--gold-soft);
  border: 1px solid rgba(215,184,122,.65);
  box-shadow: 0 10px 20px rgba(15,31,61,.16);
  direction: rtl;
  padding: 7px 14px;
  font-weight: 700;
}

.book-one { top: 0; right: 10px; }
.book-two { top: 34px; right: 0; }
.book-three { top: 68px; right: 18px; }

.candle {
  position: absolute;
  right: 28px;
  bottom: 24px;
  width: 70px;
  height: 110px;
}

.flame {
  width: 22px;
  height: 38px;
  margin: 0 auto;
  border-radius: 55% 55% 45% 45%;
  background: radial-gradient(circle at 55% 58%, #fff4b8 0 22%, #f7b44a 44%, #b56b17 78%);
  box-shadow: 0 0 30px rgba(247,180,74,.85);
}

.wick {
  width: 2px;
  height: 14px;
  margin: -5px auto 0;
  background: #2b1d10;
}

.wax {
  width: 36px;
  height: 54px;
  margin: 0 auto;
  border-radius: 8px 8px 4px 4px;
  background: linear-gradient(90deg, #fff7da, #e5d5a8);
  border: 1px solid rgba(167,115,36,.35);
}

.holder {
  width: 68px;
  height: 14px;
  margin-top: -2px;
  border-radius: 50%;
  background: linear-gradient(90deg, #8f651e, #d2a64e, #7f5518);
}

.filter-card {
  margin-top: 14px;
  border-radius: 16px;
  padding: 16px;
  display: grid;
  grid-template-columns: 1fr 130px 1.4fr;
  gap: 18px;
}

.field label {
  display: block;
  margin-bottom: 7px;
  color: var(--navy);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .09em;
  font-weight: 700;
}

select,
input {
  width: 100%;
  border: 1px solid rgba(15,31,61,.24);
  border-radius: 8px;
  background: rgba(255,255,255,.78);
  padding: 13px 14px;
  color: var(--ink);
  font: 16px Georgia, "Times New Roman", serif;
}

.calendar-card {
  margin-top: 14px;
  border-radius: 16px;
  padding: 16px;
}

.calendar-top {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.overline {
  margin: 0 0 4px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--gold);
  font-size: 12px;
  font-weight: 700;
}

.calendar-top h2 {
  color: var(--navy);
  margin: 0;
}

.small-note {
  color: var(--muted);
  font-size: 14px;
  margin: 0;
}

.month-grid {
  display: grid;
  grid-template-columns: repeat(10, minmax(56px, 1fr));
  gap: 8px;
}

.day-button {
  min-height: 54px;
  padding: 8px;
  border-radius: 10px;
  border: 1px solid rgba(167,115,36,.24);
  background: rgba(255,255,255,.65);
  color: var(--navy);
  cursor: pointer;
  text-align: center;
  position: relative;
}

.day-button:hover,
.day-button.active {
  background: #fff7e6;
  border-color: var(--gold);
}

.day-he {
  font-weight: 800;
  font-size: 18px;
}

.day-en {
  font-size: 12px;
  color: var(--muted);
}

.badge {
  display: inline-block;
  margin-top: 4px;
  min-width: 22px;
  padding: 2px 6px;
  border-radius: 999px;
  background: var(--navy);
  color: white;
  font-size: 12px;
}

.content-grid {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 28px;
  margin-top: 18px;
}

.results-heading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.results-heading h2 {
  margin: 0;
  font-size: 24px;
  text-align: center;
}

.count-line {
  text-align: center;
  color: var(--muted);
  margin: 8px 0 14px;
}

.results {
  display: grid;
  gap: 10px;
}

.yahrtzeit-card {
  border-radius: 13px;
  padding: 15px;
  display: grid;
  grid-template-columns: 78px 1fr;
  gap: 16px;
  align-items: center;
}

.card-icon {
  width: 62px;
  height: 62px;
  margin: auto;
  border-radius: 50%;
  border: 2px solid rgba(167,115,36,.62);
  background:
    radial-gradient(circle at 50% 42%, rgba(255,207,94,.16), transparent 36%),
    linear-gradient(135deg, #0f1f3d, #1c2f55);
  box-shadow: inset 0 0 0 3px rgba(255,252,246,.35), 0 8px 16px rgba(15,31,61,.16);
  position: relative;
}

.card-icon::before {
  content: "";
  position: absolute;
  left: 25px;
  top: 12px;
  width: 12px;
  height: 24px;
  border-radius: 60% 60% 45% 45%;
  background: radial-gradient(circle at 54% 56%, #fff4b8 0 22%, #f7b44a 43%, #b56b17 80%);
  box-shadow: 0 0 18px rgba(247,180,74,.82);
}

.card-icon::after {
  content: "";
  position: absolute;
  left: 20px;
  bottom: 12px;
  width: 22px;
  height: 18px;
  border: 1px solid var(--gold-soft);
  border-radius: 3px 3px 8px 8px;
  background: linear-gradient(90deg, #eadbc3, #fff7da, #c29c55);
}

.name-hebrew {
  direction: rtl;
  text-align: left;
  color: var(--navy);
  font-size: 28px;
  font-weight: 800;
  line-height: 1.15;
  margin: 0 0 4px;
}

.name-english {
  margin: 0;
  color: var(--navy);
  font-size: 18px;
}

.known-as {
  margin: 5px 0 0;
  color: #8b5a17;
  font-style: italic;
  font-size: 17px;
}

.year-line {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 15px;
}

.status {
  display: inline-block;
  margin-top: 8px;
  font-size: 12px;
  border-radius: 999px;
  padding: 3px 8px;
  background: rgba(31,122,79,.1);
  color: var(--good);
}

.status.warn,
.status.conflict {
  background: rgba(161,92,42,.1);
  color: var(--warn);
}

details { margin-top: 10px; }

summary {
  color: var(--navy);
  font-weight: 700;
  cursor: pointer;
  list-style-position: outside;
}

.details-grid {
  display: grid;
  grid-template-columns: 135px 1fr;
  gap: 8px 12px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(167,115,36,.18);
}

.details-grid dt {
  color: var(--navy);
  font-weight: 700;
}

.details-grid dd {
  margin: 0;
  color: var(--muted);
  overflow-wrap: anywhere;
}

.missing {
  color: var(--warn);
  font-style: italic;
}

.right-cards {
  display: grid;
  gap: 14px;
  align-content: start;
}

.info-card {
  border-radius: 15px;
  padding: 22px 18px;
  text-align: center;
}

.info-icon {
  color: var(--gold);
  font-size: 30px;
}

.info-card h3 {
  color: var(--navy);
  margin: 10px 0 8px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.info-card p {
  line-height: 1.55;
  margin: 0;
}

.empty {
  text-align: center;
  border: 1px dashed rgba(167,115,36,.45);
  border-radius: 14px;
  color: var(--muted);
  padding: 26px;
  background: rgba(255,252,246,.7);
}

footer {
  color: var(--muted);
  text-align: center;
  padding: 34px 0;
}

.footer-zl {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  color: var(--navy);
  margin-bottom: 12px;
}

.footer-zl span {
  width: min(210px, 22vw);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}

.footer-zl strong {
  direction: rtl;
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 800;
  letter-spacing: .04em;
}

@media (max-width: 980px) {
  .topbar,
  .layout,
  .content-grid {
    grid-template-columns: 1fr;
    display: grid;
  }

  .topbar { gap: 10px; }
  .nav { padding-top: 0; flex-wrap: wrap; }
  .side-card { position: static; }
  .hero-card { grid-template-columns: 1fr; }
  .hero-art { display: none; }
  .filter-card { grid-template-columns: 1fr; }
  .right-cards { grid-template-columns: 1fr 1fr; }
  .month-grid { grid-template-columns: repeat(6, 1fr); }
}

@media (max-width: 620px) {
  .page { width: min(100% - 18px, 1220px); }
  .topbar { padding-top: 22px; }
  .brand h1 { font-size: 42px; }
  .nav { gap: 18px; font-size: 15px; }
  .hero-card { min-height: 190px; }
  .hero-hebrew { font-size: 62px; }
  .hero-english { font-size: 26px; }
  .month-grid { grid-template-columns: repeat(5, 1fr); gap: 6px; }
  .day-button { min-height: 50px; }
  .yahrtzeit-card { grid-template-columns: 1fr; text-align: center; }
  .name-hebrew { text-align: center; font-size: 25px; }
  .details-grid { grid-template-columns: 1fr; }
  .right-cards { grid-template-columns: 1fr; }
}


/* v4: realistic hero artwork uses an image asset; hide the older CSS-drawn books/candle inside the hero. */
.hero-art .books,
.hero-art .candle {
  display: none;
}

#locationNote {
  max-width: 860px;
  margin: 0 auto 8px;
}


/* v5 enhancements */
.hero-art {
  background:
    linear-gradient(90deg, rgba(255,252,246,.98) 0%, rgba(255,252,246,.48) 18%, rgba(255,252,246,0) 42%),
    url("assets/hero-books-candle.png") center right / cover no-repeat;
  filter: saturate(1.03) contrast(1.02);
}

.card-icon {
  width: 66px;
  height: 66px;
  border: 2px solid rgba(167,115,36,.68);
  background:
    radial-gradient(circle at 50% 38%, rgba(255,220,127,.26), transparent 24%),
    radial-gradient(circle at 50% 65%, rgba(255,252,246,.10), transparent 34%),
    linear-gradient(135deg, #102247, #1e3a67 58%, #102247);
  box-shadow:
    inset 0 0 0 3px rgba(255,252,246,.40),
    0 10px 18px rgba(15,31,61,.18);
}
.card-icon::before {
  left: 25px;
  top: 11px;
  width: 14px;
  height: 26px;
  border-radius: 55% 55% 45% 45%;
  background: radial-gradient(circle at 52% 58%, #fff9d6 0 18%, #ffd36b 36%, #f49d2d 62%, #a95b0f 92%);
  box-shadow:
    0 0 7px rgba(255,227,149,.95),
    0 0 18px rgba(244,157,45,.65);
}
.card-icon::after {
  left: 18px;
  bottom: 12px;
  width: 30px;
  height: 20px;
  border: 1px solid var(--gold-soft);
  border-radius: 4px 4px 10px 10px;
  background:
    linear-gradient(90deg, #d5b06a, #fff4d6 45%, #c99647);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.65),
    0 3px 6px rgba(15,31,61,.10);
}
.card-icon .inner-wick { display:none; }

.coming-soon-card {
  background:
    linear-gradient(180deg, rgba(255,252,246,.98), rgba(249,242,229,.96));
}

.pill-row {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 12px;
}

.pill {
  display: inline-block;
  border-radius: 999px;
  padding: 5px 10px;
  background: rgba(15,31,61,.08);
  color: var(--navy);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .03em;
}

.secondary-button {
  margin-top: 14px;
  width: 100%;
  background: linear-gradient(90deg, #294067, #0f1f3d);
  opacity: 1;
}

.secondary-button[disabled] {
  cursor: default;
  filter: none;
  opacity: .94;
}

@media (max-width: 980px) {
  .right-cards {
    grid-template-columns: 1fr;
  }
}
