/* =========================
   SPACING SEIMBANG ATAS & BAWAH
   ========================= */

#sp-main-body {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
}

/* SP Page Builder */
.sp-page-builder-page-content {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}


/* =========================
   JAGA JARAK KE FOOTER
   ========================= */

#sp-bottom,
#sp-footer {
    margin-top: 20px !important;
}


/* =========================
   RESPONSIVE (HP)
   ========================= */

@media (max-width: 768px) {

    #sp-main-body {
        padding-top: 15px !important;
        padding-bottom: 15px !important;
    }

    #sp-bottom,
    #sp-footer {
        margin-top: 15px !important;
    }

}

/* ===============================
   QUOTE SECTION (FULL WIDTH SAFE)
================================= */

.quote-full {
  background: #111;
  color: #fff;
  padding: 50px 20px 30px;
  margin: 0;
  width: 100%;
}

.quote-inner {
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

.quote-full h2 {
  font-family: 'Playfair Display', serif;
  font-size: 26px;
  font-weight: 600;
  margin-bottom: 18px;
  color: #d4af37;
}

.quote-text {
  font-family: Georgia, serif;
  font-size: 18px;
  font-style: italic;
  margin-bottom: 12px;
}

.quote-meaning {
  font-family: Georgia, serif;
  font-size: 15px;
  opacity: 0.85;
  margin-bottom: 22px;
}

.quote-name {
  font-family: 'Nunito', sans-serif;
  font-size: 18px;
  font-weight: 600;
  margin: 0;
}

.quote-role {
  font-family: 'Nunito', sans-serif;
  font-size: 15px;
  opacity: 0.8;
  margin-top: 5px;
}

/* ===============================
   CONTACT GRID
================================= */

.contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 25px;
  width: 100%;
}

.contact-box {
  padding: 20px;
  border: 1px solid #eee;
  border-radius: 12px;
  text-align: center;
  box-sizing: border-box;
}

.contact-box h3 {
  color: #1f3c88;
  margin-bottom: 10px;
}

.contact-box a {
  display: inline-block;
  padding: 10px 22px;
  background: #1f3c88;
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
  font-weight: 600;
}

.small-text {
  font-size: 14px;
  color: #555;
}

/* ===============================
   FOOTER RAPAT
================================= */

footer {
  padding-top: 20px;
  margin-top: 0;
}