/* Cedarbrook Worship Sanctuary — Stylesheet */
:root{
  --ink:#1a1410;
  --paper:#fbf7f0;
  --cream:#f3ead9;
  --gold:#b08a3e;
  --gold-deep:#8a6a26;
  --moss:#4a5c3a;
  --rose:#a85a4a;
  --line:#e6dcc6;
  --shadow:0 10px 40px rgba(40,28,12,.12);
  --serif:'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--gold-deep);text-decoration:none;transition:color .25s}
a:hover{color:var(--rose)}

/* Typography */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:.005em;color:var(--ink);line-height:1.18}
h1{font-size:clamp(2.4rem,5.6vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem);margin-bottom:.6em}
h3{font-size:1.45rem;margin-bottom:.5em}
p{margin-bottom:1em}
.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  font-size:.78rem;
  letter-spacing:.28em;
  color:var(--gold-deep);
  font-weight:600;
  margin-bottom:1.2rem;
  display:inline-block;
}
.eyebrow::before{content:"✦  "}

/* Layout */
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
section{padding:110px 0;position:relative}
.section-cream{background:var(--cream)}
.section-ink{background:#221a13;color:#f5ecd9}
.section-ink h1,.section-ink h2,.section-ink h3{color:#f5ecd9}
.section-ink .eyebrow{color:#d6b269}

/* Top bar */
.topbar{
  background:#221a13;
  color:#e7d8b3;
  font-size:.82rem;
  padding:9px 0;
}
.topbar .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}
.topbar a{color:#e7d8b3}
.topbar a:hover{color:#fff}

/* Header */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(251,247,240,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:46px;height:46px;flex:0 0 46px}
.brand-name{font-family:var(--serif);font-size:1.45rem;line-height:1;letter-spacing:.01em}
.brand-name small{display:block;font-family:var(--sans);font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);margin-top:6px}
.menu{display:flex;gap:30px;align-items:center}
.menu a{color:var(--ink);font-size:.93rem;font-weight:500;position:relative;padding:6px 0}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .35s}
.menu a:hover::after,.menu a.active::after{width:100%}
.menu a:hover{color:var(--gold-deep)}
.btn{
  display:inline-block;
  padding:13px 26px;
  background:var(--ink);
  color:#fbf7f0;
  font-size:.85rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  border:1px solid var(--ink);
  border-radius:2px;
  transition:all .3s;
  font-weight:500;
}
.btn:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:#fff;transform:translateY(-2px)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:#fbf7f0}
.btn.light{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn.light:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.burger{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--ink)}

/* Hero */
.hero{
  min-height:88vh;
  display:flex;align-items:center;
  position:relative;
  color:#f5ecd9;
  background:
    linear-gradient(115deg, rgba(20,14,8,.78), rgba(20,14,8,.42)),
    url('https://images.unsplash.com/photo-1507434965515-61970f2bd7c6?auto=format&fit=crop&w=2000&q=80') center/cover no-repeat;
  overflow:hidden;
}
.hero h1{color:#f7ecd0;max-width:900px}
.hero .eyebrow{color:#d6b269}
.hero p.lead{font-size:1.18rem;max-width:640px;color:#ecdfc6;margin:1.4rem 0 2.2rem}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn.ghost{color:#f7ecd0;border-color:#f7ecd0}
.hero .btn.ghost:hover{background:#f7ecd0;color:var(--ink)}
.scroll-cue{
  position:absolute;left:50%;bottom:30px;transform:translateX(-50%);
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:#d6b269;
  animation:bob 2.4s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.12s}
.reveal.delay-2{transition-delay:.24s}
.reveal.delay-3{transition-delay:.36s}

/* Grids */
.grid{display:grid;gap:32px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:880px){
  .grid-3,.grid-2,.grid-4{grid-template-columns:1fr}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--paper);flex-direction:column;padding:24px;border-bottom:1px solid var(--line);gap:18px}
  .menu.open{display:flex}
  .burger{display:block}
  section{padding:80px 0}
}

/* Cards */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:36px 30px;
  transition:transform .35s, box-shadow .35s, border-color .35s;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;width:0;height:3px;background:var(--gold);
  transition:width .5s;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.card:hover::before{width:100%}
.card .num{font-family:var(--serif);font-size:2.4rem;color:var(--gold);display:block;margin-bottom:10px}
.card h3{margin-bottom:.4em}
.card p{color:#4f4438;font-size:.96rem;margin-bottom:0}

/* Section heading */
.sec-head{text-align:center;max-width:720px;margin:0 auto 70px}
.sec-head p{color:#5e5345;font-size:1.05rem}

/* Quote */
.quote{
  font-family:var(--serif);
  font-size:clamp(1.6rem,2.6vw,2.2rem);
  font-style:italic;
  text-align:center;
  max-width:880px;margin:0 auto;
  color:#f5ecd9;
  line-height:1.45;
}
.quote cite{display:block;margin-top:24px;font-family:var(--sans);font-style:normal;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:#d6b269}

/* About split */
.about-img{
  height:520px;
  background:url('https://images.unsplash.com/photo-1438032005730-c779502df39b?auto=format&fit=crop&w=1400&q=80') center/cover no-repeat;
  position:relative;
}
.about-img::after{
  content:"";position:absolute;inset:0;
  border:1px solid var(--gold);
  transform:translate(18px,18px);
  pointer-events:none;
}

/* Ministry list */
.minlist{list-style:none;display:grid;gap:22px}
.minlist li{
  display:grid;grid-template-columns:60px 1fr;gap:20px;
  padding:22px 0;border-bottom:1px solid var(--line);
}
.minlist li:last-child{border-bottom:0}
.minlist .ico{
  width:46px;height:46px;border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);color:var(--gold-deep);
  font-size:1.2rem;
}

/* Schedule */
.schedule{
  background:url('https://images.unsplash.com/photo-1519892338195-7c3c87bd1c08?auto=format&fit=crop&w=1800&q=80') center/cover no-repeat fixed;
  position:relative;color:#f5ecd9;padding:130px 0;
}
.schedule::before{content:"";position:absolute;inset:0;background:rgba(20,14,8,.78)}
.schedule .wrap{position:relative;z-index:1}
.svc{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;
  background:rgba(255,255,255,.18);margin-top:50px;
}
.svc>div{background:#221a13;padding:36px 28px;text-align:center}
.svc .day{font-family:var(--serif);font-size:1.6rem;color:#f5ecd9;margin-bottom:6px}
.svc .time{color:#d6b269;letter-spacing:.18em;font-size:.78rem;text-transform:uppercase;margin-bottom:14px}
.svc small{display:block;color:#cdbf9c;font-size:.88rem}
@media(max-width:780px){.svc{grid-template-columns:1fr}}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stats .v{font-family:var(--serif);font-size:3rem;color:var(--gold);line-height:1}
.stats .k{font-size:.78rem;letter-spacing:.25em;text-transform:uppercase;color:#7a6d56;margin-top:8px}
@media(max-width:780px){.stats{grid-template-columns:repeat(2,1fr)}}

/* Forms */
form .row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
@media(max-width:680px){form .row{grid-template-columns:1fr}}
label{display:block;font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:#5e5345;margin-bottom:8px}
input,textarea,select{
  width:100%;padding:14px 16px;border:1px solid var(--line);
  background:#fff;font-family:var(--sans);font-size:1rem;color:var(--ink);
  border-radius:2px;transition:border-color .25s, box-shadow .25s;
}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,138,62,.15)}
textarea{min-height:140px;resize:vertical}

/* Contact info */
.cinfo{display:grid;gap:26px}
.cinfo .row{display:grid;grid-template-columns:50px 1fr;gap:18px;align-items:start;padding-bottom:24px;border-bottom:1px solid var(--line)}
.cinfo .row:last-child{border-bottom:0}
.cinfo .ico{width:42px;height:42px;border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;color:var(--gold-deep);font-family:var(--serif);font-size:1.1rem}
.cinfo .lbl{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#7a6d56;margin-bottom:4px}
.cinfo .val{font-family:var(--serif);font-size:1.2rem;color:var(--ink)}

/* Footer */
footer.site{background:#1a1410;color:#cdbf9c;padding:80px 0 30px}
footer.site h4{font-family:var(--serif);color:#f5ecd9;margin-bottom:18px;font-size:1.2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;margin-bottom:50px}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}.foot-grid>div:first-child{grid-column:1/-1}}
footer.site a{color:#cdbf9c;display:block;padding:5px 0;font-size:.95rem}
footer.site a:hover{color:var(--gold)}
.foot-bottom{border-top:1px solid #2e251c;padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:.82rem;color:#8a7a5e}

/* Cookie banner */
#cookie{
  position:fixed;left:24px;right:24px;bottom:24px;z-index:100;
  background:#221a13;color:#f5ecd9;padding:22px 26px;
  display:flex;gap:24px;align-items:center;justify-content:space-between;
  box-shadow:0 18px 50px rgba(0,0,0,.4);
  border-left:3px solid var(--gold);
  transform:translateY(120%);opacity:0;
  transition:transform .55s ease, opacity .55s ease;
  flex-wrap:wrap;
}
#cookie.show{transform:none;opacity:1}
#cookie p{margin:0;font-size:.92rem;max-width:680px;color:#e7d8b3}
#cookie p a{color:var(--gold);text-decoration:underline}
#cookie .actions{display:flex;gap:10px}
#cookie button{
  padding:11px 22px;border:1px solid #f5ecd9;background:transparent;color:#f5ecd9;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;
  transition:all .25s;font-family:var(--sans);
}
#cookie button.accept{background:var(--gold);border-color:var(--gold);color:#1a1410;font-weight:600}
#cookie button:hover{background:#f5ecd9;color:#1a1410}
#cookie button.accept:hover{background:#f5ecd9}

/* Page banner (inner pages) */
.banner{
  padding:140px 0 80px;
  color:#f5ecd9;text-align:center;
  background:linear-gradient(rgba(20,14,8,.72),rgba(20,14,8,.72)),
    url('https://images.unsplash.com/photo-1490127252417-7c393f993ee4?auto=format&fit=crop&w=1800&q=80') center/cover no-repeat;
}
.banner h1{color:#f7ecd0;font-size:clamp(2.4rem,4.4vw,3.6rem)}
.banner p{color:#d6c69f;max-width:620px;margin:14px auto 0}
.crumbs{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:#d6b269;margin-top:22px}
.crumbs a{color:#d6b269}

/* Prose */
.prose{max-width:820px;margin:0 auto}
.prose h2{margin-top:1.8em}
.prose h3{margin-top:1.6em;color:var(--gold-deep)}
.prose p,.prose li{color:#3e3528;font-size:1.02rem}
.prose ul,.prose ol{margin:0 0 1.4em 1.4em}
.prose li{margin-bottom:.5em}

/* Events */
.event{
  display:grid;grid-template-columns:120px 1fr auto;gap:30px;align-items:center;
  padding:28px 0;border-bottom:1px solid var(--line);
}
.event:last-child{border-bottom:0}
.event .date{
  text-align:center;font-family:var(--serif);border:1px solid var(--gold);
  padding:14px 8px;color:var(--gold-deep);
}
.event .date .d{font-size:2.2rem;line-height:1;display:block}
.event .date .m{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;display:block;margin-top:4px}
.event h3{margin-bottom:.2em}
.event small{color:#7a6d56;font-size:.85rem;letter-spacing:.08em}
@media(max-width:680px){.event{grid-template-columns:90px 1fr}.event .btn{grid-column:1/-1}}

/* Misc */
.divider{width:60px;height:1px;background:var(--gold);margin:0 auto 28px}
.text-center{text-align:center}
.mt-lg{margin-top:50px}
