/*
Theme Name: PPID MAN 1 Musi Banyuasin
Theme URI: #
Author: Enter Pro
Author URI: https://enter.pro
Description: Tema resmi untuk website PPID (Pejabat Pengelola Informasi dan Dokumentasi) MAN 1 Musi Banyuasin. Dilengkapi halaman beranda lengkap, manajemen berita, pengumuman, layanan PPID, dan kategori informasi publik. Semua konten dapat diedit dari dashboard WordPress.
Version: 1.0.1
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ppid-kemenag
Tags: government, blog, custom-menu, custom-logo, featured-images, full-width-template
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --color-primary-100: #E8F5E9;
  --color-primary-500: #2E7D32;
  --color-primary-900: #1B5E20;
  --color-neutral-100: #F5F7FA;
  --color-neutral-500: #6B7280;
  --color-neutral-900: #12213A;
  --color-accent-gold: #F9A825;
  --color-accent-gold-dark: #C77800;
  --color-navy: #0D2B5E;
  --color-danger: #C62828;
  --color-white: #FFFFFF;
  --font-base: 'Plus Jakarta Sans', Arial, sans-serif;
  --shadow-card: 0 1px 4px rgba(0,0,0,0.07);
  --shadow-hover: 0 6px 20px rgba(0,0,0,0.13);
  --transition: all 0.18s ease-out;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
  font-family: var(--font-base);
  color: var(--color-neutral-900);
  background: #fff;
  line-height: 1.6;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary-500); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--color-primary-900); }
ul { list-style: none; }

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}



/* ============================================================
   TOP BAR
   ============================================================ */
.top-bar {
  background: var(--color-navy);
  border-bottom: 2px solid var(--color-accent-gold);
  padding: 7px 0;
  font-size: 13px;
}
.top-bar .container { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.top-bar-left, .top-bar-right { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.top-bar a { color: rgba(255,255,255,0.8); display: flex; align-items: center; gap: 5px; }
.top-bar a:hover { color: var(--color-accent-gold); }
.top-bar .tb-icon { color: var(--color-accent-gold); display: inline-block; }
.top-bar-divider { color: rgba(255,255,255,0.25); }
.top-bar-links { display: flex; gap: 10px; align-items: center; font-size: 12px; color: rgba(255,255,255,0.65); }
.top-bar-links a { color: rgba(255,255,255,0.65); font-size: 12px; }
.top-bar-social { display: flex; gap: 6px; padding-left: 12px; border-left: 1px solid rgba(255,255,255,0.2); }
.top-bar-social a { color: rgba(255,255,255,0.6); width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(255,255,255,0.08); }
.top-bar-social a:hover { color: var(--color-accent-gold); background: rgba(255,255,255,0.15); }

/* ============================================================
   HEADER / NAVIGATION
   ============================================================ */
.site-header {
  background: var(--color-primary-900);
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  position: sticky;
  top: 0;
  z-index: 999;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  gap: 16px;

}
.site-branding {
    display: flex;
    align-items: center;
    gap: 14px;
}

.logo-wrap{
    display:block;
    flex-shrink:0;
}

.logo-wrap .custom-logo{
    width:80px !important;
    height:80px !important;
    max-width:80px !important;
    max-height:80px !important;
    object-fit:contain;
}

.site-logo-placeholder {
  width: 50px; height: 50px; background: #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.site-logo-placeholder svg { width: 28px; height: 28px; }
.site-title-wrap .ministry-name { color: var(--color-accent-gold); font-size: 11px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; }
.site-title-wrap .site-title { color: #fff; font-size: 17px; font-weight: 700; line-height: 1.2; display: block; }
.site-title-wrap .site-subtitle { color: rgba(255,255,255,0.65); font-size: 12px; }

/* Navigation */
.main-nav { display: flex; align-items: center; gap: 2px; }
.main-nav > ul { display: flex; gap: 2px; align-items: center; }
.main-nav ul li { position: relative; }
.main-nav ul li a {
  color: rgba(255,255,255,0.9);
  font-size: 16px;
  font-weight: 600;
  padding: 8px 12px;

  display: flex;
  align-items: center;
  justify-content: center;

  gap: 6px;

  border-bottom: 0px solid transparent;
  border-radius: 0px;
  transition: var(--transition);

  white-space: nowrap;

  width: 100%;
  text-align: center;
}
.main-nav ul li a:hover,
.main-nav ul li.current-menu-item > a,
.main-nav ul li.current_page_item > a { color: var(--color-accent-gold); border-bottom-color: var(--color-accent-gold); }
.main-nav ul li .sub-menu {
  position: absolute; top: 100%; left: 0; min-width: 220px;
  background: #fff; border-top: 3px solid var(--color-accent-gold);
  box-shadow: 0 4px 16px rgba(0,0,0,0.15); border-radius: 0 0 4px 4px;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: all 0.15s ease-out; z-index: 1000;
}

.main-nav ul li:hover > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.main-nav ul li .sub-menu li a {
  color: var(--color-neutral-900);

  padding: 10px 16px;

  font-weight: 500;

  border-bottom: none;
  border-radius: 0;

  display: block;

  text-align: left;

  width: 100%;
}
/* KHUSUS DESKTOP */

.main-nav ul li .sub-menu li a:hover { background: var(--color-primary-100); color: var(--color-primary-900); }

/* Mobile Toggle */
.menu-toggle {
  display: none; background: none; border: none; cursor: pointer;
  color: var(--color-accent-gold); padding: 6px;
}
.menu-toggle svg { width: 24px; height: 24px; }

@media (max-width: 1023px) {
  .menu-toggle { display: block; }
  .main-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--color-primary-900); padding: 12px 24px 20px; flex-direction: column; align-items: flex-start; border-top: 1px solid rgba(255,255,255,0.1); }
  .main-nav.open { display: flex; }
  .main-nav ul { flex-direction: column; width: 100%; }
  .main-nav ul li {
  width: 100%;
  text-align: center;
}

.main-nav ul li a {
  padding: 10px 12px;
  border-bottom: none;

  width: 100%;

  display: flex;
  align-items: center;
  justify-content: center;

  text-align: center;
}
  .main-nav ul li .sub-menu {
 position: static;
 opacity: 0;
 visibility: hidden;
 max-height: 0;
 overflow: hidden;

 transform: none;
 box-shadow: none;
 border-top: none;

 background: rgba(0,0,0,0.2);
 margin-left: 0;
padding-left: 0;

 transition: all 0.3s ease;
}
.main-nav ul li.submenu-open > .sub-menu {
 opacity: 1;
 visibility: visible;
 max-height: 500px;
}
 .main-nav ul li .sub-menu li a {

 color: rgba(255,255,255,0.75);

 padding: 7px 12px;

 display: flex;
 align-items: center;
 justify-content: center;

 text-align: center;

 width: 100%;
}
}
	
/* ============================================================
   RUNNING TEXT / TICKER
   ============================================================ */
.running-text-bar {
  background: var(--color-primary-100);
  border-top: 1px solid rgba(46,125,50,0.15);
  border-bottom: 1px solid rgba(46,125,50,0.15);
  padding: 10px 0;
  overflow: hidden;
}
.running-text-inner { display: flex; align-items: center; gap: 12px; }
.running-text-label {
  background: var(--color-primary-900); color: #fff; font-size: 11px; font-weight: 700;
  padding: 3px 10px; border-radius: 3px; white-space: nowrap; flex-shrink: 0;
}
.running-text-content { overflow: hidden; flex: 1; }
.running-text-scroll {
  display: flex; white-space: nowrap;
  animation: marquee 35s linear infinite;
  font-size: 13px; font-weight: 500; color: var(--color-primary-900);
}
.running-text-scroll span { margin-right: 80px; }
@keyframes marquee {
  0%   { transform: translateX(50vw); }
  100% { transform: translateX(-100%); }
}

/* ============================================================
   HERO BANNER
   ============================================================ */
.hero-banner {
  position: relative; overflow: hidden; height: 520px;
  background: #0d2b5e;
}
.hero-slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  display: none;
}
.hero-slide.active { display: block; animation: heroFade 0.6s ease-in-out; }
@keyframes heroFade { from { opacity:0; } to { opacity:1; } }
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(11,35,80,0.88) 0%, rgba(11,35,80,0.55) 55%, rgba(11,35,80,0.12) 100%);
}
.hero-content {
  position: absolute; top: 50%; left: 80px; right: 120px; transform: translateY(-50%); max-width: 620px;
}
.hero-content .container { padding: 0; }
.hero-badge {
  display: inline-block; background: var(--color-accent-gold); color: var(--color-neutral-900);
  font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: 2px;
  text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 14px;
}
.hero-title { font-size: 2.2rem; font-weight: 800; color: #fff; line-height: 1.25; margin-bottom: 12px; }
.hero-subtitle { font-size: 1rem; color: rgba(255,255,255,0.85); line-height: 1.65; margin-bottom: 28px; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.btn-gold {
  background: var(--color-accent-gold); color: var(--color-neutral-900);
  font-weight: 700; font-size: 14px; padding: 12px 28px; border-radius: 3px;
  border: none; cursor: pointer; transition: var(--transition); display: inline-block;
}
.btn-gold:hover { background: var(--color-accent-gold-dark); color: var(--color-neutral-900); }
.btn-outline-white {
  background: transparent; color: #fff; border: 2px solid rgba(255,255,255,0.85);
  font-weight: 600; font-size: 14px; padding: 11px 24px; border-radius: 3px; cursor: pointer;
  transition: var(--transition); display: inline-block;
}
.btn-outline-white:hover { background: rgba(255,255,255,0.15); color: #fff; }
.hero-indicators {
  position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 8px; align-items: center;
}
.hero-dot {
  height: 8px; width: 8px; border-radius: 99px; background: rgba(255,255,255,0.4);
  border: none; cursor: pointer; transition: all 0.2s ease; padding: 0;
}
.hero-dot.active { width: 26px; background: var(--color-accent-gold); }
.hero-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(0,0,0,0.3); border: none; color: #fff; cursor: pointer;
  width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  transition: var(--transition);
}
.hero-arrow:hover { background: rgba(0,0,0,0.55); }
.hero-arrow.prev { left: 16px; }
.hero-arrow.next { right: 16px; }
@media (max-width: 768px) {
	.hero-content {
    left: 10px;
    right: 5px;
    max-width: 100%;
  }
  .hero-banner { height: 500px; }
  .hero-title { font-size: 1.5rem; }
  .hero-content { max-width: 90%; }
}

/* ============================
   HERO SEARCH MODERN
   ============================ */

.hero-search {
  margin: 18px 0 22px;
  max-width: 520px;
}

.hero-search-box {
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 50px;
  overflow: hidden;
  backdrop-filter: blur(10px);
  transition: all 0.2s ease;
}

.hero-search-box:hover {
  background: rgba(255,255,255,0.18);
  border-color: rgba(255,255,255,0.4);
}

.hero-search-icon {
  padding: 0 12px;
  color: rgba(255,255,255,0.85);
  display: flex;
  align-items: center;
}

.hero-search input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: #fff;
  font-size: 14px;
  padding: 12px 8px;
}

.hero-search input::placeholder {
  color: rgba(255,255,255,0.65);
}

.hero-search button {
  background: var(--color-accent-gold);
  border: none;
  padding: 12px 18px;
  font-weight: 700;
  cursor: pointer;
  color: #12213A;
  transition: 0.2s ease;
}

.hero-search button:hover {
  background: var(--color-accent-gold-dark);
  color: #fff;
}

/* ============================================================
   STATS SECTION
   ============================================================ */
.stats-section {
  background: var(--color-primary-900);
  border-top: 4px solid var(--color-accent-gold);
}
.stats-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  divide-color: rgba(255,255,255,0.2);
}
.stat-item {
  text-align: center; padding: 28px 16px;
  border-right: 1px solid rgba(255,255,255,0.18);
}
.stat-item:last-child { border-right: none; }
.stat-icon { color: var(--color-accent-gold); opacity: 0.7; margin-bottom: 10px; }
.stat-icon svg { width: 32px; height: 32px; margin: 0 auto; }
.stat-number { font-size: 2.2rem; font-weight: 800; color: var(--color-accent-gold); line-height: 1; }
.stat-label { font-size: 15px; font-weight: 600; color: rgba(255,255,255,0.85); margin-top: 6px; }
@media (max-width: 768px) {

  .stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1px; 
    background: rgba(255,255,255,0.12); 
  }

  .stat-item {
    box-sizing: border-box;
    border: none; 
    background: var(--color-primary-900);
  }

}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section { padding: 56px 0; }
.section-alt { background: var(--color-neutral-100); }
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.section-title { font-size: 1.6rem; font-weight: 700; color: var(--color-neutral-900); padding-left: 14px; border-left: 4px solid var(--color-accent-gold); }
.section-title-center { text-align: center; font-size: 1.8rem; font-weight: 700; color: var(--color-neutral-900); margin-bottom: 8px; }
.section-subtitle-center { text-align: center; color: var(--color-neutral-500); max-width: 560px; margin: 0 auto 40px; font-size: 14px; line-height: 1.7; }
.section-badge {
  display: inline-block; background: var(--color-primary-100); color: var(--color-primary-900);
  font-size: 11px; font-weight: 700; padding: 4px 14px; border-radius: 2px;
  text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 10px;
}
.see-all { color: var(--color-primary-500); font-weight: 600; font-size: 14px; display: flex; align-items: center; gap: 4px; white-space: nowrap; }
.see-all:hover { color: var(--color-primary-900); }

/* ============================================================
   NEWS / BERITA
   ============================================================ */
.news-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 32px; }
.news-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.news-card {
  background: #fff; border: 1px solid rgba(0,0,0,0.08); border-radius: 5px;
  overflow: hidden; box-shadow: var(--shadow-card);
  transition: var(--transition); display: flex; flex-direction: column;
}
.news-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-3px); }
.news-card-image { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.news-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; }
.news-card:hover .news-card-image img { transform: scale(1.05); }
.news-cat-badge {
  position: absolute; top: 8px; left: 8px;
  background: var(--color-primary-500); color: #fff;
  font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 2px;
}
.news-card-body { padding: 14px; flex: 1; display: flex; flex-direction: column; }
.news-date { font-size: 12px; color: var(--color-neutral-500); margin-bottom: 6px; display: flex; align-items: center; gap: 4px; }
.news-title { font-size: 14px; font-weight: 700; color: var(--color-neutral-900); line-height: 1.45; margin-bottom: 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.news-title:hover { color: var(--color-primary-500); }
.news-excerpt { font-size: 13px; color: var(--color-neutral-500); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 12px; flex: 1; }
.news-readmore { font-size: 13px; font-weight: 600; color: var(--color-primary-500); display: flex; align-items: center; gap: 4px; margin-top: auto; }
.news-readmore:hover { color: var(--color-primary-900); }

/* Announcements */
.announcements-list { display: flex; flex-direction: column; gap: 8px; }
.announcement-item {
  background: #fff; border-left: 4px solid var(--color-accent-gold);
  border-radius: 0 4px 4px 0; padding: 12px 14px; box-shadow: var(--shadow-card);
  transition: var(--transition); display: block;
}
.announcement-item:hover { border-left-color: var(--color-primary-500); background: var(--color-primary-100); }
.announcement-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.ann-type-badge { font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: 2px; }
.ann-type-pengumuman { background: var(--color-primary-500); color: #fff; }
.ann-type-info { background: var(--color-navy); color: #fff; }
.ann-type-berita { background: var(--color-accent-gold); color: var(--color-neutral-900); }
.ann-date { font-size: 11px; color: var(--color-neutral-500); }
.announcement-title { font-size: 13px; font-weight: 600; color: var(--color-neutral-900); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.announcement-item:hover .announcement-title { color: var(--color-primary-900); }

@media (max-width: 1023px) {
  .news-grid { grid-template-columns: 1fr; }
  .news-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .news-cards { grid-template-columns: 1fr; }
}

/* ============================================================
   SERVICES SECTION
   ============================================================ */
.services-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.service-card {
  background: #fff; border: 1px solid rgba(0,0,0,0.08);
  border-top: 4px solid var(--color-primary-500); border-radius: 5px; padding: 24px;
  text-align: center; box-shadow: var(--shadow-card); transition: var(--transition);
  display: flex; flex-direction: column; align-items: center;
}
.service-card:hover { border-top-color: var(--color-accent-gold); box-shadow: 0 8px 24px rgba(46,125,50,0.15); transform: translateY(-4px); }
.service-icon {
  width: 60px; height: 60px; border-radius: 50%; background: var(--color-primary-100);
  display: flex; align-items: center; justify-content: center; margin-bottom: 16px;
  transition: var(--transition);
}
.service-card:hover .service-icon { background: var(--color-accent-gold); }
.service-icon svg { width: 26px; height: 26px; color: var(--color-primary-900); }
.service-card:hover .service-icon svg { color: var(--color-neutral-900); }
.service-title { font-size: 15px; font-weight: 700; color: var(--color-neutral-900); margin-bottom: 8px; }
.service-desc { font-size: 13px; color: var(--color-neutral-500); line-height: 1.6; margin-bottom: 14px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; flex: 1; }
.service-link { font-size: 13px; font-weight: 700; color: var(--color-primary-500); display: flex; align-items: center; gap: 4px; }
.service-link:hover { color: var(--color-primary-900); }
@media (max-width: 1023px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .services-grid { grid-template-columns: 1fr; } }

/* ============================================================
   INFO CATEGORIES
   ============================================================ */
.info-categories-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.info-cat-card {
  background: #fff; border-radius: 5px; overflow: hidden;
  box-shadow: var(--shadow-card); transition: var(--transition);
}
.info-cat-card:hover { box-shadow: var(--shadow-hover); transform: translateY(-3px); }
.info-cat-strip { height: 8px; }
.info-cat-strip.berkala { background: var(--color-primary-500); }
.info-cat-strip.serta-merta { background: var(--color-accent-gold); }
.info-cat-strip.setiap-saat { background: var(--color-navy); }
.info-cat-strip.dikecualikan { background: var(--color-danger); }
.info-cat-body { padding: 20px; }
.info-cat-icon { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.info-cat-icon.berkala { background: var(--color-primary-100); }
.info-cat-icon.serta-merta { background: #FFF9E6; }
.info-cat-icon.setiap-saat { background: #E8EAF6; }
.info-cat-icon.dikecualikan { background: #FFEBEE; }
.info-cat-icon svg { width: 20px; height: 20px; }
.info-cat-icon.berkala svg { color: var(--color-primary-500); }
.info-cat-icon.serta-merta svg { color: #B8860B; }
.info-cat-icon.setiap-saat svg { color: var(--color-navy); }
.info-cat-icon.dikecualikan svg { color: var(--color-danger); }
.info-cat-title { font-size: 15px; font-weight: 700; color: var(--color-neutral-900); margin-bottom: 4px; }
.info-cat-basis { font-size: 11px; color: var(--color-neutral-500); margin-bottom: 8px; }
.info-cat-desc { font-size: 13px; color: var(--color-neutral-500); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 14px; }
.info-cat-footer { display: flex; align-items: center; justify-content: space-between; }
.info-cat-count { font-size: 12px; font-weight: 700; padding: 3px 10px; border-radius: 2px; }
.info-cat-count.berkala { background: var(--color-primary-100); color: var(--color-primary-900); }
.info-cat-count.serta-merta { background: #FFF9E6; color: #B8860B; }
.info-cat-count.setiap-saat { background: #E8EAF6; color: var(--color-navy); }
.info-cat-count.dikecualikan { background: #FFEBEE; color: var(--color-danger); }
.info-cat-link { font-size: 12px; font-weight: 700; display: flex; align-items: center; gap: 3px; }
.info-cat-link.berkala { color: var(--color-primary-500); }
.info-cat-link.serta-merta { color: #B8860B; }
.info-cat-link.setiap-saat { color: var(--color-navy); }
.info-cat-link.dikecualikan { color: var(--color-danger); }
@media (max-width: 1023px) { .info-categories-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .info-categories-grid { grid-template-columns: 1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background: var(--color-primary-900); }
.footer-gold-bar { height: 6px; background: var(--color-accent-gold); }
.footer-main { padding: 48px 0 32px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1.5fr 1.5fr 2fr; gap: 32px; }
.footer-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.footer-logo { width: 44px; height: 44px; border-radius: 50%; background: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.footer-logo svg { width: 22px; height: 22px; }
.footer-org-name .org-ministry { color: var(--color-accent-gold); font-size: 11px; font-weight: 600; }
.footer-org-name .org-ppid { color: #fff; font-size: 14px; font-weight: 700; }
.footer-about-text { color: rgba(255,255,255,0.7); font-size: 13px; line-height: 1.7; margin-bottom: 16px; }
.footer-social { display: flex; gap: 8px; }
.footer-social a { width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.6); transition: var(--transition); }
.footer-social a:hover { background: rgba(255,255,255,0.2); color: var(--color-accent-gold); }
.footer-social svg { width: 15px; height: 15px; }
.footer-col-title { color: var(--color-accent-gold); font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.18); margin-bottom: 14px; }
.footer-links { display: flex; flex-direction: column; gap: 8px; }
.footer-links a { color: rgba(255,255,255,0.7); font-size: 13px; display: flex; align-items: center; gap: 5px; }
.footer-links a:hover { color: var(--color-accent-gold); padding-left: 4px; }
.footer-links a::before { content: "›"; color: var(--color-accent-gold); opacity: 0.6; font-size: 16px; }
.footer-contact { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.footer-contact-item { display: flex; align-items: flex-start; gap: 8px; }
.footer-contact-item svg { width: 15px; height: 15px; color: var(--color-accent-gold); flex-shrink: 0; margin-top: 2px; }
.footer-contact-item span { color: rgba(255,255,255,0.7); font-size: 13px; line-height: 1.5; }
.footer-hours { background: rgba(0,0,0,0.22); border-left: 3px solid var(--color-accent-gold); padding: 10px 14px; border-radius: 0 3px 3px 0; }
.footer-hours .hours-label { color: var(--color-accent-gold); font-size: 12px; font-weight: 700; display: flex; align-items: center; gap: 5px; margin-bottom: 4px; }
.footer-hours .hours-label svg { width: 13px; height: 13px; }
.footer-hours p { color: rgba(255,255,255,0.8); font-size: 12px; line-height: 1.5; }

}
.footer-bottom {
    background: rgba(0,0,0,0.28);
    border-top: 1px solid rgba(255,255,255,0.1);
    padding: 0;
    text-align: center;
}

.footer-bottom .container {
    display: block !important;
}

.footer-copyright {
	
    width: 100%;
    margin: 0 auto;
	 padding: 0px 0 10px 0;
    text-align: center !important;
    color: rgba(255,255,255,0.5);
    font-size: 12px;
}

@media (max-width: 1023px) {

  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }

}


/* ============================================================
   SINGLE POST / PAGE
   ============================================================ */
.content-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    padding: 48px 0;
}
.post-single { background: #fff; border-radius: 5px; overflow: hidden; box-shadow: var(--shadow-card); }
.post-header { padding: 28px 28px 0; }
.post-category-badge { display: inline-block; background: var(--color-primary-500); color: #fff; font-size: 12px; font-weight: 700; padding: 3px 10px; border-radius: 2px; margin-bottom: 12px; }
.post-title-h1 { font-size: 1.8rem; font-weight: 800; color: var(--color-neutral-900); line-height: 1.3; margin-bottom: 14px; }
.post-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; font-size: 13px; color: var(--color-neutral-500); padding-bottom: 20px; border-bottom: 1px solid rgba(0,0,0,0.08); }
.post-meta span { display: flex; align-items: center; gap: 4px; }
.post-thumbnail { width: 100%; aspect-ratio: 16/7; object-fit: cover; }
.post-content { padding: 28px; }
.post-content h2, .post-content h3, .post-content h4 { font-weight: 700; color: var(--color-neutral-900); margin: 24px 0 10px; }
.post-content h2 { font-size: 1.3rem; }
.post-content h3 { font-size: 1.1rem; }
.post-content p { color: var(--color-neutral-900); font-size: 15px; line-height: 1.75; margin-bottom: 16px; }
.post-content ul, .post-content ol { padding-left: 20px; margin-bottom: 16px; }
.post-content ul { list-style: disc; }
.post-content ol { list-style: decimal; }
.post-content li { font-size: 15px; line-height: 1.75; margin-bottom: 6px; color: var(--color-neutral-900); }
.post-content a { color: var(--color-primary-500); text-decoration: underline; }
.post-content blockquote { border-left: 4px solid var(--color-accent-gold); padding: 12px 20px; background: var(--color-neutral-100); margin: 20px 0; font-style: italic; }
.post-content img { border-radius: 4px; margin: 16px 0; }
.post-content table { width: 100%; border-collapse: collapse; margin: 20px 0; font-size: 14px; }
.post-content table th { background: var(--color-primary-900); color: #fff; padding: 10px 14px; text-align: left; }
.post-content table td { padding: 9px 14px; border: 1px solid rgba(0,0,0,0.1); }
.post-content table tr:nth-child(even) td { background: var(--color-neutral-100); }
.post-tags { display: flex; flex-wrap: wrap; gap: 8px; padding: 20px 28px; border-top: 1px solid rgba(0,0,0,0.08); }
.post-tags a { background: var(--color-neutral-100); color: var(--color-neutral-500); font-size: 12px; padding: 4px 10px; border-radius: 2px; }
.post-tags a:hover { background: var(--color-primary-100); color: var(--color-primary-900); }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb-bar { background: var(--color-neutral-100); border-bottom: 1px solid rgba(0,0,0,0.08); padding: 10px 0; }
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 13px; flex-wrap: wrap; }
.breadcrumb a { color: var(--color-primary-500); }
.breadcrumb a:hover { color: var(--color-primary-900); }
.breadcrumb-sep { color: var(--color-neutral-500); }
.breadcrumb-current { color: var(--color-neutral-500); }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination { display: flex; gap: 6px; justify-content: center; margin-top: 32px; flex-wrap: wrap; }
.pagination a, .pagination span {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 3px; font-size: 14px; font-weight: 600;
  border: 1px solid rgba(0,0,0,0.1); color: var(--color-neutral-900); transition: var(--transition);
}
.pagination a:hover, .pagination .current {
  background: var(--color-primary-500); color: #fff; border-color: var(--color-primary-500);
}

/* ============================================================
   ARCHIVE / BLOG
   ============================================================ */
.archive-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 1023px) { .archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .archive-grid { grid-template-columns: 1fr; } }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.contact-form label { display: block; font-size: 13px; font-weight: 600; color: var(--color-neutral-900); margin-bottom: 5px; }
.contact-form input, .contact-form select, .contact-form textarea {
  width: 100%; border: 1px solid rgba(0,0,0,0.15); border-radius: 3px;
  padding: 10px 14px; font-family: var(--font-base); font-size: 14px;
  color: var(--color-neutral-900); margin-bottom: 14px; outline: none;
  transition: border-color 0.15s ease;
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: var(--color-primary-500); box-shadow: 0 0 0 3px rgba(46,125,50,0.15); }
.contact-form textarea { resize: vertical; min-height: 120px; }
.btn-primary { background: var(--color-primary-500); color: #fff; border: none; padding: 12px 28px; font-size: 14px; font-weight: 700; border-radius: 3px; cursor: pointer; transition: var(--transition); font-family: var(--font-base); }
.btn-primary:hover { background: var(--color-primary-900); }
@media (max-width: 768px) { .contact-grid { grid-template-columns: 1fr; } }

/* ============================================================
   404 PAGE
   ============================================================ */
.error-404-wrap { text-align: center; padding: 80px 0; }
.error-404-code { font-size: 7rem; font-weight: 800; color: var(--color-primary-100); line-height: 1; }
.error-404-title { font-size: 1.8rem; font-weight: 700; color: var(--color-neutral-900); margin-bottom: 12px; }
.error-404-text { color: var(--color-neutral-500); margin-bottom: 28px; }

/* ============================================================
   UTILITIES
   ============================================================ */
.text-center { text-align: center; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.screen-reader-text { position: absolute; clip: rect(1px,1px,1px,1px); overflow: hidden; height: 1px; width: 1px; }

/* WordPress Core Classes */
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.alignleft { float: left; margin-right: 20px; margin-bottom: 10px; }
.alignright { float: right; margin-left: 20px; margin-bottom: 10px; }
.wp-caption { background: var(--color-neutral-100); border: 1px solid rgba(0,0,0,0.1); padding: 8px; border-radius: 3px; }
.wp-caption-text { font-size: 12px; color: var(--color-neutral-500); text-align: center; margin-top: 6px; }


/* ============================================================
   BACK TO TOP BUTTON
   ============================================================ */
.back-to-top {
  position: fixed;
  bottom: 25px;
  right: 25px;
  width: 48px;
  height: 48px;
  background: var(--color-accent-gold);
  color: var(--color-neutral-900);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all 0.25s ease;
  z-index: 9999;
}

.back-to-top.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--color-accent-gold-dark);
  transform: translateY(-3px);
}

/* ============================================================
   ELEMENTOR LIST FIX
   ============================================================ */

.elementor-widget-text-editor ul {
    list-style: disc !important;
    padding-left: 20px !important;
}

.elementor-widget-text-editor ol {
    list-style: decimal !important;
    padding-left: 20px !important;
}

/* judul halaman baru */
 .page-header{
    margin-bottom: 0px;
}

.page-title{
	padding-left:15px;
    display: flex;
    align-items: center;
    gap: 10px;
    
    font-size: 1.2rem;
    font-weight: 700;
    color: #1e2f56;

    margin: 0;
}

.page-title::before{
    content: "";
    width: 5px;
    height: 30px;
    background: #f5a623; /* warna emas */
    display: block;
}

@media (max-width:768px){

    .page-title{
        font-size:20px;
        gap:10px;
    }

    .page-title::before{
        height:30px;
    }

}



.info-cat-link{
    display:inline-flex;
    align-items:center;
    gap:5px;

    padding:6px 12px;

    border:1px solid currentColor;
    border-radius:4px;

    text-decoration:none;
    transition:.3s;
}

.info-cat-link:hover{
    transform:translateY(-2px);
}


/* ============================================================
   EXTERNAL NEWS
   ============================================================ */

.external-news-grid{

    display:grid;

    grid-template-columns:repeat(4,1fr);

    gap:20px;

}

.external-news-card{

    background:#fff;

    border-radius:6px;

    overflow:hidden;

    box-shadow:0 2px 10px rgba(0,0,0,.08);

    transition:.3s;

}

.external-news-card:hover{

    transform:translateY(-4px);

}

.external-news-thumb img{

    width:100%;

    height:220px;

    object-fit:cover;

}

.external-news-content{

    padding:16px;

}

.external-news-date{

    font-size:12px;

    color:#777;

    margin-bottom:8px;

}

.external-news-title{

    font-size:16px;

    line-height:1.5;

    margin-bottom:10px;

}

.external-news-title a{

    color:#12213A;

}

.external-news-title a:hover{

    color:var(--color-primary-500);

}

.external-news-excerpt{

    font-size:14px;

    color:#666;

    line-height:1.6;

}

/* TABLET */

@media (max-width:1023px){

    .external-news-grid{

        grid-template-columns:repeat(2,1fr);

    }

}

/* MOBILE */

@media (max-width:640px){

    .external-news-grid{

        grid-template-columns:1fr;

    }

}

.latest-news-page {
    padding-top: 10px;
}

.latest-news-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.section-header-modern {
    text-align: center;
    margin-bottom: 40px;
}

@media (max-width: 1023px) {
    .latest-news-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .latest-news-grid {
        grid-template-columns: 1fr;
    }
}

.latest-news-grid .news-card-body{
    display:flex;
    flex-direction:column;
}

.latest-news-grid .info-cat-link{
    margin-top:auto;
    width:fit-content;
}

/* GRID BERITA RESPONSIVE */

.external-news-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
}

/* CARD */

.external-news-card{
    display:flex;
    flex-direction:column;
    height:100%;
    background:#fff;
    border-radius:16px;
    overflow:hidden;
}

.external-news-content{
    display:flex;
    flex-direction:column;
    flex:1;
    padding:20px;
}

/* EXCERPT FLEX */

.external-news-excerpt{
    flex-grow:1;
}

/* TOMBOL DI BAWAH */

.external-news-content .info-cat-link{
    margin-top:20px;
    width:fit-content;
}

/* =========================
   TABLET
   ========================= */

@media (max-width:1024px){

    .external-news-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

/* =========================
   MOBILE
   ========================= */

@media (max-width:767px){

    .external-news-grid{
        grid-template-columns:1fr;
    }

}



.footer-links ul{
    list-style:none;
    padding:0;
    margin:0;
}

.footer-links li{
    margin-bottom:10px;
}

.footer-links a{
    color:#d6d6d6;
    text-decoration:none;
    transition:0.3s;
}

.footer-links a:hover{
    color:#fff;
    padding-left:4px;
}


/* =========================================================
   FORM PERMOHONAN PPID MODERN
========================================================= */

.ppid-form-wrapper{
    max-width:900px;
    margin:40px auto;
    background:#ffffff;
    border-radius:24px;
    padding:40px;
    box-shadow:0 10px 35px rgba(0,0,0,0.08);
    border:1px solid #e5e7eb;
}

/* Header */
.ppid-form-header{
    margin-bottom:35px;
    text-align:center;
}

.ppid-form-badge{
    display:inline-block;
    background:#d4af37;
    color:#fff;
    font-size:13px;
    font-weight:700;
    padding:8px 18px;
    border-radius:999px;
    margin-bottom:15px;
    letter-spacing:1px;
}

.ppid-form-title{
    font-size:34px;
    font-weight:800;
    color:#111827;
    margin-bottom:10px;
}

.ppid-form-subtitle{
    color:#6b7280;
    font-size:16px;
    line-height:1.7;
}

/* Grid */
.ppid-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
}

.ppid-full{
    grid-column:1 / -1;
}

/* Field */
.ppid-field{
    margin-bottom:24px;
}

.ppid-field label{
    display:block;
    margin-bottom:10px;
    font-weight:700;
    color:#111827;
    font-size:15px;
}

.ppid-required{
    color:#dc2626;
}

/* Input */
.ppid-field input,
.ppid-field textarea,
.ppid-field select{
    width:100%;
    border:1px solid #d1d5db;
    border-radius:14px;
    padding:14px 16px;
    font-size:15px;
    background:#fff;
    transition:all .3s ease;
    box-sizing:border-box;
}

.ppid-field textarea{
    min-height:140px;
    resize:vertical;
}

.ppid-field input:focus,
.ppid-field textarea:focus,
.ppid-field select:focus{
    border-color:#d4af37;
    outline:none;
    box-shadow:0 0 0 4px rgba(212,175,55,.15);
}

/* Upload */
.ppid-upload{
    border:2px dashed #d1d5db;
    border-radius:18px;
    padding:25px;
    text-align:center;
    transition:.3s;
    background:#fafafa;
}

.ppid-upload:hover{
    border-color:#d4af37;
    background:#fffdf7;
}

.ppid-upload input{
    border:none !important;
    box-shadow:none !important;
    padding:0;
}

/* Button */
.ppid-submit{
    width:100%;
    background:linear-gradient(
        135deg,
        #0f766e,
        #115e59
    );
    color:#fff;
    border:none;
    border-radius:16px;
    padding:18px;
    font-size:16px;
    font-weight:700;
    cursor:pointer;
    transition:.3s;
    box-shadow:0 10px 20px rgba(15,118,110,.25);
}

.ppid-submit:hover{
    transform:translateY(-2px);
    box-shadow:0 14px 28px rgba(15,118,110,.35);
}

/* Success Box */
.permohonan-success{
    background:#ecfdf5;
    border:1px solid #a7f3d0;
    border-radius:22px;
    padding:35px;
    margin-bottom:35px;
    text-align:center;
}

.permohonan-success h3{
    color:#065f46;
    margin-bottom:15px;
    font-size:28px;
}

.permohonan-success strong{
    display:inline-block;
    background:#fff;
    padding:14px 22px;
    border-radius:14px;
    margin-top:10px;
    font-size:18px;
    color:#111827;
    border:1px solid #d1fae5;
}

/* Action Buttons */
.ppid-download-pdf,
.ppid-wa-button{
    display:inline-block;
    padding:14px 24px;
    border-radius:14px;
    text-decoration:none;
    font-weight:700;
    margin:10px;
    transition:.3s;
}

.ppid-download-pdf{
    display:inline-block;
    background:linear-gradient(
        135deg,
        #0f766e,
        #115e59
    );
    color:#ffffff !important;
    text-decoration:none;
    padding:14px 24px;
    border-radius:14px;
    font-weight:700;
    transition:.3s;
    box-shadow:0 10px 20px rgba(15,118,110,.25);
}
}

.ppid-download-pdf:hover{
    color:#ffffff !important;
    transform:translateY(-2px);
    box-shadow:0 14px 28px rgba(15,118,110,.35);
}
}

.ppid-wa-button{
    background:#25D366;
    color:#fff;
}

.ppid-wa-button:hover{
    background:#1ebe5d;
    transform:translateY(-2px);
}

/* Print Button */
.ppid-print-btn{
    background:#111827;
    color:#fff;
    border:none;
    padding:14px 24px;
    border-radius:14px;
    font-weight:700;
    cursor:pointer;
    transition:.3s;
    margin-top:10px;
}

.ppid-print-btn:hover{
    background:#000;
}

/* Info Box */
.ppid-info-box{
    background:#fff8e7;
    border:1px solid #f5d98b;
    border-radius:18px;
    padding:20px;
    margin-bottom:30px;
    color:#7c5e10;
    line-height:1.7;
}

/* Mobile */
@media(max-width:768px){

    .ppid-form-wrapper{
        padding:25px;
        border-radius:18px;
    }

    .ppid-grid{
        grid-template-columns:1fr;
        gap:0;
    }

    .ppid-form-title{
        font-size:28px;
    }

}