@font-face {
	font-family: 'Lato-Regular'; /* Nama bebas yang akan dipanggil nanti */
	src: url('../fonts/Lato/Lato-Regular.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'CormorantGaramond-Medium';
	src: url('../fonts/CormorantGaramond/CormorantGaramond-Medium.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'CormorantGaramond-MediumItalic';
	src: url('../fonts/CormorantGaramond/CormorantGaramond-MediumItalic.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

body {
	color: #fff;
	background-color: #333;
	min-height: 100vh;
	overflow-x: hidden;
}


/* --- Logo Menu Pojok Kiri Atas (Floating) --- */
		.top-left-logo {
			position: absolute;
			top: 15px;
			left: 30px;
			width: 150px;
			z-index: 1050; /* Di atas navbar */
		}
		@media (max-width: 768px) {
			.top-left-logo {
				position: relative;
				left: 0px;
				margin: 0px auto;
				display: block;
				width: 120px;
				margin-bottom: -40px;
			}
		}
/* --- Logo Menu Pojok Kiri Atas (Floating) --- */

/* Menu Navigasi */
		.navbar-nav .nav-link {
			color: #000 !important;
			background-color: #bfa55d; /* Warna emas kusam */
			margin: 5px;
			padding: 5px 20px !important;
			border-radius: 5px;
			font-family: 'Lato-Regular', sans-serif;
			font-weight: 400;
			font-size: 0.9rem;
			transition: all 0.3s ease;
			border: 1px solid transparent;
		}
		.navbar-nav .nav-link:hover {
			background-color: #e2cc8a; /* Warna emas lebih terang saat hover */
			color: #000 !important;
			transform: translateY(-3px); /* Efek melayang ke atas */
			box-shadow: 0 4px 15px rgba(191, 165, 93, 0.4); /* Efek bayangan bercahaya */
			border: 1px solid #fff; /* Garis tepi putih tipis */
		}
		.navbar-nav .nav-link:active {
			transform: translateY(0);
			background-color: #a38b45;
		}
		.navbar .container {
			display: flex;
			justify-content: flex-end; /* Posisi (navbar-toggler) ke kanan */
		}
/* Menu Navigasi */


/* Content Styling */
		.pt-50 {
			padding-top: 50px;
		}
		.pd-50 {
			padding-bottom: 40px;
		}
        .text-overlapping {
			white-space: nowrap;
			overflow:visible;
        }
		
		@media (max-width: 768px) {
			.text-overlapping {
				white-space:unset;
				overflow:unset;
			}
		}
/* Content Styling */


/* --- BERANDA --- */
		.beranda-coverbox {
			/*background: linear-gradient(to right, rgba(0,0,0,0.9) 30%, rgba(0,0,0,0.1) 100%);*/
			background: rgba(0, 0, 0, 0.8);
			box-shadow: 0 4px 15px rgba(191, 165, 93, 0.4); 
			border-radius: 15px;
			padding:15px;
			/*	backdrop-filter: blur(5px);*/
		}
		.beranda-title {
			font-family: 'CormorantGaramond-MediumItalic', serif;
			font-weight: bold;
			font-size: 3rem;
			color: #fff;
			margin-top: 50px;
		}
		.beranda-subtitle {
			font-family: 'Lato-Regular', sans-serif;
			font-weight: 400;
			font-size: 2rem;
			margin-bottom: 20px;
		}
		.beranda-description {
			font-family: 'Lato-Regular', sans-serif;
			font-weight: 300;
			line-height: 1.6;
			font-size: 1rem;
			text-align: justify;
		}
		/* Icon Grid */
			.feature-card {
				background-color: #d1d1d1;
				border-radius: 10px;
				padding: 20px;
				text-align: center;
				color: #000;
				height: 100%;
				transition: transform 0.3s;
				cursor: pointer;
			}
			.feature-card:hover {
				transform: translateY(-5px);
				background-color: #fff;
			}
			.feature-card i {
				font-size: 3rem;
				display: block;
				margin-bottom: 10px;
			}
			.feature-card p {
				margin: 0;
				font-weight: bold;
				font-size: 0.9rem;
			}
		/* Icon Grid */
		@media (max-width: 768px) {
			.beranda-title {
				font-size: 5vw;
				margin-top: -50px;
			}
			.beranda-subtitle {
				font-size: 4vw;
			}
		}
/* --- BERANDA --- */


/* --- TENTANG KAMI --- */
		.tentang-kami-title {
			font-family: 'CormorantGaramond-Medium', serif;
			font-size: 3rem;
			color: #fff;
			margin-top: -10px;
			margin-left: 120px;
		}
		.tentang-kami-description {
			font-family: 'Lato-Regular', sans-serif;
			font-weight: 300;
			line-height: 1.6;
			font-size: 1rem;
			text-align: justify;
		}
		@media (max-width: 768px) {
			.tentang-kami-title {
				margin-top: -60px;
			}
		}
/* --- TENTANG KAMI --- */

/* --- PORTFOLIO  --- */
		.portfolio-title {
			font-family: 'CormorantGaramond-Medium', serif;
			font-size: 3rem;
			color: #fff;
			text-align: center;
			margin-top: -10px;
		}
		@media (max-width: 768px) {
			.portfolio-title {
				margin-top: -60px;
				margin-bottom: -10px;
			}
		}
		/* Portfolio Carousel / Slider Cards */
			 .portfolio-slider-wrapper {
				position: relative;
				width: 100%;
				padding: 0px;
			}
			.portfolio-container {
				display: flex;
				gap: 20px;
				overflow-x: auto;
				padding: 20px 40px;
				scroll-behavior: smooth;
				-ms-overflow-style: none; /* Hide scrollbar IE/Edge */
				scrollbar-width: none; /* Hide scrollbar Firefox */
			}
			.portfolio-container::-webkit-scrollbar { display: none; } /* Hide scrollbar Chrome */
			.portfolio-card {
				min-width: 250px;
				min-height: 350px;
				background-color: #fff;
				color: #333;
				padding: 30px 20px;
				text-align: center;
				border-radius: 4px;
				display: flex;
				flex-direction: column;
				justify-content: center;
			}
			.portfolio-card:hover {
				background-color: #edd89e;
				transform: translateY(-15px) scale(1.03); /* Naik ke atas dan sedikit membesar */
				box-shadow: 0 20px 40px rgba(0,0,0,0.5); /* Shadow lebih dramatis */
				z-index: 2; /* Pastikan kartu yang di-hover berada di atas yang lain */
			}
			.portfolio-card h3 {
				font-family: 'Playfair Display', serif;
				font-size: 1.4rem;
				margin-bottom: 20px;
				color: #bfa55d;
			}
			.portfolio-card:hover h3 {
				color: #af803a;
			}
			.portfolio-card p {
				font-size: 0.9rem;
				margin-bottom: 25px;
				line-height: 1.5;
			}
			.portfolio-card .result {
				font-weight: bold;
				font-size: 0.95rem;
			}
			.portfolio-link {
				text-decoration: none !important; /* Menghilangkan garis bawah link */
				display: block;
				color: inherit; /* Mengikuti warna teks card */
			}
		/* Portfolio Carousel / Slider Cards */
		/* Portfolio Floating Navigation */
			.portfolio-float-nav {
				position: absolute;
				top: 50%;
				transform: translateY(-50%);
				width: 60px;
				height: 60px;
				background: rgba(0, 0, 0, 0.2);
				backdrop-filter: blur(5px);
				border: 1px solid rgba(255,255,255,0.3);
				border-radius: 50%;
				display: flex;
				align-items: center;
				justify-content: center;
				cursor: pointer;
				z-index: 100;
				transition: all 0.3s ease;
				color: white;
				font-size: 1.5rem;
			}
		.portfolio-float-nav:hover {
			background: #bfa55d;
			border-color: #bfa55d;
			transform: translateY(-50%) scale(1.1);
		}
		.portfolio-prev-btn { left: 10px; }
		.portfolio-next-btn { right: 10px; }
		@media (max-width: 768px) {
			.portfolio-float-nav { width: 45px; height: 45px; font-size: 1.2rem; }
		}
		/* Portfolio Floating Navigation */
		/* Portfolio Bottom Navigation */
		.nav-controls {
			display: flex;
			justify-content: center;
			gap: 20px;
			margin-top: 0px;
			padding-bottom: 50px;
		}
		.portfolio-btn-nav {
			background: linear-gradient(to right, #ccc, #eee);
			border: none;
			width: 150px;
			height: 40px;
			border-radius: 20px;
			display: flex;
			align-items: center;
			justify-content: center;
			cursor: pointer;
			transition: 0.3s;
		}
		.portfolio-btn-nav:hover { background: #bfa55d; opacity: 0.8; }
		/* Portfolio Bottom Navigation */
/* --- PORTFOLIO  --- */


/* --- VISI MISI CARDS --- */
		.visimisi-title {
			font-family: 'CormorantGaramond-Medium', serif;
			font-size: 3rem;
			color: #fff;
			text-align: center;
			margin-top: -40px;
		}
		@media (max-width: 768px) {
			.visimisi-title {
				margin-top: -60px;
				margin-bottom: 10px;
			}
		}
		.visi-description {
			font-family: 'Lato-Regular', sans-serif;
			font-size: 1rem;
			line-height: 1.6;
			text-align: justify;
		}
		.misi-description {
			font-family: 'Lato-Regular', sans-serif;
			padding-left: 10px;
			font-size: 0.90rem;
			line-height: 1.5;
			text-align: justify;
		}
		.misi-description li {
			margin-bottom: 12px;
		}
		 /* Card Styling */
		.content-card {
			background-color: #999; 
			color: #000;
			border-radius: 15px;
			padding: 30px;
			/* Membuat tinggi selalu sama dan konten di tengah */
			display: flex;
			flex-direction: column;
			justify-content: top; /* Vertical Center */
			min-height: 450px; /* Atur tinggi minimal agar seragam */
			height: 100%;
			box-shadow: 0 10px 30px rgba(0,0,0,0.5);
			margin-bottom:50px;
		}
		.content-card:hover {
			transform: translateY(-10px) scale(1.02); /* Mengangkat dan memperbesar sedikit */
			box-shadow: 0 20px 40px rgba(0,0,0,0.6);
		}
		.logo-center {
			width: 100%;
			max-width: 600px; /* Ukuran maksimal diperbesar dari sebelumnya */
			height: auto;
			filter: drop-shadow(0 0 30px rgba(0,0,0,0.4));
			transition: transform 0.5s ease;
		}
		@media (max-width: 768px) {
			.logo-center {
				width: 100%;
				max-width: 200px; /* Ukuran maksimal diperbesar dari sebelumnya */
				margin-top: -50px;
				margin-bottom: 50px;
			}
			.content-card {
				min-height: auto;
			}
		}
/* --- VISI MISI CARDS --- */


/* --- LAYANAN KAMI --- */
		/* Panel Kiri */
			.left-panel {
				display: flex;
				flex-direction: column;
				align-items: center;
				justify-content: center;
			}
			.curved-text-container {
				position: relative;
				width: 100%;
				max-width: 450px; /* Ukuran container diperketat */
				display: flex;
				justify-content: center;
				align-items: center;
				padding-top: 50px;
			}
			.curved-text-svg {
				width: 130%; /* Sedikit lebih besar dari logo agar membungkus */
				height: auto;
				overflow: visible;
				position: absolute;
				top: -50px; /* Menyesuaikan posisi atas logo */
				z-index: 2;
			}
			.curved-text-style {
				font-family: 'CormorantGaramond-Medium', serif;
				font-size: 3rem;
				fill: white;
				font-weight: bold;
				text-transform: capitalize;
			}
			.main-logo-large {
				width: 80%;
				height: auto;
				position: relative;
				z-index: 1;
				margin-top: -30px; /* Jarak agar tidak bertabrakan dengan teks */
			}
			@media (max-width: 768px) {
				.curved-text-svg { width: 100%; top: -50px; }
				.curved-text-style { font-size: 2.5rem; }
				.main-logo-large { margin-top: -60px; width: 65%; }
			}
		/* Panel Kiri */
		/* Panel Kanan */
		.right-panel {
			display: flex;
			flex-direction: column;
			align-items: center;
			justify-content: center;
		}
		.layanan-kami-title {
			font-family: 'CormorantGaramond-Medium', serif;
			font-size: 4rem;
			color: #fff;
			text-align: center;
			margin-top: -55px;
			margin-bottom: 15px;
		}
		.layanan-list-item {
			background-color: #bfa55d;
			color: #fff;
			font-family: 'Lato-Regular', sans-serif;
			padding: 12px 100px;
			margin-bottom: 15px;
			font-size: 1.2rem;
			font-weight: 500;
			text-align: center;
			border-radius: 4px;
			width: 100%;
			max-width: 500px;
			margin-left: auto;
		}
		.layanan-list-item:hover {
			background-color: #c6ad67;
			transform: translateY(-1px) scale(1.02); /* Mengangkat dan memperbesar sedikit */
			box-shadow: 0 20px 40px rgba(0,0,0,0.6);
		}
		@media (max-width: 768px) {
			.right-panel { padding: 60px 20px; }
			.layanan-kami-title { margin-top: -50px; margin-bottom: 10px; }
			.layanan-list-item { margin: 10px auto; font-size: 1rem; }
		}
		/* Panel Kanan */
/* --- LAYANAN KAMI --- */

/* --- LAYANAN 12345 --- */
		.left-section {
			padding: 0 20px; /* Menghilangkan padding top berlebih agar sejajar atas */
			text-align: center;
			display: flex;
			flex-direction: column;
			align-items: center;
		}
		.layanan-side-logo {
			width: 100%;
			max-width: 280px; 
			height: auto;
			margin-bottom: 20px;
		}
		.layanan-title-text {
			font-family: 'CormorantGaramond-Medium', serif;
			font-size: 2rem; 
			font-weight: bold;
			line-height: 1.4;
		}

		.layanan-title-gold {
			color: #ffcc00; 
			margin-top: 5px;
		}

		/* --- RIGHT SIDE: FEATURE BOXES --- */
		.feature-box {
			background-color: #e0e0e0; 
			color: #000;
			padding: 30px;
			height: 100%;
			display: flex;
			flex-direction: column;
			justify-content: top; 
			min-height: 300px; 
			border-radius: 2px;
		}
		.feature-box:hover {
			transform: translateY(-1px) scale(1.02); /* Mengangkat dan memperbesar sedikit */
		}
		.feature-box h3 {
			font-family: 'CormorantGaramond-Medium', serif;
			font-size: 1.7rem;
			text-align: center;
			margin-bottom: 20px;
			font-weight: 700;
		}

		.feature-box p {
			font-family: 'Lato-Regular', sans-serif;
			text-align: justify; 
			font-size: 0.95rem;
			line-height: 1.6;
			margin-bottom: 0;
		}

		/* Responsive Fixes */
		@media (max-width: 768px) {
			.left-section { margin-top: -50px; margin-bottom: 40px; }
			.layanan-side-logo { max-width: 200px; }
			.feature-box { min-height: auto; }
		}
/* --- LAYANAN 12345 --- */

/* --- LEGAL EXPERT --- */
		.legal-expert-title {
			font-family: 'CormorantGaramond-Medium', serif;
			font-size: 3rem;
			color: #fff;
			text-align: center;
			margin-top: -10px;
		}
		/* --- EXPERT CARD --- */
			.expert-card {
				background: transparent;
				border: none;
				text-align: center;
				transition: transform 0.3s ease;
				margin-bottom: 30px;
			}
			.expert-img-wrapper {
				width: 100%;
				aspect-ratio: 3 / 4;
				overflow: hidden;
				border-radius: 15px;
				margin-bottom: 15px;
				box-shadow: 0 10px 20px rgba(0,0,0,0.3);
			}
			.expert-img {
				width: 100%;
				height: 100%;
				object-fit: cover;
				transition: transform 0.5s ease;
			}
			.expert-card:hover .expert-img {
				transform: scale(1.1);
			}
			.expert-card:hover {
				transform: translateY(-5px);
			}
			.expert-name {
				color: #bfa55d;
				font-size: 1.1rem;
				font-family: 'Lato-Regular', sans-serif;
				font-weight: bold;
				margin-bottom: 5px;
				text-decoration: none;
				display: block;
			}
			.expert-link {
				color: #fff;
				text-decoration: none;
				font-size: 0.95rem;
				font-family: 'Lato-Regular', sans-serif;
				display: block;
				margin-bottom: 8px;
				transition: color 0.3s;
			}
			.expert-link:hover {
				color: #bfa55d;
			}
			.contact-wa {
				color: #fff;
				text-decoration: none;
				font-size: 0.95rem;
				font-family: 'Lato-Regular', sans-serif;
				display: flex;
				align-items: center;
				justify-content: center;
				gap: 8px;
				transition: color 0.3s;
			}
			.contact-wa i {
				color: #25d366; /* Warna Hijau WhatsApp */
				font-size: 1.2rem;
			}
			.contact-wa:hover {
				color: #25d366;
			}
			@media (max-width: 768px) {
				.expert-header { font-size: 3rem; }
				.expert-img-wrapper {
					width: 50%;
					position: relative;
					left: 0px;
					margin: 10px auto;
					display: block;
				}
		   }
/* --- LEGAL EXPERT --- */

/* --- LEGAL PROFILE --- */
		/* header section */
        .profile-header {
            padding: 30px 0px 60px 0px;
            border-bottom: 2px solid rgba(191, 165, 93, 0.3);
        }
        .img-profile {
            width: 100%;
            max-width: 350px;
            border-radius: 15px;
            border: 3px solid #bfa55d;
            box-shadow: 0 10px 30px rgba(0,0,0,0.5);
        }
        .img-profile:hover {
			transform: scale(1.1);
        }
		.profile-title {
			font-family: 'CormorantGaramond-Medium', serif;
            font-size: 2.5rem;
            color: #bfa55d;
            margin-bottom: 10px;
        }
		.profile-subtitle {
			font-family: 'Lato-Regular', sans-serif;
            font-size: 1.2rem;
            font-weight: 300;
            letter-spacing: 1px;
            color: #ddd;
            margin-bottom: 25px;
            text-transform: uppercase;
        }
		.profile-description{
			font-family: 'Lato-Regular', sans-serif;
			text-align: justify;
			font-size: 1.05rem;
			line-height: 1.5;
			color: #ccc;
		}
        .badge-honor {
            border: 1px solid #bfa55d;
            color: #bfa55d;
            font-weight: 500;
            margin-right: 5px;
            margin-bottom: 5px;
            display: inline-block;
            padding: 5px 15px;
            border-radius: 20px;
            font-size: 0.85rem;
        }
        .badge-honor:hover {
            background-color: #bfa55d;
            color: #000;
        }
        /* card styling */
        .info-card {
            background-color: rgba(255, 255, 255, 0.05);
            border-radius: 15px;
            padding: 30px;
            height: 100%;
            border-top: 4px solid #bfa55d;
            transition: all 0.3s ease;
			text-align: justify;
        }
        .info-card:hover {
            transform: translateY(-5px);
            background-color: rgba(255, 255, 255, 0.08);
            box-shadow: 0 10px 20px rgba(0,0,0,0.3);
        }
        .section-title {
			font-family: 'CormorantGaramond-Medium', serif;
            color: #bfa55d;
            margin-bottom: 20px;
            font-size: 1.6rem;
            display: flex;
            align-items: center;
            gap: 12px;
        }
        /* table styling */
		 .table-custom {
            color: #fff;
            margin-bottom: 0;
        }

        .table-custom td {
			font-family: 'Lato-Regular', sans-serif;
            border: none;
            color: #fff;
			background: transparent;
            padding: 8px;
        }
        .label {
			white-space: nowrap;
            color: #edd89e !important;
        }
        /* list styling */
        .custom-list {
            list-style: none;
            padding-left: 0;
        }
        .custom-list li {
			font-family: 'Lato-Regular', sans-serif;
            font-size: 0.95rem;
            line-height: 1.4;
			text-align: justify;
            margin-bottom: 8px;
            position: relative;
            padding-left: 25px;
        }
        .custom-list li::before {
            content: "\F287"; /* Bootstrap Icon Check */
            font-family: "bootstrap-icons";
            color: #bfa55d;
            position: absolute;
            left: 0;
            font-weight: bold;
            font-size: 0.6rem;
			top: 5px;
        }
        @media (max-width: 991px) {
            .profile-header { text-align: center; }
            .img-profile { margin-bottom: 30px; }
            .name-title { font-size: 2rem; }
        }
		
		
		#cv-download-overlay {
			position: fixed;
			top: 0; left: 0;
			width: 100%; height: 100%;
			background: rgba(0, 0, 0, 0.7);
			display: none; /* Tersembunyi secara default */
			flex-direction: column;
			justify-content: center;
			align-items: center;
			z-index: 9999;
			color: white;
			font-family: sans-serif;
		}

		.spinner {
			border: 4px solid rgba(255, 255, 255, 0.3);
			border-radius: 50%;
			border-top: 4px solid #ffffff;
			width: 40px;
			height: 40px;
			animation: spin 1s linear infinite;
			margin-bottom: 10px;
		}

		@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

/* --- LEGAL PROFILE --- */



/* --- HUBUNGI KAMI--- */
		.hubungi-kami-logo-container {
			display: flex;
			justify-content: center;
			align-items: center;
			padding: 0px;
		}
		.hubungi-kami-logo {
			width: 100%;
			max-width: 450px;
			height: auto;
		}
		/* --- RIGHT SIDE: CONTENT --- */
			.hubungi-kami-title {
				font-family: 'CormorantGaramond-Medium', serif;
				font-size: 2.8rem;
				color: #fff;
			}
			.hubungi-kami-alamat {
				font-family: 'Lato-Regular', sans-serif;
				font-size: 0.9rem;
				line-height: 1.3;
				margin-bottom: 5px;
			}
			.hubungi-kami-alamat a {
				color: #fff;
				text-decoration:none;
				transition: color 0.3s;
			}
			.hubungi-kami-alamat a:hover {
				color: #bfa55d;
			}
			.hubungi-kami-wa {
				font-family: 'Lato-Regular', sans-serif;
				font-size: 0.9rem;
				line-height: 1.3;
				margin-bottom: 5px;
			}
			.hubungi-kami-wa a {
				color: #fff;
				text-decoration:none;
				transition: color 0.3s;
			}
			.hubungi-kami-wa a:hover {
				color: #bfa55d;
			}
			.hubungi-kami-email {
				font-family: 'Lato-Regular', sans-serif;
				font-size: 0.9rem;
				line-height: 1.3;
				margin-bottom: 5px;
			}
			.hubungi-kami-email a {
				color: #fff;
				text-decoration:none;
				transition: color 0.3s;
			}
			.hubungi-kami-email a:hover {
				color: #bfa55d;
			}
			.hubungi-kami-operasional {
				font-size: 1rem;
				font-family: 'Lato-Regular', sans-serif;
				line-height: 1.6;
				margin-bottom: 5px;
			}
			.social-icons {
				margin: 0px 0px 30px 0px;
			}
			.social-icons a {
				color: #fff;
				font-size: 1.8rem;
				margin-right: 15px;
				transition: color 0.3s;
			}
			.social-icons a:hover {
				color: #bfa55d;
			}
			.hubungi-kami-description {
				font-size: 1rem;
				font-family: 'Lato-Regular', sans-serif;
				text-align: justify;
				line-height: 1.5;
				margin-top: 10px;
				color: #ddd;
			}

		/* Responsive Fixes */
		@media (max-width: 768px) {
			.hubungi-kami-logo-container { margin-top: -50px; margin-bottom: 30px;}
			.hubungi-kami-logo { max-width: 150px; }
			.info-column { text-align: center; margin-bottom: 30px; }
		}
/* --- HUBUNGI KAMI--- */

