:root{
  --ink:#FFFFFF;        /* page background */
  --paper:#1a1a1a;      /* primary text */
  --white:#000000;      /* headings / wordmark / strong */
  --gray:#4a4a4a;       /* secondary text */
  --charcoal:#ededed;
  --line:#ececec;       /* hairlines */
  --line-2:#e3e3e3;
  --muted:#777777;
  --red:#FC0000;
  /* Production: license Helvetica Now Display (Black for logo + headlines) and Helvetica Now Text (body), then add them as web fonts. This stack approximates with system Helvetica. */
  --sans:'Helvetica Neue',Helvetica,Arial,sans-serif;
  --pad:clamp(22px,6vw,120px);
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
::selection{background:var(--paper);color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
:focus-visible{outline:2px solid var(--red);outline-offset:4px}
.rd{color:var(--red)}
.site-main{flex:1 0 auto}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

.eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--muted)}

/* header */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--pad);
  transition:background .35s ease,border-color .35s ease,padding .35s ease;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding-top:14px;padding-bottom:14px;
}
.mark{font-weight:900;letter-spacing:-.01em;font-size:19px;color:var(--white)}
.nav{display:flex;align-items:center;gap:clamp(18px,3vw,34px)}
.nav a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--gray);transition:color .25s}
.nav a:hover{color:var(--white)}
.nav a.give{color:var(--red);border:1px solid var(--red);padding:9px 16px;transition:border-color .25s,background .25s,color .25s}
.nav a.give:hover{background:var(--red);color:#fff}

/* hero */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-top:140px;padding-bottom:60px;position:relative}
.hero .eyebrow{margin-bottom:30px}
.hero h1{font-weight:800;font-size:clamp(56px,11vw,128px);line-height:.96;letter-spacing:-.035em;color:var(--white)}
.hero .sub{font-size:clamp(17px,1.5vw,21px);color:var(--gray);margin-top:36px;max-width:38ch;font-weight:400}
.hero-actions{display:flex;align-items:center;gap:26px;flex-wrap:wrap;margin-top:46px}
.btn{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--paper);color:var(--white);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;padding:16px 26px;transition:background .3s,color .3s,opacity .3s;cursor:pointer}
.btn:hover{background:var(--paper);color:var(--ink)}
.btn.solid{background:var(--red);color:#fff;border-color:var(--red)}
.btn.solid:hover{opacity:.85;background:var(--red);color:#fff}
.btn .arr{transition:transform .3s}
.btn:hover .arr{transform:translateX(4px)}
.next-line{font-size:13px;letter-spacing:.04em;color:var(--muted)}
.next-line b{color:var(--paper);font-weight:600}

/* sections */
.band{padding-top:clamp(90px,15vh,180px);padding-bottom:clamp(90px,15vh,180px);border-top:1px solid var(--line)}
.lede{font-weight:600;font-size:clamp(28px,4.6vw,60px);line-height:1.04;letter-spacing:-.025em;color:var(--white);max-width:20ch;margin-top:24px}
p.body{font-size:clamp(16px,1.2vw,18px);line-height:1.7;color:var(--paper);max-width:60ch}
p.body.muted{color:#555;margin-top:28px}

/* pillars */
.pillars{margin-top:clamp(48px,7vw,84px);border-top:1px solid var(--line-2)}
.pillar{padding:clamp(26px,3vw,38px) 0;border-bottom:1px solid var(--line-2);display:grid;grid-template-columns:1fr;gap:10px;transition:padding-left .35s ease}
@media(min-width:760px){.pillar{grid-template-columns:minmax(0,260px) 1fr;gap:clamp(24px,5vw,70px);align-items:baseline}}
.pillar:hover{padding-left:10px}
.pillar .p-word{font-weight:800;font-size:clamp(26px,3vw,40px);letter-spacing:-.02em;color:var(--white);line-height:1}
.pillar .p-desc{color:#555;font-size:clamp(15px,1.15vw,17px);max-width:50ch}

/* prayer meta */
.prayer-meta{display:flex;flex-wrap:wrap;gap:0;margin-top:clamp(44px,6vw,70px);border:1px solid var(--line-2)}
.pm{flex:1 1 200px;padding:26px 28px;border-right:1px solid var(--line-2)}
.pm:last-child{border-right:0}
.pm .k{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
.pm .v{font-size:clamp(18px,1.6vw,22px);color:var(--white);margin-top:8px;font-weight:600;letter-spacing:-.01em}
.pm-sub{color:var(--muted);font-size:14px;font-weight:400}
.prayer-cta{margin-top:clamp(34px,5vw,52px)}

/* updates */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:clamp(34px,5vw,56px)}
.sec-head h2{font-size:clamp(26px,3vw,42px);font-weight:800;color:var(--white);letter-spacing:-.03em;margin-top:14px}
.more-link{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--muted);transition:color .25s}
.more-link:hover{color:var(--white)}
.updates{border-top:1px solid var(--line-2)}
.update{display:grid;grid-template-columns:1fr;gap:6px;padding:clamp(26px,3.4vw,40px) 0;border-bottom:1px solid var(--line-2);transition:padding-left .35s ease}
@media(min-width:760px){.update{grid-template-columns:150px 1fr;gap:clamp(24px,4vw,64px);align-items:baseline}}
.update:hover{padding-left:10px}
.update .date{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600}
.update .u-title{font-weight:700;font-size:clamp(21px,2.5vw,32px);line-height:1.12;letter-spacing:-.02em;color:var(--white)}
.update .u-dek{color:#5a5a5a;font-size:15px;margin-top:10px;max-width:58ch}
.update .u-more{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:14px}

/* give */
.give-band .lede{max-width:18ch}

/* subscribe + members form */
.sub-inner{max-width:560px}
.sub-h{font-weight:800;font-size:clamp(30px,4.8vw,58px);line-height:1.0;color:var(--white);letter-spacing:-.03em;margin-top:18px}
.sub-inner p{color:#555;margin-top:18px;font-size:16px;max-width:48ch}
.subform{display:flex;gap:12px;margin-top:34px;flex-wrap:wrap}
.subform input{flex:1 1 240px;background:transparent;border:1px solid #cfcfcf;color:var(--white);padding:15px 18px;font-family:var(--sans);font-size:15px;transition:border-color .25s}
.subform input::placeholder{color:#9a9a9a}
.subform input:focus{outline:none;border-color:var(--paper)}
.subform button{background:var(--red);color:#fff;border:1px solid var(--red);font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;padding:15px 28px;cursor:pointer;transition:opacity .25s}
.subform button:hover{opacity:.85}
.subform.loading button{opacity:.5;pointer-events:none}
.subform.error input{border-color:var(--red)}
.sub-note{font-size:12px;color:#888;margin-top:16px}
.sub-success{display:none;color:var(--white);font-size:18px;margin-top:24px;font-weight:600;letter-spacing:-.01em}
.subform.success{display:none}
.subform.success + .sub-success{display:block}

/* post + page */
.post,.page{padding-top:clamp(120px,16vh,180px);padding-bottom:clamp(80px,12vh,140px);max-width:760px}
.post-head{margin-bottom:clamp(34px,5vw,52px)}
.back-link{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--muted);transition:color .25s}
.back-link:hover{color:var(--white)}
.post-date{display:block;margin-top:26px;color:var(--muted)}
.post-title{font-weight:800;font-size:clamp(34px,5.5vw,64px);line-height:1.02;letter-spacing:-.03em;color:var(--white);margin-top:18px}
.post-dek{font-size:clamp(18px,1.6vw,22px);color:#555;margin-top:22px;max-width:60ch;line-height:1.5}
.post-image{margin:clamp(34px,5vw,56px) 0}
.post-image img{width:100%}
.post-content{font-size:clamp(17px,1.25vw,19px);line-height:1.75;color:var(--paper);max-width:68ch}
.post-content > * + *{margin-top:1.5em}
.post-content h2{font-weight:800;font-size:clamp(24px,2.6vw,34px);letter-spacing:-.02em;color:var(--white);margin-top:1.8em;line-height:1.15}
.post-content h3{font-weight:700;font-size:clamp(20px,2vw,26px);letter-spacing:-.01em;color:var(--white);margin-top:1.6em}
.post-content a{color:var(--white);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#bbb;transition:text-decoration-color .2s}
.post-content a:hover{text-decoration-color:var(--paper)}
.post-content strong{color:var(--white);font-weight:700}
.post-content blockquote{border-left:2px solid var(--red);padding-left:24px;margin-left:0;color:var(--white);font-weight:500;font-size:1.1em}
.post-content ul,.post-content ol{padding-left:1.3em}
.post-content li{margin-top:.5em}
.post-content img{margin:1.5em 0}
.post-content figcaption{font-size:13px;color:var(--muted);text-align:center;margin-top:10px}
.post-content hr{border:0;border-top:1px solid var(--line-2);margin:2.4em 0}
/* Koenig editor card widths — required by Ghost */
.post-content .kg-card{margin-top:1.6em;margin-bottom:1.6em}
.kg-width-wide{position:relative;left:50%;transform:translateX(-50%);width:min(1040px,92vw);max-width:none}
.kg-width-full{position:relative;left:50%;width:100vw;margin-left:-50vw;max-width:none}
.kg-width-wide img,.kg-width-full img{width:100%}
.post-foot{margin-top:clamp(56px,8vw,90px);padding-top:clamp(40px,5vw,56px);border-top:1px solid var(--line-2)}
.post-cta .sub-h{margin-top:14px}

/* archive */
.archive{padding-top:clamp(130px,17vh,200px)}
.archive-title{font-weight:800;font-size:clamp(40px,7vw,90px);letter-spacing:-.03em;color:var(--white);margin-top:16px;margin-bottom:clamp(30px,4vw,50px)}
.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:clamp(40px,5vw,60px);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--muted)}
.pagination a{color:var(--white)}

/* footer */
.site-footer{border-top:1px solid var(--line);padding:clamp(60px,9vh,110px) var(--pad) 50px;flex-shrink:0}
.footer-inner{max-width:var(--maxw);margin:0 auto}
.foot-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:30px}
.foot-mark{font-weight:900;letter-spacing:-.01em;font-size:34px;color:var(--white)}
.foot-lines{font-weight:600;font-size:clamp(18px,2vw,26px);letter-spacing:-.02em;color:var(--gray);text-align:right;line-height:1.4}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-top:clamp(40px,6vw,64px);padding-top:26px;border-top:1px solid var(--line)}
.foot-bottom span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#999;font-weight:600}

/* reveal (gated on .js so content is visible if JS fails) */
.js .rv{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.js .rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js .rv{opacity:1!important;transform:none!important}
  .btn .arr,.update,.pillar{transition:none!important}
}

/* give page (embedded donation form — works on mobile + desktop) */
.give-page{padding-top:clamp(120px,16vh,180px);padding-bottom:clamp(80px,12vh,140px);display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,72px)}
@media(min-width:880px){.give-page{grid-template-columns:1fr 500px;align-items:start}}
.give-page-title{font-weight:800;font-size:clamp(34px,5vw,60px);letter-spacing:-.03em;color:var(--white);margin-top:18px;margin-bottom:24px}
.give-page-intro .body{margin-top:0;max-width:46ch}
.give-form{background:#fff;border:1px solid var(--line-2);border-radius:4px;overflow:hidden}
.give-form iframe{display:block;width:100%;border:0}

/* connect / join the community page */
.connect-page{padding-top:clamp(120px,16vh,180px);padding-bottom:clamp(80px,12vh,140px);display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,72px)}
@media(min-width:880px){.connect-page{grid-template-columns:1fr 1fr;align-items:start}}
.connect-title{font-weight:800;font-size:clamp(34px,5vw,60px);letter-spacing:-.03em;color:var(--white);margin-top:18px;margin-bottom:24px}
.connect-intro .body{margin-top:0;max-width:42ch}
.connect-form{display:flex;flex-direction:column;gap:22px;max-width:520px}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--muted)}
.form-field label .opt{text-transform:none;letter-spacing:0;color:#999;font-weight:400}
.connect-form input,.connect-form select,.connect-form textarea{background:transparent;border:1px solid #cfcfcf;color:var(--white);padding:14px 16px;font-family:var(--sans);font-size:15px;transition:border-color .25s;border-radius:0;width:100%}
.connect-form input:focus,.connect-form select:focus,.connect-form textarea:focus{outline:none;border-color:var(--paper)}
.connect-form select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23777777' stroke-width='1.5' fill='none'/></svg>");background-repeat:no-repeat;background-position:right 16px center}
.connect-form option{background:#fff;color:var(--paper)}
.connect-form textarea{resize:vertical;min-height:104px}
.connect-form .form-submit{align-self:flex-start;margin-top:6px}
.form-success,.form-error{display:none;font-size:16px;margin-top:6px;font-weight:600}
.form-success{color:var(--white)}
.form-error{color:var(--red)}

/* form checkbox */
.form-check{display:flex;align-items:center;gap:12px}
.form-check input[type=checkbox]{width:18px;height:18px;accent-color:var(--red);cursor:pointer;flex:0 0 auto}
.form-check label{font-size:15px;color:var(--paper);cursor:pointer;letter-spacing:0;text-transform:none;font-weight:400}
