/* =============================================================
   St Nicholas' — shared design system (structure + components)
   Every theme sets the CSS variables in :root; this file styles
   the shared component vocabulary against those variables so all
   themes are a true apples-to-apples comparison on identical HTML.
   -------------------------------------------------------------
   Variable contract (themes MUST define these):
   Colour : --bg --surface --surface-2 --ink --muted --line
            --primary --on-primary --accent --accent-2
            --hero-bg --hero-ink --hero-accent
            --footer-bg --footer-ink --footer-head --footer-muted
   Type   : --font-display --font-body --display-weight
            --display-style --h1 --h2 --h3 --lede
   Shape  : --radius --radius-lg --radius-pill --btn-radius
            --shadow --shadow-lg --border
   Accent : --eyebrow --eyebrow-tt (text-transform) --rule
   ============================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body,system-ui,sans-serif);
  color:var(--ink,#222);background:var(--bg,#fff);
  line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased;
  padding-bottom:64px; /* room for preview toolbar */
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:var(--display-weight,600);line-height:1.12;color:var(--ink);letter-spacing:-.005em}
h1{font-size:clamp(2.3rem,6vw,var(--h1,4rem))}
h2{font-size:clamp(1.8rem,4.5vw,var(--h2,2.7rem))}
h3{font-size:var(--h3,1.6rem)}
p{color:var(--ink)}

.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(20px,4vw,40px)}
.section{padding:clamp(56px,8vw,96px) 0}
.center{text-align:center}
.lede{font-size:var(--lede,1.18rem);color:var(--muted);line-height:1.6}

.eyebrow{font-family:var(--font-body);font-size:.74rem;letter-spacing:.18em;
  text-transform:var(--eyebrow-tt,uppercase);color:var(--eyebrow,var(--accent));font-weight:700;display:inline-block}

.rule{width:60px;height:2px;background:var(--rule,var(--accent));margin:22px 0;border:0}
.center .rule{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:14px 30px;border-radius:var(--btn-radius,4px);
  font-family:var(--font-body);font-weight:700;font-size:.85rem;letter-spacing:.04em;
  cursor:pointer;border:1.5px solid transparent;transition:.2s;line-height:1}
.btn--primary{background:var(--primary);color:var(--on-primary);box-shadow:var(--btn-shadow,none)}
.btn--primary:hover{filter:brightness(1.06)}
.btn--secondary{background:var(--surface);color:var(--primary);border-color:var(--line)}
.btn--secondary:hover{background:var(--surface-2)}
.btn--ghost{background:transparent;border-color:currentColor;color:inherit}
.btn--ghost:hover{background:rgba(255,255,255,.12)}

/* ---------- Header / Nav ---------- */
.site-header{background:var(--bg);position:relative;z-index:20}
.topbar{background:var(--primary);color:var(--on-primary);font-size:.78rem;letter-spacing:.03em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding:9px 0;flex-wrap:wrap;gap:8px}
.topbar a{opacity:.92}
.nav{display:flex;justify-content:space-between;align-items:center;padding:22px 0;gap:24px}
.brand{display:flex;align-items:center;gap:13px}
.brand__mark{width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  color:var(--primary);flex:0 0 auto}
.brand__mark svg{width:100%;height:100%}
.brand__name{font-family:var(--font-display);font-size:1.7rem;font-weight:var(--display-weight,700);color:var(--ink);line-height:1}
.brand__tag{display:block;font-family:var(--font-body);font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:4px;font-weight:600}
.main-nav ul{display:flex;gap:30px;list-style:none;align-items:center;font-size:.82rem;letter-spacing:.08em;
  text-transform:uppercase;font-weight:700}
.main-nav a{padding-bottom:4px;border-bottom:2px solid transparent;transition:.2s}
.main-nav a:hover,.main-nav a.is-active{border-color:var(--accent);color:var(--primary)}
.main-nav .btn{padding:11px 22px;border-bottom:none}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;color:var(--ink);flex:0 0 auto}
.nav-toggle svg{width:26px;height:26px}

/* ---------- Hero ---------- */
.hero{background:var(--hero-bg);color:var(--hero-ink);position:relative;overflow:hidden}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;
  padding:clamp(60px,9vw,104px) 0}
.hero--center .hero__inner{grid-template-columns:1fr;max-width:840px;text-align:center;justify-items:center}
.hero h1{color:var(--hero-ink);font-size:clamp(2.6rem,7vw,var(--hero-h1,4.6rem));margin:16px 0 6px}
.hero h1 em{font-style:italic;color:var(--hero-accent)}
.hero .eyebrow{color:var(--hero-accent)}
.hero__lede{font-size:1.24rem;color:var(--hero-ink);opacity:.92;max-width:540px;margin:18px 0 32px;line-height:1.55}
.hero--center .hero__lede{margin-left:auto;margin-right:auto}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.hero--center .hero__actions{justify-content:center}
.hero__media{position:relative}

/* ---------- Media placeholders ---------- */
.media{position:relative;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(150deg,var(--accent-2),var(--accent));
  display:flex;align-items:center;justify-content:center;min-height:200px;
  font-family:var(--font-display);font-style:italic;color:rgba(255,255,255,.85);font-size:1.05rem;text-align:center;padding:20px}
.media[data-label]::after{content:attr(data-label);position:absolute;bottom:12px;right:14px;
  font-family:var(--font-body);font-style:normal;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.7);font-weight:700}
.media.has-photo{background-size:cover;background-position:center;color:transparent}
.media.has-photo::after{display:none}
.media--portrait{aspect-ratio:4/5}
.media--wide{aspect-ratio:16/10}
.media--square{aspect-ratio:1/1}
.media--card{aspect-ratio:3/2;border-radius:0}

/* ---------- Service strip ---------- */
.services{background:var(--surface-2)}
.services .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,2vw,22px);padding:clamp(28px,4vw,40px) 0}
.service{background:var(--surface);border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow);
  border:var(--border);display:flex;flex-direction:column;gap:5px}
.service__tag{align-self:flex-start;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;
  color:var(--accent);background:var(--surface-2);padding:5px 12px;border-radius:var(--radius-pill);margin-bottom:6px}
.service__time{font-family:var(--font-display);font-size:2.1rem;color:var(--primary);line-height:1}
.service__name{font-weight:700;font-size:1rem;color:var(--ink)}
.service__note{color:var(--muted);font-size:.9rem}

/* ---------- Feature / welcome ---------- */
.feature .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,64px);align-items:center}
.feature--flip .wrap{direction:rtl}
.feature--flip .feature__body{direction:ltr}
.feature__body h2{margin:12px 0 20px}
.feature__body p{color:var(--muted);margin-bottom:16px}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,28px)}
.card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  border:var(--border);transition:.2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card__media{aspect-ratio:3/2;position:relative}
.card__body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.card__title{font-size:1.5rem;margin-bottom:8px}
.card__text{color:var(--muted);font-size:.95rem;margin-bottom:16px;flex:1}
.link-more{font-family:var(--font-body);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  font-weight:700;color:var(--accent)}
.link-more:hover{color:var(--primary)}

/* ---------- Quote band ---------- */
.quote{background:var(--quote-bg,var(--primary));color:var(--quote-ink,var(--on-primary));text-align:center}
.quote .wrap{padding:clamp(60px,9vw,92px) 0;max-width:900px}
.quote__text{font-family:var(--font-display);font-style:italic;font-size:clamp(1.6rem,3.2vw,2.4rem);
  line-height:1.4;color:var(--quote-ink,var(--on-primary))}
.quote .eyebrow{color:var(--hero-accent);display:block;margin-bottom:18px}

/* ---------- CTA / signup ---------- */
.cta .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,60px);align-items:center}
.cta--center .wrap{grid-template-columns:1fr;max-width:620px;text-align:center}
.signup{display:flex;gap:10px;max-width:480px;margin-top:8px}
.cta--center .signup{margin-left:auto;margin-right:auto}
.field{flex:1;padding:14px 18px;border:1.5px solid var(--line);border-radius:var(--btn-radius,4px);
  font-family:var(--font-body);font-size:.95rem;background:var(--surface);color:var(--ink)}
.info-card{background:var(--surface);border:var(--border,1px solid var(--line));border-radius:var(--radius-lg);padding:34px}
.info-card h3{margin-bottom:14px}
.info-card ul{list-style:none;line-height:2.05}
.info-card li b{color:var(--primary)}

/* ---------- Interior page hero ---------- */
.page-hero{background:var(--hero-bg);color:var(--hero-ink)}
.page-hero .wrap{padding:clamp(56px,8vw,86px) 0;max-width:840px}
.page-hero h1{color:var(--hero-ink);font-size:clamp(2.6rem,5vw,3.8rem)}
.page-hero .eyebrow{color:var(--hero-accent)}
.page-hero p{color:var(--hero-ink);opacity:.92;font-size:1.15rem;margin-top:14px;max-width:620px}

/* ---------- Prose ---------- */
.prose{max-width:720px}
.prose.center{margin:0 auto}
.prose h2{margin:0 0 18px}
.prose h3{margin:34px 0 10px;color:var(--primary)}
.prose p{color:var(--muted);margin-bottom:18px}
.prose blockquote{border-left:3px solid var(--accent);padding:6px 0 6px 24px;margin:24px 0;
  font-family:var(--font-display);font-style:italic;font-size:1.4rem;color:var(--ink)}

/* ---------- Team / who's who ---------- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,30px)}
.member{text-align:center}
.member .media{aspect-ratio:1/1;border-radius:var(--radius-lg);margin-bottom:16px}
.member h3{font-size:1.35rem}
.member .role{color:var(--accent);font-weight:700;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin:4px 0 8px}
.member p{color:var(--muted);font-size:.92rem}

/* ---------- Style guide ---------- */
.sg-section{padding:48px 0;border-bottom:1px solid var(--line)}
.sg-label{font-family:var(--font-body);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:22px}
.swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}
.swatch{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--surface)}
.swatch .chip{height:88px}
.swatch .meta{padding:12px 14px;font-size:.8rem}
.swatch .meta b{display:block;font-weight:700}
.swatch .meta span{color:var(--muted);font-size:.72rem}
.type-row{display:flex;align-items:baseline;gap:20px;padding:14px 0;border-bottom:1px dashed var(--line);flex-wrap:wrap}
.type-row .tag{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);min-width:120px;font-weight:700}
.comp-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.pill{display:inline-block;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;
  color:var(--accent);background:var(--surface-2);padding:6px 14px;border-radius:var(--radius-pill)}
.note{border-left:3px solid var(--accent);background:var(--surface-2);padding:16px 20px;border-radius:var(--radius);color:var(--muted)}

/* ---------- Footer ---------- */
.site-footer{background:var(--footer-bg);color:var(--footer-muted,var(--footer-ink));padding:64px 0 30px;font-size:.93rem}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:clamp(28px,5vw,48px);margin-bottom:42px}
.site-footer h4{font-family:var(--font-display);color:var(--footer-head);font-size:1.4rem;margin-bottom:14px;font-weight:600}
.site-footer .brand__name{color:var(--footer-ink)}
.site-footer p{color:var(--footer-muted)}
.site-footer ul{list-style:none;line-height:2.05}
.site-footer a:hover{color:var(--footer-head)}
.social{display:flex;gap:12px;margin-top:18px}
.social a{width:38px;height:38px;border-radius:var(--social-radius,50%);border:1px solid var(--footer-line,rgba(255,255,255,.25));
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--footer-ink)}
.social a:hover{background:var(--accent);border-color:var(--accent);color:var(--on-primary)}
.copyright{border-top:1px solid var(--footer-line,rgba(255,255,255,.14));padding-top:22px;font-size:.78rem;color:var(--footer-muted);text-align:center}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .hero__inner,.feature .wrap,.cta .wrap{grid-template-columns:1fr}
  .feature--flip .wrap{direction:ltr}
  .cards,.services .wrap,.team,.footer__grid,.events-layout{grid-template-columns:1fr}
  .hero__media{order:-1}
  /* mobile nav: hamburger dropdown */
  .nav{position:relative;flex-wrap:wrap}
  .nav-toggle{display:flex;align-items:center;justify-content:center}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--surface);
    border-top:1px solid var(--line);box-shadow:var(--shadow-lg);z-index:60;padding:6px 0}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:0}
  .main-nav li{border-bottom:1px solid var(--line)}
  .main-nav li:last-child{border-bottom:0;padding:12px 22px}
  .main-nav a{display:block;padding:14px 22px;border-bottom:none}
  .main-nav a.is-active{color:var(--primary)}
  .main-nav .btn{display:inline-block}
}
@media (max-width:520px){
  body{font-size:16px}
  .topbar{font-size:.7rem}
  .hero__lede{font-size:1.08rem}
  .gallery{column-count:1}
  .date-chip{width:60px}
  .eyebrow{letter-spacing:.1em}
}

/* prevent grid/flex children from overflowing on narrow screens */
.hero__inner>*,.feature .wrap>*,.cta .wrap>*,.events-layout>*,
.footer__grid>*,.team>*,.cards>*,.topbar .wrap>*{min-width:0}
.hero__text,.feature__body,.page-hero,.prose,.card__body,.event-row__body{overflow-wrap:break-word}
.hero .eyebrow,.page-hero .eyebrow{display:block}
@media (max-width:760px){body{padding-bottom:118px}}

/* ---------- Map embed (OpenStreetMap tiles) ---------- */
.map-embed{position:relative;aspect-ratio:1/1;border-radius:var(--radius);overflow:hidden;border:var(--border)}
.map-tiles{display:grid;grid-template-columns:repeat(3,1fr);width:100%;height:100%}
.map-tiles img{width:100%;height:100%;display:block}
.map-pin{position:absolute;left:42%;top:37%;width:18px;height:18px;background:var(--accent-2);
  border:3px solid #fff;border-radius:50% 50% 50% 0;transform:translate(-50%,-100%) rotate(-45deg);
  box-shadow:0 3px 8px rgba(0,0,0,.4)}
.map-attr{position:absolute;bottom:0;right:0;background:rgba(255,255,255,.82);font-size:.58rem;
  padding:2px 6px;color:#333;font-family:var(--font-body)}

/* ---------- Events ---------- */
.event-list{display:flex;flex-direction:column;gap:14px}
.event-row{display:flex;gap:20px;align-items:center;background:var(--surface);border:var(--border);
  border-radius:var(--radius);padding:18px 22px;box-shadow:var(--shadow)}
.date-chip{flex:0 0 auto;width:72px;text-align:center;background:var(--surface-2);border-radius:var(--radius);padding:10px 0}
.date-chip .m{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--accent)}
.date-chip .d{font-family:var(--font-display);font-size:1.9rem;line-height:1;color:var(--primary)}
.event-row__body{flex:1}
.event-row__body h3{font-size:1.3rem;margin-bottom:2px}
.event-row__body .meta{color:var(--muted);font-size:.9rem}
.events-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:start}

/* Calendar */
.calendar{background:var(--surface);border:var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cal-head h3{font-size:1.6rem}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-grid .dow{text-align:center;font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;padding-bottom:6px}
.cal-cell{aspect-ratio:1/1;border-radius:8px;display:flex;flex-direction:column;align-items:center;
  padding-top:8px;font-size:.85rem;background:var(--surface-2)}
.cal-cell.dim{opacity:.32}
.cal-cell .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);margin-top:5px}
.cal-cell.special{background:var(--primary);color:var(--on-primary)}
.cal-cell.special .dot{background:var(--on-primary)}
.cal-legend{display:flex;gap:18px;margin-top:18px;font-size:.82rem;color:var(--muted);flex-wrap:wrap}
.cal-legend span{display:flex;align-items:center;gap:7px}
.cal-legend i{width:10px;height:10px;border-radius:50%;display:inline-block}

/* ---------- Blog ---------- */
.post-meta{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:8px}
.post-card .card__title{font-size:1.35rem}

/* ---------- Article ---------- */
.article{max-width:760px;margin:0 auto}
.article__meta{color:var(--muted);font-size:.92rem;margin-top:10px}
.article__hero{aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;margin:26px 0;background-size:cover;background-position:center}
.article .prose{max-width:none}
.byline{display:flex;align-items:center;gap:12px;margin:30px 0;padding-top:22px;border-top:1px solid var(--line)}
.byline .av{width:48px;height:48px;border-radius:50%;background-size:cover;background-position:center;flex:0 0 auto}
.byline b{display:block}.byline span{color:var(--muted);font-size:.85rem}

/* ---------- Gallery ---------- */
.gallery{column-count:3;column-gap:16px}
.gallery img{width:100%;margin:0 0 16px;border-radius:var(--radius);display:block;break-inside:avoid}

@media (max-width:860px){
  .gallery{column-count:2}
  .event-row{flex-wrap:wrap}
}
