/* Kumham Imipas PPID Template
   Bootstrap-only; custom accents extracted from logo (gold/black/white).
*/

/* Global palette (site-wide) */
:root{
  /* Page */
  --kumham-bg: #FFF8EE;         /* Cream */
  --kumham-surface: #ffffff;    /* Card surface */
  --kumham-surface-2: #FFFDF7;  /* Subtle section surface */

  /* Text */
  --kumham-text: #2D2D2D;       /* Body text */
  --kumham-muted: rgba(45,45,45,.70);

  /* Brand */
  --kumham-primary: #333333;    /* Header / Footer */
  --kumham-on-primary: #FFF8EE;
  --kumham-on-primary-muted: rgba(255,248,238,.78);

  /* Accent (border / icons / link accent) */
  --kumham-border: rgba(120,144,156,.45);
  --kumham-gold: #78909C;       /* repurposed: accent */
  --kumham-gold-2: #607D8B;     /* darker accent */
  --kumham-gold-soft: rgba(120,144,156,.18);

  --kumham-focus: rgba(120,144,156,.35);
  --kumham-radius: 1.25rem;
}

html, body { height: 100%; }
body.app{
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  /* Flat background (no gradient) */
  background: var(--kumham-bg);
  color: var(--kumham-text);
  font-size: var(--app-font-size, 16px);
}

/* Theme variants controlled by JS */
body.app.theme-light{
  /* Kept for compatibility with existing JS theme toggle.
     This palette is already light, so theme-light stays identical. */
  background: var(--kumham-bg);
}

body.app.high-contrast{
  --kumham-border: currentColor;
  --kumham-muted: currentColor;
}

a{ color: var(--kumham-gold); }
a:hover{ color: var(--kumham-gold-2); }
.text-muted{ color: var(--kumham-muted) !important; }
.text-accent{ color: var(--kumham-gold) !important; }

/* Focus */
:focus-visible{
  outline: 3px solid var(--kumham-focus);
  outline-offset: 2px;
  border-radius: .5rem;
}

/* Topbar */
.topbar{
  background: var(--kumham-primary);
  color: var(--kumham-on-primary);
}
.btn-kumham-ghost{
  border-color: rgba(255,248,238,.25) !important;
  color: var(--kumham-on-primary) !important;
  background: rgba(255,248,238,.08) !important;
}
.btn-kumham-ghost:hover{
  background: rgba(255,248,238,.14) !important;
}

/* Header + Navbar */
.app-header .navbar{
  /* Flat header (no gradient) */
  background: var(--kumham-primary);
  border-bottom: 1px solid rgba(255,248,238,.14);
}
.navbar .nav-link{
  color: var(--kumham-on-primary);
  opacity: .88;
  font-weight: 600;
}
.navbar .nav-link:hover, .navbar .nav-link:focus{
  opacity: 1;
  color: var(--kumham-gold);
}
.navbar .dropdown-menu{
  border: 1px solid var(--kumham-border);
}
.brand-logo{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  object-fit: cover;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.brand-title{ letter-spacing: -0.02em; }
.brand-subtitle{ font-size: .85rem; color: var(--kumham-muted); }
.app-header .brand-subtitle{ color: var(--kumham-on-primary-muted); }

/* Mega menu */
.dropdown-mega .mega-menu{
  width: min(980px, 96vw);
  border-radius: var(--kumham-radius);
}
.mega-heading{
  font-weight: 800;
  letter-spacing: -0.01em;
  margin-bottom: .5rem;
}
.mega-link{
  display: flex;
  align-items: center;
  padding: .55rem .65rem;
  border-radius: .75rem;
  text-decoration: none;
  color: var(--kumham-text);
  border: 1px solid transparent;
}
.mega-link:hover{
  border-color: var(--kumham-border);
  background: rgba(255,255,255,.04);
  color: var(--kumham-gold);
}
.mega-card{
  background: rgba(255,255,255,.03);
  border: 1px solid var(--kumham-border);
}
.mega-icon{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: var(--kumham-gold-soft);
  color: var(--kumham-gold);
}

/* Buttons */
.btn-kumham{
  --bs-btn-color: var(--kumham-on-primary);
  --bs-btn-bg: var(--kumham-primary);
  --bs-btn-border-color: var(--kumham-primary);
  --bs-btn-hover-bg: #2B2B2B;
  --bs-btn-hover-border-color: #2B2B2B;
  --bs-btn-active-bg: #2B2B2B;
  --bs-btn-active-border-color: #2B2B2B;
  --bs-btn-focus-shadow-rgb: 51, 51, 51;
  font-weight: 800;
  border-radius: 999px;
}
.btn-kumham-outline{
  --bs-btn-color: var(--kumham-gold);
  --bs-btn-border-color: var(--kumham-gold);
  --bs-btn-hover-color: var(--kumham-on-primary);
  --bs-btn-hover-bg: var(--kumham-gold);
  --bs-btn-hover-border-color: var(--kumham-gold);
  --bs-btn-focus-shadow-rgb: 120, 144, 156;
  font-weight: 800;
  border-radius: 999px;
  background: transparent;
}
.border-kumham{ border-color: var(--kumham-border) !important; }
.input-group .form-control::placeholder{ color: rgba(45,45,45,.45); }

/* Badges */
.badge-kumham{
  background: var(--kumham-gold-soft);
  color: var(--kumham-gold);
  border: 1px solid rgba(120,144,156,.35);
}
.badge-kumham-soft{
  background: var(--kumham-surface);
  color: var(--kumham-text);
  border: 1px solid var(--kumham-border);
  padding: .55rem .65rem;
  border-radius: 999px;
}

/* Hero */
.hero{
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--kumham-border);
}
.hero::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(900px 450px at 20% 0%, rgba(120,144,156,.20), transparent 60%),
    radial-gradient(700px 350px at 90% 15%, rgba(120,144,156,.12), transparent 55%),
    linear-gradient(180deg, rgba(255,248,238,.85), rgba(255,248,238,.55));
  pointer-events:none;
}
.hero .container-xxl{ position: relative; z-index: 2; }
.hero-pill{
  border: 1px solid var(--kumham-border);
  background: var(--kumham-surface);
  color: var(--kumham-text);
}
.hero-card{
  background: var(--kumham-surface);
  border: 1px solid var(--kumham-border);
  box-shadow: 0 20px 55px rgba(0,0,0,.10);
}
.stat-card{
  display:flex;
  align-items:center;
  gap:12px;
  padding: 12px 14px;
  border-radius: 16px;
  background: var(--kumham-surface);
  border: 1px solid var(--kumham-border);
}
.stat-icon{
  width: 40px;
  height: 40px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: var(--kumham-gold-soft);
  color: var(--kumham-gold);
}
.quick-link{
  display:flex;
  align-items:center;
  gap:12px;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid var(--kumham-border);
  background: var(--kumham-surface);
  text-decoration:none;
}
.quick-link:hover{
  border-color: rgba(120,144,156,.55);
  background: var(--kumham-gold-soft);
}
.ql-icon{
  width: 44px;
  height: 44px;
  border-radius: 18px;
  display:grid;
  place-items:center;
  background: var(--kumham-gold-soft);
  color: var(--kumham-gold);
}
.ql-text{ flex: 1; }
.hero-wave{
  height: 18px;
  background: linear-gradient(90deg, transparent, rgba(120,144,156,.25), transparent);
  opacity: .9;
}


/* Hero Carousel */
.hero-carousel .carousel-indicators{
  margin-bottom: 1.25rem;
}
.hero-carousel .carousel-indicators [data-bs-target]{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background-color: rgba(120,144,156,.35);
  border: 0;
}
.hero-carousel .carousel-indicators .active{
  background-color: var(--kumham-gold);
}
.hero-carousel .carousel-control-prev,
.hero-carousel .carousel-control-next{
  width: 3.25rem;
}
.hero-carousel .carousel-control-prev-icon,
.hero-carousel .carousel-control-next-icon{
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.55));
}

/* Hero Carousel (Images) */
.hero-carousel::before{
  content: none;
}
.hero-carousel .carousel-item{
  position: relative;
}

/*
  Mode responsif + tetap "penuh":
  - Gambar utama pakai contain (tidak terpotong)
  - Background diisi versi cover (blur) supaya area kosong tidak terlihat
*/
.hero-carousel .carousel-item.hero-slide{
  --hero-bg: none;
  overflow: hidden;
  background: var(--kumham-bg);
}
.hero-carousel .carousel-item.hero-slide::before{
  content:"";
  position:absolute;
  inset:-12px;
  background-image: var(--hero-bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(18px);
  transform: scale(1.08);
  opacity: .55;
  z-index: 0;
}
.hero-carousel .carousel-item.hero-slide::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(51,51,51,.60) 0%, rgba(51,51,51,.20) 45%, rgba(51,51,51,.60) 100%);
  z-index: 1;
}
.hero-carousel .hero-slide-img{
  position: relative;
  z-index: 2;
  width: 100%;
  height: clamp(260px, 56vh, 680px);
  object-fit: contain; /* mobile: seperti saat ini (tidak terpotong) */
  object-position: center;
}

/*
  Beranda (Desktop):
  - Tetap full lebar
  - Tidak terpotong (no-crop)
  - Tinggi mengikuti rasio banner (default hero 1920x720 = 8/3)
    supaya tidak terjadi crop seperti mode cover.
  Catatan: jika suatu slide berbeda rasio, gambar tetap tidak terpotong (contain)
  dan area kosong diisi blur background.
*/
@media (min-width: 992px){
  .page-home .hero-carousel .carousel-item.hero-slide{
    aspect-ratio: 8 / 3;
  }
  .page-home .hero-carousel .hero-slide-img{
    height: 100% !important;
    object-fit: contain !important;
  }
}
.hero-carousel .hero-slide-overlay{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  background: linear-gradient(90deg, rgba(51,51,51,.78) 0%, rgba(51,51,51,.45) 42%, rgba(51,51,51,.72) 100%);
}
.hero-carousel .carousel-indicators,
.hero-carousel .carousel-control-prev,
.hero-carousel .carousel-control-next{
  z-index: 5;
}


/* Akses Cepat tiles */
.quick-tile{
  transition: transform .15s ease, border-color .15s ease, background-color .15s ease;
}
.quick-tile:hover{
  transform: translateY(-2px);
  border-color: rgba(120,144,156,.55);
  background: var(--kumham-gold-soft);
}
.quick-tile:focus-visible{
  outline: 2px solid rgba(120,144,156,.55);
  outline-offset: 3px;
}

/* Akses Cepat (Beranda) - Card seperti desain referensi */
.quick-access-card{
  border-radius: 22px;
  overflow: hidden;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.quick-access-card:hover{
  transform: translateY(-2px);
  border-color: rgba(120,144,156,.55);
  box-shadow: 0 18px 44px rgba(0,0,0,.12);
}
.quick-access-top{
  background: var(--kumham-gold);
  height: 150px;
  display: grid;
  place-items: center;
}
.quick-access-icon{
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  color: #fff;
}
.quick-access-icon i{
  font-size: 46px;
}
.quick-access-body{
  padding: 1.75rem 1.5rem 1.9rem;
}
.quick-access-title{
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
  line-height: 1.15;
  color: var(--kumham-text);
  margin-top: .25rem;
  margin-bottom: 1.15rem;
  min-height: 3.2rem; /* jaga tinggi judul agar tombol sejajar */
}

@media (min-width: 992px){
  .quick-access-top{ height: 170px; }
}

/* Sections */
.section{ padding: 3rem 0; }
.section-alt{
  background: var(--kumham-surface-2);
  border-top: 1px solid var(--kumham-border);
  border-bottom: 1px solid var(--kumham-border);
}

.card-kumham{
  background: var(--kumham-surface);
  border: 1px solid var(--kumham-border);
  box-shadow: 0 16px 40px rgba(0,0,0,.08);
}
body.app.theme-light .card-kumham{
  background: var(--kumham-surface);
  box-shadow: 0 16px 40px rgba(0,0,0,.08);
}

.doc-icon{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  border: 1px solid var(--kumham-border);
}
.doc-pdf{ background: var(--kumham-surface-2); color: #ff6b6b; }
.doc-doc{ background: var(--kumham-surface-2); color: #74c0fc; }

/* Table tweaks for dark + light */
.table-dark{
  --bs-table-bg: transparent;
  --bs-table-striped-bg: rgba(0,0,0,.02);
  --bs-table-hover-bg: rgba(120,144,156,.10);
  --bs-table-border-color: var(--kumham-border);
  color: var(--kumham-text);
}


/* Breadcrumb */
.breadcrumb-kumham .breadcrumb-item a{
  color: var(--kumham-muted);
  text-decoration:none;
}
.breadcrumb-kumham .breadcrumb-item a:hover{ color: var(--kumham-gold); }
.breadcrumb-kumham .breadcrumb-item.active{ color: var(--kumham-text); }

/* Footer */
.app-footer{
  border-top: 1px solid rgba(255,248,238,.14);
  background: var(--kumham-primary);
  color: var(--kumham-on-primary);
}
.app-footer .text-muted{ color: var(--kumham-on-primary-muted) !important; }
.footer-logo{
  width: 46px;
  height: 46px;
  border-radius: 999px;
  object-fit: cover;
  border: 1px solid var(--kumham-border);
}
.footer-heading{
  font-weight: 800;
  margin-bottom: .75rem;
}
.footer-links a{
  color: var(--kumham-on-primary-muted);
  text-decoration:none;
  display:inline-block;
  padding: .18rem 0;
}
.footer-links a:hover{ color: var(--kumham-gold); }

/* Utility */
.fw-extrabold{ font-weight: 800 !important; }

/* AOS micro-optimizations (professional + smooth) */
[data-aos]{
  will-change: transform, opacity;
}
@media (prefers-reduced-motion: reduce){
  [data-aos]{
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}


/* Beranda - Daftar Informasi Publik (DIP) inline loader + tabs */
#dipSection .dip-card{ overflow: hidden; }
#dipSection .dip-loading-overlay{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(51,51,51,.20);
  backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
}
#dipSection .dip-card.is-loading .dip-loading-overlay{
  opacity: 1;
  pointer-events: auto;
}
#dipSection .dip-loading-card{
  display: flex;
  align-items: center;
  gap: .9rem;
  padding: 1rem 1.25rem;
  border-radius: 1.25rem;
  background: var(--kumham-surface);
  border: 1px solid var(--kumham-border);
  box-shadow: 0 1rem 2.2rem rgba(0,0,0,.12);
}
#dipSection .dip-loading-card .spinner-border{
  width: 1.25rem;
  height: 1.25rem;
}
#dipSection .dip-tabs.is-busy .js-dip-tab{
  pointer-events: none;
  opacity: .75;
}
#dipSection .dip-desc{
  max-width: 62ch;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* File badge color variants */
.doc-xls{ background: var(--kumham-surface-2); color: #69db7c; }

.dip-title, .dip-desc{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* DIP - Halaman kategori: sub kategori + daftar dokumen */
.dip-subcat-head{
  color: #78909c;
}

/* Halaman DIP: judul boleh wrap, tombol tetap di kanan */
.dip-subcat-item .dip-subcat-title{
  flex: 1 1 auto;
  min-width: 0;               /* penting agar flex item bisa mengecil dan text bisa wrap */
  overflow-wrap: anywhere;    /* aman untuk judul panjang */
  word-break: break-word;
}

.dip-subcat-item .dip-subcat-actions{ flex-shrink: 0; }

@media (min-width: 768px){
  .dip-subcat-item .dip-subcat-actions{ white-space: nowrap; }
}

/* Warna sub-kategori khusus /dip-setiap-saat */
.dip-type-setiap-saat .dip-subcat-header .dip-subcat-icon,
.dip-type-setiap-saat .dip-subcat-header .dip-subcat-name{
  color: #78909c;
}

/* --- RSS News Content: make images responsive (Berita Detail) --- */
.news-content img {
  max-width: 100% !important;
  height: auto !important;
}

/* Optional: keep long content from breaking layout */
.news-content {
  overflow-wrap: anywhere;
}

/* --- Profile Content: make images responsive (Profil) --- */
.profile-content img {
  max-width: 100% !important;
  height: auto !important;
}

.profile-content {
  overflow-wrap: anywhere;
}

.profile-content * { color: var(--kumham-text) !important; }

/* Biar link tetap kelihatan sebagai link */
.profile-content a {
  text-decoration: underline;
  color: var(--kumham-gold) !important;
}

/* --- Static Page Content: images responsive + text white (Struktur/Tugas-Fungsi/Maklumat) --- */
.page-content img {
  max-width: 100% !important;
  height: auto !important;
}

.page-content {
  overflow-wrap: anywhere;
}

.page-content * { color: var(--kumham-text) !important; }

.page-content a {
  text-decoration: underline;
  color: var(--kumham-gold) !important;
}

/* --- FAQ Accordion: border & icon white (remove blue focus ring) --- */
#faqAcc .accordion-item{
  border-color: var(--kumham-border) !important;
}

#faqAcc .accordion-button{
  color: var(--kumham-text) !important;
  background: var(--kumham-surface) !important;
}

/* Remove default bootstrap blue focus outline, replace with subtle white */
#faqAcc .accordion-button:focus{
  border-color: rgba(120,144,156,.85) !important;
  box-shadow: 0 0 0 .15rem rgba(120,144,156,.20) !important;
}

/* Keep border consistent on active state */
#faqAcc .accordion-button:not(.collapsed){
  box-shadow: none !important;
}

/* Make accordion arrow white */
#faqAcc .accordion-button::after{
  filter: none;
}

/* FAQ divider antara header (pertanyaan) dan body (jawaban) */
.faq-page .accordion-body{
  border-top: 1px solid var(--kumham-border);
}

/* (opsional) kalau divider cuma mau muncul saat item terbuka */
.faq-page .accordion-collapse:not(.show) .accordion-body{
  border-top: 0;
}

.accordion-body{ border-top: 1px solid var(--kumham-border); }
