
/* === UNIVERSAL RESET & LAYOUT === */
body {
  margin: 0;
  padding: 0;
  font-family: 'Segoe UI', sans-serif;
  background: #f5f7fa;
}

.site-nav,
.site-footer {
  width: 100vw;
  margin: 0 !important;
  border-radius: 0 !important;
  left: 0;
  right: 0;
  box-sizing: border-box;
}

.site-nav {
  background: #fff;
  border-bottom: 1px solid #eee;
  padding: 10px 20px;
  text-align: center;
}

.site-footer {
  background: #2b2d42;
  color: #fff;
  text-align: center;
  padding: 20px;
  margin-top: 40px;
}

/* === MAIN CONTENT CONTAINERS (centered, max-width, padding) === */
.library-box,
.about-box,
.blog-box,
.legal-box,
.search-box,
.post-container,
.page-container,
.faq-box,
.product-container,
.products-container,
.notfound-box,
.settings form,
.subscribe-box,
.contact-box {
  max-width: 1100px;
  margin: 40px auto;
  padding: 40px 20px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}

.subscribe-box, .contact-box {
  max-width: 500px;
}

.notfound-box,
.settings form {
  max-width: 480px;
}

/* === LANDING PAGE SPECIALS (full width) === */
body.landing {
  background: #f7f9fc;
}
.section-hero {
  text-align: center;
  padding: 80px 20px;
  background: #fff0f0;
}
.section-hero h1 { font-size: 2rem; margin-bottom: 15px; }
.section-hero p { font-size: 1.05rem; margin-bottom: 10px; }
.section-block {
  text-align: center;
  padding: 60px 20px;
  background: #fff;
  border-top: 1px solid #eee;
}
.section-block h2 { font-size: 1.5rem; margin-bottom: 10px; }
.section-block p { max-width: 700px; margin: 0 auto 20px; font-size: 1rem; color: #333; }

/* === PAGE-SPECIFIC BACKGROUNDS === */
body.library { background: #f5f7fa; }
body.about { background: #f7f9fc; }
body.blog { background: #f7f9fc; }
body.legal { background: #f9f9fc; }
body.faq { background: #f5f7fa; }
body.subscribe { background: #f5f7fa; min-height: 100vh; }
body.contact { background: #f9f9fc; min-height: 100vh; }
body.search { background: #f5f7fa; }
body.notfound { background: #fff0f0; min-height: 100vh; display: flex; align-items: center; justify-content: center; }
body.post-page { background: #fdfdfd; }
body.page-view { background: #fefefe; }
body.product-page { background: #f8f9fc; }
body.products-view { background: #fefefe; }

/* === GRIDS & SPECIALS === */
.book-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap: 20px;
}
.book-card {
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.05);
  text-align: center;
}
.book-card img {
  max-width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 6px;
  margin-bottom: 10px;
}
.book-card h2 { font-size: 1.1rem; margin-bottom: 10px; color: #2b2d42; }
.book-card p { font-size: 0.95rem; color: #555; margin-bottom: 10px; }
.book-card strong { display: block; margin: 10px 0; color: #5e60ce; }
.btn.small { padding: 6px 12px; font-size: 0.85rem; border-radius: 4px; background: #5e60ce; color: #fff; text-decoration: none; }

/* === BUTTONS & ALERTS === */
.btn, .btn.small, .btn.primary {
  display: inline-block;
  background: #5e60ce;
  color: #fff;
  padding: 12px 28px;
  border: none;
  border-radius: 6px;
  text-decoration: none;
  font-size: 1rem;
  font-weight: bold;
  cursor: pointer;
  margin: 8px 4px 0 0;
  transition: background 0.18s;
}
.btn.primary { background: #198754; }
.btn:hover { background: #4346a3; }

.notice, .error {
  padding: 10px;
  border-radius: 6px;
  margin-bottom: 10px;
  text-align: center;
}
.notice { background: #d3f9d8; color: #2f9e44; }
.error { background: #fff0f0; color: #e03131; }

/* === NAV STYLES (include submenu, responsive) === */
.site-nav {
  background: #fff;
  border-bottom: 1px solid #eee;
  padding: 1rem;
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
.site-nav a {
  margin: 0 10px;
  color: #333;
  font-weight: bold;
  text-decoration: none;
}
.site-nav a.active { color: #007BFF; }
.nav-links { display: flex; gap: 1rem; flex-wrap: wrap; }
.nav-toggle { display: none; font-size: 1.5rem; cursor: pointer; }
@media (max-width: 768px) {
  .nav-links { display: none; flex-direction: column; width: 100%; }
  .nav-links.open { display: flex; }
  .nav-toggle { display: block; }
}
.submenu-parent { position: relative; display: inline-block; }
.submenu-toggle { cursor: pointer; font-weight: bold; }
.submenu {
  display: none;
  position: absolute;
  background: #fff;
  min-width: 140px;
  box-shadow: 0 2px 10px #0001;
  border-radius: 6px;
  padding: 8px 0;
  z-index: 100;
}
.submenu-parent:hover .submenu,
.submenu-parent:focus-within .submenu { display: block; }
.submenu a {
  display: block;
  padding: 8px 18px;
  color: #333;
  text-decoration: none;
}
.submenu a:hover,
.submenu a.active { background: #f1f3f7; color: #007BFF; }

/* === PAGE-SPECIFIC FORM STYLES (inputs, etc) === */
.contact-box input,
.contact-box textarea,
.subscribe-box input {
  width: 100%;
  padding: 12px;
  margin: 10px 0;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 1rem;
}
.contact-box textarea {
  min-height: 120px;
  resize: vertical;
}
.subscribe-box .btn { width: 100%; padding: 12px; }
.contact-box .btn { width: 100%; padding: 12px; }

/* === SPECIAL CENTERING FOR CONTACT/SUBSCRIBE IF NEEDED === */
.contact-center,
.subscribe-center {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* === FOR NOTFOUND PAGE CENTERING === */
body.notfound .notfound-box {
  margin: 0 auto;
  padding: 40px;
}

/* ==================================================
   LOGIN STYLES  |  append to /assets/css/style.css
================================================== */
/* Center Login Box Vertically & Horizontally */
.login-center {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-box {
  background:#fff;
  padding:40px;
  border-radius:8px;
  box-shadow:0 4px 20px rgba(0,0,0,0.05);
  text-align:center;
  width:100%;
  max-width:400px;
}
.login-box h1 {
  margin-bottom:20px;
  font-size:1.5rem;
}
.login-box input {
  width:100%;
  padding:12px;
  margin:10px 0;
  border:1px solid #ccc;
  border-radius:6px;
  font-size:1rem;
}
.login-box .btn {
  width:100%;
  padding:12px;
}
.error {
  color:#e03131;
  background:#fff0f0;
  padding:10px;
  border-radius:6px;
  margin-bottom:10px;
}

/* ================================================== */

/* sticky footer */
html, body {
  height: 100%;
}
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.site-main {
  flex: 1 0 auto;
  /* Keeps main content stretched to push footer down */
}
.site-footer {
  flex-shrink: 0;
}
