:root {
  --site-navy: #1a2f4a;
  --site-navy-deep: #0f1c2e;
  --site-gold: #c9a227;
  --site-cream: #f7f4ee;
}

body {
  font-family: "Noto Sans KR", system-ui, sans-serif;
  background: var(--site-cream);
  color: #1e293b;
}

.font-serif {
  font-family: "Source Serif 4", Georgia, serif;
}

.site-nav {
  background: linear-gradient(90deg, var(--site-navy-deep), var(--site-navy));
}

.hero {
  background: linear-gradient(135deg, var(--site-navy-deep) 0%, #1e3a5f 45%, var(--site-navy) 100%);
  position: relative;
  overflow: hidden;
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 80% 20%, rgba(201, 162, 39, 0.12), transparent 55%);
  pointer-events: none;
}

.hero .container {
  position: relative;
  z-index: 1;
}

.hero-eyebrow {
  letter-spacing: 0.2em;
  font-size: 0.75rem;
  color: rgba(201, 162, 39, 0.95);
}

.text-white-75 {
  color: rgba(255, 255, 255, 0.82) !important;
}

.card-accent {
  border-top: 3px solid var(--site-gold) !important;
  background: #fff;
}

.about-block {
  background: #fff;
  border: 1px solid rgba(26, 47, 74, 0.08);
  box-shadow: 0 8px 30px rgba(15, 28, 46, 0.06);
}

.about-list li {
  position: relative;
  padding-left: 1.25rem;
}

.bullet-dot {
  display: inline-block;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: var(--site-gold);
  margin-right: 0.6rem;
  vertical-align: 0.15rem;
}

.site-footer {
  background: var(--site-navy-deep);
}

.btn-primary {
  background-color: var(--site-navy);
  border-color: var(--site-navy);
}

.btn-primary:hover {
  background-color: #243e5f;
  border-color: #243e5f;
}

a {
  color: #1e4d8c;
}

a:hover {
  color: var(--site-navy-deep);
}

.youtube-preview-wrap {
  max-width: 42rem;
}

.sermon-card-grid .sermon-youtube.youtube-preview-wrap {
  max-width: none;
}

.sermon-card {
  background: #fff;
}

@media (max-width: 767.98px) {
  .sermon-card-grid > [class*="col-"] {
    max-width: 28rem;
    margin-left: auto;
    margin-right: auto;
  }
}

.youtube-preview-iframe {
  border: 0;
}

.album-card .album-photo {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.album-photo-link:focus-visible {
  outline: 2px solid var(--site-gold);
  outline-offset: 2px;
}

.news-item-card {
  border-top: 3px solid var(--site-gold) !important;
  background: #fff;
}

.news-body {
  font-size: 1rem;
  line-height: 1.65;
}

.news-body p:last-child {
  margin-bottom: 0;
}

.news-body ul,
.news-body ol {
  padding-left: 1.25rem;
}

.news-body a {
  word-break: break-word;
}

.quill-editor-wrap .ql-editor {
  min-height: 220px;
}
