body {
	background: linear-gradient(to right, #e9fef5, #eef6fc);
	padding-top: 72px; /* kira-kira setinggi navbar */
	margin: 0;
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen, Ubuntu, Cantarell, "Open Sans", "Inter", "Helvetica Neue",
		sans-serif;
	background-color: #f8f9fa; /* Warna latar sedikit abu-abu */
	color: #333;
	--primary-color: #4db6ac; /* Warna hijau toska */
}

p {
	font-family: "Open Sans", sans-serif;
}
.fade-in-video {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.8s ease-in-out;
}
.fade-in-video.visible {
  opacity: 1;
  transform: translateY(0);
}
.label-bold {
            font-weight: bold;
            color: #21897e;
            /* hijau tua senada, bisa diganti #21897e atau #388e3c sesuai template */
            letter-spacing: 0.5px;
            margin-bottom: 4px;
            font-size: 1.08rem;
            display: block;
        }
    .form-control, .form-select {
        background: #f8fafc;
        border: 1.5px solid #bdbdbd;
        color: #222;
        font-size: 1.04rem;
        margin-bottom: 8px;
    }
    .form-control:focus, .form-select:focus {
        border-color: #1976d2;
        background: #fff;
        box-shadow: 0 0 0 2px #bbdefb;
    }

	.upload-section-title {
        font-weight: bold;
        color: #21897e;
        background: #e0f7f1;
        border-left: 5px solid #21897e;
        padding: 10px 16px;
        border-radius: 6px;
        font-size: 1.13rem;
        margin-bottom: 12px;
        display: flex;
        align-items: center;
        letter-spacing: 0.2px;
        box-shadow: 0 1px 4px 0 #e0f2f1;
    }
    .upload-section-title .bi-upload {
        font-size: 1.3em;
        color: #21897e;
        margin-right: 8px;
    }

.hidden {
      display: none;
    }

    /* Highlight hasil pencarian */
    .highlight {
      background: yellow;
    }
.folder-structure {
      background: white;
      border-radius: 8px;
      padding: 15px;
      box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    }

	.folder::before {
      content: "📁 ";
    }

    .file::before {
      content: "📄 ";
    }

	ul {
      list-style: none;
      padding-left: 20px;
    }

    li {
      margin: 5px 0;
      cursor: pointer;
    }
/* ===== Cara Kerja Section ===== */

.cara-kerja-subtitle {
	text-align: center;
	color: #6c757d;
	font-size: 1.25rem;
	margin-bottom: 2.5rem;
}
.cara-kerja-steps .cara-kerja-step-circle {
	background: #4CAF50;
	color: #fff;
	width: 80px;
	height: 80px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	margin: 0 auto;
	font-size: 2.2rem;
	font-weight: 700;
	box-shadow: 0 4px 16px rgba(35,70,176,0.08);
}
.cara-kerja-progress {
	background: #fff;
}
.cara-kerja-progress-circle {
	background: #e3eafd;
	width: 60px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	margin: 0 auto;
	font-size: 1.7rem;
	color: #2346b0;
}
.cara-kerja-progress-circle-success {
	background: #0347f4;
	color: #fff;
}
.cara-kerja-progress-line {
	width: 60px;
	height: 2px;
	background: #e3eafd;
	align-self: center;
}
.tracking-container {
	max-width: 800px;
}

/* Styling untuk Header Utama */
.header-title {
	font-weight: 700;
	font-size: 2.5rem;
}
.header-subtitle {
	font-size: 1.1rem;
	color: #7f8c8d;
	max-width: 600px;
}

/* Styling untuk Kartu Input & Hasil */
.tracking-card,
.status-card {
	background-color: #ffffff;
	border-radius: 1rem;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
	padding: 2rem;
}

.card-title {
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	color: #34a8a2;
}
.card-subtitle {
	font-size: 0.9rem;
	color: #7f8c8d;
	margin-top: 0.5rem;
}

/* Styling Form */
#trackingForm label {
	font-weight: 600;
}
.form-control:focus {
	border-color: #34a8a2;
	box-shadow: 0 0 0 0.25rem rgba(52, 168, 162, 0.25);
}
.btn-track {
	background-color: #34a8a2;
	border-color: #34a8a2;
	font-weight: 600;
}
.btn-track:hover {
	background-color: #2c8e88;
	border-color: #2c8e88;
}

/* == Styling untuk Timeline Detail (Digabungkan) == */
.status-header h3 {
	font-weight: 700;
	font-size: 1.5rem;
	color: #2c3e50;
}
.status-header p {
	font-size: 1.1rem;
	color: #7f8c8d;
	margin-bottom: 2rem;
}
.timeline {
	list-style: none;
	padding-left: 1rem;
	position: relative;
}
.timeline::before {
	content: "";
	position: absolute;
	left: 1.25rem;
	top: 0.5rem;
	bottom: 0.5rem;
	width: 2px;
	background-color: #e9ecef;
}
.timeline-item {
	display: flex;
	gap: 1.5rem;
	position: relative;
}
.timeline-item:not(:last-child) {
	margin-bottom: 1rem;
}
.timeline-icon {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	flex-shrink: 0;
	background-color: #fff;
	z-index: 2;
}
.timeline-content .title {
	font-weight: 600;
	font-size: 1.1rem;
}
.timeline-content .date {
	font-size: 0.875rem;
	color: #7f8c8d;
	margin-bottom: 0.5rem;
}
.timeline-content .description {
	font-size: 0.95rem;
	color: #7f8c8d;
}
.timeline-item.is-done .timeline-icon {
	background-color: #198754;
	color: #ffffff;
}
.timeline-item.is-pending .timeline-icon {
	background-color: #f8f9fa;
	border: 2px solid #e9ecef;
	color: #6c757d;
}
/* CSS Tambahan untuk efek hover */
.layanan-link .layanan-card {
	/* Menambahkan transisi agar efek lebih halus */
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.layanan-link:hover .layanan-card {
	/* Efek kartu sedikit terangkat saat disentuh kursor */
	transform: translateY(-5px);
	/* Bayangan kartu menjadi lebih jelas */
	box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

/* CSS Tambahan untuk efek hover */
.layanan-link {
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	display: block; /* Pastikan link mengisi seluruh area kolom */
}
.layanan-link:hover {
	transform: translateY(-5px);
	box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.12);
}

/* Banner Utama */
.hero-banner {
	background-color: #38761d;
	color: #ffffff;
	text-align: center;
	padding: 60px 20px;
}

.hero-banner h2 {
	margin: 0 0 10px 0;
	font-size: 2.8rem;
	font-weight: bold;
}

.hero-banner p {
	margin: 0;
	font-size: 1.1rem;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

/* Konten Berita */
.news-content {
	padding: 40px 5%;
	background-color: #ffffff;
}

/* Filter dan Pencarian */
.search-filter-container {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
	margin-bottom: 40px;
}

.search-bar {
	position: relative;
	width: 100%;
	max-width: 600px;
}

.search-bar input {
	width: 100%;
	padding: 15px 20px 15px 50px;
	border: 1px solid #ccc;
	border-radius: 25px;
	font-size: 1rem;
}

.search-bar .fa-search {
	position: absolute;
	left: 20px;
	top: 50%;
	transform: translateY(-50%);
	color: #999;
}

.filter-tags {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	justify-content: center;
}

.filter-tags button {
	background-color: #ffffff;
	border: 1px solid #ccc;
	border-radius: 20px;
	padding: 8px 18px;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 8px;
	color: #555;
	font-weight: 500;
	transition: all 0.3s;
}

.filter-tags button:hover {
	background-color: #e9e9e9;
	border-color: #999;
}

.filter-tags button.active {
	background-color: #38761d;
	color: #ffffff;
	border-color: #38761d;
}

/* == BAGIAN KARTU BERITA YANG DIPERBARUI == */

.news-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 30px;
}

.news-card {
	background-color: #ffffff;
	border-radius: 12px;
	border: 1px solid #e5e7eb;
	overflow: hidden; /* Agar sudut border-radius terlihat */
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.3s, transform 0.3s;
}

.news-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 20px rgba(0, 0, 0, 0.08);
}

.card-image-placeholder {
	height: 200px;
	background-color: #f0f0f0;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #b0b0b0;
}

.card-image-placeholder .fa-image {
	font-size: 3rem;
}

.card-content {
	padding: 20px;
	display: flex;
	flex-direction: column;
	flex-grow: 1; /* Agar konten mengisi ruang kartu */
}

.card-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 0.85rem;
	color: #666;
	margin-bottom: 15px;
}

.card-date {
	display: flex;
	align-items: center;
	gap: 8px;
}

.card-tag {
	background-color: #fde68a; /* Warna kuning dari gambar */
	color: #92400e; /* Warna teks gelap agar kontras */
	padding: 4px 12px;
	border-radius: 12px;
	font-weight: 500;
}

.card-title {
	font-size: 1.25rem;
	font-weight: bold;
	margin: 0 0 10px 0;
	color: #1f2937;
}

.card-excerpt {
	font-size: 0.95rem;
	line-height: 1.6;
	color: #4b5563;
	margin: 0 0 20px 0;
	flex-grow: 1; /* Mendorong footer ke bawah */
}

.card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 0.9rem;
	color: #6b7280;
}

.read-more-link {
	text-decoration: none;
	color: #38761d;
	font-weight: bold;
	transition: color 0.3s;
}

.read-more-link:hover {
	color: #2b5a14;
}

/* Responsif */
@media (max-width: 768px) {
	.header {
		flex-direction: column;
		gap: 15px;
	}
	.nav-links {
		flex-wrap: wrap;
		justify-content: center;
		gap: 15px;
	}
	.hero-banner h2 {
		font-size: 2rem;
	}
	.hero-banner p {
		font-size: 1rem;
	}
}

/* Tata Letak Utama (Dua Kolom) */
.page-container {
	display: grid;
	grid-template-columns: 1fr; /* Default 1 kolom untuk mobile */
	gap: 40px;
	padding: 40px 5%;
	max-width: 1200px;
	margin: auto;
}

/* Aturan untuk layar lebih besar (desktop) */
@media (min-width: 992px) {
	.page-container {
		grid-template-columns: 2.5fr 1fr; /* Kolom artikel lebih besar dari sidebar */
	}
}

/* Kolom Artikel (Kiri) */
.article-column {
	background-color: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 30px;
}

.article-image-placeholder {
	height: 350px;
	background-color: #f0f0f0;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #b0b0b0;
	border-radius: 8px;
	margin-bottom: 25px;
}
.article-image-placeholder .fa-image {
	font-size: 4rem;
}

.article-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 20px;
	font-size: 0.9rem;
	color: #666;
	margin-bottom: 15px;
}

.article-meta span {
	display: flex;
	align-items: center;
	gap: 8px;
}

.article-meta .tag {
	background-color: #fde68a;
	color: #92400e;
	padding: 4px 12px;
	border-radius: 12px;
	font-weight: 500;
}

.article-title {
	font-size: 2.2rem;
	font-weight: bold;
	color: #1f2937;
	margin: 0 0 20px 0;
	line-height: 1.3;
}

.share-button {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background-color: #f3f4f6;
	border: 1px solid #d1d5db;
	color: #38761d;
	font-weight: 500;
	padding: 8px 16px;
	border-radius: 20px;
	cursor: pointer;
	transition: all 0.3s;
	margin-bottom: 30px;
}
.share-button:hover {
	background-color: #e5e7eb;
}

.article-content {
	font-size: 1.05rem;
	line-height: 1.8;
	color: #374151;
}
.article-content p {
	margin: 0 0 20px 0;
}
.article-content ul {
	padding-left: 25px;
}
.article-content li {
	margin-bottom: 10px;
}

/* Kolom Sidebar (Kanan) */
.sidebar-column .widget {
	background-color: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 25px;
	margin-bottom: 30px;
}

.widget-title {
	font-size: 1.3rem;
	font-weight: bold;
	color: #1f2937;
	margin: 0 0 20px 0;
	padding-bottom: 10px;
	border-bottom: 2px solid #38761d;
}

.widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.widget li {
	margin-bottom: 15px;
}
.widget li:last-child {
	margin-bottom: 0;
}

.widget a {
	text-decoration: none;
	color: #374151;
	font-weight: 500;
	transition: color 0.3s;
	display: flex;
	gap: 10px;
	align-items: flex-start;
}
.widget a:hover {
	color: #38761d;
}
.widget a .fa-angle-right {
	margin-top: 5px;
	color: #38761d;
}

.logo-stain {
	height: 36px; /* Sesuaikan tinggi logo */
	width: auto;
	object-fit: contain;
	display: block;
}

.btn-gradient {
	background: linear-gradient(to right, #72c07b, #2b7a3a);
	color: white;
	padding: 6px 18px;
	font-weight: 600;
	border-radius: 10px;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
	transition: transform 0.2s ease;
}

.btn-gradient:hover {
	background: linear-gradient(to right, #2b7a3a, #72c07b);
	transform: scale(1.05);
}


.navbar-glass {
	background: rgba(255, 255, 255, 0.3); /* transparan */
	backdrop-filter: blur(12px); /* efek blur kaca */
	-webkit-backdrop-filter: blur(12px); /* dukungan Safari */
	box-shadow: none;
	border-bottom: none;
}

.navbar-nav .nav-link {
	font-weight: 600;
	font-size: 16px;
	padding: 8px 16px;
	color: #333;
	transition: 0.3s;
}

.navbar-nav .nav-item {
	margin-right: 1.5rem; /* atau 2rem sesuai kebutuhan */
}

.navbar-nav .nav-item:last-child {
	margin-right: 0;
}

.navbar-nav .nav-link:hover {
	color: #1b8a3c;
	text-decoration: underline;
}
.navbar-nav .nav-link.active {
	color: #1b8a3c; /* hijau STAIN */
}

/* Hover effect untuk dropdown navbar */
.navbar .dropdown:hover .dropdown-menu {
	display: block;
	margin-top: 0; /* hilangkan delay muncul */
}

.navbar .dropdown-toggle::after {
	transition: transform 0.3s ease;
}

/* Optional: animasi panah turun */
.navbar .dropdown:hover .dropdown-toggle::after {
	transform: rotate(180deg);
}

.error-img {
	max-width: 300px;
	height: auto;
	display: block;
	margin: 0 auto;
}

.dropdown-menu {
	border-radius: 8px;
	border: 1px solid #e0e0e0;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
}

.dropdown-item {
	font-weight: 500;
	color: #2b7a3a;
	transition: background 0.2s, color 0.2s;
}

.dropdown-item:hover {
	background-color: #e9fef5;
	color: #1b8a3c;
}

.hero-text-gradient {
	animation: fadeInLeft 1s ease-in-out;
}

@keyframes fadeInLeft {
	from {
		opacity: 0;
		transform: translateX(-50px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

.hero-text-gradient span:nth-child(2) {
	color: #3aafa9;
}

h1,
.hero-text-gradient {
	font-family: "Poppins", sans-serif;
}

.hero-text-gradient span:nth-child(3) {
	color: #2c7a7b;
}

.hero-img {
	max-width: 100%;
	height: auto;
	width: 80%; /* bisa ubah ke 70%-90% sesuai selera */
}

.form-container {
	max-width: 700px;
	margin: auto;
	padding: 30px;
	background: #fff;
	border-radius: 12px;
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
}
.form-title {
	font-weight: bold;
	color: #14532d;
}

.info-card-link {
	text-decoration: none;
	color: inherit;
	display: block;
	height: 100%;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.info-card-link:hover {
	transform: translateY(-5px);
	box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.1);
}
.info-card {
	background-color: #ffffff;
	border: 1px solid #e9ecef;
	border-radius: 0.75rem;
	padding: 1.5rem;
	text-align: left;
	height: 100%;
}
.info-card .icon {
	font-size: 2rem;
	color: #198754; /* Menggunakan warna text-success */
	margin-bottom: 1rem;
}
.info-card h5 {
	font-weight: 700;
}
.info-card p {
	font-size: 0.9rem;
	color: #6c757d;
}

.layanan-link {
	display: block;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	border-radius: 1rem; /* Tambahkan ini agar shadow mengikuti bentuk kartu */
}
.layanan-link:hover {
	transform: translateY(-5px);
	box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.1) !important;
}
.layanan-card {
	/* Warna latar hijau muda seperti pada gambar */
	background-color: #f3fbf9;
}

.layanan-section {
	background: #fff;
}

.layanan-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 20px rgba(0, 128, 0, 0.05);
}

.layanan-icon i {
	color: #2b7a3a;
}

.berita-section {
	background: linear-gradient(
		to right,
		#e9fef5,
		#eef6fc
	); /* sama dengan section hero */
}

.berita-card img {
	border-top-left-radius: 0.75rem;
	border-top-right-radius: 0.75rem;
	height: 200px;
	object-fit: cover;
}

.berita-card {
	border-radius: 0.75rem;
	transition: 0.3s ease;
}

.berita-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 20px rgba(0, 128, 0, 0.1);
}

.card-title {
	font-family: "Poppins", sans-serif;
}

.card-text {
	font-size: 0.95rem;
	line-height: 1.5;
}

.tentang-section {
	background-color: #ffffff; /* putih bersih */
}

.contact-card {
	background: linear-gradient(to right, #e9fef5, #eef6fc);
	border-radius: 1rem;
	font-size: 15px;
}

.contact-card h5 {
	font-family: "Poppins", sans-serif;
}

.contact-card strong {
	color: #2c7a7b;
}

.tentang-section {
	background-color: #fff;
}

.contact-box {
	border-radius: 1rem;
	background: linear-gradient(to right, #e9fef5, #eef6fc);
	box-shadow: 0 4px 8px rgba(0, 128, 0, 0.05);
}

.icon-circle {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	font-size: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.section-gradient {
	background: linear-gradient(to right, #e9fef5, #eef6fc);
}
/* #faq {
	background: linear-gradient(to right, #e9fef5, #eef6fc);
}

.accordion-button {
	font-weight: 600;
	color: #2c7a7b;
}

.accordion-button:not(.collapsed) {
	background-color: #fef3c7;
	color: #1b8a3c;
} */

.faq-section {
	background-color: #f3fbf9; /* Latar belakang hijau sangat muda */
}
.accordion-item {
	margin-bottom: 1rem;
	border: 1px solid #e9ecef;
	border-radius: 0.75rem !important; /* !important untuk menimpa gaya Bootstrap */
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
	overflow: hidden; /* Agar sudut tetap melengkung */
}
.accordion-button {
	font-weight: 600;
	color: #2c3e50;
}
.accordion-button:focus {
	box-shadow: none; /* Menghilangkan shadow biru saat diklik */
	border-color: rgba(0, 0, 0, 0.125);
}
/* Gaya untuk tombol saat pertanyaan terbuka */
.accordion-button:not(.collapsed) {
	color: #2c3e50;
	background-color: #fffbeb; /* Latar belakang kuning muda */
	box-shadow: none;
}
.accordion-body {
	background-color: #fffbeb; /* Latar belakang kuning muda untuk jawaban */
	padding: 1rem 1.25rem;
	font-size: 0.95rem;
}
/* Mengganti ikon panah default Bootstrap */
.accordion-button::after {
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	margin-left: auto;
	content: " "; /* Hapus konten default */
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23212529'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-size: 1.25rem;
	transition: transform 0.2s ease-in-out;
}
.accordion-button:not(.collapsed)::after {
	transform: rotate(-180deg);
}

/* =================================
   GAYA FOOTER KUSTOM
==================================== */

.footer-custom {
	background: #004225;
}

/* Mengubah warna heading di footer */
.footer-custom h5 {
	color: #fce599; /* Warna kuning pucat untuk judul */
}

/* Logo 'S' yang melingkar */
.logo-s {
	width: 50px;
	height: 50px;
	background-color: #fcc201; /* Warna kuning cerah */
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.8rem;
	font-weight: bold;
	color: #274e13; /* Warna hijau tua */
	flex-shrink: 0; /* Mencegah logo menyusut */
}

.small-text {
	font-size: 0.9em;
	color: #e6e6e6; /* Warna abu-abu terang */
}

/* Menghilangkan garis bawah pada link dan memberi efek hover */
.footer-custom a {
	text-decoration: none;
	transition: color 0.3s ease;
}

.footer-custom ul a:hover {
	color: #fcc201 !important; /* Warna kuning saat disentuh */
	text-decoration: underline;
}

/* Ikon Media Sosial */
.social-icon {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: #38761d; /* Warna hijau sedikit lebih terang */
	color: #ffffff;
	margin-right: 10px;
	font-size: 1.2rem;
	transition: background-color 0.3s ease;
}

.social-icon:hover {
	background-color: #4a942a; /* Warna lebih terang saat hover */
	color: #ffffff;
}

/* Ikon di bagian Hubungi Kami */
.footer-custom .bi {
	font-size: 1.2rem;
	color: #fce599; /* Warna ikon disamakan dengan judul */
}

/* Garis pemisah horizontal */
.footer-custom hr {
	border-color: #4a942a; /* Warna garis yang lembut */
}

.wa-float {
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 999;
	background-color: #25d366;
	padding: 10px;
	border-radius: 50%;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
	transition: transform 0.3s ease;
}

.wa-float:hover {
	transform: scale(1.1);
}

.wa-icon {
	width: 32px;
	height: 32px;
	display: block;
}

/* Header Section */
.download-header {
	background-color: #38761d;
	color: #ffffff;
	padding: 4rem 0;
	text-align: center;
}
.download-header h1 {
	font-weight: 700;
}
.search-bar {
	max-width: 500px;
	margin: 1.5rem auto 0 auto;
}
.search-bar .form-control {
	padding: 0.9rem 1.5rem;
	border-radius: 2rem;
	border: none;
}

/* Main Content & Sidebar */
.card {
	border: none;
	border-radius: 0.75rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.05);
	margin-bottom: 1.5rem;
}
.section-card .card-header {
	background: none;
	border-bottom: 1px solid #e9ecef;
	padding: 1.5rem;
	font-size: 1.25rem;
	font-weight: 600;
}

/* Download Item List */
.download-item {
	display: flex;
	align-items: center;
	padding: 1rem 1.5rem;
	border-bottom: 1px solid #e9ecef;
}
.download-item:last-child {
	border-bottom: none;
}
.download-item .icon {
	font-size: 1.5rem;
	color: #38761d;
	flex-shrink: 0;
}
.download-item .details {
	flex-grow: 1;
}
.download-item .title {
	font-weight: 600;
	color: #2c3e50;
}
.download-item .metadata {
	font-size: 0.8rem;
	color: #7f8c8d;
}
.download-item .metadata span:not(:last-child)::after {
	content: "•";
	margin: 0 0.5rem;
}
.btn-download {
	font-weight: 600;
	font-size: 0.9rem;
}

/* Sidebar Widgets */
.sidebar .card-header {
	padding: 1rem 1.25rem;
	font-weight: 600;
}
.popular-list .list-group-item {
	border: none;
	padding: 0.75rem 0.25rem;
	border-bottom: 1px solid #e9ecef;
}
.popular-list .list-group-item:last-child {
	border-bottom: none;
}
.stat-number {
	font-size: 2rem;
	font-weight: 700;
	color: #38761d;
}
.stat-label {
	font-size: 0.9rem;
	color: #7f8c8d;
}
.trending-badge {
	font-size: 0.7rem;
	font-weight: 600;
	padding: 0.2rem 0.6rem;
}

.survey-header {
	background-color: #38761d;
	color: #ffffff;
	padding: 3rem 0;
	text-align: center;
}
.survey-header h1 {
	font-weight: 700;
}
.progress-container {
	max-width: 400px;
	margin: 1.5rem auto 0 auto;
}
.progress {
	height: 0.75rem;
	border-radius: 0.75rem;
	background-color: rgba(255, 255, 255, 0.3);
}
.progress-bar {
	background-color: #ffffff;
}

.survey-container {
	max-width: 700px;
	margin-top: -2rem;
}
.survey-card {
	border: none;
	border-radius: 1rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
	margin-bottom: 1rem;
}
.survey-card-header {
	background-color: #ffffff;
	border-bottom: 1px solid #e9ecef;
	padding: 1rem 1.5rem;
	font-weight: 600;
}
.survey-question {
	font-size: 1.25rem;
	font-weight: 600;
}

.radio-option {
	display: flex;
	align-items: center;
	padding: 1rem;
	border: 1px solid e9ecef;
	border-radius: 0.75rem;
	margin-bottom: 0.75rem;
	cursor: pointer;
	transition: border-color 0.2s, box-shadow 0.2s;
}
.radio-option:hover {
	border-color: #38761d;
}
.radio-option input[type="radio"] {
	display: none;
}
.radio-custom {
	width: 1.5rem;
	height: 1.5rem;
	border: 2px solid #e9ecef;
	border-radius: 50%;
	margin-right: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: #e9ecef 0.2s;
}
.radio-option input[type="radio"]:checked + .radio-custom {
	border-color: #38761d;
}
.radio-option input[type="radio"]:checked + .radio-custom::after {
	content: "";
	width: 0.75rem;
	height: 0.75rem;
	background-color: #38761d;
	border-radius: 50%;
}
.radio-number {
	font-weight: 600;
	color: #7f8c8d;
	margin-right: 1rem;
}

.survey-card-footer {
	background-color: transparent;
	border-top: 1px solid #e9ecef;
}
.btn-prev {
	background-color: #f1f3f5;
	border-color: #f1f3f5;
	color: #2c3e50;
	font-weight: 600;
}
.btn-next {
	font-weight: 600;
}

.submission-section {
	padding: 2rem 0;
}
.section-title {
	position: relative;
	display: inline-block;
	font-weight: 700;
	color: #2c3e50;
	padding-bottom: 15px;
	font-size: 2.5rem;
}

/* SOLUSI 1: Menambahkan style untuk kartu informasi */
.info-card {
	background-color: #ffffff;
	padding: 1.5rem;
	border-radius: 0.75rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
	height: 100%;
}
.info-card h5 {
	font-weight: 600;
	margin-bottom: 1rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.info-list {
	padding-left: 0;
	list-style: none;
	margin-bottom: 0;
}
.info-list li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}
.info-list .icon-check {
	color: #20c997;
	margin-top: 0.2rem;
}

/* SOLUSI 2: Perbaikan struktur timeline */
.timeline-item {
	display: flex;
	gap: 1rem;
}
.timeline-item .time {
	font-weight: 600;
	white-space: nowrap; /* Mencegah waktu terpotong */
}

.page-header {
	padding: 1rem 0 3rem 0;
}
.page-header h1 {
	font-weight: 800;
	font-size: 2.5rem;
}
.page-header p {
	font-size: 1.1rem;
	color: #7f8c8d;
	max-width: 600px;
	margin: 1rem auto 0 auto;
}
.section-title {
	font-weight: 600;
	font-size: 1.5rem;
	margin-bottom: 1.5rem;
}
.service-card {
	background-color: #ffffff;
	border: 1px solid #e9ecef;
	border-radius: 0.75rem;
	padding: 1.5rem;
	margin-bottom: 1.5rem;
}
/* SOLUSI 2: Menambahkan kartu untuk informasi penting */
.info-wrapper {
	background-color: #ffffff;
	border-radius: 0.75rem;
	padding: 1.5rem;
	border: 1px solid #e9ecef;
}
.content-container {
	max-width: 800px;
}

.custom-card {
	background-color: #ffffff;
	border: 1px solid #e9ecef;
	border-radius: 1rem;
	padding: 2rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.05);
}

.card-title {
	font-weight: 600;
	font-size: 1.25rem;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.card-subtitle {
	font-size: 0.95rem;
	color: #7f8c8d;
}

.note-list {
	padding-left: 1.25rem; /* Indentasi untuk list */
}

.note-list li {
	margin-bottom: 0.5rem;
}

.btn-track {
	font-weight: 600;
}
.btn-custom {
	background-color: #5ba89d;
	color: white;
	padding: 12px 20px;
	border: none;
	border-radius: 8px;
	font-weight: 600;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	transition: background-color 0.3s;
}

.btn-custom:hover {
	background-color: #4a938a; /* Warna sedikit lebih gelap saat disentuh cursor */
}

/* =================================
   GAYA FOOTER KUSTOM
==================================== */

.footer-custom {
	background: #004225;
}

/* Mengubah warna heading di footer */
.footer-custom h5 {
	color: #fce599; /* Warna kuning pucat untuk judul */
}

/* Logo 'S' yang melingkar */
.logo-s {
	width: 50px;
	height: 50px;
	background-color: #fcc201; /* Warna kuning cerah */
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.8rem;
	font-weight: bold;
	color: #274e13; /* Warna hijau tua */
	flex-shrink: 0; /* Mencegah logo menyusut */
}

.small-text {
	font-size: 0.9em;
	color: #e6e6e6; /* Warna abu-abu terang */
}

/* Menghilangkan garis bawah pada link dan memberi efek hover */
.footer-custom a {
	text-decoration: none;
	transition: color 0.3s ease;
}

.footer-custom ul a:hover {
	color: #fcc201 !important; /* Warna kuning saat disentuh */
	text-decoration: underline;
}

/* Ikon Media Sosial */
.social-icon {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: #38761d; /* Warna hijau sedikit lebih terang */
	color: #ffffff;
	margin-right: 10px;
	font-size: 1.2rem;
	transition: background-color 0.3s ease;
}

.social-icon:hover {
	background-color: #4a942a; /* Warna lebih terang saat hover */
	color: #ffffff;
}

/* Ikon di bagian Hubungi Kami */
.footer-custom .bi {
	font-size: 1.2rem;
	color: #fce599; /* Warna ikon disamakan dengan judul */
}

/* Garis pemisah horizontal */
.footer-custom hr {
	border-color: #4a942a; /* Warna garis yang lembut */
}

.wa-float {
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 999;
	background-color: #25d366;
	padding: 10px;
	border-radius: 50%;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
	transition: transform 0.3s ease;
}

.wa-float:hover {
	transform: scale(1.1);
}

.wa-icon {
	width: 32px;
	height: 32px;
	display: block;
}

/* Header Section */
.download-header {
	background-color: #38761d;
	color: #ffffff;
	padding: 4rem 0;
	text-align: center;
}
.download-header h1 {
	font-weight: 700;
}
.search-bar {
	max-width: 500px;
	margin: 1.5rem auto 0 auto;
}
.search-bar .form-control {
	padding: 0.9rem 1.5rem;
	border-radius: 2rem;
	border: none;
}

/* Main Content & Sidebar */
.card {
	border: none;
	border-radius: 0.75rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.05);
	margin-bottom: 1.5rem;
}
.section-card .card-header {
	background: none;
	border-bottom: 1px solid #e9ecef;
	padding: 1.5rem;
	font-size: 1.25rem;
	font-weight: 600;
}

/* Download Item List */
.download-item {
	display: flex;
	align-items: center;
	padding: 1rem 1.5rem;
	border-bottom: 1px solid #e9ecef;
}
.download-item:last-child {
	border-bottom: none;
}
.download-item .icon {
	font-size: 1.5rem;
	color: #38761d;
	flex-shrink: 0;
}
.download-item .details {
	flex-grow: 1;
}
.download-item .title {
	font-weight: 600;
	color: #2c3e50;
}
.download-item .metadata {
	font-size: 0.8rem;
	color: #7f8c8d;
}
.download-item .metadata span:not(:last-child)::after {
	content: "•";
	margin: 0 0.5rem;
}
.btn-download {
	font-weight: 600;
	font-size: 0.9rem;
}

/* Sidebar Widgets */
.sidebar .card-header {
	padding: 1rem 1.25rem;
	font-weight: 600;
}
.popular-list .list-group-item {
	border: none;
	padding: 0.75rem 0.25rem;
	border-bottom: 1px solid #e9ecef;
}
.popular-list .list-group-item:last-child {
	border-bottom: none;
}
.stat-number {
	font-size: 2rem;
	font-weight: 700;
	color: #38761d;
}
.stat-label {
	font-size: 0.9rem;
	color: #7f8c8d;
}
.trending-badge {
	font-size: 0.7rem;
	font-weight: 600;
	padding: 0.2rem 0.6rem;
}

.survey-header {
	background-color: #38761d;
	color: #ffffff;
	padding: 3rem 0;
	text-align: center;
}
.survey-header h1 {
	font-weight: 700;
}
.progress-container {
	max-width: 400px;
	margin: 1.5rem auto 0 auto;
}
.progress {
	height: 0.75rem;
	border-radius: 0.75rem;
	background-color: rgba(255, 255, 255, 0.3);
}
.progress-bar {
	background-color: #ffffff;
}

.survey-container {
	max-width: 700px;
	margin-top: -2rem;
}
.survey-card {
	border: none;
	border-radius: 1rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
	margin-bottom: 1rem;
}
.survey-card-header {
	background-color: #ffffff;
	border-bottom: 1px solid #e9ecef;
	padding: 1rem 1.5rem;
	font-weight: 600;
}
.survey-question {
	font-size: 1.25rem;
	font-weight: 600;
}

.radio-option {
	display: flex;
	align-items: center;
	padding: 1rem;
	border: 1px solid e9ecef;
	border-radius: 0.75rem;
	margin-bottom: 0.75rem;
	cursor: pointer;
	transition: border-color 0.2s, box-shadow 0.2s;
}
.radio-option:hover {
	border-color: #38761d;
}
.radio-option input[type="radio"] {
	display: none;
}
.radio-custom {
	width: 1.5rem;
	height: 1.5rem;
	border: 2px solid #e9ecef;
	border-radius: 50%;
	margin-right: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: #e9ecef 0.2s;
}
.radio-option input[type="radio"]:checked + .radio-custom {
	border-color: #38761d;
}
.radio-option input[type="radio"]:checked + .radio-custom::after {
	content: "";
	width: 0.75rem;
	height: 0.75rem;
	background-color: #38761d;
	border-radius: 50%;
}
.radio-number {
	font-weight: 600;
	color: #7f8c8d;
	margin-right: 1rem;
}

.survey-card-footer {
	background-color: transparent;
	border-top: 1px solid #e9ecef;
}
.btn-prev {
	background-color: #f1f3f5;
	border-color: #f1f3f5;
	color: #2c3e50;
	font-weight: 600;
}
.btn-next {
	font-weight: 600;
}

.submission-section {
	padding: 2rem 0;
}
.section-title {
	position: relative;
	display: inline-block;
	font-weight: 700;
	color: #2c3e50;
	padding-bottom: 15px;
	font-size: 2.5rem;
}

/* SOLUSI 1: Menambahkan style untuk kartu informasi */
.info-card {
	background-color: #ffffff;
	padding: 1.5rem;
	border-radius: 0.75rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
	height: 100%;
}
.info-card h5 {
	font-weight: 600;
	margin-bottom: 1rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.info-list {
	padding-left: 0;
	list-style: none;
	margin-bottom: 0;
}
.info-list li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}
.info-list .icon-check {
	color: #20c997;
	margin-top: 0.2rem;
}

/* SOLUSI 2: Perbaikan struktur timeline */
.timeline-item {
	display: flex;
	gap: 1rem;
}
.timeline-item .time {
	font-weight: 600;
	white-space: nowrap; /* Mencegah waktu terpotong */
}

.page-header {
	padding: 1rem 0 3rem 0;
}
.page-header h1 {
	font-weight: 800;
	font-size: 2.5rem;
}
.page-header p {
	font-size: 1.1rem;
	color: #7f8c8d;
	max-width: 600px;
	margin: 1rem auto 0 auto;
}
.section-title {
	font-weight: 600;
	font-size: 1.5rem;
	margin-bottom: 1.5rem;
}
.service-card {
	background-color: #ffffff;
	border: 1px solid #e9ecef;
	border-radius: 0.75rem;
	padding: 1.5rem;
	margin-bottom: 1.5rem;
}
/* SOLUSI 2: Menambahkan kartu untuk informasi penting */
.info-wrapper {
	background-color: #ffffff;
	border-radius: 0.75rem;
	padding: 1.5rem;
	border: 1px solid #e9ecef;
}
.content-container {
	max-width: 800px;
}

.custom-card {
	background-color: #ffffff;
	border: 1px solid #e9ecef;
	border-radius: 1rem;
	padding: 2rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.05);
}

.card-title {
	font-weight: 600;
	font-size: 1.25rem;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.card-subtitle {
	font-size: 0.95rem;
	color: #7f8c8d;
}

.note-list {
	padding-left: 1.25rem; /* Indentasi untuk list */
}

.note-list li {
	margin-bottom: 0.5rem;
}

.btn-track {
	font-weight: 600;
}
.btn-custom {
	background-color: #5ba89d;
	color: white;
	padding: 12px 20px;
	border: none;
	border-radius: 8px;
	font-weight: 600;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	transition: background-color 0.3s;
}

.btn-custom:hover {
	background-color: #4a938a; /* Warna sedikit lebih gelap saat disentuh cursor */
}

.btn-lupa-resi {
  background: #fff;
  border: 2px solid #388e3c;
  color: #388e3c;
  border-radius: 16px;
  padding: 4px 16px;
  font-size: 15px;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: background 0.2s;
  font-family: 'Poppins',sans-serif;
}
.btn-lupa-resi i {
  font-size: 1.1rem;
}
.btn-lupa-resi:hover, .btn-lupa-resi:focus {
  background: #ffe066;
  color: #388e3c;
}
