/*
Theme Name: BrokenChains Divi 5 Child
Theme URI: https://brokenchains.nl
Description: Premium Divi 5 child theme basis voor BrokenChains.nl
Author: Martin Jung
Template: Divi
Version: 1.0.0
*/

:root {
  --bc-gold: #C9962B;
  --bc-gold-dark: #9B6A17;
  --bc-white: #FFFFFF;
  --bc-warm: #F7F3ED;
  --bc-beige: #ECE5DA;
  --bc-brown: #2A160B;
  --bc-text: #1A1A1A;
  --bc-muted: rgba(42, 22, 11, .82);
}

body {
  color: var(--bc-text);
  background: var(--bc-warm);
}

.bc-section { padding: 120px 0; }
.bc-section-large { padding: 140px 0; }
.bc-container { max-width: 1180px; margin-inline: auto; }

.bc-eyebrow {
  font-family: Inter, sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--bc-gold);
  margin-bottom: 18px;
}

.bc-heading {
  font-family: "Cormorant Garamond", Georgia, serif;
  color: var(--bc-text);
  line-height: .98;
  font-weight: 600;
}

.bc-heading-large { font-size: clamp(48px, 6vw, 82px); }
.bc-heading-medium { font-size: clamp(38px, 4vw, 58px); }

.bc-body {
  font-family: Inter, Arial, sans-serif;
  font-size: 18px;
  line-height: 1.8;
  color: var(--bc-muted);
}

.bc-gold { color: var(--bc-gold); }

.bc-btn-primary,
.et_pb_button.bc-btn-primary {
  background: var(--bc-gold) !important;
  color: #fff !important;
  border: 1px solid var(--bc-gold) !important;
  border-radius: 8px !important;
  padding: 17px 30px !important;
  font-weight: 800 !important;
  letter-spacing: .4px;
  transition: all .3s ease;
}

.bc-btn-primary:hover,
.et_pb_button.bc-btn-primary:hover {
  background: var(--bc-gold-dark) !important;
  border-color: var(--bc-gold-dark) !important;
  transform: translateY(-3px);
  box-shadow: 0 14px 35px rgba(201,150,43,.28);
}

.bc-btn-secondary,
.et_pb_button.bc-btn-secondary {
  background: transparent !important;
  color: var(--bc-brown) !important;
  border: 1px solid var(--bc-gold) !important;
  border-radius: 8px !important;
  padding: 16px 30px !important;
  font-weight: 800 !important;
  transition: all .3s ease;
}

.bc-card,
.bc-theme-card,
.bc-article-card {
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 18px 50px rgba(42,22,11,.08);
  transition: all .35s ease;
}

.bc-card:hover,
.bc-theme-card:hover,
.bc-article-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 80px rgba(42,22,11,.14);
}

.bc-theme-card {
  background: var(--bc-warm);
  border: 1px solid rgba(42,22,11,.08);
  padding: 36px;
  min-height: 260px;
}

.bc-review-card {
  background: #fff;
  border-radius: 20px;
  padding: 34px;
  box-shadow: 0 18px 50px rgba(42,22,11,.10);
  border-left: 4px solid var(--bc-gold);
}

.bc-scripture-section {
  background: var(--bc-brown);
  color: #fff;
  position: relative;
  overflow: hidden;
}

.bc-scripture-section:before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 25% 20%, rgba(201,150,43,.22), transparent 38%);
  pointer-events: none;
}

.bc-scripture-card {
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
  border-radius: 22px;
  padding: 42px;
  border: 1px solid rgba(255,255,255,.08);
}

.bc-newsletter-box {
  background: #fff;
  border-radius: 28px;
  padding: 70px;
  box-shadow: 0 20px 60px rgba(42,22,11,.08);
}

.bc-input input,
.bc-input textarea,
.bc-input select {
  min-height: 58px;
  border-radius: 10px !important;
  border: 1px solid rgba(42,22,11,.10) !important;
  padding: 0 18px !important;
  font-size: 16px !important;
}

.bc-input input:focus,
.bc-input textarea:focus {
  border-color: var(--bc-gold) !important;
  box-shadow: 0 0 0 4px rgba(201,150,43,.12) !important;
}

.bc-header {
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(42,22,11,.08);
  z-index: 9999;
}

.bc-footer {
  background: var(--bc-brown);
  color: rgba(255,255,255,.78);
}

.bc-footer h4 {
  color: #fff;
  font-family: Inter, sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 22px;
}

.bc-footer a {
  color: rgba(255,255,255,.72);
  text-decoration: none;
  transition: color .25s ease;
}

.bc-footer a:hover { color: var(--bc-gold); }

.bc-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.10);
  margin-top: 60px;
  padding-top: 26px;
}

.bc-book-glow { position: relative; z-index: 1; }
.bc-book-glow:before {
  content: "";
  position: absolute;
  inset: 10%;
  background: radial-gradient(circle, rgba(201,150,43,.28), transparent 65%);
  filter: blur(30px);
  z-index: -1;
}

.bc-image-zoom img { transition: transform .45s ease; }
.bc-image-zoom:hover img { transform: scale(1.04); }

@media (max-width: 980px) {
  .bc-section, .bc-section-large { padding: 90px 0; }
  .bc-newsletter-box { padding: 46px; }
}

@media (max-width: 767px) {
  .bc-section, .bc-section-large { padding: 70px 0; }
  .bc-body { font-size: 16px; }
  .bc-theme-card,
  .bc-scripture-card { padding: 28px; }
  .bc-newsletter-box {
    padding: 34px;
    border-radius: 20px;
  }
}
