/* ============================================================================
   Kollel Bnei Torah — shared styles
   Palette:  parchment #FAF7F0 · ink #1C2536 · tekhelet navy #22386A
             antique brass #A9852F · sand line #E7E0D2 · muted #5C6577
   Type:     Frank Ruhl Libre (display + Hebrew) · Libre Franklin (body/UI/data)
   ========================================================================== */

:root{
  --parchment:#FAF7F0;
  --parchment-deep:#F3EEE2;
  --surface:#FFFFFF;
  --ink:#1C2536;
  --navy:#22386A;
  --navy-deep:#192a52;
  --brass:#A9852F;
  --brass-soft:#c9aa5e;
  --sand:#E7E0D2;
  --muted:#5C6577;
  --shadow:0 1px 2px rgba(28,37,54,.04), 0 8px 28px rgba(28,37,54,.06);
  --radius:14px;
  --maxw:1080px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--parchment);
  color:var(--ink);
  font-family:"Libre Franklin",system-ui,-apple-system,Segoe UI,sans-serif;
  font-size:17px;
  line-height:1.62;
  font-feature-settings:"tnum" 0;
  -webkit-font-smoothing:antialiased;
}
:lang(he),.he{font-family:"Frank Ruhl Libre",serif;direction:rtl;unicode-bidi:isolate}

a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
img{max-width:100%}

/* ---- Layout shell -------------------------------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:54px 0}
.section + .section{padding-top:0}

/* ---- Header / banner ----------------------------------------------------- */
.banner{
  background:
    linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,0)),
    var(--parchment);
  border-bottom:1px solid var(--sand);
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(6px);
}
.banner-inner{max-width:var(--maxw);margin:0 auto;padding:18px 24px 0}
.brand{display:flex;align-items:baseline;justify-content:center;gap:14px;flex-wrap:wrap;text-align:center}
.brand .he-name{font-size:35px;color:var(--navy);line-height:1;font-weight:700}
.brand .en-name{font-family:"Frank Ruhl Libre",serif;font-size:30px;font-weight:600;letter-spacing:.01em;color:var(--ink)}
.brand-tag{
  text-align:center;color:var(--muted);font-size:12.5px;letter-spacing:.16em;
  text-transform:uppercase;margin:6px 0 0
}
.rule-brass{height:2px;background:linear-gradient(90deg,transparent,var(--brass),transparent);opacity:.5;margin:14px auto 0;max-width:340px}

/* nav */
nav.mainnav{display:flex;justify-content:center;flex-wrap:wrap;gap:2px;padding:6px 0 4px}
nav.mainnav a{
  position:relative;color:var(--ink);font-size:13.5px;font-weight:500;
  padding:11px 14px;border-radius:8px;white-space:nowrap;letter-spacing:.01em
}
nav.mainnav a:hover{background:var(--parchment-deep);text-decoration:none}
nav.mainnav a[aria-current="page"]{color:var(--navy);font-weight:600}
nav.mainnav a[aria-current="page"]::after{
  content:"";position:absolute;left:14px;right:14px;bottom:5px;height:2px;
  background:var(--brass);border-radius:2px
}

/* ---- Eyebrow + headings -------------------------------------------------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--brass);font-size:12px;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;margin:0 0 14px
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass);opacity:.7}
h1,h2,h3{font-family:"Frank Ruhl Libre",serif;color:var(--ink);font-weight:600;line-height:1.15}
h1{font-size:clamp(30px,5vw,44px);margin:.1em 0 .35em;letter-spacing:-.01em}
h2{font-size:clamp(23px,3.4vw,30px);margin:0 0 .5em}
h3{font-size:19px;margin:0 0 .35em}
.lede{font-size:19px;color:var(--muted);max-width:62ch;margin:0 0 0}

/* ---- Cards --------------------------------------------------------------- */
.card{
  background:var(--surface);border:1px solid var(--sand);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:28px 30px
}
.card.tight{padding:22px 24px}
.grid{display:grid;gap:22px}
@media(min-width:760px){.grid.cols-2{grid-template-columns:1fr 1fr}.grid.cols-3{grid-template-columns:repeat(3,1fr)}}
.card-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;border-bottom:1px solid var(--sand);padding-bottom:12px;margin-bottom:6px}
.card-head .he{color:var(--navy);font-size:22px}
.card-kicker{color:var(--brass);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600}

/* ---- The "luach line": label · · · · time  (signature element) ----------- */
.luach{list-style:none;margin:0;padding:0}
.luach li{
  display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;
  gap:10px;padding:12px 0;border-bottom:1px dotted var(--sand)
}
.luach li:last-child{border-bottom:0}
.luach .name{font-weight:500}
.luach .name small{display:block;font-weight:400;color:var(--muted);font-size:13px;letter-spacing:0;text-transform:none}
.luach .name .he{font-size:17px;color:var(--navy);font-weight:600;margin-inline-end:8px}
.luach .leader{border-bottom:1px dotted #c9c0ad;transform:translateY(-4px);min-width:18px}
.luach .time{
  font-variant-numeric:tabular-nums;font-weight:600;font-size:18px;color:var(--navy);
  white-space:nowrap
}
.luach .time.pending{color:var(--muted);font-weight:500;font-style:italic}

/* time tables (weekday neitz) */
table.zt{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
table.zt th,table.zt td{text-align:left;padding:11px 10px;border-bottom:1px solid var(--sand)}
table.zt th{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}
table.zt td.t{font-weight:600;color:var(--navy);text-align:right}
table.zt tr.today{background:#fbfaf4}
table.zt tr.today td:first-child::after{content:" • today";color:var(--brass);font-size:12px;font-weight:600}
table.zt tr.nextweek td{border-top:2px solid var(--sand)}
table.zt .nx{display:block;color:var(--muted);font-weight:400;font-size:12px;letter-spacing:.02em}

/* note / footnote chips */
.note{font-size:14.5px;color:var(--muted);background:var(--parchment-deep);border-left:3px solid var(--brass);border-radius:0 8px 8px 0;padding:12px 16px;margin:16px 0}
.muted{color:var(--muted)}
.small{font-size:14px}

/* hero (home + shabbos) */
.hero{padding:58px 0 34px}
.parsha-hero{text-align:center;padding:40px 0 8px}
.parsha-hero .he{font-size:clamp(40px,8vw,68px);color:var(--navy);line-height:1.05;margin:0}
.parsha-hero .en{font-family:"Frank Ruhl Libre",serif;font-size:clamp(20px,3.4vw,26px);color:var(--ink);margin:6px 0 0}
.parsha-hero .dates{margin-top:12px;color:var(--muted);font-size:16px}
.parsha-hero .dates .he{font-size:20px;color:var(--ink)}

/* feature row */
.feature{display:grid;gap:6px}
.feature .big{font-size:30px;font-weight:600;color:var(--navy);font-variant-numeric:tabular-nums}
.feature .lbl{color:var(--brass);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;
  padding:12px 22px;border-radius:10px;font-weight:600;font-size:15px;border:1px solid var(--navy);
  cursor:pointer;transition:background .15s
}
.btn:hover{background:var(--navy-deep);text-decoration:none}
.btn.ghost{background:transparent;color:var(--navy)}
.btn.ghost:hover{background:var(--parchment-deep)}

/* donation logos row */
.logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px}
.logo-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:104px;
  background:var(--surface);border:1px solid var(--sand);border-radius:12px;
  padding:22px 26px;min-width:200px;flex:1;text-align:center;transition:box-shadow .15s,transform .15s
}
.logo-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);text-decoration:none}
.logo-card .lname{font-family:"Frank Ruhl Libre",serif;font-size:20px;color:var(--navy);font-weight:600}
.logo-card .lsub{font-size:12px;color:var(--muted);letter-spacing:.04em}
.logo-card .logo-img{max-height:46px;max-width:170px;width:auto;height:auto;object-fit:contain;display:block}
.logo-card .logo-img.is-icon{max-height:74px;max-width:150px}
.logo-card .logo-fallback{display:none;flex-direction:column;align-items:center;gap:6px}
.logo-card.img-failed .logo-img{display:none}
.logo-card.img-failed .logo-fallback{display:flex}

/* zelle blocks */
.zelle{display:grid;gap:22px}
@media(min-width:980px){.zelle{grid-template-columns:1fr 1fr 1fr}}
.zelle-card{display:flex;gap:14px;align-items:center;background:var(--surface);border:1px solid var(--sand);border-radius:12px;padding:16px}
.zelle-card svg,.zelle-card img{width:96px;height:96px;flex:0 0 auto}
.zelle-card .z-purpose{font-weight:600;margin-bottom:2px;font-size:14.5px}
.zelle-card .z-email{font-size:12px;white-space:nowrap;letter-spacing:-.01em}
.zelle-card .z-email a{display:inline-block}
.zelle-card .z-acct{font-size:11.5px;color:var(--muted);letter-spacing:.04em;margin-top:6px;text-transform:uppercase}

/* forms */
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.field .req{color:var(--brass)}
.field input,.field textarea{
  width:100%;padding:12px 14px;border:1px solid var(--sand);border-radius:10px;
  background:var(--surface);font:inherit;color:var(--ink)
}
.field input:focus,.field textarea:focus{outline:2px solid var(--navy);outline-offset:1px;border-color:var(--navy)}
.field textarea{min-height:130px;resize:vertical}
.field .hint{font-size:13px;color:var(--muted);margin-top:5px}
.field .error{font-size:13px;color:#9a3324;margin-top:5px;display:none}
.field.invalid .error{display:block}
.field.invalid input,.field.invalid textarea{border-color:#c47b6e}
.form-status{margin-top:14px;font-weight:600}

/* contact directory */
.dir{list-style:none;margin:0;padding:0}
.dir li{padding:14px 0;border-bottom:1px dotted var(--sand);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.dir li:last-child{border-bottom:0}
.dir li.stack{flex-direction:column;align-items:flex-start;gap:4px}
.dir .role{font-weight:600}

/* footer */
footer.site{border-top:1px solid var(--sand);background:var(--parchment-deep);margin-top:40px}
footer.site .wrap{padding-top:30px;padding-bottom:34px;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center}
footer.site .he{color:var(--navy);font-size:20px}
footer.site .small{color:var(--muted)}

/* update stamp */
.stamp{font-size:12.5px;color:var(--muted);letter-spacing:.02em}
.stamp.warn{color:#9a6b1f}

/* reduced motion */
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ============================ RESPONSIVE / MOBILE ========================= */

/* Tablet and below */
@media(max-width:760px){
  .section{padding:42px 0}
  .hero{padding:44px 0 26px}
  .parsha-hero{padding:30px 0 6px}
  footer.site .wrap{flex-direction:column;align-items:flex-start;gap:10px}
}

/* Nav becomes a single swipeable row so all items stay reachable */
@media(max-width:680px){
  nav.mainnav{
    flex-wrap:nowrap;justify-content:flex-start;
    overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
    padding:6px 2px 4px
  }
  nav.mainnav::-webkit-scrollbar{display:none}
  nav.mainnav a{flex:0 0 auto}
}

/* Phone */
@media(max-width:560px){
  body{font-size:16px}
  .banner-inner{padding:14px 16px 0}
  .wrap{padding:0 16px}
  .brand{gap:8px}
  .brand .he-name{font-size:29px}
  .brand .en-name{font-size:25px}
  .brand-tag{font-size:11px;letter-spacing:.13em}
  .rule-brass{margin-top:10px}
  .card{padding:22px 18px}
  .card.tight{padding:18px 18px}
  h1{font-size:clamp(26px,8vw,34px)}
  .lede{font-size:17px}
  .luach li{grid-template-columns:1fr auto;gap:4px 10px}
  .luach .leader{display:none}
  .luach .time{font-size:17px}
  /* zelle cards: keep QR beside text, allow email to wrap as a fallback */
  .zelle-card{gap:14px;padding:14px}
  .zelle-card svg,.zelle-card img{width:84px;height:84px}
  .zelle-card .z-email{font-size:12.5px;white-space:normal;word-break:break-all}
  /* donor logos: one per row, comfortably sized */
  .logos{flex-direction:column;gap:14px}
  .logo-card{width:100%;min-height:84px;padding:18px}
  .logo-card .logo-img{max-height:42px}
  .logo-card .logo-img.is-icon{max-height:64px}
  /* directory rows stack label over value */
  .dir li{flex-direction:column;gap:2px}
  table.zt th,table.zt td{padding:10px 6px}
}

/* Small phone */
@media(max-width:380px){
  .brand .he-name{font-size:25px}
  .brand .en-name{font-size:21px}
  nav.mainnav a{font-size:13px;padding:10px 11px}
}
