/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── TOKENS ── */
:root{
  --bg:#f5fafb;--card-a:#ffffff;--card-b:#f0f8fc;--card-c:#e5f3f9;--card-d:#d8eef6;
  --blue:#0891b2;--blue-light:#22d3ee;--blue-dim:rgba(8,145,178,0.10);
  --teal:#0e7490;--teal-dim:rgba(14,116,144,0.08);
  --text:#0c1f2c;--text-dim:rgba(12,31,44,0.62);--text-muted:rgba(12,31,44,0.55);
  --border:rgba(12,31,44,0.09);--border-blue:rgba(8,145,178,0.25);
  --shadow:0 2px 16px rgba(8,145,178,0.06);--shadow-md:0 4px 28px rgba(8,145,178,0.12);
  --serif:'Outfit',system-ui,sans-serif;--sans:'Inter',system-ui,sans-serif;
  --r:16px;--r-sm:10px;--gap:10px;
  --g-btn:linear-gradient(135deg,#0e7490 0%,#0891b2 45%,#38bdf8 100%);
  --g-btn-hover:linear-gradient(135deg,#0a5f72 0%,#0773a0 45%,#1daad8 100%);
  --g-accent:linear-gradient(90deg,#0891b2 0%,#22d3ee 60%,#38bdf8 100%);
  --g-text:linear-gradient(135deg,#0891b2 0%,#38bdf8 100%);
}

/* ── BASE ── */
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* ── NAV ── */
.nav{position:sticky;top:0;z-index:300;background:rgba(245,250,251,0.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:60px}
.nav-brand{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--text);text-decoration:none;letter-spacing:-0.02em;white-space:nowrap}
.nav-brand em{color:var(--blue);font-style:normal}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-link{font-size:12px;font-weight:500;color:var(--text-dim);text-decoration:none;padding:7px 13px;border-radius:7px;letter-spacing:0.02em;transition:color 0.2s,background 0.2s;white-space:nowrap}
.nav-link:hover,.nav-link.active{color:var(--blue);background:rgba(8,145,178,0.07)}
.nav-dropdown{position:relative}
.nav-dropdown>.nav-link{display:flex;align-items:center;gap:5px}
.nav-dropdown>.nav-link::after{content:'';display:block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform 0.2s}
.nav-dropdown:hover>.nav-link::after,.nav-dropdown:focus-within>.nav-link::after{transform:rotate(-135deg) translateY(-2px)}
.nav-dropdown-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);background:var(--card-a);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--shadow-md);min-width:210px;padding:6px;opacity:0;pointer-events:none;transition:opacity 0.15s,transform 0.15s;z-index:400}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:12px;font-weight:500;color:var(--text-dim);text-decoration:none;transition:all 0.15s;white-space:nowrap}
.nav-dropdown-item:hover{background:var(--blue-dim);color:var(--blue)}
.nav-dropdown-badge{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;flex-shrink:0;letter-spacing:-0.02em}
.badge-ap{background:rgba(8,145,178,0.10);color:var(--blue)}
.badge-gg{background:rgba(14,116,144,0.10);color:var(--teal)}
.badge-x39{background:rgba(12,31,44,0.05);color:var(--text-muted)}
.nav-dropdown-label{display:flex;flex-direction:column}
.nav-dropdown-label span:first-child{color:var(--text);font-weight:600;font-size:12px}
.nav-dropdown-label span:last-child{color:var(--text-muted);font-size:10px;font-weight:400}
.nav-cta{display:inline-flex;align-items:center;font-size:12px;font-weight:600;background:var(--g-btn);color:#fff;padding:8px 18px;border-radius:7px;text-decoration:none;margin-left:10px;letter-spacing:0.02em;transition:background 0.25s,box-shadow 0.2s;white-space:nowrap}
.nav-cta:hover{background:var(--g-btn-hover);box-shadow:0 4px 16px rgba(8,145,178,0.4)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.nav-hamburger span{display:block;width:20px;height:1.5px;background:var(--text-dim);border-radius:2px;transition:all 0.3s}
.nav-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;width:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-mobile{display:none;position:fixed;top:60px;left:0;right:0;background:var(--card-a);border-bottom:1px solid var(--border);padding:16px 24px;z-index:299;flex-direction:column;gap:4px;box-shadow:var(--shadow-md)}
.nav-mobile.open{display:flex}
.nav-mobile-link{font-size:14px;font-weight:500;color:var(--text-dim);text-decoration:none;padding:11px 14px;border-radius:8px;transition:all 0.2s}
.nav-mobile-link:hover{color:var(--text);background:rgba(8,145,178,0.07)}
.nav-mobile-link.indent{padding-left:36px;font-size:13px;color:var(--text-muted)}
.nav-mobile-link.indent:hover{color:var(--blue)}
.nav-mobile-section{font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);padding:8px 14px 4px}
.nav-mobile-cta{background:var(--g-btn);color:#fff;font-size:14px;font-weight:700;text-decoration:none;padding:13px 14px;border-radius:8px;text-align:center;margin-top:8px}
.mobile-book-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--g-btn) !important;align-items:center;justify-content:center;z-index:500;text-align:center}
.mobile-book-bar a{color:#fff;font-family:var(--sans,sans-serif);font-size:14px;font-weight:700;letter-spacing:0.04em;text-decoration:none}
@media(max-width:768px){.mobile-book-bar{display:flex}}
@media(max-width:860px){.nav-links{display:none}.nav-hamburger{display:flex}.nav{padding:0 20px}}

/* ── PAGE HERO (interior pages) ── */
.page-hero{background:var(--card-b);border-bottom:1px solid var(--border);padding:64px 48px 56px}
.page-hero-inner{max-width:760px;margin:0 auto}
.page-eyebrow{font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.page-eyebrow::before{content:'';display:block;width:20px;height:1px;background:var(--g-accent)}
.page-hero h1{font-family:var(--serif);font-size:clamp(36px,5vw,60px);font-weight:700;line-height:1.05;letter-spacing:-0.03em;color:var(--text);margin-bottom:16px}
.page-hero p{font-size:17px;font-weight:300;color:var(--text-dim);line-height:1.75;max-width:560px}
@media(max-width:600px){.page-hero{padding:40px 20px 36px}}

/* ── LAYOUT ── */
.section{max-width:760px;margin:0 auto;padding:56px 24px}
h2{font-family:var(--serif);font-size:clamp(24px,3vw,34px);font-weight:700;letter-spacing:-0.025em;color:var(--text);margin-bottom:16px;line-height:1.2}
.lead{font-size:16px;font-weight:400;color:var(--text-dim);line-height:1.8;margin-bottom:24px}
p{font-size:15px;font-weight:400;color:var(--text-dim);line-height:1.8;margin-bottom:16px}

/* ── COMPONENTS ── */
.card{background:var(--card-a);border:1px solid var(--border);border-radius:var(--r);padding:32px;box-shadow:var(--shadow);margin-bottom:16px}
.card h3{font-family:var(--serif);font-size:20px;font-weight:700;letter-spacing:-0.02em;color:var(--text);margin-bottom:10px}
.tag{display:inline-block;background:rgba(8,145,178,0.10);color:var(--blue);font-size:11px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:4px 12px;border-radius:100px;margin-bottom:14px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--g-btn);color:#fff;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:0.04em;padding:14px 28px;border-radius:var(--r-sm);text-decoration:none;transition:background 0.25s,box-shadow 0.25s,transform 0.15s;box-shadow:0 4px 20px rgba(8,145,178,0.32),0 1px 4px rgba(14,116,144,0.18)}
.btn-primary:hover{background:var(--g-btn-hover);box-shadow:0 8px 30px rgba(8,145,178,0.45),0 2px 8px rgba(14,116,144,0.25);transform:translateY(-2px)}
.cta-block{background:linear-gradient(140deg,#ebf7fb,#d4edf8);border:1px solid var(--border-blue);border-radius:var(--r);padding:40px;text-align:center;margin-top:48px}
.cta-block h2{margin-bottom:12px}
.cta-block p{max-width:440px;margin:0 auto 28px;font-size:15px}

/* ── POST STYLES ── */
.post-hero{background:var(--card-b);border-bottom:1px solid var(--border);padding:64px 48px 48px}
.post-hero-inner{max-width:720px;margin:0 auto}
.post-eyebrow{font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--blue);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.post-eyebrow::before{content:'';display:block;width:20px;height:1px;background:var(--g-accent)}
.post-hero h1{font-family:var(--serif);font-size:clamp(30px,5vw,52px);font-weight:700;line-height:1.1;letter-spacing:-0.03em;color:var(--text);margin-bottom:18px}
.post-date{font-size:13px;color:var(--text-muted)}
@media(max-width:600px){.post-hero{padding:40px 20px 36px}}
.post-wrap{max-width:720px;margin:0 auto;padding:48px 24px}
.post-img{width:100%;height:300px;object-fit:cover;border-radius:var(--r);margin-bottom:40px;display:block}
.post-wrap h2{font-family:var(--serif);font-size:clamp(20px,2.5vw,26px);font-weight:700;letter-spacing:-0.02em;color:var(--text);margin:36px 0 14px;line-height:1.25}
.post-wrap p{font-size:16px;font-weight:400;color:var(--text-dim);line-height:1.85;margin-bottom:20px}
.post-wrap strong{font-weight:600;color:var(--text)}
.post-wrap blockquote{border-left:3px solid var(--blue);padding:18px 20px;background:var(--card-b);border-radius:0 var(--r-sm) var(--r-sm) 0;margin:28px 0}
.post-wrap blockquote p{font-size:17px;font-weight:500;color:var(--text);font-family:var(--serif);letter-spacing:-0.01em;margin:0;line-height:1.55}
.post-wrap blockquote cite{display:block;font-size:11px;font-weight:600;color:var(--blue);letter-spacing:0.12em;text-transform:uppercase;margin-top:10px}
.post-wrap ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin:20px 0 24px}
.post-wrap li{font-size:15px;font-weight:400;color:var(--text-dim);display:flex;gap:12px;align-items:flex-start;line-height:1.7}
.post-wrap li::before{content:'→';color:var(--blue);font-weight:600;flex-shrink:0;margin-top:3px}
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--blue);text-decoration:none;letter-spacing:0.04em;margin-bottom:32px}
.back-link:hover{color:var(--teal)}
.post-body p,.post-body li,.post-body blockquote,.section p,.section li{max-width:68ch}

/* ── SUBSCRIBE STRIP ── */
.subscribe-strip{background:linear-gradient(135deg,#0c2233 0%,#0e3347 60%,#0e4a64 100%);padding:56px 24px;text-align:center}
.subscribe-strip-inner{max-width:520px;margin:0 auto}
.subscribe-eyebrow{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:#38bdf8;margin-bottom:14px}
.subscribe-strip h2{font-family:var(--serif);font-size:clamp(22px,3vw,32px);font-weight:700;letter-spacing:-0.03em;color:#f0f9ff;margin-bottom:12px;line-height:1.1}
.subscribe-strip p{font-size:15px;font-weight:300;color:rgba(240,249,255,0.62);line-height:1.75;margin-bottom:28px}
.subscribe-form{display:flex;gap:10px;max-width:440px;margin:0 auto 14px}
.subscribe-form input{flex:1;font-family:var(--sans);font-size:14px;color:var(--text);background:#fff;border:none;border-radius:var(--r-sm);padding:11px 16px;outline:none;transition:box-shadow 0.2s}
.subscribe-form input:focus{box-shadow:0 0 0 3px rgba(34,211,238,0.25)}
.subscribe-form input::placeholder{color:var(--text-muted)}
.subscribe-btn{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:0.04em;background:var(--blue);color:#fff;border:none;border-radius:var(--r-sm);padding:11px 20px;cursor:pointer;white-space:nowrap;transition:background 0.2s,transform 0.15s;box-shadow:0 4px 20px rgba(8,145,178,0.35)}
.subscribe-btn:hover{background:var(--teal);transform:translateY(-1px)}
.subscribe-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none}
.subscribe-note{font-size:11px;color:rgba(240,249,255,0.3);line-height:1.6}
.subscribe-success{display:none;font-size:15px;font-weight:500;color:#38bdf8;padding:14px;background:rgba(56,189,248,0.08);border:1px solid rgba(56,189,248,0.2);border-radius:var(--r-sm);margin-top:8px}
.subscribe-error{display:none;font-size:13px;color:#fca5a5;margin-top:8px}
@media(max-width:520px){.subscribe-form{flex-direction:column}.subscribe-btn{padding:13px}}

/* ── READING PROGRESS ── */
.read-progress{position:fixed;top:0;left:0;height:3px;background:var(--g-accent);z-index:9999;width:0;transition:width 80ms linear;pointer-events:none}

/* ── FOOTER ── */
.footer-social{display:flex;gap:18px;margin-bottom:16px;align-items:center}
.footer-social-link{display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.55);text-decoration:none;transition:color 0.2s}
.footer-social-link:hover{color:#fff}
.footer-social-link svg{width:18px;height:18px;display:block}
footer{background:#1a2430;border-top:1px solid rgba(255,255,255,0.06);padding:56px 48px 40px}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;gap:48px;justify-content:space-between;align-items:flex-start;flex-wrap:wrap}
.footer-brand{font-family:var(--serif);font-size:20px;font-weight:700;color:#f5f9fb;letter-spacing:-0.02em;margin-bottom:8px}
.footer-brand em{color:#38bdf8;font-style:normal}
.footer-tagline{font-size:12px;font-weight:300;color:rgba(245,249,251,0.35);line-height:1.7;margin-bottom:20px;max-width:220px}
.footer-nav{display:flex;flex-direction:column;gap:6px}
.footer-nav a{font-size:12px;color:rgba(245,249,251,0.3);text-decoration:none;transition:color 0.2s}
.footer-nav a:hover{color:rgba(245,249,251,0.6)}
.footer-disc{font-size:10px;color:rgba(245,249,251,0.2);line-height:1.85;max-width:440px}
.footer-bottom{max-width:1100px;margin:28px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,0.06);display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.footer-bottom a{font-size:11px;color:rgba(245,249,251,0.2);text-decoration:none}
.footer-subscribe-btn,.blog-subscribe-btn{background:var(--g-btn);border:none}
.form-submit{display:block;width:100%;background:var(--g-btn) !important;color:#fff;font-family:var(--sans);font-size:14px;font-weight:700;padding:14px 28px;border:none;border-radius:var(--r-sm);cursor:pointer;letter-spacing:0.02em;transition:background 0.25s,box-shadow 0.2s,transform 0.15s}
.form-submit:hover{background:var(--g-btn-hover) !important;box-shadow:0 4px 16px rgba(8,145,178,0.4);transform:translateY(-1px)}
@media(max-width:700px){footer{padding:40px 20px 28px}.footer-inner{flex-direction:column;gap:28px}}

/* ── GRADIENT EYEBROWS ── */
.page-eyebrow::before,.hero-eyebrow::before,.eyebrow::before,.proof-eyebrow::before,
.scripture-ref::before,.section-eyebrow::before,.section-eyebrow::after,.post-eyebrow::before{
  background:var(--g-accent) !important
}

/* ── ACCESSIBILITY ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
:focus-visible{outline:2px solid var(--blue,#0891b2);outline-offset:3px;border-radius:4px}
a,button,[role="button"],input,select,textarea{touch-action:manipulation}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}

/* ── BREADCRUMBS (post pages) ── */
.breadcrumb{margin:0 0 20px}
.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;gap:8px;list-style:none;padding:0;margin:0;font-size:12px;font-weight:400;color:var(--text-muted)}
.breadcrumb-list li{display:flex;align-items:center;gap:8px}
.breadcrumb-list li:not(:last-child)::after{content:'\203A';color:var(--text-muted);opacity:.55}
.breadcrumb-list a{color:var(--text-muted);text-decoration:none;transition:color .2s}
.breadcrumb-list a:hover{color:var(--blue)}
.breadcrumb-list li[aria-current]{color:var(--text);font-weight:500;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:600px){.breadcrumb-list li[aria-current]{max-width:190px}}

/* ── RELATED POSTS (injected by related-posts.js on post pages) ──
   Scoped under #related-posts so the card .post-img does NOT inherit the
   full-width 300px hero .post-img style defined earlier in this file. */
#related-posts{max-width:900px;margin:0 auto;padding:8px 24px 72px}
#related-posts .series-heading{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}
#related-posts .series-badge{background:rgba(8,145,178,0.10);color:var(--blue);font-size:10px;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;padding:5px 10px;border-radius:6px;white-space:nowrap}
#related-posts .series-heading h2{font-family:var(--serif);font-size:clamp(20px,2.5vw,26px);font-weight:700;letter-spacing:-0.02em;color:var(--text);margin:0}
#related-posts .post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
#related-posts .post-card{background:var(--card-a);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);text-decoration:none;display:flex;flex-direction:column;transition:transform 0.2s,box-shadow 0.2s}
#related-posts .post-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
#related-posts .post-img{width:100%;height:160px;border-radius:0;margin:0;background-size:cover;background-position:center;display:block}
#related-posts .post-body{padding:22px;flex:1;display:flex;flex-direction:column}
#related-posts .post-tag{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--blue);margin-bottom:10px}
#related-posts .post-title{font-family:var(--serif);font-size:17px;font-weight:700;letter-spacing:-0.02em;color:var(--text);line-height:1.3;margin-bottom:10px}
#related-posts .post-excerpt{font-size:13px;font-weight:400;color:var(--text-dim);line-height:1.7;margin-bottom:0}
#related-posts .post-meta{font-size:12px;color:var(--text-muted);margin-top:16px}
@media(max-width:760px){#related-posts .post-grid{grid-template-columns:1fr}}
@media(max-width:430px){
  .card{padding:24px 20px}
  .cta-block{padding:32px 20px}
  .section{padding:40px 16px}
  .subscribe-strip{padding:40px 16px}
  .subscribe-form{flex-direction:column}
  .subscribe-btn{padding:13px;width:100%}
  footer{padding:36px 16px 28px}
}
