:root{
  --bg:#f7f4ef;          /* warm paper */
  --card:#ffffff;
  --ink:#211c17;         /* near-black warm */
  --ink-soft:#6b6256;
  --line:#e7e0d5;
  --accent:#7c1f2e;      /* liturgical deep red */
  --accent-soft:#f3e6e3;
  --gold:#b08a3e;
  --green:#2f6b4f;
  --radius:16px;
  --shadow:0 1px 2px rgba(33,28,23,.05), 0 8px 24px rgba(33,28,23,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--ink);
  font-family:'Outfit',system-ui,-apple-system,sans-serif;
  font-weight:400; line-height:1.5;
  -webkit-font-smoothing:antialiased;
  padding-bottom:64px;
}
a{color:inherit;text-decoration:none}

/* ---------- top bar ---------- */
.topbar{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; gap:14px;
  padding:14px clamp(16px,5vw,40px);
  background:rgba(247,244,239,.85); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex; align-items:center; gap:9px}
.brand-mark{
  color:var(--accent); font-size:20px; line-height:1;
  transform:translateY(-1px);
}
.brand-name{font-family:'Outfit';font-weight:300;font-size:22px;letter-spacing:.2px}
.brand-name b{font-weight:600}
.brand-scope{
  margin-left:auto; font-size:13px; color:var(--ink-soft);
  font-weight:500; letter-spacing:.3px; text-transform:uppercase;
}

/* ---------- layout ---------- */
main{max-width:760px; margin:0 auto; padding:clamp(20px,5vw,40px) clamp(16px,5vw,40px)}

/* ---------- hero / search ---------- */
.hero{text-align:center; margin:14px 0 26px}
.hero h1{
  font-family:'Cormorant Garamond',serif; font-weight:600;
  font-size:clamp(34px,7vw,52px); line-height:1.05; margin:0 0 8px;
  letter-spacing:.3px;
}
.hero p{color:var(--ink-soft); font-size:17px; margin:0 auto; max-width:34ch}
.search{position:relative; margin:22px auto 6px; max-width:520px}
.search input{
  width:100%; padding:16px 18px 16px 48px; font-size:17px; font-family:'Outfit';
  color:var(--ink); background:var(--card); border:1px solid var(--line);
  border-radius:999px; box-shadow:var(--shadow); outline:none;
}
.search input:focus{border-color:var(--accent)}
.search .mag{position:absolute; left:18px; top:50%; transform:translateY(-50%); color:var(--ink-soft); font-size:18px}
.counts{font-size:13px;color:var(--ink-soft);text-align:center;margin-top:12px}

/* ---------- list ---------- */
.section-label{
  font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); font-weight:600; margin:26px 4px 10px;
}
.card{
  display:block; background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius); padding:16px 18px; margin-bottom:10px;
  box-shadow:var(--shadow); transition:transform .12s ease, border-color .12s ease;
}
.card:hover{transform:translateY(-1px); border-color:#d8cfc0}
.card .name{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:21px;line-height:1.15}
.card .meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:5px;font-size:14px;color:var(--ink-soft)}
.card .chips{margin-top:9px;display:flex;gap:6px;flex-wrap:wrap}
.chip{
  font-size:12px;font-weight:500;padding:3px 9px;border-radius:999px;
  background:var(--accent-soft); color:var(--accent);
}
.chip.lead{background:#f0ede6;color:var(--ink-soft)}
.chip.gold{background:#f6efdd;color:var(--gold)}
.chip.green{background:#e7f1ec;color:var(--green)}

/* ---------- detail ---------- */
.back{display:inline-flex;align-items:center;gap:6px;color:var(--ink-soft);font-size:14px;margin-bottom:16px}
.back:hover{color:var(--accent)}
.detail-head h1{
  font-family:'Cormorant Garamond',serif;font-weight:700;
  font-size:clamp(28px,6vw,42px);line-height:1.05;margin:0 0 6px;
}
.detail-head .loc{color:var(--ink-soft);font-size:16px}
.contact{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0 4px}
.btn{
  display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:500;
  padding:9px 15px;border-radius:999px;border:1px solid var(--line);
  background:var(--card);color:var(--ink);box-shadow:var(--shadow);
}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.primary:hover{color:#fff;opacity:.92}

/* next mass banner */
.nextmass{
  margin:22px 0 4px;padding:16px 18px;border-radius:var(--radius);
  background:linear-gradient(135deg,#7c1f2e,#9a2c3c);color:#fff;box-shadow:var(--shadow);
}
.nextmass .lbl{font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.85}
.nextmass .when{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:600;margin-top:2px}
.nextmass .sub{font-size:14px;opacity:.9;margin-top:2px}

/* schedule groups */
.sched-group{margin-top:24px}
.sched-group h3{
  font-family:'Outfit';font-weight:600;font-size:15px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--accent);margin:0 0 8px;
  display:flex;align-items:center;gap:8px;
}
.sched-group h3 .ico{font-size:16px}
.dayblock{border-top:1px solid var(--line);padding:11px 2px;display:flex;gap:14px}
.dayblock:first-of-type{border-top:none}
.dayname{flex:0 0 92px;font-weight:500;color:var(--ink)}
.times{display:flex;flex-direction:column;gap:6px;flex:1}
.timerow{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.time{font-family:'DM Mono',monospace;font-size:15px;font-weight:500;color:var(--ink)}
.lang{font-size:11px;font-weight:600;letter-spacing:.05em;padding:2px 7px;border-radius:6px;background:var(--accent-soft);color:var(--accent)}
.lang.es{background:#e7f1ec;color:var(--green)}
.lang.vi{background:#eee7f3;color:#6b3fa0}
.lang.la{background:#f6efdd;color:var(--gold)}
.note{font-size:13px;color:var(--ink-soft);font-style:italic}

/* lead / no-schedule state */
.empty{
  margin-top:22px;padding:22px;border:1px dashed var(--line);border-radius:var(--radius);
  text-align:center;color:var(--ink-soft);background:#fcfaf6;
}
.empty strong{color:var(--ink);font-family:'Cormorant Garamond',serif;font-size:20px;display:block;margin-bottom:6px}

.no-results{text-align:center;color:var(--ink-soft);padding:40px 0}

/* footer */
.foot{
  position:fixed;bottom:0;left:0;right:0;
  font-size:11px;color:var(--ink-soft);text-align:center;
  padding:9px 16px;background:rgba(247,244,239,.9);backdrop-filter:blur(8px);
  border-top:1px solid var(--line);
}
.foot-sep{margin:0 7px;opacity:.5}
@media(max-width:520px){
  .foot .foot-sep,.foot #footMeta{display:none}
  .dayname{flex-basis:74px}
}

/* ============ confirm / claim page ============ */
.cf-wrap{max-width:640px;margin:0 auto;padding:clamp(18px,5vw,34px) clamp(16px,5vw,34px) 40px}
.cf-hero{margin:8px 0 22px}
.cf-eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:8px}
.cf-hero h1{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:clamp(30px,6.5vw,44px);line-height:1.05;margin:0 0 12px;
}
.cf-hero p{color:var(--ink-soft);font-size:16px;line-height:1.55;margin:0}
.cf-hero strong{color:var(--ink)}

.cf-overall{display:flex;flex-direction:column;gap:8px;align-items:flex-start;margin:0 0 18px}
.cf-allgood{
  font-family:'Outfit';font-size:15px;font-weight:600;cursor:pointer;
  padding:12px 18px;border-radius:999px;border:1.5px solid var(--line);
  background:var(--card);color:var(--ink);box-shadow:var(--shadow);transition:all .12s ease;
}
.cf-allgood.on{background:var(--green);border-color:var(--green);color:#fff}
.cf-allgood:hover{border-color:var(--green)}
.cf-or{font-size:13px;color:var(--ink-soft);padding-left:4px}

.cf-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;margin-bottom:14px;box-shadow:var(--shadow);
}
.cf-cardhead{
  font-family:'Outfit';font-weight:600;font-size:14px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--accent);margin:0 0 12px;display:flex;align-items:center;gap:8px;
}
.cf-cardhead .ico{font-size:16px}
.cf-empty{color:var(--ink-soft);font-size:14px;margin:0 0 12px}

.cf-dayrow{display:flex;gap:14px;align-items:flex-start;border-top:1px solid var(--line);padding:11px 0}
.cf-dayrow:first-of-type{border-top:none;padding-top:2px}
.cf-dayname{flex:0 0 90px;font-weight:500;font-size:14px;padding-top:5px}
.cf-chips{display:flex;flex-wrap:wrap;gap:7px;flex:1}
.cf-chip{
  font-family:'DM Mono',monospace;font-size:13.5px;font-weight:500;cursor:pointer;
  padding:6px 12px;border-radius:999px;border:1px solid var(--line);
  background:var(--bg);color:var(--ink);transition:all .1s ease;
}
.cf-chip:hover{border-color:var(--accent)}
.cf-chip.is-wrong{
  background:#fbecec;border-color:#e3b3b3;color:#a23030;
  text-decoration:line-through;text-decoration-thickness:2px;
}
.cf-chip.is-wrong::after{content:' \2715';text-decoration:none;font-size:11px}

.cf-added{display:flex;flex-direction:column;gap:8px;margin:10px 0 0}
.cf-addrow{display:flex;gap:7px;align-items:center;flex-wrap:wrap;
  background:#f6efe0;border:1px solid #e7d9bd;border-radius:12px;padding:8px 10px}
.cf-mini{font-family:'Outfit';font-size:14px;padding:7px 9px;border-radius:9px;
  border:1px solid var(--line);background:#fff;color:var(--ink)}
.cf-mini.cf-day{flex:1 1 110px}
.cf-mini.cf-lang{flex:1 1 110px}
.cf-mini.cf-time{flex:0 0 120px}
.cf-remove{margin-left:auto;border:none;background:none;cursor:pointer;color:var(--ink-soft);font-size:15px;padding:6px}
.cf-remove:hover{color:var(--accent)}
.cf-add{
  margin-top:12px;font-family:'Outfit';font-size:13.5px;font-weight:500;cursor:pointer;
  padding:8px 14px;border-radius:999px;border:1px dashed #cdbf9b;
  background:transparent;color:var(--gold);
}
.cf-add:hover{border-color:var(--gold);background:#faf4e6}

.cf-contact{display:flex;align-items:center;gap:12px;flex-wrap:wrap;border-top:1px solid var(--line);padding:12px 0}
.cf-contact:first-of-type{border-top:none;padding-top:2px}
.cf-contact-main{display:flex;flex-direction:column;flex:1;min-width:140px}
.cf-contact-label{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.cf-contact-val{font-size:15px;color:var(--ink);margin-top:2px}
.cf-contact-val em{color:var(--ink-soft)}
.cf-contact-flag{
  font-family:'Outfit';font-size:13px;font-weight:500;cursor:pointer;
  padding:7px 13px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--ink-soft);
}
.cf-contact-flag:hover{border-color:var(--accent);color:var(--accent)}
.cf-contact.is-fixing .cf-contact-flag{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}
.cf-contact-fix{flex-basis:100%;margin-top:6px}

.cf-label{display:block;font-size:14px;font-weight:500;margin-bottom:8px}
.cf-input,.cf-textarea{
  width:100%;font-family:'Outfit';font-size:15px;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 13px;outline:none;
}
.cf-input{margin-bottom:9px}
.cf-input:last-child{margin-bottom:0}
.cf-input:focus,.cf-textarea:focus{border-color:var(--accent)}
.cf-input.cf-need{border-color:var(--accent);background:#fbecec}
.cf-textarea{min-height:74px;resize:vertical}
.cf-who .cf-sub{font-size:13px;color:var(--ink-soft);margin:-4px 0 12px}

.cf-submit{
  display:block;width:100%;font-family:'Outfit';font-size:17px;font-weight:600;cursor:pointer;
  padding:15px;border-radius:14px;border:none;background:var(--accent);color:#fff;
  box-shadow:var(--shadow);margin-top:6px;transition:opacity .12s ease;
}
.cf-submit:hover{opacity:.93}
.cf-submit:disabled{opacity:.6;cursor:default}
.cf-foot-note{text-align:center;font-size:12px;color:var(--ink-soft);margin-top:12px}

.cf-thanks{text-align:center;padding:40px 0}
.cf-check{
  width:64px;height:64px;border-radius:50%;background:var(--green);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:34px;margin:0 auto 18px;
}
.cf-thanks h1{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:40px;margin:0 0 10px}
.cf-thanks p{color:var(--ink-soft);font-size:16px;line-height:1.55;max-width:42ch;margin:0 auto 22px}
.cf-back{display:inline-block;font-weight:500;color:var(--accent)}

.cf-flash{
  position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;font-size:14px;padding:11px 18px;border-radius:999px;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:all .25s ease;z-index:50;
}
.cf-flash.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* in-finder CTA on the detail page */
.parish-cta{
  margin-top:30px;padding:16px 18px;border:1px dashed var(--line);border-radius:var(--radius);
  background:#fcfaf6;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
}
.parish-cta .pc-txt{font-size:14px;color:var(--ink-soft)}
.parish-cta .pc-txt b{color:var(--ink);font-weight:600}
.parish-cta a.pc-btn{
  font-size:14px;font-weight:500;white-space:nowrap;
  padding:9px 15px;border-radius:999px;border:1px solid var(--accent);color:var(--accent);background:#fff;
}
.parish-cta a.pc-btn:hover{background:var(--accent);color:#fff}
