/* Broad Street Bible — light theme (white + navy/silver) */
:root{
  --navy:#1a2a44;
  --navy-deep:#14233d;
  --steel:#5b6b86;
  --silver:#c9d2e0;
  --silver-soft:#e8ecf3;
  --bg:#ffffff;
  --bg-alt:#f5f7fa;
  --ink:#202733;
  --muted:#5f6b7d;
  --line:#e2e7ef;
  --radius:14px;
  --shadow:0 10px 30px rgba(20,35,61,.08);
  --maxw:1140px;
  --serif:"Georgia","Times New Roman",serif;
  --sans:"Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--serif);color:var(--navy);line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(2rem,4vw,3rem)}
h2{font-size:clamp(1.6rem,3vw,2.2rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--steel)}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.section--alt{background:var(--bg-alt)}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:700;color:var(--steel);margin-bottom:.6em}
.lead{font-size:1.15rem;color:var(--muted);max-width:62ch}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* Buttons */
.btn{display:inline-block;padding:13px 26px;border-radius:999px;font-weight:600;font-size:.95rem;
  border:1.5px solid var(--navy);transition:.2s;cursor:pointer}
.btn--primary{background:var(--navy);color:#fff}
.btn--primary:hover{background:var(--navy-deep);color:#fff}
.btn--ghost{background:transparent;color:var(--navy)}
.btn--ghost:hover{background:var(--navy);color:#fff}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.logo-badge{display:flex;align-items:center;justify-content:center;height:54px;width:54px;
  background:radial-gradient(circle at 35% 30%,#283a5c,#13203a 72%);
  border-radius:13px;box-shadow:inset 0 1px 2px rgba(255,255,255,.12),0 4px 12px rgba(20,35,61,.22)}
.logo-badge img{height:42px;width:42px;object-fit:contain}
.brand img{height:52px;width:52px}
.brand .brand-text{font-family:var(--serif);font-weight:700;color:var(--navy);line-height:1.05}
.brand .brand-text small{display:block;font-family:var(--sans);font-weight:600;font-size:.62rem;letter-spacing:.22em;color:var(--steel);text-transform:uppercase}
.brand .brand-text span{font-size:1.15rem;letter-spacing:.02em}
.nav-links{display:flex;align-items:center;gap:4px;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.nav-links a{padding:9px 13px;border-radius:8px;font-size:.92rem;font-weight:600;color:var(--ink)}
.nav-links a:hover{background:var(--silver-soft);color:var(--navy)}
.nav-links a.active{color:var(--navy);background:var(--silver-soft)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:.2s}

/* Hero */
.hero{position:relative;background:linear-gradient(160deg,#f5f7fa 0%,#e8ecf3 100%);overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;
  background:radial-gradient(circle,rgba(91,107,134,.18),transparent 70%);border-radius:50%}
.hero .container{position:relative;padding:90px 24px;text-align:center}
.hero h1{margin-bottom:.3em}
.hero .lead{margin:0 auto 1.6em}
.hero .btn-row{justify-content:center}

/* Grid cards */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.card h3{margin-bottom:.4em}
.card .ico{width:46px;height:46px;border-radius:12px;background:var(--silver-soft);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--navy);font-size:1.3rem}

/* Service times strip */
.times{display:flex;gap:30px;flex-wrap:wrap;justify-content:center}
.times .t{text-align:center;min-width:160px}
.times .t .day{font-family:var(--serif);font-size:1.3rem;color:var(--navy)}
.times .t .time{color:var(--muted)}

/* Verse band */
.verse{background:var(--navy);color:#fff;text-align:center}
.verse .container{padding:64px 24px}
.verse h2{color:#fff;font-style:italic;font-weight:400;max-width:24ch;margin:0 auto .4em}
.verse cite{color:var(--silver);font-style:normal;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem}

/* Page header (interior) */
.page-head{background:linear-gradient(160deg,#f5f7fa,#e8ecf3);border-bottom:1px solid var(--line)}
.page-head .container{padding:60px 24px;text-align:center}

/* Lists */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{position:relative;padding:8px 0 8px 32px}
.checklist li::before{content:"✦";position:absolute;left:0;color:var(--steel)}

/* Sermon list */
.sermon{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.sermon:last-child{border-bottom:0}
.sermon .meta{color:var(--muted);font-size:.88rem}

/* Calendar/events */
.event{display:flex;gap:20px;align-items:center;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
.event .date{flex:0 0 70px;text-align:center;background:var(--navy);color:#fff;border-radius:10px;padding:10px 0}
.event .date .m{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em}
.event .date .d{font-size:1.5rem;font-family:var(--serif)}

/* Forms */
.form{display:grid;gap:16px;max-width:560px}
.form label{font-weight:600;font-size:.9rem;color:var(--navy);display:block;margin-bottom:6px}
.form input,.form textarea,.form select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;background:#fff}
.form input:focus,.form textarea:focus{outline:2px solid var(--silver);border-color:var(--steel)}

/* Footer */
.site-footer{background:var(--navy-deep);color:#cdd6e4;margin-top:0}
.site-footer .container{padding:56px 24px 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:.8em}
.site-footer a{color:#cdd6e4}
.site-footer a:hover{color:#fff}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:8px;font-size:.92rem}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.foot-brand img{height:50px;width:50px;object-fit:contain}
/* dark badge for emblem on light cards */
.logo-card{background:radial-gradient(circle at 38% 30%,#283a5c,#13203a 75%);border-radius:18px;
  display:flex;align-items:center;justify-content:center;padding:26px;box-shadow:var(--shadow)}
.logo-card img{height:150px;width:auto}
.foot-brand strong{font-family:var(--serif);color:#fff;font-size:1.15rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:36px;padding-top:18px;font-size:.84rem;color:#9fadc4;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Responsive */
@media(max-width:860px){
  .grid-3,.grid-2,.foot-grid{grid-template-columns:1fr}
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--line);padding:10px 16px;display:none;box-shadow:var(--shadow)}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 10px}
  .nav{position:relative}
}

/* ============================================================
   MOTION & POLISH
   ============================================================ */
@media (prefers-reduced-motion: no-preference){

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,.84,.44,1),transform .7s cubic-bezier(.16,.84,.44,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* Hero: animated aurora gradient + floating orbs */
.hero{background:linear-gradient(125deg,#eef2f7,#e3e9f2,#f3f6fa,#e7edf5);background-size:300% 300%;animation:aurora 18s ease infinite}
@keyframes aurora{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.hero::after{animation:floatOrb 12s ease-in-out infinite}
.hero::before{content:"";position:absolute;left:-140px;bottom:-160px;width:380px;height:380px;
  background:radial-gradient(circle,rgba(40,58,92,.16),transparent 70%);border-radius:50%;animation:floatOrb 16s ease-in-out infinite reverse}
@keyframes floatOrb{0%,100%{transform:translate(0,0)}50%{transform:translate(24px,-30px)}}

/* Hero content entrance */
.hero .eyebrow{animation:fadeUp .8s .05s both}
.hero h1{animation:fadeUp .9s .18s both}
.hero .lead{animation:fadeUp .9s .32s both}
.hero .btn-row{animation:fadeUp .9s .46s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* Logo badge: metallic shimmer sweep + gentle float */
.logo-badge{position:relative;overflow:hidden;animation:badgeFloat 6s ease-in-out infinite}
.logo-badge::after{content:"";position:absolute;top:-60%;left:-80%;width:60%;height:220%;
  background:linear-gradient(115deg,transparent,rgba(255,255,255,.55),transparent);
  transform:rotate(8deg);animation:shimmer 5.5s ease-in-out infinite}
@keyframes shimmer{0%{left:-80%}28%{left:140%}100%{left:140%}}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.logo-card{position:relative;overflow:hidden}
.logo-card::after{content:"";position:absolute;top:-50%;left:-70%;width:50%;height:200%;
  background:linear-gradient(115deg,transparent,rgba(255,255,255,.4),transparent);transform:rotate(10deg);animation:shimmer 7s ease-in-out infinite}
.logo-card img{transition:transform .6s cubic-bezier(.16,.84,.44,1)}
.logo-card:hover img{transform:scale(1.05) rotate(-1deg)}

/* Verse parallax shimmer */
.verse{position:relative;overflow:hidden}
.verse::before{content:"✝";position:absolute;font-size:22rem;right:-2rem;top:50%;transform:translateY(-50%);
  color:rgba(255,255,255,.04);font-family:var(--serif);pointer-events:none;animation:pulseGlow 7s ease-in-out infinite}
@keyframes pulseGlow{0%,100%{opacity:.5;transform:translateY(-50%) scale(1)}50%{opacity:1;transform:translateY(-50%) scale(1.04)}}

}/* end reduced-motion guard */

/* Card hover lift (safe for all) */
.card{transition:transform .35s cubic-bezier(.16,.84,.44,1),box-shadow .35s,border-color .35s}
.card:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(20,35,61,.16);border-color:var(--silver)}
.card .ico{transition:transform .4s cubic-bezier(.34,1.56,.64,1),background .3s}
.card:hover .ico{transform:scale(1.12) rotate(-6deg);background:var(--navy);color:#fff}

/* Nav animated underline */
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:13px;right:13px;bottom:5px;height:2px;background:var(--navy);
  transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.16,.84,.44,1)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}

/* Buttons: shine sweep + lift */
.btn{position:relative;overflow:hidden;transition:transform .25s,background .2s,color .2s,box-shadow .25s}
.btn::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg)}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(20,35,61,.22)}
.btn--primary:hover::before{animation:btnShine .7s ease}
@keyframes btnShine{from{left:-120%}to{left:140%}}

/* Service time + event hover */
.times .t{transition:transform .3s}.times .t:hover{transform:translateY(-4px)}
.event{transition:transform .3s,box-shadow .3s}
.event:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.sermon{transition:background .25s,padding-left .25s}
.sermon:hover{background:var(--bg-alt);padding-left:12px;border-radius:10px}

/* Header shadow on scroll */
.site-header{transition:box-shadow .3s,background .3s}
.site-header.scrolled{box-shadow:0 6px 24px rgba(20,35,61,.08)}

/* ===== Add to Calendar ===== */
.event__body{position:relative}
.cal-add{position:relative;display:inline-block}
.cal-add__btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;
  background:#fff;border:1.5px solid var(--line);color:var(--navy);font:600 .85rem var(--sans);
  padding:8px 14px;border-radius:999px;transition:border-color .2s,box-shadow .2s,transform .2s}
.cal-add__btn:hover{border-color:var(--silver);box-shadow:var(--shadow);transform:translateY(-1px)}
.cal-add__chev{font-size:.7rem;color:var(--steel)}
.cal-menu{position:absolute;left:0;top:calc(100% + 8px);z-index:30;min-width:240px;
  background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 40px rgba(20,35,61,.16);
  padding:6px;display:none;opacity:0;transform:translateY(-6px);transition:opacity .18s,transform .18s}
.cal-menu.open{display:block;opacity:1;transform:none}
.cal-menu__item{display:block;width:100%;text-align:left;background:none;border:0;cursor:pointer;
  font:500 .9rem var(--sans);color:var(--ink);padding:10px 12px;border-radius:8px;text-decoration:none}
.cal-menu__item:hover{background:var(--silver-soft);color:var(--navy)}

/* Calendar dropdown stacking + flip-up */
.event{position:relative}
.event.menu-open{z-index:60}
.event.menu-open:hover{transform:none}      /* avoid jitter while menu is open */
.cal-menu.up{top:auto;bottom:calc(100% + 8px);transform:translateY(6px)}
.cal-menu.up.open{transform:none}
