/* =============================================
   DESA HUTARUHOM — Base / Reset
   ============================================= */

*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--krem);
  color: var(--teks-gelap);
  line-height: 1.6;
  font-size: 15px;
}

a { text-decoration: none; color: inherit; }

ul, ol { list-style: none; }

img { max-width: 100%; display: block; }

button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ---- Utility ---- */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--page-pad);
}

.section {
  padding: var(--space-xl) 0;
}

.section-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-display);
  font-size: 1.55rem;
  color: var(--hijau-tua);
  margin-bottom: var(--space-lg);
  padding-bottom: 12px;
  border-bottom: 2px solid var(--emas);
}

.section-title::before {
  content: '';
  width: 5px;
  height: 30px;
  background: var(--emas);
  border-radius: 3px;
  flex-shrink: 0;
}

/* ---- Page Hero (inner pages) ---- */
.page-hero {
  background: linear-gradient(135deg, var(--hijau-tua), var(--hijau));
  padding: 40px 0;
  text-align: center;
  color: #fff;
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E");
}

.page-hero h1 {
  font-family: var(--font-display);
  font-size: 2rem;
  position: relative;
  margin-bottom: 8px;
}

.page-hero .breadcrumb {
  font-size: 13px;
  color: #b2dfdb;
  position: relative;
}

.page-hero .breadcrumb a { color: var(--emas-muda); }

/* ---- Btn ---- */
.btn {
  display: inline-block;
  padding: 10px 28px;
  border-radius: var(--radius-full);
  font-weight: 700;
  font-size: 14px;
  transition: all 0.2s;
  cursor: pointer;
}

.btn-primary {
  background: var(--hijau);
  color: #fff;
}
.btn-primary:hover { background: var(--hijau-tua); transform: translateY(-2px); }

.btn-gold {
  background: var(--emas);
  color: var(--hijau-tua);
}
.btn-gold:hover { background: var(--emas-muda); transform: translateY(-2px); }

.btn-outline {
  border: 2px solid var(--hijau);
  color: var(--hijau);
}
.btn-outline:hover { background: var(--hijau); color: #fff; }

/* ---- Badge ---- */
.badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
}

.badge-green  { background: var(--hijau); color: #fff; }
.badge-gold   { background: var(--emas); color: var(--hijau-tua); }
.badge-blue   { background: #1565c0; color: #fff; }
.badge-orange { background: #e65100; color: #fff; }

/* ---- Responsive ---- */
@media (max-width: 900px) {
  .section { padding: var(--space-lg) 0; }
  .section-title { font-size: 1.25rem; }
}

@media (max-width: 600px) {
  body { font-size: 14px; }
}
