/* English inner-page styles — extends styles.css */

/* ===== LIVE COMPONENTS (LiveComponents.jsx) ===== */

/* Live Activity Clock — institutional ticker */
.liveclock { font-family: var(--font-sans); font-size: .8rem; letter-spacing: .04em; color: var(--cream); display: inline-flex; align-items: center; gap: .55rem; padding: .55rem 1rem; background: rgba(0,0,0,.3); border: 1px solid rgba(212,165,116,.3); animation: lc-fade .55s ease-out; }
.liveclock .dot { width: 8px; height: 8px; border-radius: 50%; background: #4ade80; box-shadow: 0 0 0 0 rgba(74,222,128,.7); animation: lc-pulse 1.6s infinite; }
.liveclock .time { font-variant-numeric: tabular-nums; color: var(--gold-soft); font-weight: 600; }
.liveclock .city { color: var(--cream); font-weight: 600; text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; }
.liveclock .msg { color: rgba(245,240,232,.85); font-family: var(--font-serif); font-size: .92rem; letter-spacing: 0; }
.liveclock .sep { color: rgba(245,240,232,.35); }
@keyframes lc-pulse { 0% { box-shadow: 0 0 0 0 rgba(74,222,128,.6);} 70% { box-shadow: 0 0 0 8px rgba(74,222,128,0);} 100% { box-shadow: 0 0 0 0 rgba(74,222,128,0);} }
@keyframes lc-fade  { from { opacity: 0; transform: translateY(4px);} to { opacity: 1; transform: none;} }
.liveclock-light { background: var(--paper); border: 1px solid var(--rule); color: var(--ink); }
.liveclock-light .city { color: var(--teal); }
.liveclock-light .msg { color: var(--slate); }
.liveclock-light .time { color: var(--gold); }
.liveclock-light .sep { color: var(--rule); }

/* Animated Counter — inline numeric */
.counter { font-variant-numeric: tabular-nums; }

/* WhatsApp floater */
.wa-floater { position: fixed; right: 1.4rem; bottom: 1.4rem; z-index: 80; display: flex; flex-direction: column; align-items: flex-end; gap: .9rem; }
.wa-btn { width: 56px; height: 56px; border-radius: 50%; background: #25D366; color: white; border: none; box-shadow: 0 8px 24px rgba(37,211,102,.4), 0 2px 8px rgba(0,0,0,.2); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: transform .2s; }
.wa-btn:hover { transform: scale(1.06); }
.wa-card { width: 300px; background: var(--paper); border: 1px solid var(--rule); border-bottom: 4px solid #25D366; box-shadow: 0 24px 60px rgba(0,0,0,.16); animation: wa-slide .25s ease-out; overflow: hidden; }
@keyframes wa-slide { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.wa-head { display: flex; align-items: flex-start; justify-content: space-between; padding: 1rem 1.2rem .6rem; background: var(--ink); color: var(--cream); }
.wa-head .nm { font-family: var(--font-serif); font-weight: 700; }
.wa-head .meta { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(245,240,232,.65); margin-top: .15rem; font-weight: 600; }
.wa-head .x { background: none; border: none; color: var(--cream); font-size: 1.6rem; line-height: 1; cursor: pointer; padding: 0; }
.wa-body { padding: 1rem 1.2rem; }
.wa-body p { font-family: var(--font-serif); color: var(--slate); font-size: .92rem; line-height: 1.5; margin: 0; }
.wa-cta { display: block; padding: .85rem 1.2rem; background: #25D366; color: white; text-decoration: none; font-family: var(--font-sans); text-transform: uppercase; letter-spacing: .12em; font-size: .76rem; font-weight: 700; text-align: center; }

/* Charidy-style live campaign embed */
.charidy { background: var(--paper); border: 1px solid var(--rule); box-shadow: 0 30px 60px rgba(10,42,38,.08); overflow: hidden; }
.ch-head { display: grid; grid-template-columns: 1.6fr .8fr; align-items: stretch; }
.ch-head > div:first-child { padding: 2rem 2rem 1.4rem; }
.ch-kicker { font-family: var(--font-sans); font-size: .74rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.ch-raised { font-family: var(--font-display); font-style: italic; color: var(--ink); font-size: clamp(2.4rem, 4.6vw, 3.6rem); line-height: 1; margin: .4rem 0 .3rem; letter-spacing: -.02em; }
.ch-of { font-family: var(--font-serif); color: var(--slate); font-size: .98rem; }
.ch-clock { background: var(--ink); color: var(--cream); padding: 2rem 1.6rem; display: flex; flex-direction: column; justify-content: center; align-items: flex-start; gap: .4rem; }
.ch-clock-lbl { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-soft); font-weight: 600; }
.ch-clock-val { font-family: var(--font-serif); font-style: italic; color: var(--cream); font-size: 1.15rem; line-height: 1.2; }
.ch-clock-pulse { display: inline-flex; align-items: center; gap: .4rem; font-family: var(--font-sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(245,240,232,.6); margin-top: .3rem; font-weight: 600; }
.ch-clock-pulse .dot { width: 7px; height: 7px; border-radius: 50%; background: #ef4444; box-shadow: 0 0 0 0 rgba(239,68,68,.7); animation: lc-pulse 1.4s infinite; }
.ch-bar { height: 14px; background: var(--bg-cream); position: relative; }
.ch-bar-fill { height: 100%; background: linear-gradient(90deg, var(--gold), #c89860); transition: width 1.4s cubic-bezier(.4,.0,.2,1); position: relative; }
.ch-bar-fill::after { content:""; position: absolute; right: 0; top:0; bottom:0; width: 4px; background: rgba(255,255,255,.5); animation: lc-pulse 1.4s infinite; }
.ch-tiers { display: grid; grid-template-columns: repeat(6, 1fr); border-top: 1px solid var(--rule); }
.ch-tier { padding: 1.4rem 1rem; background: var(--cream); border: none; border-right: 1px solid var(--rule); text-align: left; cursor: pointer; transition: background .15s; font-family: inherit; display: flex; flex-direction: column; gap: .3rem; }
.ch-tier:last-child { border-right: none; }
.ch-tier:hover { background: var(--paper); }
.ch-tier .amt { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: 1.5rem; line-height: 1; }
.ch-tier .l { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: .96rem; }
.ch-tier .d { font-family: var(--font-serif); color: var(--slate); font-size: .82rem; line-height: 1.4; flex: 1; }
.ch-tier .cta { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--teal); font-weight: 600; margin-top: .4rem; }
.ch-tier.featured { background: var(--ink); color: var(--cream); }
.ch-tier.featured .l { color: var(--cream); }
.ch-tier.featured .d { color: rgba(245,240,232,.7); }
.ch-tier.featured .amt { color: var(--gold-soft); }
.ch-tier.featured .cta { color: var(--gold-soft); }
.ch-foot { display: flex; justify-content: space-between; padding: 1rem 1.6rem; background: var(--bg-cream); border-top: 1px solid var(--rule); font-family: var(--font-sans); font-size: .72rem; letter-spacing: .08em; color: var(--slate); font-weight: 500; }
.ch-foot .trust { color: var(--gold); font-weight: 700; }
@media (max-width: 900px) { .ch-head { grid-template-columns: 1fr; } .ch-tiers { grid-template-columns: repeat(2,1fr); } .ch-tier { border-bottom: 1px solid var(--rule); } }

/* ===== YAHRZEIT WALL ===== */
.yw-hero { background: #0c2422; color: var(--cream); padding: 5rem 1.5rem 3rem; text-align: center; position: relative; overflow: hidden; }
.yw-hero::before { content:""; position: absolute; inset: 0; background: radial-gradient(ellipse 800px 400px at center top, rgba(212,165,116,.12), transparent 70%); }
.yw-hero .inner { position: relative; z-index: 2; max-width: 720px; margin: 0 auto; }
.yw-hero .deco { font-family: var(--font-display); font-style: italic; color: var(--gold-soft); font-size: 3.2rem; line-height: 1; }
.yw-hero h1 { font-family: var(--font-serif); font-weight: 700; color: var(--cream); font-size: clamp(2.2rem, 4.6vw, 3.4rem); line-height: 1.1; margin: .5rem 0 1rem; }
.yw-hero h1 em { font-family: var(--font-display); font-style: italic; color: var(--gold-soft); font-weight: 600; }
.yw-hero p { font-family: var(--font-serif); font-style: italic; color: rgba(245,240,232,.78); font-size: 1.15rem; line-height: 1.55; }
.yw-meta { background: var(--ink); color: var(--cream); padding: 1.2rem 1.5rem; display: flex; justify-content: center; gap: 2.4rem; flex-wrap: wrap; font-family: var(--font-sans); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; }
.yw-meta b { color: var(--gold-soft); margin-right: .4rem; }
.yw-search { padding: 2rem 1.5rem; background: var(--bg-cream); border-bottom: 1px solid var(--rule); }
.yw-search .row { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1.3fr 1fr 1fr auto; gap: .7rem; align-items: end; }
.yw-search label { display: block; font-family: var(--font-sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); font-weight: 600; margin-bottom: .25rem; }
.yw-search input, .yw-search select { width: 100%; padding: .7rem .85rem; border: 1px solid var(--rule); background: var(--paper); font-family: var(--font-serif); font-size: .96rem; color: var(--ink); }
.yw-search button { padding: .7rem 1.4rem; background: var(--ink); color: var(--cream); font-family: var(--font-sans); font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; border: none; cursor: pointer; }
@media (max-width: 760px) { .yw-search .row { grid-template-columns: 1fr; } }
.yw-grid { padding: 2.4rem 1.5rem; max-width: 1200px; margin: 0 auto; }
.yw-letter { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: 2rem; padding: 1.2rem 0 .6rem; border-bottom: 1px solid var(--rule); margin-top: 1.6rem; }
.yw-letter:first-child { margin-top: 0; }
.yw-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 0; margin-top: 1rem; }
.yw-card { padding: 1.2rem 1.4rem; border: 1px solid var(--rule); background: var(--paper); margin: -1px 0 0 -1px; }
.yw-card .nm { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: 1.04rem; }
.yw-card .nm em { font-style: italic; font-weight: 500; color: var(--slate); font-size: .9rem; display: block; margin-top: .15rem; }
.yw-card .yr { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 600; margin-top: .5rem; }
.yw-card .ded { font-family: var(--font-serif); font-style: italic; color: var(--slate); font-size: .88rem; margin-top: .5rem; line-height: 1.45; }
.yw-card .by { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--slate-soft); margin-top: .5rem; font-weight: 600; }

/* ===== IMPACT (KPIs) ===== */
.imp-hero { background: var(--teal); color: var(--cream); padding: 5rem 1.5rem 4rem; }
.imp-hero .inner { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1.1fr .9fr; gap: 3rem; align-items: end; }
.imp-hero h1 { font-family: var(--font-serif); font-weight: 700; color: var(--cream); font-size: clamp(2.4rem, 5vw, 3.8rem); line-height: 1.05; margin: .5rem 0 1rem; }
.imp-hero h1 em { font-family: var(--font-display); font-style: italic; color: var(--gold-soft); font-weight: 600; }
.imp-hero .lede { font-family: var(--font-serif); font-style: italic; color: rgba(245,240,232,.85); font-size: 1.2rem; line-height: 1.55; }
.imp-hero .pill { display: inline-block; font-family: var(--font-sans); font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold-soft); border: 1px solid rgba(212,165,116,.5); padding: .35rem .8rem; font-weight: 600; }
.imp-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1px; background: var(--rule); border: 1px solid var(--rule); margin-top: -3rem; max-width: 1100px; margin-left: auto; margin-right: auto; position: relative; z-index: 5; box-shadow: 0 30px 60px rgba(10,42,38,.18); }
.imp-kpi { background: var(--paper); padding: 2rem 1.6rem; }
.imp-kpi .lbl { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: var(--slate); font-weight: 600; }
.imp-kpi .num { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: clamp(2.4rem, 4vw, 3.4rem); line-height: 1; margin: .5rem 0 .3rem; letter-spacing: -.02em; }
.imp-kpi .delta { font-family: var(--font-serif); color: var(--slate); font-size: .88rem; line-height: 1.4; }
.imp-kpi .delta b { color: var(--teal); font-family: var(--font-sans); font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 700; }

.imp-section { padding: 4.5rem 1.5rem; }
.imp-section.cream { background: var(--bg-cream); }
.imp-section .container { max-width: 1100px; margin: 0 auto; }
.imp-section h2 { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: clamp(1.8rem, 3.4vw, 2.4rem); line-height: 1.15; margin: 0 0 .5rem; }
.imp-section h2 em { font-family: var(--font-display); font-style: italic; color: var(--gold); font-weight: 600; }
.imp-section .sub { font-family: var(--font-serif); font-style: italic; color: var(--slate); font-size: 1.05rem; max-width: 620px; margin-bottom: 2.4rem; }

.imp-bars { display: grid; gap: 1.2rem; }
.imp-bar { display: grid; grid-template-columns: 200px 1fr 110px; gap: 1.2rem; align-items: center; }
.imp-bar .lbl { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: 1rem; }
.imp-bar .lbl small { display: block; font-family: var(--font-sans); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--slate-soft); margin-top: .15rem; font-weight: 600; }
.imp-bar .track { height: 26px; background: var(--paper); border: 1px solid var(--rule); position: relative; overflow: hidden; }
.imp-bar .track .fill { position: absolute; inset: 0 auto 0 0; background: linear-gradient(90deg, var(--teal-deep), var(--teal)); }
.imp-bar .track .fill.gold { background: linear-gradient(90deg, var(--gold-deep), var(--gold)); }
.imp-bar .v { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: 1.6rem; line-height: 1; text-align: right; }
@media (max-width: 700px) { .imp-bar { grid-template-columns: 1fr; gap: .35rem; } .imp-bar .v { text-align: left; } }

.imp-spend { display: grid; grid-template-columns: repeat(4, 1fr); gap: .8rem; }
.imp-spend .cell { background: var(--paper); border: 1px solid var(--rule); padding: 1.4rem 1.2rem; }
.imp-spend .pct { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: 2.2rem; line-height: 1; }
.imp-spend .nm { font-family: var(--font-serif); font-weight: 700; color: var(--ink); margin-top: .4rem; }
.imp-spend .desc { font-family: var(--font-serif); color: var(--slate); font-size: .88rem; margin-top: .4rem; line-height: 1.45; }
@media (max-width: 800px) { .imp-spend { grid-template-columns: 1fr 1fr; } }

.imp-quote { background: var(--ink); color: var(--cream); padding: 4rem 1.5rem; text-align: center; }
.imp-quote .col { max-width: 740px; margin: 0 auto; }
.imp-quote blockquote { font-family: var(--font-display); font-style: italic; color: var(--cream); font-size: clamp(1.4rem, 2.5vw, 1.9rem); line-height: 1.45; margin: 0; }
.imp-quote .who { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold-soft); margin-top: 1.6rem; font-weight: 600; }

/* ===== YESHUOS HUB ===== */
.ys-hero { background: var(--paper); padding: 4rem 1.5rem 3rem; text-align: center; position: relative; }
.ys-hero::before { content:""; position: absolute; left:0; right:0; top:0; height: 6px; background: linear-gradient(90deg, transparent, var(--gold), transparent); }
.ys-hero .deco { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: 3rem; line-height: 1; }
.ys-hero .kicker { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .22em; text-transform: uppercase; color: var(--slate); font-weight: 600; margin: .8rem 0 .5rem; }
.ys-hero h1 { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: clamp(2.4rem, 5vw, 3.6rem); line-height: 1.05; margin: 0 0 1rem; }
.ys-hero h1 em { font-family: var(--font-display); font-style: italic; color: var(--gold); font-weight: 600; }
.ys-hero p { font-family: var(--font-serif); font-style: italic; color: var(--slate); font-size: 1.18rem; max-width: 640px; margin: 0 auto; line-height: 1.55; }
.ys-grid { padding: 4rem 1.5rem; background: var(--bg-cream); }
.ys-grid .container { max-width: 1100px; margin: 0 auto; columns: 3; column-gap: 1.4rem; }
@media (max-width: 900px) { .ys-grid .container { columns: 2; } }
@media (max-width: 600px) { .ys-grid .container { columns: 1; } }
.ys-card { break-inside: avoid; background: var(--paper); border: 1px solid var(--rule); padding: 1.6rem; margin-bottom: 1.4rem; display: block; }
.ys-card .cat { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.ys-card h3 { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: 1.12rem; margin: .4rem 0 .5rem; line-height: 1.3; }
.ys-card .when { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--slate-soft); font-weight: 600; }
.ys-card blockquote { font-family: var(--font-display); font-style: italic; color: var(--ink); font-size: 1.05rem; line-height: 1.5; margin: 1rem 0; padding-left: 1rem; border-left: 2px solid var(--gold); }
.ys-card .who { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--slate); font-weight: 600; margin-top: .8rem; }
.ys-segula { background: var(--ink); color: var(--cream); padding: 4rem 1.5rem; text-align: center; }
.ys-segula .col { max-width: 720px; margin: 0 auto; }
.ys-segula h2 { font-family: var(--font-display); font-style: italic; color: var(--gold-soft); font-size: clamp(2rem, 4vw, 2.8rem); margin: 0 0 1rem; }
.ys-segula p { font-family: var(--font-serif); font-style: italic; color: rgba(245,240,232,.85); font-size: 1.15rem; line-height: 1.6; }
.ys-segula .btn { display: inline-block; margin-top: 1.6rem; background: var(--gold); color: var(--ink); padding: .9rem 1.6rem; font-family: var(--font-sans); font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 700; text-decoration: none; }

/* ===== DEDICATION CATALOG ===== */
.dc-hero { background: var(--paper); padding: 5rem 1.5rem 3rem; }
.dc-hero .inner { max-width: 1080px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.dc-hero .img { aspect-ratio: 4/5; overflow: hidden; box-shadow: 0 30px 60px rgba(10,42,38,.18); }
.dc-hero .img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dc-hero h1 { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: clamp(2.4rem, 5vw, 3.6rem); line-height: 1.05; margin: .5rem 0 1.4rem; }
.dc-hero h1 em { font-family: var(--font-display); font-style: italic; color: var(--gold); font-weight: 600; }
.dc-hero p { font-family: var(--font-serif); color: var(--slate); font-size: 1.1rem; line-height: 1.65; }
@media (max-width: 800px) { .dc-hero .inner { grid-template-columns: 1fr; } }

.dc-cat { padding: 4.5rem 1.5rem; }
.dc-cat.dark { background: var(--ink); color: var(--cream); }
.dc-cat.cream { background: var(--bg-cream); }
.dc-cat .container { max-width: 1100px; margin: 0 auto; }
.dc-cat h2 { font-family: var(--font-serif); font-weight: 700; font-size: clamp(2rem, 4vw, 2.6rem); line-height: 1.1; margin: 0 0 .4rem; }
.dc-cat h2 em { font-family: var(--font-display); font-style: italic; color: var(--gold); font-weight: 600; }
.dc-cat.cream h2 { color: var(--ink); }
.dc-cat.dark h2 { color: var(--cream); }
.dc-cat p.lede { font-family: var(--font-serif); font-style: italic; font-size: 1.1rem; max-width: 640px; margin-bottom: 2.4rem; }
.dc-cat.cream p.lede { color: var(--slate); }
.dc-cat.dark p.lede { color: rgba(245,240,232,.78); }

.dc-items { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.6rem; }
.dc-item { background: var(--paper); border: 1px solid var(--rule); display: grid; grid-template-columns: 1.1fr 1fr; min-height: 280px; }
.dc-cat.dark .dc-item { background: rgba(255,255,255,.03); border-color: rgba(212,165,116,.18); }
.dc-item .img { background: var(--bg-cream); overflow: hidden; }
.dc-item .img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dc-item .body { padding: 1.6rem 1.6rem; display: flex; flex-direction: column; }
.dc-item .price { font-family: var(--font-display); font-style: italic; color: var(--gold); font-size: 2.2rem; line-height: 1; margin-bottom: .5rem; }
.dc-item h3 { font-family: var(--font-serif); font-weight: 700; font-size: 1.2rem; margin: 0 0 .5rem; line-height: 1.25; }
.dc-cat.cream .dc-item h3 { color: var(--ink); }
.dc-cat.dark .dc-item h3 { color: var(--cream); }
.dc-item p { font-family: var(--font-serif); font-size: .92rem; line-height: 1.55; flex: 1; }
.dc-cat.cream .dc-item p { color: var(--slate); }
.dc-cat.dark .dc-item p { color: rgba(245,240,232,.7); }
.dc-item .cta { display: inline-block; margin-top: 1rem; font-family: var(--font-sans); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 700; text-decoration: none; }
.dc-item .incl { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--slate-soft); margin-top: 1rem; padding-top: .8rem; border-top: 1px dashed var(--rule); font-weight: 600; line-height: 1.5; }
.dc-cat.dark .dc-item .incl { color: rgba(245,240,232,.55); border-color: rgba(212,165,116,.18); }
@media (max-width: 800px) { .dc-items, .dc-item { grid-template-columns: 1fr; } .dc-item { min-height: 0; } }

.dc-plaque { background: var(--paper); padding: 4.5rem 1.5rem; }
.dc-plaque .col { max-width: 980px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.1fr; gap: 3rem; align-items: center; }
.dc-plaque h2 { font-family: var(--font-serif); font-weight: 700; color: var(--ink); font-size: clamp(1.8rem, 3.6vw, 2.4rem); margin: 0 0 1rem; line-height: 1.15; }
.dc-plaque h2 em { font-family: var(--font-display); font-style: italic; color: var(--gold); font-weight: 600; }
.dc-plaque p { font-family: var(--font-serif); color: var(--slate); font-size: 1.05rem; line-height: 1.65; margin-bottom: .8rem; }
.dc-plaque-mockup { background: linear-gradient(135deg, #b8a072 0%, #8a6d3a 50%, #b8a072 100%); padding: 3rem 2.4rem; aspect-ratio: 5/4; display: flex; flex-direction: column; justify-content: center; align-items: center; box-shadow: 0 30px 60px rgba(0,0,0,.25), inset 0 0 60px rgba(0,0,0,.15); border: 4px solid #6a4f24; position: relative; }
.dc-plaque-mockup::before { content:""; position: absolute; inset: 8px; border: 1px solid rgba(0,0,0,.3); pointer-events: none; }
.dc-plaque-mockup .deco { font-family: var(--font-display); font-style: italic; color: rgba(0,0,0,.55); font-size: 1.6rem; }
.dc-plaque-mockup .lh { font-family: var(--font-display); font-style: italic; color: rgba(0,0,0,.7); font-size: 1.3rem; letter-spacing: .04em; margin: .8rem 0 .4rem; }
.dc-plaque-mockup .nm { font-family: var(--font-serif); font-weight: 700; color: rgba(0,0,0,.85); font-size: 1.7rem; line-height: 1.2; text-align: center; }
.dc-plaque-mockup .ded { font-family: var(--font-serif); font-style: italic; color: rgba(0,0,0,.7); font-size: 1.05rem; margin-top: .6rem; text-align: center; }
.dc-plaque-mockup .by { font-family: var(--font-sans); font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(0,0,0,.65); margin-top: 1rem; font-weight: 700; }
@media (max-width: 800px) { .dc-plaque .col { grid-template-columns: 1fr; } }

/* page hero (smaller than home hero) */
.page-hero { background: var(--teal); color: var(--cream); padding: 4rem 1.5rem 4.5rem; position: relative; overflow: hidden; }
.page-hero .inner { max-width: 980px; margin: 0 auto; text-align: center; position: relative; z-index: 2; }
.page-hero .eyebrow { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold-soft); font-weight: 600; }
.page-hero h1 { font-family: var(--font-serif); font-weight: 700; font-size: clamp(2.2rem, 4.2vw, 3.4rem); line-height: 1.05; margin: .8rem 0 1rem; color: var(--cream); letter-spacing: -.01em; }
.page-hero h1 em { font-style: italic; color: var(--gold-soft); font-weight: 600; }
.page-hero p { font-family: var(--font-sans); font-size: 1.08rem; line-height: 1.6; color: rgba(245,240,232,.78); max-width: 640px; margin: 0 auto; }

/* breadcrumb */
.crumb { max-width: 1180px; margin: 0 auto; padding: 1rem 1.5rem 0; font-family: var(--font-sans); font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); }
.crumb a { color: var(--slate); }
.crumb a:hover { color: var(--gold); }
.crumb .sep { padding: 0 .6rem; color: var(--gold); }

/* editorial column */
.col-narrow { max-width: 760px; margin: 0 auto; }
.prose p { font-family: var(--font-sans); font-size: 1.08rem; line-height: 1.75; color: var(--ink); margin: 0 0 1.2rem; }
.prose h2 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.9rem; margin: 2.2rem 0 1rem; line-height: 1.15; }
.prose h2 em { font-style: italic; color: var(--gold); font-weight: 600; }
.prose h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.35rem; margin: 1.6rem 0 .6rem; }
.prose blockquote { border-left: 3px solid var(--gold); padding: .6rem 1.4rem; margin: 1.5rem 0; font-family: var(--font-serif); font-style: italic; color: var(--teal); font-size: 1.15rem; line-height: 1.5; }
.prose blockquote .who { display: block; font-style: normal; font-family: var(--font-sans); font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: var(--slate); margin-top: .5rem; font-weight: 600; }

/* timeline */
.timeline { position: relative; padding-left: 2rem; }
.timeline::before { content: ""; position: absolute; left: 6px; top: 0; bottom: 0; width: 2px; background: var(--line); }
.tl-item { position: relative; padding: 0 0 2rem 0; }
.tl-item::before { content: ""; position: absolute; left: -2rem; top: 6px; width: 14px; height: 14px; border-radius: 999px; background: var(--gold); border: 3px solid var(--paper); transform: translateX(-50%); }
.tl-year { font-family: var(--font-serif); font-weight: 700; color: var(--gold); font-size: 1.25rem; margin-bottom: .25rem; }
.tl-text { font-family: var(--font-sans); color: var(--ink); font-size: 1rem; line-height: 1.65; }

/* leadership grid */
.lead-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.lead-card { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; padding: 1.5rem; text-align: center; }
.lead-card img { width: 96px; height: 96px; border-radius: 999px; object-fit: cover; margin: 0 auto .8rem; display: block; }
.lead-card .nm { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.05rem; }
.lead-card .role { font-family: var(--font-sans); font-size: .82rem; letter-spacing: .08em; color: var(--slate); margin-top: .35rem; }

/* services full grid */
.svc-full-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.svc-full-card { display: grid; grid-template-columns: 1fr 1fr; background: var(--cream); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: 4px; overflow: hidden; }
.svc-full-card img { width: 100%; height: 100%; min-height: 240px; object-fit: cover; }
.svc-full-card .body { padding: 1.6rem; display: flex; flex-direction: column; gap: .5rem; }
.svc-full-card h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.35rem; margin: 0; }
.svc-full-card p { font-family: var(--font-sans); color: var(--slate); margin: 0; line-height: 1.55; font-size: .95rem; }
.svc-full-card .stat { font-family: var(--font-serif); font-weight: 700; font-style: italic; color: var(--gold); font-size: 1.3rem; margin-top: auto; }

/* stories grid */
.stories-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.story-card { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; overflow: hidden; cursor: pointer; transition: all 200ms cubic-bezier(.16,1,.3,1); display: block; color: inherit; }
.story-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(14,61,58,.14); }
.story-card .img { aspect-ratio: 4/3; overflow: hidden; }
.story-card .img img { width: 100%; height: 100%; object-fit: cover; }
.story-card .body { padding: 1.4rem; }
.story-card .cat { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.story-card h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.25rem; margin: .35rem 0 .5rem; line-height: 1.2; }
.story-card p { font-family: var(--font-sans); color: var(--slate); margin: 0; line-height: 1.55; font-size: .92rem; }

/* story detail */
.story-cover { aspect-ratio: 16/9; max-width: 1080px; margin: 0 auto 3rem; border-radius: 6px; overflow: hidden; }
.story-cover img { width: 100%; height: 100%; object-fit: cover; }
.story-meta-row { display: flex; gap: 2.5rem; flex-wrap: wrap; max-width: 760px; margin: 0 auto 2rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); font-family: var(--font-sans); }
.story-meta-row .item { display: flex; flex-direction: column; }
.story-meta-row .lbl { font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--slate); font-weight: 600; }
.story-meta-row .val { font-size: 1.05rem; color: var(--teal); font-weight: 600; margin-top: .25rem; font-family: var(--font-serif); }

.pull-quote { background: var(--paper); border-left: 3px solid var(--gold); padding: 2rem; margin: 2.5rem 0; font-family: var(--font-serif); font-style: italic; font-size: 1.4rem; color: var(--teal); line-height: 1.4; }
.pull-quote .who { display: block; font-style: normal; margin-top: 1rem; font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); font-weight: 600; font-family: var(--font-sans); }

/* contact */
.contact-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 3rem; align-items: start; }
.contact-info .block { padding: 1.4rem 0; border-bottom: 1px solid var(--line); }
.contact-info .block:last-child { border-bottom: 0; }
.contact-info .lbl { font-family: var(--font-sans); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.contact-info .val { font-family: var(--font-serif); color: var(--teal); font-size: 1.15rem; margin-top: .35rem; line-height: 1.5; font-weight: 600; }
.contact-info .small { font-family: var(--font-sans); font-size: .92rem; color: var(--slate); margin-top: .35rem; line-height: 1.55; font-weight: 400; }
.contact-form { background: var(--cream); border: 1px solid var(--line); border-radius: 6px; padding: 2rem; }
.contact-form h2 { font-family: var(--font-serif); color: var(--teal); margin: 0 0 1.5rem; font-size: 1.5rem; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
textarea.field-input { width: 100%; min-height: 140px; padding: .8rem .9rem; border: 1px solid var(--line); border-radius: 4px; font-family: var(--font-sans); font-size: 1rem; background: var(--paper); color: var(--ink); resize: vertical; }
textarea.field-input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(181,138,79,.18); }

/* donate landing */
.donate-shell { display: grid; grid-template-columns: 1fr 420px; gap: 3rem; max-width: 1180px; margin: 0 auto; align-items: start; padding: 3rem 1.5rem 5rem; }
.donate-aside { background: var(--cream); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: 6px; padding: 2rem; position: sticky; top: 6rem; }
.donate-aside h3 { font-family: var(--font-serif); color: var(--teal); margin: 0 0 1rem; font-size: 1.3rem; }
.donate-aside h3 em { font-style: italic; color: var(--gold); font-weight: 600; }
.summary-row { display: flex; justify-content: space-between; padding: .55rem 0; font-family: var(--font-sans); font-size: .95rem; border-bottom: 1px dashed var(--line); color: var(--slate); }
.summary-row .v { color: var(--ink); font-weight: 500; }
.summary-row.total { border-bottom: 0; padding-top: 1rem; font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.3rem; }
.summary-row.total .v { color: var(--teal); font-weight: 700; }
.donate-step { background: var(--cream); border: 1px solid var(--line); border-radius: 6px; padding: 2rem; margin-bottom: 1.5rem; }
.donate-step .num { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.donate-step h2 { font-family: var(--font-serif); color: var(--teal); font-size: 1.6rem; margin: .25rem 0 1.2rem; }
.donate-step h2 em { font-style: italic; color: var(--gold); font-weight: 600; }

.zechus-strip { background: var(--paper); border: 1px solid var(--gold-soft); border-radius: 4px; padding: 1.5rem; margin-bottom: 1.5rem; display: flex; gap: 1rem; align-items: flex-start; }
.zechus-strip svg { width: 28px; height: 28px; color: var(--gold); flex-shrink: 0; }
.zechus-strip h4 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); margin: 0 0 .35rem; font-size: 1.1rem; }
.zechus-strip h4 em { font-style: italic; color: var(--gold); font-weight: 600; }
.zechus-strip p { font-family: var(--font-sans); color: var(--slate); margin: 0; line-height: 1.5; font-size: .92rem; }

/* yahrzeit calendar */
.yz-calendar { display: grid; grid-template-columns: repeat(4, 1fr); gap: .8rem; }
.yz-month { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; padding: 1rem 1.2rem; cursor: pointer; transition: all 200ms; }
.yz-month:hover { border-color: var(--gold); transform: translateY(-2px); }
.yz-month .nm { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.1rem; }
.yz-month .en { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); }
.yz-month .count { font-family: var(--font-sans); font-size: .85rem; color: var(--gold); margin-top: .5rem; font-weight: 600; }

.yz-list { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; }
.yz-row { display: grid; grid-template-columns: 100px 1fr auto; gap: 1.2rem; align-items: center; padding: 1.1rem 1.4rem; border-bottom: 1px solid var(--line); font-family: var(--font-sans); }
.yz-row:last-child { border-bottom: 0; }
.yz-row .date { font-family: var(--font-serif); font-weight: 700; color: var(--gold); font-size: 1rem; }
.yz-row .nm { font-family: var(--font-serif); color: var(--teal); font-weight: 700; font-size: 1.05rem; }
.yz-row .rel { font-size: .82rem; color: var(--slate); margin-top: 2px; }
.yz-row .act { font-family: var(--font-sans); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 600; }

/* receipt */
.receipt { background: var(--paper); border: 1px solid var(--line); padding: 3rem; max-width: 720px; margin: 0 auto; font-family: var(--font-sans); position: relative; }
.receipt-head { display: flex; justify-content: space-between; align-items: flex-end; padding-bottom: 1.2rem; border-bottom: 2px solid var(--teal); margin-bottom: 1.5rem; }
.receipt-head .l img { width: 72px; }
.receipt-head .r { text-align: right; }
.receipt-head .r .ttl { font-family: var(--font-serif); font-weight: 700; font-size: 1.5rem; color: var(--teal); line-height: 1; }
.receipt-head .r .sub { font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); margin-top: .35rem; }
.receipt-meta { display: grid; grid-template-columns: 1fr 1fr; gap: .4rem 2rem; margin-bottom: 1.5rem; }
.receipt-meta .row { display: flex; justify-content: space-between; padding: .5rem 0; border-bottom: 1px dashed var(--line); }
.receipt-meta .lbl { font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); font-weight: 600; }
.receipt-meta .val { color: var(--teal); font-weight: 500; font-family: var(--font-serif); }
.receipt-amount { background: var(--cream); border: 1px solid var(--gold); border-radius: 4px; padding: 1.5rem; text-align: center; margin: 1.5rem 0; }
.receipt-amount .big { font-family: var(--font-serif); font-weight: 700; font-size: 2.5rem; color: var(--teal); }
.receipt-amount .lbl { font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--slate); font-weight: 600; }
.receipt-foot { font-size: .82rem; color: var(--slate); line-height: 1.6; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--line); }
.receipt-stamp { margin-top: 2rem; display: flex; justify-content: space-between; align-items: flex-end; }
.receipt-stamp .sig { font-family: var(--font-serif); font-style: italic; color: var(--teal); font-weight: 700; }
.receipt-stamp .seal { width: 90px; opacity: .9; }

/* major gifts */
.recog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.recog-tier { background: var(--cream); border: 1px solid var(--line); border-top: 4px solid var(--gold); border-radius: 4px; padding: 2rem; }
.recog-tier .price { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 2.2rem; line-height: 1; }
.recog-tier .price small { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .14em; color: var(--slate); font-weight: 500; text-transform: uppercase; }
.recog-tier .nm { font-family: var(--font-serif); font-weight: 700; font-style: italic; color: var(--gold); font-size: 1.3rem; margin: .6rem 0 1rem; }
.recog-tier h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.4rem; margin: 0 0 .4rem; }
.recog-tier ul { list-style: none; padding: 0; margin: 1rem 0 0; }
.recog-tier li { font-family: var(--font-sans); padding: .4rem 0; padding-left: 1.2rem; position: relative; color: var(--ink); font-size: .95rem; line-height: 1.55; }
.recog-tier li::before { content: "◆"; position: absolute; left: 0; color: var(--gold); font-size: .8rem; top: .5rem; }

/* mega menu */
.has-mega { position: relative; }
.has-mega .mega { position: absolute; top: calc(100% + 1.1rem); left: -1.2rem; min-width: 280px; background: var(--cream); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: 4px; padding: .8rem; box-shadow: 0 24px 60px rgba(14,61,58,.18); z-index: 50; }
.has-mega .mega a { display: block; padding: .8rem 1rem; border-radius: 3px; color: var(--ink) !important; text-transform: none; letter-spacing: 0; font-size: .92rem; transition: background 150ms; cursor: pointer; }
.has-mega .mega a:hover { background: var(--paper); color: var(--teal) !important; }
.has-mega .mega a strong { font-family: var(--font-serif); font-weight: 700; color: var(--teal); display: block; font-size: 1rem; margin-bottom: .15rem; }
.has-mega .mega a:hover strong { color: var(--gold); }
.has-mega .mega a span { font-family: var(--font-sans); font-size: .82rem; color: var(--slate); display: block; line-height: 1.4; }
.footer-grid-5 { grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr !important; }

/* ============================================================
   DAY IN THE LIFE — long-form narrative scrolling page
   ============================================================ */
.day-section { padding: 5rem 1.5rem; position: relative; }
.day-time { display: inline-block; font-family: var(--font-serif); font-weight: 700; font-style: italic; color: var(--gold); font-size: 2.2rem; padding-bottom: .3rem; border-bottom: 2px solid var(--gold); margin-bottom: 1.5rem; letter-spacing: -.01em; }
.day-time .meridian { font-size: 1rem; letter-spacing: .14em; text-transform: uppercase; font-style: normal; color: var(--slate); margin-left: .5rem; font-family: var(--font-sans); }
.day-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; max-width: 1180px; margin: 0 auto; }
.day-grid.reverse { grid-template-columns: 1fr 1fr; }
.day-grid.reverse > div:first-child { order: 2; }
.day-photo { aspect-ratio: 4/5; border-radius: 4px; overflow: hidden; box-shadow: 0 30px 70px rgba(14,61,58,.18); }
.day-photo img { width: 100%; height: 100%; object-fit: cover; }
.day-text h2 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 2.4rem; line-height: 1.05; margin: 0 0 1rem; letter-spacing: -.01em; }
.day-text h2 em { font-style: italic; color: var(--gold); font-weight: 600; }
.day-text p { font-family: var(--font-sans); font-size: 1.08rem; color: var(--ink); line-height: 1.75; margin: 0 0 1.2rem; }
.day-text p.lead { font-family: var(--font-serif); font-style: italic; font-size: 1.3rem; color: var(--teal); line-height: 1.5; }
.day-stat { background: var(--paper); padding: 1.2rem 1.5rem; border-left: 3px solid var(--gold); margin: 1.5rem 0; }
.day-stat .num { font-family: var(--font-serif); font-weight: 700; color: var(--gold); font-size: 2rem; line-height: 1; }
.day-stat .lbl { font-family: var(--font-sans); font-size: .82rem; color: var(--slate); margin-top: .25rem; line-height: 1.4; }

/* ============================================================
   WHERE WE WORK — Israel map
   ============================================================ */
.map-shell { display: grid; grid-template-columns: 1.4fr 1fr; gap: 3rem; max-width: 1280px; margin: 0 auto; padding: 4rem 1.5rem; align-items: start; }
.map-canvas { background: var(--paper); border: 1px solid var(--line); border-radius: 8px; padding: 1.5rem; aspect-ratio: 4/5; position: relative; overflow: hidden; }
.map-canvas svg { width: 100%; height: 100%; }
.map-pin { fill: var(--gold); stroke: var(--cream); stroke-width: 1.5; cursor: pointer; transition: all 200ms; }
.map-pin:hover, .map-pin.active { fill: var(--teal); transform-origin: center; }
.map-region-list .region { background: var(--cream); border: 1px solid var(--line); border-left: 3px solid var(--line); padding: 1.2rem 1.5rem; margin-bottom: .8rem; cursor: pointer; transition: all 200ms; border-radius: 0 4px 4px 0; }
.map-region-list .region.active { border-left-color: var(--gold); background: var(--paper); }
.map-region-list .region:hover { border-left-color: var(--gold); }
.map-region-list .region .nm { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.2rem; }
.map-region-list .region .meta { font-family: var(--font-sans); font-size: .82rem; color: var(--slate); margin-top: .35rem; letter-spacing: .04em; }
.map-region-list .region .desc { font-family: var(--font-sans); font-size: .92rem; color: var(--ink); margin-top: .6rem; line-height: 1.6; display: none; }
.map-region-list .region.active .desc { display: block; }

/* ============================================================
   ANNUAL REPORT / IMPACT
   ============================================================ */
.report-cover { background: var(--teal); color: var(--cream); padding: 6rem 1.5rem 5rem; text-align: center; position: relative; overflow: hidden; }
.report-cover::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 30%, rgba(181,138,79,.18) 0, transparent 40%), radial-gradient(circle at 80% 70%, rgba(181,138,79,.12) 0, transparent 40%); }
.report-cover .inner { position: relative; z-index: 2; max-width: 980px; margin: 0 auto; }
.report-cover .year { font-family: var(--font-serif); font-weight: 700; font-style: italic; color: var(--gold-soft); font-size: 5rem; line-height: 1; }
.report-cover h1 { font-family: var(--font-serif); font-weight: 700; font-size: clamp(2.6rem, 5vw, 4rem); line-height: 1; margin: 1rem 0; }
.report-cover h1 em { font-style: italic; color: var(--gold-soft); font-weight: 600; }
.report-cover .by { font-family: var(--font-sans); font-size: .82rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(245,240,232,.65); margin-top: 2rem; }

.report-letter { padding: 5rem 1.5rem; background: var(--paper); }
.report-letter .col-narrow { background: var(--cream); padding: 4rem; border-radius: 4px; border-top: 4px solid var(--gold); }
.report-letter h2 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 2.2rem; line-height: 1.1; margin: 0 0 1.5rem; }
.report-letter h2 em { font-style: italic; color: var(--gold); font-weight: 600; }
.report-letter p { font-family: var(--font-sans); font-size: 1.05rem; color: var(--ink); line-height: 1.75; margin: 0 0 1rem; }
.report-letter .signature { font-family: var(--font-serif); font-style: italic; color: var(--teal); font-size: 1.6rem; margin-top: 2rem; }
.report-letter .signature-meta { font-family: var(--font-sans); font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: var(--slate); font-weight: 600; }

.report-impact { padding: 5rem 1.5rem; background: var(--cream); }
.impact-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; max-width: 1180px; margin: 3rem auto 0; }
.impact-stat { background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: 4px; padding: 2rem; }
.impact-stat .num { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 3.4rem; line-height: 1; letter-spacing: -.02em; }
.impact-stat .num em { font-style: italic; color: var(--gold); font-weight: 600; }
.impact-stat .delta { font-family: var(--font-sans); font-size: .82rem; color: var(--gold); font-weight: 600; margin-top: .35rem; }
.impact-stat .lbl { font-family: var(--font-sans); font-size: .92rem; color: var(--slate); margin-top: .6rem; line-height: 1.5; }

.report-finance { padding: 5rem 1.5rem; background: var(--paper); }
.fin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; max-width: 1180px; margin: 3rem auto 0; }
.fin-block { background: var(--cream); padding: 2rem; border: 1px solid var(--line); border-radius: 4px; }
.fin-block h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.5rem; margin: 0 0 1.5rem; }
.fin-bar-row { display: grid; grid-template-columns: 180px 1fr 80px; gap: 1rem; align-items: center; padding: .8rem 0; border-bottom: 1px solid var(--line); font-family: var(--font-sans); font-size: .92rem; }
.fin-bar-row:last-child { border-bottom: 0; font-weight: 700; color: var(--teal); }
.fin-bar { height: 8px; background: var(--paper); border-radius: 999px; overflow: hidden; }
.fin-bar-fill { height: 100%; background: var(--gold); }
.fin-bar-row.row-total .fin-bar-fill { background: var(--teal); }
.fin-amount { text-align: right; font-family: var(--font-serif); font-weight: 700; color: var(--teal); }

/* ============================================================
   BUS NETWORK
   ============================================================ */
.bus-hero { background: var(--ink-deep, var(--teal-deep)); color: var(--cream); padding: 5rem 1.5rem; position: relative; overflow: hidden; }
.bus-stats-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; background: var(--cream); border: 1px solid var(--line); border-radius: 4px; max-width: 1180px; margin: 2rem auto 0; }
.bus-stats-strip .item { padding: 2rem; text-align: center; border-right: 1px solid var(--line); }
.bus-stats-strip .item:last-child { border-right: 0; }
.bus-stats-strip .num { font-family: var(--font-serif); font-weight: 700; color: var(--gold); font-size: 2.6rem; font-style: italic; line-height: 1; }
.bus-stats-strip .lbl { font-family: var(--font-sans); font-size: .82rem; color: var(--slate); letter-spacing: .12em; text-transform: uppercase; margin-top: .6rem; font-weight: 600; }

.route-list { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; max-width: 980px; margin: 0 auto; }
.route-row { display: grid; grid-template-columns: 90px 1fr 1fr auto; gap: 1.5rem; padding: 1.4rem 1.6rem; border-bottom: 1px solid var(--line); align-items: center; font-family: var(--font-sans); }
.route-row:last-child { border-bottom: 0; }
.route-row .num { font-family: var(--font-serif); font-weight: 700; color: var(--gold); font-size: 1.3rem; }
.route-row .name { font-family: var(--font-serif); color: var(--teal); font-weight: 700; font-size: 1.1rem; }
.route-row .meta { font-size: .82rem; color: var(--slate); margin-top: 2px; }
.route-row .stops { font-size: .92rem; color: var(--ink); }
.route-row .kids { font-family: var(--font-serif); font-style: italic; font-weight: 700; color: var(--gold); font-size: 1.4rem; }
.route-row .kids small { font-family: var(--font-sans); font-style: normal; font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); display: block; font-weight: 600; }

/* ============================================================
   HEMSHECH program page
   ============================================================ */
.hemshech-hero { padding: 6rem 1.5rem 5rem; background: linear-gradient(180deg, var(--teal) 0%, var(--teal-deep) 100%); color: var(--cream); position: relative; overflow: hidden; }
.hemshech-hero .inner { position: relative; z-index: 2; max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1.3fr 1fr; gap: 4rem; align-items: center; }
.hemshech-hero h1 { font-family: var(--font-serif); font-weight: 700; font-size: clamp(2.4rem, 5vw, 3.8rem); line-height: 1.05; margin: 1rem 0; letter-spacing: -.01em; }
.hemshech-hero h1 em { font-style: italic; color: var(--gold-soft); font-weight: 600; }
.hemshech-hero .quote-block { background: rgba(245,240,232,.06); border-left: 3px solid var(--gold-soft); padding: 1.5rem 1.8rem; margin-top: 1.8rem; }
.hemshech-hero .quote-block p { font-family: var(--font-serif); font-style: italic; font-size: 1.2rem; line-height: 1.5; color: rgba(245,240,232,.92); margin: 0; }
.hemshech-hero .quote-block .who { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold-soft); margin-top: 1rem; font-weight: 600; }
.hemshech-portrait { aspect-ratio: 4/5; background: var(--paper); border-radius: 4px; overflow: hidden; box-shadow: 0 40px 80px rgba(0,0,0,.4); }
.hemshech-portrait img { width: 100%; height: 100%; object-fit: cover; filter: sepia(.15); }

.path-flow { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; max-width: 1180px; margin: 4rem auto; position: relative; }
.path-flow::before { content: ""; position: absolute; top: 30px; left: 10%; right: 10%; height: 2px; background: var(--gold); z-index: 1; }
.path-step { text-align: center; position: relative; z-index: 2; padding: 0 1rem; }
.path-step .dot { width: 60px; height: 60px; border-radius: 999px; background: var(--cream); border: 3px solid var(--gold); margin: 0 auto 1rem; display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-weight: 700; font-style: italic; color: var(--gold); font-size: 1.6rem; }
.path-step .age { font-family: var(--font-sans); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); font-weight: 600; }
.path-step h4 { font-family: var(--font-serif); color: var(--teal); margin: .35rem 0 .5rem; font-size: 1.15rem; }
.path-step p { font-family: var(--font-sans); font-size: .88rem; color: var(--ink); line-height: 1.55; margin: 0; }

/* ============================================================
   FOUNDERS — historical/editorial
   ============================================================ */
.founders-hero { padding: 5rem 1.5rem; background: var(--paper); }
.founders-portrait-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; max-width: 1080px; margin: 0 auto; }
.founder-portrait { text-align: center; }
.founder-portrait .img { aspect-ratio: 4/5; background: var(--cream); border: 1px solid var(--line); overflow: hidden; margin-bottom: 1.5rem; filter: sepia(.2); }
.founder-portrait .img img { width: 100%; height: 100%; object-fit: cover; }
.founder-portrait .nm { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.6rem; }
.founder-portrait .titles { font-family: var(--font-serif); font-style: italic; color: var(--gold); font-size: 1.1rem; margin-top: .35rem; }
.founder-portrait .years { font-family: var(--font-sans); font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: var(--slate); margin-top: .35rem; font-weight: 600; }

/* ============================================================
   MEMORIAL / YAHRZEIT WALL
   ============================================================ */
.memorial-hero { padding: 5rem 1.5rem; background: var(--teal); color: var(--cream); text-align: center; }
.memorial-hero h1 { font-family: var(--font-serif); font-weight: 700; font-size: clamp(2.4rem, 5vw, 3.6rem); margin: 0 0 1rem; }
.memorial-hero p { font-family: var(--font-serif); font-style: italic; font-size: 1.3rem; max-width: 720px; margin: 0 auto; line-height: 1.5; color: rgba(245,240,232,.85); }
.memorial-controls { background: var(--paper); border-bottom: 1px solid var(--line); padding: 1.5rem 1.5rem; position: sticky; top: 5rem; z-index: 20; backdrop-filter: blur(8px); }
.memorial-controls-inner { max-width: 1180px; margin: 0 auto; display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
.memorial-search { flex: 1; min-width: 240px; padding: .8rem 1rem; border: 1px solid var(--line); background: var(--cream); border-radius: 4px; font-family: var(--font-sans); font-size: .95rem; color: var(--ink); }
.letter-tabs { display: flex; gap: .25rem; flex-wrap: wrap; }
.letter-tabs .ltr { padding: .4rem .7rem; font-family: var(--font-serif); font-weight: 700; color: var(--slate); background: transparent; border: 1px solid var(--line); border-radius: 3px; cursor: pointer; font-size: .92rem; min-width: 32px; text-align: center; transition: all 150ms; }
.letter-tabs .ltr:hover, .letter-tabs .ltr.on { color: var(--cream); background: var(--gold); border-color: var(--gold); }

.wall-grid { columns: 4; column-gap: 2rem; max-width: 1280px; margin: 0 auto; padding: 4rem 1.5rem; }
.wall-card { break-inside: avoid; margin-bottom: 2rem; padding: 1.5rem; background: var(--cream); border: 1px solid var(--line); border-top: 2px solid var(--gold); border-radius: 4px; text-align: center; }
.wall-card .nm { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.15rem; line-height: 1.25; }
.wall-card .yz { font-family: var(--font-serif); font-style: italic; color: var(--gold); font-size: .95rem; margin-top: .35rem; }
.wall-card .by { font-family: var(--font-sans); font-size: .76rem; color: var(--slate); margin-top: .8rem; padding-top: .8rem; border-top: 1px dashed var(--line); }

/* ============================================================
   EVENTS
   ============================================================ */
.events-list { max-width: 1080px; margin: 0 auto; padding: 4rem 1.5rem; }
.event-row { display: grid; grid-template-columns: 100px 1fr 220px; gap: 2rem; padding: 2rem 0; border-bottom: 1px solid var(--line); align-items: start; }
.event-row:last-child { border-bottom: 0; }
.event-date { background: var(--cream); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: 4px; padding: 1rem; text-align: center; }
.event-date .mo { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); font-weight: 700; }
.event-date .day { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 2.2rem; line-height: 1; }
.event-date .yr { font-family: var(--font-sans); font-size: .76rem; color: var(--slate); margin-top: .25rem; }
.event-body .cat { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.event-body h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.5rem; margin: .25rem 0 .6rem; }
.event-body p { font-family: var(--font-sans); color: var(--slate); margin: 0 0 .6rem; line-height: 1.6; }
.event-body .meta { font-family: var(--font-sans); font-size: .82rem; color: var(--ink); display: flex; gap: 1.2rem; flex-wrap: wrap; margin-top: .8rem; }
.event-body .meta span { display: inline-flex; align-items: center; gap: .35rem; }
.event-body .meta strong { color: var(--teal); }

/* ============================================================
   PRESS / MEDIA KIT
   ============================================================ */
.press-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; max-width: 1180px; margin: 0 auto; padding: 0 1.5rem; }
.press-card { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; padding: 1.5rem; }
.press-card .pub { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 700; }
.press-card .date { font-family: var(--font-sans); font-size: .82rem; color: var(--slate); margin-top: .35rem; }
.press-card h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.2rem; margin: .8rem 0 .8rem; line-height: 1.3; }
.press-card .quote { font-family: var(--font-serif); font-style: italic; color: var(--ink); border-left: 2px solid var(--gold); padding-left: .8rem; font-size: .92rem; line-height: 1.5; }

.press-assets { background: var(--paper); padding: 4rem 1.5rem; }
.asset-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; max-width: 1180px; margin: 0 auto; }
.asset-card { background: var(--cream); border: 1px solid var(--line); padding: 1.5rem; text-align: center; cursor: pointer; transition: all 200ms; }
.asset-card:hover { border-color: var(--gold); transform: translateY(-2px); }
.asset-card .ic { width: 48px; height: 48px; margin: 0 auto 1rem; color: var(--gold); }
.asset-card .nm { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1rem; }
.asset-card .meta { font-family: var(--font-sans); font-size: .78rem; color: var(--slate); margin-top: .35rem; letter-spacing: .04em; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-shell { display: grid; grid-template-columns: 280px 1fr; gap: 4rem; max-width: 1180px; margin: 0 auto; padding: 4rem 1.5rem; align-items: start; }
.faq-side { position: sticky; top: 6rem; }
.faq-side h4 { font-family: var(--font-sans); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); margin: 0 0 1rem; font-weight: 700; }
.faq-side a { display: block; padding: .6rem 0; border-bottom: 1px solid var(--line); font-family: var(--font-serif); color: var(--teal); font-size: 1rem; cursor: pointer; }
.faq-side a:hover { color: var(--gold); }
.faq-section { margin-bottom: 3rem; }
.faq-section h2 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.8rem; margin: 0 0 1.2rem; padding-bottom: .8rem; border-bottom: 2px solid var(--gold); }
.faq-q { background: var(--cream); border: 1px solid var(--line); border-left: 3px solid var(--line); border-radius: 0 4px 4px 0; margin-bottom: .8rem; transition: border-color 200ms; }
.faq-q.open { border-left-color: var(--gold); }
.faq-q .q { padding: 1.2rem 1.5rem; cursor: pointer; display: flex; justify-content: space-between; align-items: center; font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.1rem; }
.faq-q .q .plus { color: var(--gold); font-size: 1.4rem; line-height: 1; transition: transform 250ms; }
.faq-q.open .q .plus { transform: rotate(45deg); }
.faq-q .a { padding: 0 1.5rem 1.2rem; font-family: var(--font-sans); color: var(--ink); line-height: 1.7; font-size: .95rem; display: none; }
.faq-q.open .a { display: block; }

/* ============================================================
   ACCOUNT DASHBOARD
   ============================================================ */
.acct-shell { display: grid; grid-template-columns: 240px 1fr; gap: 2rem; max-width: 1280px; margin: 0 auto; padding: 3rem 1.5rem 5rem; align-items: start; }
.acct-side { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; padding: 1.5rem; position: sticky; top: 6rem; }
.acct-side .me { padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); margin-bottom: 1rem; }
.acct-side .avatar { width: 56px; height: 56px; border-radius: 999px; background: var(--gold); color: var(--cream); display: flex; align-items: center; justify-content: center; font-family: var(--font-serif); font-weight: 700; font-size: 1.5rem; margin-bottom: .8rem; }
.acct-side .nm { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.1rem; }
.acct-side .since { font-family: var(--font-sans); font-size: .76rem; color: var(--slate); margin-top: .25rem; }
.acct-nav a { display: flex; align-items: center; gap: .8rem; padding: .7rem .8rem; border-radius: 3px; font-family: var(--font-sans); font-size: .92rem; color: var(--ink); cursor: pointer; }
.acct-nav a:hover { background: var(--paper); color: var(--teal); }
.acct-nav a.on { background: var(--paper); color: var(--gold); font-weight: 600; }

.acct-hero { background: var(--paper); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: 4px; padding: 2.5rem; margin-bottom: 1.5rem; }
.acct-hero .greet { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.acct-hero h1 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 2.2rem; margin: .35rem 0 1rem; }
.acct-hero h1 em { font-style: italic; color: var(--gold); font-weight: 600; }
.acct-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 1.5rem; }
.acct-stat { background: var(--cream); padding: 1.2rem; border-radius: 4px; }
.acct-stat .num { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.8rem; line-height: 1; }
.acct-stat .lbl { font-family: var(--font-sans); font-size: .82rem; color: var(--slate); margin-top: .4rem; }

.acct-card { background: var(--cream); border: 1px solid var(--line); border-radius: 4px; padding: 1.8rem; margin-bottom: 1.2rem; }
.acct-card h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.3rem; margin: 0 0 1.2rem; display: flex; justify-content: space-between; align-items: center; }
.acct-card h3 a { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); font-weight: 600; cursor: pointer; }
.subscriptions-list .sub { display: grid; grid-template-columns: 1fr auto; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid var(--line); align-items: center; font-family: var(--font-sans); }
.subscriptions-list .sub:last-child { border-bottom: 0; }
.subscriptions-list .sub .nm { font-family: var(--font-serif); color: var(--teal); font-weight: 700; font-size: 1.05rem; }
.subscriptions-list .sub .meta { font-size: .82rem; color: var(--slate); margin-top: 2px; }
.subscriptions-list .sub .amt { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.2rem; }

.history-list { font-family: var(--font-sans); }
.history-list .hist-row { display: grid; grid-template-columns: 110px 1fr 120px 100px; gap: 1rem; padding: .9rem 0; border-bottom: 1px solid var(--line); font-size: .92rem; align-items: center; }
.history-list .hist-row .dt { color: var(--slate); }
.history-list .hist-row .desc { color: var(--ink); }
.history-list .hist-row .amt { font-family: var(--font-serif); color: var(--teal); font-weight: 700; text-align: right; }
.history-list .hist-row .act { color: var(--gold); font-weight: 600; cursor: pointer; text-align: right; font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; }

/* ============================================================
   THANK-YOU / CONFIRMATION
   ============================================================ */
.thanks-hero { padding: 6rem 1.5rem 5rem; text-align: center; background: var(--cream); position: relative; overflow: hidden; }
.thanks-hero::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 50% 50%, rgba(181,138,79,.10) 0, transparent 50%); }
.thanks-hero .inner { position: relative; z-index: 2; max-width: 720px; margin: 0 auto; }
.thanks-hero .seal { width: 120px; margin: 0 auto 2rem; display: block; }
.thanks-hero .eyebrow { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.thanks-hero h1 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: clamp(2.4rem, 5vw, 3.6rem); margin: 1rem 0; line-height: 1.05; }
.thanks-hero h1 em { font-style: italic; color: var(--gold); font-weight: 600; }
.thanks-hero p { font-family: var(--font-serif); font-style: italic; color: var(--ink); font-size: 1.3rem; line-height: 1.5; max-width: 560px; margin: 0 auto; }
.thanks-receipt { background: var(--paper); padding: 1.5rem; border: 1px solid var(--line); border-radius: 4px; max-width: 480px; margin: 2.5rem auto 0; text-align: left; font-family: var(--font-sans); }
.thanks-receipt .row { display: flex; justify-content: space-between; padding: .5rem 0; font-size: .92rem; border-bottom: 1px dashed var(--line); }
.thanks-receipt .row:last-child { border-bottom: 0; font-weight: 700; color: var(--teal); padding-top: 1rem; }
.thanks-actions { display: flex; gap: .8rem; justify-content: center; margin-top: 2rem; flex-wrap: wrap; }
.thanks-next { padding: 4rem 1.5rem; background: var(--paper); }
.thanks-next-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; max-width: 1080px; margin: 2rem auto 0; }
.thanks-next-card { background: var(--cream); padding: 2rem; border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: 4px; }
.thanks-next-card h3 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 1.2rem; margin: 0 0 .5rem; }
.thanks-next-card p { font-family: var(--font-sans); color: var(--slate); margin: 0 0 1rem; font-size: .92rem; line-height: 1.55; }

/* ============================================================
   404
   ============================================================ */
.notfound { min-height: 70vh; display: grid; place-items: center; padding: 3rem 1.5rem; background: var(--paper); text-align: center; }
.notfound .num { font-family: var(--font-serif); font-weight: 700; font-style: italic; color: var(--gold); font-size: clamp(8rem, 18vw, 14rem); line-height: .9; }
.notfound h1 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 2.4rem; margin: 0 0 .8rem; }
.notfound p { font-family: var(--font-sans); color: var(--slate); max-width: 500px; margin: 0 auto 2rem; font-size: 1.05rem; line-height: 1.6; }

/* ============================================================
   NEWSLETTER standalone
   ============================================================ */
.news-shell { min-height: 80vh; display: grid; place-items: center; padding: 3rem 1.5rem; background: var(--teal); color: var(--cream); position: relative; overflow: hidden; }
.news-shell::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 30% 30%, rgba(181,138,79,.18) 0, transparent 40%); }
.news-card { position: relative; z-index: 2; max-width: 680px; background: var(--cream); color: var(--ink); padding: 4rem; border-radius: 4px; box-shadow: 0 60px 120px rgba(0,0,0,.4); }
.news-card .eyebrow { font-family: var(--font-sans); font-size: .76rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.news-card h1 { font-family: var(--font-serif); font-weight: 700; color: var(--teal); font-size: 2.4rem; margin: 1rem 0 1rem; line-height: 1.1; }
.news-card h1 em { font-style: italic; color: var(--gold); font-weight: 600; }
.news-card p { font-family: var(--font-sans); color: var(--ink); line-height: 1.65; }
.news-frequency { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: .6rem; margin: 1.5rem 0; }
.news-frequency .opt { padding: 1rem; background: var(--paper); border: 1px solid var(--line); border-radius: 3px; cursor: pointer; text-align: center; font-family: var(--font-sans); font-size: .88rem; transition: all 200ms; }
.news-frequency .opt:hover, .news-frequency .opt.on { background: var(--cream); border-color: var(--gold); }
.news-frequency .opt strong { display: block; font-family: var(--font-serif); color: var(--teal); font-size: 1.05rem; margin-bottom: .25rem; }
.news-frequency .opt span { color: var(--slate); font-size: .76rem; }

/* ============================================================
   HOLIDAY CAMPAIGN (Rosh Hashana)
   ============================================================ */
.holiday-hero { padding: 6rem 1.5rem; background: var(--teal-deep); color: var(--cream); position: relative; overflow: hidden; }
.holiday-hero::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 40%, rgba(181,138,79,.20) 0, transparent 45%), radial-gradient(circle at 80% 60%, rgba(181,138,79,.15) 0, transparent 40%); }
.holiday-hero .inner { position: relative; z-index: 2; max-width: 1080px; margin: 0 auto; text-align: center; }
.holiday-hero .yom-tov { font-family: var(--font-serif); font-style: italic; color: var(--gold-soft); font-size: 1.4rem; letter-spacing: .04em; }
.holiday-hero h1 { font-family: var(--font-serif); font-weight: 700; font-size: clamp(3rem, 6vw, 5rem); line-height: 1; margin: 1rem 0 1.5rem; letter-spacing: -.02em; }
.holiday-hero h1 em { font-style: italic; color: var(--gold-soft); font-weight: 600; }
.holiday-hero p.deck { font-family: var(--font-serif); font-style: italic; font-size: 1.5rem; max-width: 720px; margin: 0 auto 2rem; line-height: 1.4; color: rgba(245,240,232,.85); }

.shofar-meter { max-width: 760px; margin: 3rem auto 0; padding: 2rem; background: rgba(245,240,232,.07); border: 1px solid rgba(181,138,79,.3); border-radius: 4px; }
.shofar-meter .top { display: flex; justify-content: space-between; align-items: baseline; font-family: var(--font-serif); font-weight: 700; }
.shofar-meter .top .raised { color: var(--gold-soft); font-size: 2rem; font-style: italic; }
.shofar-meter .top .goal { color: rgba(245,240,232,.7); font-family: var(--font-sans); font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; }
.shofar-meter .bar { height: 12px; background: rgba(245,240,232,.12); border-radius: 999px; overflow: hidden; margin: 1rem 0 .8rem; }
.shofar-meter .fill { height: 100%; background: linear-gradient(90deg, var(--gold) 0%, var(--gold-soft) 100%); border-radius: 999px; }
.shofar-meter .meta { display: flex; justify-content: space-between; font-family: var(--font-sans); font-size: .82rem; color: rgba(245,240,232,.7); }

/* ============================================================
   STORY page extensions for new stories
   ============================================================ */
.story-cover-tall { aspect-ratio: 21/9; }

/* ============================================================
   mobile refinements (consolidated)
   ============================================================ */
@media (max-width: 860px) {
  .lead-grid, .svc-full-grid, .stories-grid, .recog-grid, .impact-grid, .fin-grid, .bus-stats-strip, .press-grid, .asset-grid, .thanks-next-grid, .acct-stats { grid-template-columns: 1fr; }
  .impact-grid, .press-grid, .asset-grid { grid-template-columns: 1fr 1fr; }
  .yz-calendar { grid-template-columns: 1fr 1fr; }
  .contact-grid, .donate-shell, .map-shell, .day-grid, .day-grid.reverse, .hemshech-hero .inner, .founders-portrait-pair, .faq-shell, .acct-shell { grid-template-columns: 1fr; gap: 2rem; }
  .day-grid.reverse > div:first-child { order: 0; }
  .donate-aside, .faq-side, .acct-side { position: static; }
  .field-row { grid-template-columns: 1fr; }
  .svc-full-card { grid-template-columns: 1fr; }
  .receipt-meta { grid-template-columns: 1fr; }
  .receipt { padding: 1.5rem; }
  .footer-grid-5 { grid-template-columns: 1fr 1fr !important; }
  .path-flow { grid-template-columns: 1fr; gap: 1.5rem; }
  .path-flow::before { display: none; }
  .wall-grid { columns: 2; }
  .event-row { grid-template-columns: 1fr; gap: 1rem; }
  .route-row { grid-template-columns: 1fr; gap: .5rem; }
  .has-mega .mega { position: fixed; left: 1rem; right: 1rem; }
}
@media (max-width: 560px) {
  .wall-grid { columns: 1; }
}

