
/*
Theme Name: BibleStep
Theme URI: https://biblestep.com/
Author: BibleStep
Author URI: https://biblestep.com/
Description: A gentle, single-page WordPress theme replicating the current biblestep.com layout — calm typography, soft spacing, and anchor navigation.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: biblestep
Tags: one-column, blog, custom-colors, custom-menu, featured-images
*/

/* Reset & base */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, "Helvetica Neue", Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color: #1a1a1a;
  background: #faf9f8;
  line-height: 1.75;
}
a { color: #2c5e50; text-decoration: none; }
a:hover { text-decoration: underline; }
.container {
  max-width: 960px;
  margin: 0 auto;
  padding: 24px 20px;
}
.header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(250,249,248,0.9);
  backdrop-filter: saturate(120%) blur(4px);
  border-bottom: 1px solid #eee;
}
.brand { font-weight: 700; letter-spacing: .2px; }
.nav {
  display: flex; gap: 12px; flex-wrap: wrap;
  font-size: 15px;
}
.hero h1 { font-size: 42px; line-height: 1.2; margin: 12px 0 6px; }
.hero p.tagline { color: #444; margin-top: 0; }
.section { padding: 56px 0; border-top: 1px solid #eee; }
.section h2 { font-size: 28px; margin: 0 0 8px; }
.section h3 { font-size: 20px; margin: 24px 0 8px; }
.card {
  background: white; border: 1px solid #eee; border-radius: 14px; padding: 18px 18px;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02);
}
.grid { display: grid; gap: 16px; }
.grid.two { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.small { color: #555; font-size: 15px; }
footer { border-top: 1px solid #eee; padding: 32px 0; color: #555; }
kbd {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  background: #f2f2f2; border: 1px solid #e5e5e5; padding: 2px 6px; border-radius: 6px; font-size: 12px;
}
.button {
  display: inline-block; padding: 10px 14px; border: 1px solid #dcdcdc; border-radius: 10px; background: white;
}
.badge { display:inline-block; background:#eef6f3; color:#2c5e50; padding:2px 8px; border-radius:999px; font-size:12px; border:1px solid #d9ebe6;}
/* Section-specific trims */
.list-inline { display:flex; gap:8px; flex-wrap:wrap; padding:0; margin:0; list-style:none; }
.anchor { scroll-margin-top: 80px; }
*/
