
:root{
  --navy:#172033;
  --navy2:#202a43;
  --burgundy:#7b1e20;
  --red:#b33a2e;
  --gold:#d9a441;
  --gold2:#f3c765;
  --cream:#fff5df;
  --cream2:#f3e4c3;
  --blue:#7fa8c9;
  --ink:#261b14;
  --muted:#6a5848;
  --white:#fffdf8;
  --line:rgba(123,30,32,.18);
  --shadow:0 24px 60px rgba(38,27,20,.16);
  --radius:26px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);line-height:1.55;background:linear-gradient(180deg,var(--cream),#fff 46%,#fff9ed)}
img{max-width:100%;display:block}
a{color:var(--burgundy)}
.topbar{background:var(--navy);color:#fff;text-align:center;padding:8px 18px;font-weight:900;letter-spacing:.03em}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,253,248,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{max-width:1240px;margin:auto;padding:13px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--navy)}
.brand img{width:58px;height:58px;object-fit:contain}.brand strong{display:block;font-size:22px;line-height:1;color:var(--navy)}.brand em{display:block;font-style:normal;font-size:12px;text-transform:uppercase;font-weight:900;letter-spacing:.14em;color:var(--burgundy)}
.menu{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.menu a{font-weight:900;text-decoration:none;color:var(--navy);padding:9px 10px;border-radius:999px}.menu a:hover,.menu a.active{background:var(--cream2);color:var(--burgundy)}
.menu-toggle{display:none;border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 14px;font-weight:900;color:var(--navy)}
.button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--burgundy);color:#fff!important;text-decoration:none;border:2px solid var(--burgundy);padding:12px 19px;font-weight:950;box-shadow:0 10px 20px rgba(123,30,32,.14);line-height:1.1}.button.secondary{background:transparent;color:var(--burgundy)!important;border-color:rgba(123,30,32,.28);box-shadow:none}.button.gold{background:var(--gold);border-color:var(--gold);color:var(--ink)!important}.text-link{font-weight:950;color:var(--burgundy);text-decoration-thickness:2px;text-underline-offset:4px}.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.actions.right{justify-content:flex-end}
.kicker{display:inline-flex;align-items:center;gap:10px;color:var(--burgundy);font-weight:950;letter-spacing:.16em;text-transform:uppercase;font-size:13px}.kicker:before{content:'';width:42px;height:4px;border-radius:99px;background:var(--gold)}
h1,h2,h3{font-family:Georgia,'Times New Roman',serif;color:var(--navy);line-height:1.04;margin:0 0 15px}h1{font-size:clamp(44px,6vw,82px);letter-spacing:-.04em}h2{font-size:clamp(32px,4.4vw,56px);letter-spacing:-.035em}h3{font-size:24px}p{margin:0 0 16px;color:var(--muted)}
.home-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#fff6df,#fffdf8 40%,#f7e7c7)}.hero-bg{height:110px;overflow:hidden;border-bottom:5px solid var(--gold)}.hero-bg img{width:100%;height:100%;object-fit:cover}.home-hero-inner{max-width:1240px;margin:auto;display:grid;grid-template-columns:.95fr 1.05fr;gap:42px;align-items:center;padding:58px 20px 74px}.hero-copy p{font-size:22px;max-width:720px;color:#4f3d31}.hero-mosaic{display:grid;grid-template-columns:1fr 1fr;gap:14px}.hero-mosaic img{height:245px;object-fit:cover;border-radius:24px;border:6px solid #fff;box-shadow:var(--shadow)}.hero-mosaic .wide{grid-column:1/-1;height:310px}
.section{max-width:1240px;margin:auto;padding:72px 20px}.section.tint{max-width:none;background:linear-gradient(180deg,#fffdf8,var(--cream));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.section.tint>*{max-width:1240px;margin-left:auto;margin-right:auto}.section-head{max-width:880px;margin-bottom:32px}.grid{display:grid;gap:22px}.grid.three{grid-template-columns:repeat(3,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}.grid.two{grid-template-columns:repeat(2,1fr)}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 14px 36px rgba(38,27,20,.08);padding:28px;position:relative;overflow:hidden}.card:before{content:'';position:absolute;inset:0 0 auto;height:6px;background:linear-gradient(90deg,var(--burgundy),var(--gold),var(--blue),var(--navy))}.card img{width:100%;height:210px;object-fit:cover;border-radius:18px;margin:-6px 0 20px;border:1px solid var(--line)}.card h2{font-size:36px}.big-time{font-size:20px;font-weight:950;color:var(--burgundy)}
.mission-band{background:linear-gradient(135deg,var(--navy),#111825);color:#fff}.mission-inner{max-width:1240px;margin:auto;display:grid;grid-template-columns:.95fr 1.05fr;gap:42px;align-items:center;padding:72px 20px}.mission-inner img{width:100%;height:430px;object-fit:cover;border-radius:32px;border:6px solid rgba(255,255,255,.12)}.mission-inner h2,.mission-inner .kicker{color:#fff}.mission-inner p{color:#f6e7c6;font-size:19px}.mission-inner .kicker:before{background:var(--gold)}
.photo-grid{display:grid;gap:18px}.photo-grid.editorial{grid-template-columns:repeat(3,1fr)}.photo-card{margin:0;position:relative;overflow:hidden;border-radius:24px;background:#fff;box-shadow:0 14px 36px rgba(38,27,20,.08);border:1px solid var(--line)}.photo-card img{width:100%;height:300px;object-fit:cover}.photo-card figcaption{position:absolute;left:12px;bottom:12px;background:rgba(23,32,51,.86);color:#fff;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:900}.photo-card:nth-child(1){grid-column:span 2}.photo-card:nth-child(1) img{height:360px}
.cta-panel{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;background:linear-gradient(135deg,#fff,var(--cream));border:1px solid var(--line);border-radius:32px;box-shadow:var(--shadow);margin-top:40px;margin-bottom:40px}.split{display:grid;grid-template-columns:.95fr 1.05fr;gap:36px;align-items:start}.split>div>img,.mission-collage img,.stacked-photos img,.page-hero-photo img{width:100%;object-fit:cover;border-radius:26px;border:6px solid #fff;box-shadow:var(--shadow)}.stacked-photos{display:grid;grid-template-columns:1fr 1fr;gap:14px}.stacked-photos img:first-child{grid-column:1/-1;height:310px}.stacked-photos img{height:230px}
.page-hero{background:linear-gradient(135deg,var(--burgundy),#3c0f10);color:#fff}.page-hero-inner{max-width:1240px;margin:auto;display:grid;grid-template-columns:1fr .72fr;gap:34px;align-items:center;padding:62px 20px}.page-hero h1,.page-hero .kicker{color:#fff}.page-hero .kicker:before{background:var(--gold)}.page-hero p{color:#fff2d1;font-size:21px;max-width:850px}.page-hero-photo img{height:360px}.feature-list{list-style:none;margin:0 0 20px;padding:0}.feature-list li{padding:10px 0;border-bottom:1px solid rgba(123,30,32,.13);font-weight:750;color:#4d3b31}
.form-card{background:#fff;border:1px solid var(--line);border-radius:30px;padding:30px;box-shadow:var(--shadow)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.form-grid .full{grid-column:1/-1}label{font-weight:950;color:var(--navy)}input,select,textarea{width:100%;margin-top:7px;border:1px solid rgba(123,30,32,.28);border-radius:14px;padding:13px 14px;font:inherit;background:#fffdf8;color:var(--ink)}textarea{min-height:130px}.hidden-field{position:absolute!important;left:-5000px!important}
.footer{background:#151012;color:#fff;padding:52px 20px}.footer-inner{max-width:1240px;margin:auto;display:grid;grid-template-columns:1.4fr .7fr .7fr;gap:26px}.footer h2,.footer h3{color:#fff}.footer p{color:#ecd9b8}.footer a{color:#ffd36d}.footer-logo{width:82px;height:82px;object-fit:contain;margin-bottom:8px}.mini{font-size:14px;opacity:.78}
@media(max-width:1050px){.grid.four{grid-template-columns:repeat(2,1fr)}.home-hero-inner,.mission-inner,.page-hero-inner,.split{grid-template-columns:1fr}.page-hero-photo img{height:280px}.menu-toggle{display:inline-flex}.menu{display:none;position:absolute;right:20px;top:84px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:14px;max-width:320px}.menu.open{display:grid}.menu a{display:block}.photo-grid.editorial{grid-template-columns:repeat(2,1fr)}.photo-card:nth-child(1){grid-column:span 1}.photo-card:nth-child(1) img{height:300px}.cta-panel{grid-template-columns:1fr}.actions.right{justify-content:flex-start}}
@media(max-width:680px){.grid.three,.grid.four,.grid.two,.footer-inner,.photo-grid.editorial,.form-grid{grid-template-columns:1fr}.home-hero-inner{padding:38px 16px 50px}.section{padding:54px 16px}.hero-mosaic{grid-template-columns:1fr}.hero-mosaic .wide,.hero-mosaic img{height:240px}.brand strong{font-size:18px}.brand em{font-size:10px}.brand img{width:50px;height:50px}h1{font-size:42px}.topbar{font-size:13px}.mission-inner{padding:54px 16px}.mission-inner img{height:290px}.page-hero-inner{padding:48px 16px}.stacked-photos{grid-template-columns:1fr}.stacked-photos img,.stacked-photos img:first-child{height:260px}.form-card{padding:22px}.card{padding:22px}.card img{height:220px}}

/* Forgiving cover crop for photo cards
   Keeps the polished grid look while reducing face/head cropping.
   Regular gallery/card images stay cropped, but the frames are taller and the crop favors the upper center where faces usually sit.
*/
.photo-card figcaption { display: none !important; }
.photo-card img {
  height: 380px !important;
  object-fit: cover !important;
  object-position: center 30% !important;
}
.photo-card:nth-child(1) img {
  height: 440px !important;
  object-position: center 30% !important;
}
.card img {
  height: 260px !important;
  object-fit: cover !important;
  object-position: center 30% !important;
}
.stacked-photos img,
.split > div > img {
  object-fit: cover !important;
  object-position: center 30% !important;
}
.hero-mosaic img,
.hero-bg img,
.page-hero-photo img,
.mission-inner img {
  object-fit: cover !important;
}
img[data-position="face"] { object-position: center 28% !important; }
img[data-position="face-top"] { object-position: center 22% !important; }
img[data-position="face-left"] { object-position: 34% 28% !important; }
img[data-position="face-right"] { object-position: 66% 28% !important; }
img[data-position="center"] { object-position: center center !important; }
@media(max-width:1050px){
  .photo-card img,
  .photo-card:nth-child(1) img { height: 340px !important; }
  .card img { height: 240px !important; }
}
@media(max-width:640px){
  .photo-card img,
  .photo-card:nth-child(1) img { height: 310px !important; }
  .card img { height: 230px !important; }
}


/* Future dates table */
.date-table-wrap{overflow-x:auto;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:0 14px 36px rgba(38,27,20,.08);}
.date-table{width:100%;border-collapse:collapse;min-width:620px;}
.date-table th,.date-table td{text-align:left;padding:14px 18px;border-bottom:1px solid rgba(123,30,32,.12);}
.date-table th{color:var(--navy);font-weight:950;background:var(--cream2);}
.date-table tr:last-child td{border-bottom:0;}
.future-dates{padding-top:30px;}


/* Editor-friendly image controls: add data-position="face", "face-top", "face-left", "face-right", or "center" to an img tag when a crop needs adjustment. */
img[data-position="face"] { object-position: center 28% !important; }
img[data-position="face-top"] { object-position: center 18% !important; }
img[data-position="face-left"] { object-position: 34% 28% !important; }
img[data-position="face-right"] { object-position: 66% 28% !important; }
img[data-position="center"] { object-position: center center !important; }
.notice-card{background:#fff7e6;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 10px 24px rgba(38,27,20,.06)}

/* Dark hero button contrast */
.page-hero .button.secondary, .mission-inner .button.secondary {
  color:#fff!important;
  border-color:rgba(255,255,255,.58);
  background:rgba(255,255,255,.08);
}
.page-hero .button.secondary:hover, .mission-inner .button.secondary:hover {
  background:rgba(255,255,255,.16);
}


/* Requested image additions: Mary artwork and beer sponsor logo */
.mission-inner img.contain-art{
  object-fit:contain!important;
  background:#111825;
  padding:18px;
}
.sponsor-logo-card img{
  height:160px!important;
  object-fit:contain!important;
  object-position:center center!important;
  background:#fff;
  padding:16px;
}

/* Homepage legacy section: gives context to people/history photos instead of treating them as decorative gallery images. */
.legacy-home .section-head{max-width:980px;}
.legacy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.legacy-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 14px 36px rgba(38,27,20,.08);overflow:hidden;}
.legacy-card img{width:100%;height:260px;object-fit:cover;object-position:center 30%;}
.legacy-card h3{font-size:26px;margin:22px 24px 10px;}
.legacy-card p{margin:0 24px 24px;}
@media(max-width:1050px){.legacy-grid{grid-template-columns:repeat(2,1fr);}.legacy-card img{height:250px;}}
@media(max-width:680px){.legacy-grid{grid-template-columns:1fr;}.legacy-card img{height:260px;}}


/* Priority preview: clearer decision paths before launch */
.visit-basics{padding-top:56px;padding-bottom:56px;}
.basics-grid .notice-card h3,.parent-basics .notice-card h3,.sponsor-guide .notice-card h3{font-size:24px;margin-bottom:10px;}
.basics-grid .notice-card p,.parent-basics .notice-card p,.sponsor-guide .notice-card p{margin-bottom:0;}
.sponsor-guide{padding-top:58px;padding-bottom:58px;}

/* Parish mission collage: remove the heavy, double-framed look and keep the section balanced. */
.mission-collage img{display:block;aspect-ratio:1100/702;object-fit:cover;object-position:center center;}


/* Mission section v6: let the collage breathe a bit more and show the full artwork more naturally. */
.mission-split{grid-template-columns:.9fr 1.1fr;gap:28px;align-items:center;}
.mission-collage{display:flex;align-items:center;}
.mission-collage img{width:100%;height:auto;aspect-ratio:auto;object-fit:contain;object-position:center center;}
@media(max-width:1050px){.mission-split{grid-template-columns:1fr;gap:24px;}}
