:root {
  --budaye-bg: #f8f6f2;
  --budaye-surface: #ffffff;
  --budaye-primary: #a55b42;
  --budaye-secondary: #1e3d34;
  --budaye-tan: #d7b89b;
  --budaye-ink: #1e1e1e;
  --budaye-muted: #6b7280;
  --budaye-radius: 1rem;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  font-family: 'Poppins', sans-serif;
  color: var(--budaye-ink);
  background-color: var(--budaye-bg);
  background-image:
    radial-gradient(circle at 12% 6%, rgba(218, 176, 107, .14), transparent 30%),
    radial-gradient(circle at 92% 90%, rgba(92, 49, 51, .10), transparent 36%);
  background-repeat: no-repeat, no-repeat;
  background-size: auto, auto;
  background-position: left top, right bottom;
  padding-top: 96px; /* Matches navbar height (80px logo + 16px py) */
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: url('/assets/images/backgroundtry.PNG') repeat center / 900px auto;
  opacity: 1;
  pointer-events: none;
  z-index: -1;
}

h1, h2, h3, h4, h5, .hero-title, .section-title {
  font-family: 'Merriweather', serif;
}

.navbar-budaye {
  backdrop-filter: blur(12px);
  background: rgba(92, 49, 51, 0.92);
  transition: all .3s ease;
  border-bottom: none;
}

.navbar-budaye.navbar-shrink {
  background: rgba(92, 49, 51, 0.96);
  box-shadow: 0 12px 30px rgba(10, 16, 14, 0.18);
}

.navbar-budaye .navbar-toggler {
  border: 1px solid rgba(255, 255, 255, .35);
  background: rgba(255, 255, 255, .4);
  padding: .4rem .5rem;
  border-radius: .7rem;
}

.navbar-budaye .navbar-toggler:focus {
  box-shadow: 0 0 0 .2rem rgba(255, 255, 255, .2);
}

.navbar-budaye .navbar-toggler-icon {
  width: 1.2rem;
  height: 1.2rem;
  background-size: 100% 100%;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.9)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.brand-logo {
  height: 80px;
  width: auto;
  object-fit: contain;
}


.btn-brand {
  background: var(--budaye-primary);
  color: #fff;
  border-color: var(--budaye-primary);
}

.btn-brand:hover { background: #8e4e39; border-color: #8e4e39; color: #fff; }

.btn-outline-brand {
  border-color: var(--budaye-primary);
  color: var(--budaye-primary);
}

.btn-outline-brand:hover {
  background: var(--budaye-primary);
  color: #fff;
}

.text-brand { color: var(--budaye-primary) !important; }

.hero-budaye {
  background:
    radial-gradient(circle at 85% 15%, rgba(30, 61, 52, 0.14), transparent 45%),
    linear-gradient(120deg, #f6efe8, #f9f7f3);
}

.hero-orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(0.6px);
  opacity: .35;
  pointer-events: none;
}

.hero-orb-1 {
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(165, 91, 66, .44), transparent 68%);
  top: -120px;
  right: -80px;
  animation: floatY 8s ease-in-out infinite;
}

.hero-orb-2 {
  width: 240px;
  height: 240px;
  background: radial-gradient(circle, rgba(30, 61, 52, .5), transparent 72%);
  bottom: -100px;
  left: -60px;
  animation: floatY 10s ease-in-out infinite reverse;
}

.hero-budaye::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(180deg, rgba(255, 255, 255, .2), transparent 68%),
    radial-gradient(circle at 14% 20%, rgba(165, 91, 66, .12), transparent 30%);
  background-repeat: no-repeat, no-repeat;
  background-size: 100% 100%, 100% 100%;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.58), transparent);
  opacity: .76;
  pointer-events: none;
}

.min-vh-75 { min-height: 75vh; }

.hero-metric-card {
  background: var(--budaye-surface);
  border-radius: 1.2rem;
  padding: 1.4rem;
  box-shadow: 0 18px 40px rgba(24, 30, 25, .08);
  border: 1px solid rgba(165, 91, 66, 0.12);
  position: relative;
  overflow: hidden;
}

.hero-metric-card::after {
  content: "";
  position: absolute;
  width: 130px;
  height: 130px;
  right: -35px;
  bottom: -35px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(165, 91, 66, .16), transparent 70%);
}

.hero-chip {
  border: 1px solid rgba(30, 61, 52, .2);
  background: rgba(255, 255, 255, .62);
  color: #2f3a35;
  padding: .5rem .8rem;
  border-radius: 999px;
  font-size: .84rem;
  backdrop-filter: blur(8px);
}

.hero-chip i { color: var(--budaye-primary); margin-right: .2rem; }

.hero-mini-panel {
  border-radius: 1rem;
  padding: .9rem 1rem;
  background: rgba(255, 255, 255, .76);
  border: 1px solid rgba(30, 61, 52, .14);
  backdrop-filter: blur(8px);
}

.kpi-ribbon {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  padding: .75rem;
  border-radius: 1.1rem;
  background: linear-gradient(90deg, #f5efe6, #f9f6f0);
  border: 1px solid rgba(165, 91, 66, .15);
}

.kpi-item {
  border-radius: .9rem;
  background: #fff;
  padding: .95rem .9rem;
  text-align: center;
}

.kpi-number {
  display: block;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--budaye-secondary);
}

.kpi-label {
  font-size: .8rem;
  color: var(--budaye-muted);
}

.badge-soft, .badge-success-soft, .badge-warning-soft, .badge-danger-soft {
  font-weight: 500;
  letter-spacing: .01em;
}

.badge-soft { background: rgba(165, 91, 66, .12); color: var(--budaye-primary); }
.badge-success-soft { background: rgba(30, 125, 87, .13); color: #1e7d57; }
.badge-warning-soft { background: rgba(198, 126, 27, .13); color: #aa6608; }
.badge-danger-soft { background: rgba(190, 57, 57, .13); color: #b42a2a; }

.section-title { font-size: clamp(1.6rem, 2.2vw, 2.2rem); }
.section-kicker { color: var(--budaye-primary); text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; }
.section-muted { background: rgba(242, 238, 232, .55); }

.culture-card {
  border-radius: var(--budaye-radius);
  overflow: hidden;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  border: 1px solid rgba(30, 61, 52, .08);
  position: relative;
}

.culture-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(260px circle at var(--mx, 0) var(--my, 0), rgba(255,255,255,.28), transparent 45%);
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}

.culture-card img {
  height: 220px;
  object-fit: cover;
}

.culture-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 34px rgba(20, 26, 22, .14) !important;
  border-color: rgba(165, 91, 66, .3);
}

.culture-card:hover::after { opacity: 1; }

.map-preview, .culture-map {
  height: 420px;
  background: #ece7de;
}

.map-sidebar {
  max-height: 420px;
  overflow-y: auto;
  background: #fff;
}

.map-location-item {
  border: 1px solid rgba(30, 61, 52, .1);
  background: #fbfaf8;
}

.map-location-thumb {
  width: 84px;
  height: 84px;
  object-fit: cover;
  flex: 0 0 auto;
  border: 1px solid rgba(30, 61, 52, .12);
  background: #ece7de;
}

.page-header {
  background: linear-gradient(180deg, #f5f1eb, transparent);
}

.detail-cover {
  background-size: cover;
  background-position: center;
  min-height: 340px;
  position: relative;
}

.detail-cover .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 18, 15, .58), rgba(10, 18, 15, .36));
}

.detail-title { font-size: clamp(1.9rem, 4vw, 2.8rem); max-width: 720px; }

.article-content {
  font-size: 1.05rem;
  line-height: 1.9;
}

.timeline-flow {
  display: grid;
  gap: 1rem;
}

.flow-item {
  padding: 1rem;
  border-radius: .9rem;
  background: #faf6f1;
  border: 1px dashed rgba(165, 91, 66, .35);
}

.month-calendar {
  background: #fff;
  border: 1px solid #ece8e3;
}

.month-calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  border-bottom: 1px solid #ece8e3;
}

.month-calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .45rem;
  padding-top: .6rem;
  padding-bottom: .45rem;
  font-weight: 600;
  color: #5a646f;
}

.month-calendar-weekdays > div {
  text-align: right;
  font-size: .9rem;
}

.month-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .45rem;
  background: #fff;
}

.month-cell {
  min-height: 132px;
  border: 1px solid #ece8e3;
  border-radius: .7rem;
  padding: .45rem;
  position: relative;
  background: #fcfaf7;
}

.month-cell.is-outside-month {
  opacity: .55;
}

.day-number {
  font-size: .86rem;
  color: #5b6670;
  text-align: right;
}

.month-cell-events {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  margin-top: .35rem;
}

.month-event-chip {
  border: 0;
  border-radius: 999px;
  background: rgba(30, 61, 52, .12);
  color: #1e3d34;
  font-size: .72rem;
  line-height: 1.15;
  padding: .22rem .52rem;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.month-event-chip:hover {
  background: rgba(165, 91, 66, .18);
}

.month-event-more {
  font-size: .72rem;
  color: #7b858f;
  padding-left: .25rem;
}

.thread-card { position: relative; }
.forum-highlight-card {
  position: relative;
  overflow: hidden;
}

.forum-highlight-card::before {
  content: "";
  position: absolute;
  width: 120px;
  height: 84px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(30, 61, 52, .15), transparent 72%);
  top: -30px;
  right: -30px;
}

.forum-arrow {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(165, 91, 66, .12);
  color: var(--budaye-primary);
  margin-top: 1rem;
}

.pagination-modern .page-link {
  border: 0;
  border-radius: .75rem;
  margin: 0 .2rem;
  color: var(--budaye-secondary);
}

.pagination-modern .page-item.active .page-link {
  background: var(--budaye-primary);
  color: #fff;
}

.skeleton-card {
  height: 340px;
  border-radius: var(--budaye-radius);
  background: linear-gradient(90deg, #ece7e1, #f5f2ee, #ece7e1);
  background-size: 240% 100%;
  animation: pulse 1.2s linear infinite;
}

@keyframes pulse {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-14px); }
}

.footer-budaye {
  background: #5c3133;
  color: #f0e6e0;
  border-top: 1px solid rgba(255, 255, 255, .08);
}

.footer-title { color: #ffffff; }
.footer-budaye h6 { color: #f4f0ec; }
.footer-muted { color: #d4c4ba; }
.footer-logo {
  width: 210px;
  max-width: 100%;
  height: auto;
  object-fit: contain;
}
.footer-budaye hr { border-color: rgba(255, 255, 255, .16); }
.footer-links a, .footer-budaye a { color: #e8ddd6; text-decoration: none; }
.footer-budaye a:hover { color: #ffffff; }

/* Footer — Didukung Oleh & Mitra Kami Atas Bawah */
.footer-support-row {
  align-items: flex-start;
  border-top: 1px solid rgba(255, 255, 255, .4);
}

.footer-section-label {
  color: rgba(255, 255, 255, .75);
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .06rem;
}

.border-bottom-support {
  border-bottom: 1px solid rgba(255, 255, 255, .4);
  padding-bottom: 0.25rem !important;
  margin-bottom: 0.25rem !important;
}

.footer-supporters-logos {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}

.footer-supporter-box {
  flex: 0 1 220px;
}

.footer-supporter-img {
  width: 100%;
  max-width: 100%;
  height: 84px;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: .85;
  transition: opacity .2s ease;
}

.footer-supporter-img:hover {
  opacity: 1;
}

/* Footer — Mitra Kami */
.footer-mitra-logos {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.25rem;
}

.footer-mitra-box {
  flex: 0 1 100px;
}

.footer-mitra-img {
  width: 100%;
  max-width: 100%;
  height: 38px;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: .7;
  transition: opacity .2s ease;
}

.footer-mitra-img:hover {
  opacity: 1;
}

@media (max-width: 991.98px) {
  .footer-support-col {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, .12);
    padding-bottom: 1rem;
  }
}

@media (max-width: 991.98px) {
  body { padding-top: 76px; } /* Matches mobile navbar height (60px logo + 16px py) */
  .map-preview, .culture-map { height: 320px; }
  .kpi-ribbon { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 575.98px) {
  .kpi-ribbon { grid-template-columns: 1fr; }
  .hero-chip { font-size: .78rem; }

  .hero-orb-1 {
    width: 160px;
    height: 84px;
    right: -30px;
    top: -60px;
  }

  .hero-orb-2 {
    width: 120px;
    height: 84px;
    left: -20px;
    bottom: -50px;
  }
}

/* Premium Refresh */
:root {
  --budaye-accent: #cfa467;
  --budaye-deep: #0f2a23;
}

body {
  background-color: var(--budaye-bg);
  background-image:
    radial-gradient(circle at 12% 6%, rgba(218, 176, 107, .14), transparent 30%),
    radial-gradient(circle at 92% 90%, rgba(92, 49, 51, .10), transparent 36%);
  background-repeat: no-repeat, no-repeat;
  background-size: auto, auto;
  background-position: left top, right bottom;
  overflow-x: hidden;
}

.navbar-budaye {
  box-shadow: 0 8px 28px rgba(42, 18, 20, .18);
}

.navbar-budaye .nav-link {
  color: rgba(255, 255, 255, .88);
  font-weight: 500;
  border-radius: 999px;
  padding: .42rem .78rem;
  transition: all .2s ease;
}

.navbar-budaye .nav-link:hover,
.navbar-budaye .nav-link:focus-visible {
  color: #fff;
  background: rgba(255, 255, 255, .14);
}

.btn-brand,
.btn-outline-brand {
  border-radius: .85rem;
  padding: .6rem 1rem;
  font-weight: 600;
  letter-spacing: .01em;
}

.btn-brand {
  background: linear-gradient(135deg, #ad6448, #8f4c37);
  border-color: transparent;
  box-shadow: 0 10px 24px rgba(165, 91, 66, .26);
}

.btn-brand:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(165, 91, 66, .32);
}

.hero-budaye {
  border-bottom: 1px solid rgba(165, 91, 66, .08);
}

.hero-title {
  letter-spacing: -.01em;
}

.section-muted {
  background:
    linear-gradient(180deg, rgba(242, 238, 232, .5), rgba(242, 238, 232, .3));
}

.card,
.hero-metric-card,
.hero-mini-panel,
.map-location-item,
.thread-card {
  border: 1px solid rgba(30, 61, 52, .09) !important;
  box-shadow: 0 14px 30px rgba(13, 21, 18, .06) !important;
}

.card:hover {
  box-shadow: 0 22px 34px rgba(13, 21, 18, .1) !important;
}

.section-title {
  position: relative;
  padding-bottom: .4rem;
}

.section-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 76px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--budaye-primary), var(--budaye-accent));
}

.text-center .section-title::after {
  left: 50%;
  transform: translateX(-50%);
}

.month-grid {
  border-radius: 1rem;
  padding: .7rem;
}

.month-cell {
  background: linear-gradient(180deg, #fff, #fcfbf8);
}

.footer-budaye {
  background:
    radial-gradient(circle at 8% 10%, rgba(207, 164, 103, .08), transparent 26%),
    #5c3133;
}

.footer-logo {
  width: 160px;
}

.detail-cover {
  border-bottom-left-radius: 1.2rem;
  border-bottom-right-radius: 1.2rem;
  overflow: hidden;
}

.article-content p {
  margin-bottom: 1.05rem;
}

.badge-soft {
  border: 1px solid rgba(165, 91, 66, .18);
}

@media (max-width: 991.98px) {
  body {
    background-image:
      radial-gradient(circle at 12% 6%, rgba(218, 176, 107, .12), transparent 32%),
      radial-gradient(circle at 92% 90%, rgba(92, 49, 51, .09), transparent 38%);
    background-size: auto, auto;
    background-position: left top, right bottom;
  }


  .hero-budaye::before {
    background-image:
      linear-gradient(180deg, rgba(255, 255, 255, .18), transparent 70%),
      radial-gradient(circle at 14% 20%, rgba(165, 91, 66, .10), transparent 32%);
    background-size: 100% 100%, 100% 100%;
    opacity: .72;
  }

  .navbar-budaye .navbar-collapse {
    margin-top: .8rem;
    border-radius: .9rem;
    padding: .85rem;
    background: rgba(72, 34, 36, .96);
    border: 1px solid rgba(255, 255, 255, .14);
    box-shadow: 0 18px 26px rgba(8, 5, 5, .2);
  }

  .navbar-budaye .nav-link {
    padding: .5rem .7rem;
    color: rgba(255, 255, 255, .88);
  }

  .navbar-budaye .nav-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, .14);
  }

  .brand-logo {
    height: 60px;
  }

  .navbar-budaye .navbar-toggler {
    flex-shrink: 0;
    order: 2;
  }

  .navbar-budaye .navbar-brand {
    flex: 1;
    min-width: 0;
  }
}

.navbar-budaye .nav-link.active {
  color: #fff;
  background: rgba(255, 255, 255, .18);
}

.pre-reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .45s ease, transform .45s ease;
}

.is-revealed {
  opacity: 1;
  transform: translateY(0);
}

.map-location-item {
  cursor: pointer;
  transition: border-color .2s ease, background-color .2s ease, transform .2s ease;
}

.map-location-item:hover {
  border-color: rgba(165, 91, 66, .45) !important;
  background: #fff;
  transform: translateY(-1px);
}

.map-location-item.is-active {
  border-color: rgba(165, 91, 66, .65) !important;
  background: rgba(165, 91, 66, .1);
  box-shadow: 0 10px 24px rgba(165, 91, 66, .14) !important;
}

.calendar-highlight-thumb {
  width: 160px;
  height: 96px;
  object-fit: cover;
  border: 1px solid rgba(30, 61, 52, .14);
}

.calendar-event-thumb {
  width: 100%;
  height: 170px;
  object-fit: cover;
  background: #ece7de;
}

.calendar-event-card {
  transition: transform .25s ease, box-shadow .25s ease;
}

.calendar-event-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 30px rgba(13, 21, 18, .1) !important;
}

@media (max-width: 767.98px) {
  .calendar-highlight-thumb {
    width: 100%;
    height: 180px;
  }
}

/* Calendar list view: portrait poster with hover detail */
.calendar-event-poster {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: #d9d5cd;
  border: 1px solid rgba(30, 61, 52, .12);
  transition: transform .28s ease, box-shadow .28s ease;
}

.calendar-event-poster:hover,
.calendar-event-poster:focus-within {
  transform: translateY(-4px);
  box-shadow: 0 20px 36px rgba(13, 21, 18, .18) !important;
}

.calendar-event-poster .calendar-event-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #ece7de;
}

.calendar-event-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(6, 12, 10, .92) 10%, rgba(6, 12, 10, .3) 48%, rgba(6, 12, 10, .06) 68%);
}

.calendar-event-meta {
  position: absolute;
  left: .9rem;
  right: .9rem;
  bottom: .9rem;
  z-index: 2;
  color: #f5f2ec;
}

.calendar-event-title {
  color: #fff;
  font-size: 1.05rem;
  line-height: 1.25;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .36);
}

.calendar-event-time {
  color: rgba(255, 255, 255, .88);
  font-size: .9rem;
}

.calendar-event-detail {
  position: absolute;
  left: .75rem;
  right: .75rem;
  bottom: .75rem;
  z-index: 3;
  background: rgba(255, 253, 249, .96);
  color: #27342f;
  border: 1px solid rgba(193, 142, 108, .45);
  border-radius: .8rem;
  padding: .7rem .8rem;
  font-size: .85rem;
  line-height: 1.4;
  transform: translateY(115%);
  opacity: 0;
  transition: transform .26s ease, opacity .26s ease;
}

.calendar-event-poster:hover .calendar-event-detail,
.calendar-event-poster:focus-within .calendar-event-detail {
  transform: translateY(0);
  opacity: 1;
}

@media (max-width: 767.98px) {
  .calendar-event-poster {
    aspect-ratio: 2 / 3;
  }

  .calendar-event-detail {
    transform: translateY(0);
    opacity: 1;
    font-size: .8rem;
  }

  .calendar-event-title {
    font-size: .98rem;
  }
}

/* Home top carousel */
.home-top-carousel {
  padding-top: .5rem;
  padding-bottom: .5rem;
}

.home-top-carousel--fullscreen {
  padding-top: 0;
  padding-bottom: 0;
  margin-bottom: 1.5rem;
}

.home-hero-swiper {
  position: relative;
  overflow: hidden;
  border-radius: 1rem;
  width: 100%;
}

.home-top-carousel--fullscreen .home-hero-swiper {
  border-radius: 0;
}

.home-hero-swiper .swiper-slide {
  width: 100%;
  display: block;
}

.home-hero-slide {
  position: relative;
  width: 100%;
  height: clamp(240px, 36vw, 420px);
  border-radius: 1rem;
  overflow: hidden;
}

.home-top-carousel--fullscreen .home-hero-slide {
  height: calc(100vh - 96px); /* Matches body desktop padding */
  min-height: 520px;
  border-radius: 0;
}

.home-hero-slide-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.home-top-carousel--fullscreen .home-hero-slide-image {
  object-fit: cover;
  object-position: center 40%;
}

.home-hero-slide-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(8, 10, 10, .64) 8%, rgba(8, 10, 10, .28) 50%, rgba(8, 10, 10, .18) 100%);
}

.home-hero-slide-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: min(640px, 92%);
  padding: clamp(1rem, 2vw, 2rem);
  color: #fff;
}

.home-top-carousel--fullscreen .home-hero-slide-content {
  max-width: none;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: flex-end;
  padding: clamp(1.25rem, 3vw, 2.5rem) 0;
}

.home-top-carousel--fullscreen .home-hero-slide-content .container {
  width: 100%;
}

.home-top-carousel--fullscreen .home-hero-slide-content .container > * {
  max-width: 640px;
}

.home-hero-slide-content h2 {
  margin-bottom: .5rem;
  font-size: clamp(1.25rem, 2.2vw, 2rem);
}

.home-hero-slide-content p {
  color: rgba(255, 255, 255, .92);
  margin-bottom: .75rem;
}

.home-hero-swiper-prev,
.home-hero-swiper-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  border: 0;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .9);
  color: #5c3133;
  display: grid;
  place-items: center;
}

.home-hero-swiper-prev { left: 12px; }
.home-hero-swiper-next { right: 12px; }

.home-hero-swiper-pagination {
  position: absolute;
  z-index: 4;
  left: 0;
  right: 0;
  bottom: 10px;
  text-align: center;
}

.home-hero-swiper .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  opacity: 1;
  background: rgba(255, 255, 255, .6);
}

.home-hero-swiper .swiper-pagination-bullet-active {
  background: #dab06b;
}

@media (max-width: 767.98px) {
  .home-hero-slide {
    height: 240px;
  }

  .home-hero-slide-content {
    max-width: 100%;
    padding: 1rem;
  }

  .home-hero-slide-content h2 {
    font-size: 1.1rem;
  }

  .home-hero-swiper-prev,
  .home-hero-swiper-next {
    width: 34px;
    height: 34px;
  }

  .home-top-carousel--fullscreen {
    margin-bottom: .75rem;
  }

  .home-top-carousel--fullscreen .home-hero-slide {
    height: calc(100dvh - 76px); /* Matches body mobile padding */
    min-height: 420px;
  }
}

/* Corner decorative SVGs */
.corner-decor {
  position: fixed;
  pointer-events: none;
  z-index: 0;
  opacity: .10;
}

.corner-decor img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.corner-decor--tl {
  top: -40px;
  left: -40px;
  width: 260px;
  height: 260px;
  transform: rotate(0deg);
}

.corner-decor--tr {
  top: -30px;
  right: -40px;
  width: 280px;
  height: 280px;
  transform: rotate(90deg);
}

.corner-decor--br {
  bottom: -40px;
  right: -40px;
  width: 260px;
  height: 260px;
  transform: rotate(180deg);
}

@media (max-width: 991.98px) {
  .corner-decor--tl { width: 180px; height: 180px; }
  .corner-decor--tr { width: 200px; height: 200px; }
  .corner-decor--br { width: 180px; height: 180px; }
}

@media (max-width: 575.98px) {
  .corner-decor { opacity: .07; }
  .corner-decor--tl { width: 100px; height: 100px; left: -20px; top: -20px; }
  .corner-decor--tr { width: 110px; height: 110px; right: -20px; top: -15px; }
  .corner-decor--br { width: 100px; height: 100px; right: -20px; bottom: -20px; }
}

/* Public gallery */
.gallery-shell {
  display: grid;
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
  gap: 1.25rem;
  align-items: start;
}

.gallery-filter-panel {
  position: sticky;
  top: 110px;
}

.gallery-masonry {
  column-count: 3;
  column-gap: 1rem;
}

.gallery-item-card {
  break-inside: avoid;
  margin-bottom: 1rem;
  position: relative;
}

.gallery-item-image {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.gallery-item-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, .05) 18%, rgba(0, 0, 0, .78) 100%);
}

.gallery-item-content {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  padding: .9rem .95rem;
  color: #fff;
}

.gallery-item-content h6 {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
}

.gallery-item-content p {
  color: rgba(255, 255, 255, .86);
}

.gallery-item-link {
  color: #fff;
  text-decoration: none;
  border-bottom: 1px dashed rgba(255, 255, 255, .7);
}

.gallery-item-link:hover {
  color: #fff;
  border-bottom-color: #fff;
}

@media (max-width: 1199.98px) {
  .gallery-masonry {
    column-count: 2;
  }
}

@media (max-width: 991.98px) {
  .gallery-shell {
    grid-template-columns: 1fr;
  }

  .gallery-filter-panel {
    position: static;
  }
}

@media (max-width: 575.98px) {
  .gallery-masonry {
    column-count: 1;
  }
}

/* Supporters section */
.supporters-wrap {
  background: linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, .82));
  border: 1px solid rgba(30, 61, 52, .12);
  box-shadow: 0 12px 24px rgba(24, 30, 25, .06);
  padding-top: 1.1rem !important;
  padding-bottom: 1.15rem !important;
}

.supporters-title {
  color: var(--budaye-secondary);
  font-size: clamp(1.35rem, 2.2vw, 1.7rem);
  margin-bottom: 1.1rem !important;
}

.supporters-logos {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  column-gap: 2rem;
  row-gap: 1.15rem;
}

.supporter-logo-box {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 1 250px;
  min-height: 88px;
  padding: .1rem .25rem;
}

.supporter-logo-img {
  width: 100%;
  max-width: 100%;
  height: 76px;
  object-fit: contain;
  filter: saturate(.96) contrast(1.02);
  opacity: .98;
  transition: transform .25s ease, opacity .25s ease, filter .25s ease;
}

.supporter-logo-box:hover .supporter-logo-img {
  transform: translateY(-1px);
  opacity: 1;
  filter: saturate(1) contrast(1.03);
}

@media (max-width: 991.98px) {
  .supporters-logos {
    column-gap: 1.4rem;
    row-gap: 1rem;
  }

  .supporter-logo-box {
    flex: 0 1 220px;
  }
}

@media (max-width: 575.98px) {
  .supporters-wrap {
    padding-top: .95rem !important;
    padding-bottom: 1rem !important;
  }

  .supporter-logo-box {
    flex: 0 1 160px;
    min-height: 72px;
  }

  .supporter-logo-img {
    height: 54px;
  }
}

/* ============================================================
   TENTANG KAMI
   ============================================================ */

/* Hero */
.tentang-hero {
  background: linear-gradient(135deg, #f5f0e8 0%, #f9f6f1 60%, #eef4f0 100%);
  border-bottom: 1px solid rgba(165, 91, 66, .1);
}

.tentang-hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 8% 20%, rgba(165, 91, 66, .13), transparent 38%),
    radial-gradient(circle at 90% 80%, rgba(30, 61, 52, .10), transparent 36%);
  pointer-events: none;
}

.min-vh-50 { min-height: 50vh; }

.tentang-hero-title {
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  line-height: 1.25;
  color: var(--budaye-ink);
}

.tentang-hero-accent {
  color: var(--budaye-primary);
}

/* Stat grid */
.tentang-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.tentang-stat-card {
  background: #fff;
  border-radius: 1.1rem;
  padding: 1.4rem 1.2rem;
  border: 1px solid rgba(165, 91, 66, .12);
  box-shadow: 0 8px 28px rgba(20, 26, 22, .06);
  display: flex;
  flex-direction: column;
  gap: .25rem;
}

.tentang-stat-card--accent {
  background: var(--budaye-primary);
}

.tentang-stat-card--accent .tentang-stat-number,
.tentang-stat-card--accent .tentang-stat-label { color: #fff; }

.tentang-stat-card--dark {
  background: var(--budaye-secondary);
}

.tentang-stat-card--dark .tentang-stat-number,
.tentang-stat-card--dark .tentang-stat-label { color: #fff; }

.tentang-stat-number {
  font-family: 'Merriweather', serif;
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--budaye-secondary);
  line-height: 1.1;
}

.tentang-stat-label {
  font-size: .8rem;
  color: var(--budaye-muted);
}

/* Visi Misi cards */
.tentang-vm-card {
  background: #fff;
  border-radius: 1.2rem;
  padding: 2rem 1.8rem;
  border: 1px solid rgba(30, 61, 52, .1);
  box-shadow: 0 6px 24px rgba(20, 26, 22, .06);
}

.tentang-vm-card--visi {
  border-top: 4px solid var(--budaye-primary);
}

.tentang-vm-card--misi {
  border-top: 4px solid var(--budaye-secondary);
}

.tentang-vm-icon {
  width: 52px;
  height: 52px;
  border-radius: .9rem;
  background: rgba(165, 91, 66, .1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--budaye-primary);
}

.tentang-vm-card--misi .tentang-vm-icon {
  background: rgba(30, 61, 52, .1);
  color: var(--budaye-secondary);
}

/* Story section */
.tentang-story-img-wrap {
  position: relative;
  display: inline-block;
  width: 100%;
}

.tentang-story-img {
  width: 100%;
  max-width: 420px;
  border-radius: 1.4rem;
  object-fit: cover;
  background: #f0ebe3;
  padding: 2rem;
  border: 1px solid rgba(165, 91, 66, .15);
  box-shadow: 0 16px 40px rgba(20, 26, 22, .1);
  display: block;
  margin: 0 auto;
}

.tentang-story-badge {
  position: absolute;
  bottom: 1.2rem;
  right: 1rem;
  background: var(--budaye-primary);
  color: #fff;
  font-size: .82rem;
  font-weight: 600;
  padding: .4rem .9rem;
  border-radius: 999px;
  box-shadow: 0 4px 12px rgba(165, 91, 66, .3);
}

/* Nilai cards */
.tentang-nilai-card {
  background: #fff;
  border-radius: 1.1rem;
  padding: 2rem 1.5rem;
  border: 1px solid rgba(30, 61, 52, .08);
  transition: transform .3s ease, box-shadow .3s ease;
}

.tentang-nilai-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 36px rgba(20, 26, 22, .1);
}

.tentang-nilai-icon {
  width: 56px;
  height: 56px;
  border-radius: 1rem;
  background: linear-gradient(135deg, rgba(165, 91, 66, .12), rgba(30, 61, 52, .08));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: var(--budaye-primary);
  margin: 0 auto;
}

/* Founder cards */
.tentang-founder-card {
  background: #fff;
  border-radius: 1.3rem;
  padding: 2rem 1.5rem;
  border: 1px solid rgba(30, 61, 52, .08);
  box-shadow: 0 6px 24px rgba(20, 26, 22, .06);
  transition: transform .3s ease, box-shadow .3s ease;
}

.tentang-founder-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(20, 26, 22, .12);
}

.tentang-founder-photo-wrap {
  display: flex;
  justify-content: center;
}

.tentang-founder-photo {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid rgba(165, 91, 66, .25);
  box-shadow: 0 6px 20px rgba(165, 91, 66, .15);
  background: #f0ebe3;
}

.tentang-social-link {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(165, 91, 66, .1);
  color: var(--budaye-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  text-decoration: none;
  transition: background .25s ease, color .25s ease;
}

.tentang-social-link:hover {
  background: var(--budaye-primary);
  color: #fff;
}

@media (max-width: 575.98px) {
  .tentang-stat-grid {
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
  }

  .tentang-stat-number { font-size: 1.3rem; }
}

/* Tentang - hero card, story card, cta card */
.tentang-hero-card {
  background: rgba(255, 255, 255, .72);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(165, 91, 66, .15);
  border-radius: 1.4rem;
  padding: 2.2rem 2rem;
  box-shadow: 0 8px 32px rgba(20, 26, 22, .07);
}

.tentang-story-card {
  background: #fff;
  border-radius: 1.3rem;
  padding: 2rem 2rem;
  border: 1px solid rgba(30, 61, 52, .1);
  box-shadow: 0 8px 32px rgba(20, 26, 22, .07);
  border-left: 4px solid var(--budaye-primary);
}

.tentang-cta-card {
  background: #fff;
  border-radius: 1.4rem;
  padding: 3rem 2rem;
  border: 1px solid rgba(165, 91, 66, .15);
  box-shadow: 0 8px 32px rgba(20, 26, 22, .07);
  max-width: 680px;
  margin: 0 auto;
}
