@import "https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700";

.floating_label  {
	position: relative;
}

.floating_label input {
	width: 100%;
	padding: 20px 0;
	border: none;
	outline: none;
	letter-spacing: 1px;
	border-bottom: 2px solid #fff;
	background: transparent;
	transition: .5s;
    -webkit-transition: 0.5s;
    -moz-transition: 0.5s;
    -o-transition: 0.5s;
}

.floating_label textarea {
	width: 100%;
	padding: 10px 0 15px 0;
	border: none;
	outline: none;
	letter-spacing: 1px;
	border-bottom: 2px solid #fff;
	background: transparent;
	transition: .5s;
    -webkit-transition: 0.5s;
    -moz-transition: 0.5s;
    -o-transition: 0.5s;
}


.floating_label label  {
	position: absolute;
	top: 0;
	left: 0;
	padding: 10px 15px;
	letter-spacing: 1px;
	pointer-events: none;
	transition: .5s;
    -webkit-transition: 0.5s;
    -moz-transition: 0.5s;
    -o-transition: 0.5s;
}

.floating_label input:valid ~ label,
.floating_label input:focus ~ label {
	top: -35px;
	left: 0;
	padding: 10px 0;
}

.floating_label input:read-only ~ label {
	top: -35px;
	left: 0;
	padding: 10px 0;
}

.floating_label input.active_float ~ label {
	top: -35px;
	left: 0;
	padding: 10px 0;
}

/* Kalau pengen si labelnya juga merah */
/*.floating_label input.invalid_active_float ~ label {
	color: red;
}*/

.floating_label input.invalid_active_float {
	border-bottom: 2px solid red;
}

.floating_label textarea:valid ~ label,
.floating_label textarea:focus ~ label {
	top: -35px;
	left: 0;
	padding: 10px 0;
}

.floating_label textarea:read-only ~ label {
	top: -35px;
	left: 0;
	padding: 10px 0;
}

.floating_label textarea.active_float ~ label {
	top: -35px;
	left: 0;
	padding: 10px 0;
}

.floating_label textarea.invalid_active_float {
	border-bottom: 2px solid red;
}

.floating_label textarea:valid,
.floating_label textarea:focus {
	height: 10em;
}

#ifrm {
    display: none;
}

html {
	margin: 0;
	padding: 0;
    max-width: 100%;
    height: 100%;
    overflow-x: hidden;
}

body {
	min-height: 100%;
	font-family: 'Poppins', sans-serif;
	font-size: 16px;
}

h3::first-letter, p::first-letter {
 text-transform: uppercase;
}

h1, h2, h3, h4, h5, h6, ul li, ol li {
	text-align: left;
}

p {
	text-align: justify;
	margin-bottom: 0;
}

p img {
	display: inline-block;
	-webkit-display: inline-block;
	padding: 10px;
	width: 50%;
	height: auto;
	margin-left: auto;
	margin-right: auto;
}

@media (max-width: 768px) {
  p img {
	width: 100%;
	height: auto;
	padding-left: 0;
	padding-right: 0;
  }
}

label {
    text-align: justify;
}


label::first-letter {
 text-transform: uppercase;
}

.btn-primary {
  color: #fff;
  background-color: #007bff;
  border:none;
  font-size: 95%;
}


.btn-primary:hover {
  -webkit-filter: brightness(75%);
  filter: brightness(75%);
  cursor: pointer;
}

.btn {
  border: none;
  white-space: normal;
  text-transform: capitalize;
}

.btn:focus, .btn.focus {
  outline: none;
  box-shadow: none;
}

.subtitle {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 2px;
    color: #ffffffcc;
    text-transform: uppercase;
    margin-bottom: 8px;
}

.title_revenue_custom {
    font-size: 46px;
    font-weight: 800;
    line-height: 1.15;
    color: #fff;
    margin-bottom: 20px;
}

.desc_revenue_custom {
    font-size: 17px;
    font-weight: 400;
    color: #ffffffd8;
    margin-bottom: 18px;
    line-height: 1.7;
    max-width: 550px;
}

.meta_revenue_custom {
    font-size: 15px;
    font-weight: 500;
    color: #ffffffb5;
    margin-top: 8px;
    margin-bottom: 25px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.meta_revenue_custom::before {
    content: "🎵";
    margin-right: 4px;
}

.revenue .container {
    padding-left: 40px !important;
}

@media (max-width: 768px) {
    .title_revenue_custom {
        font-size: 34px;
    }

    .desc_revenue_custom {
        font-size: 15px;
    }

    .revenue .container {
        padding-left: 20px !important;
    }
}


/*--------------------------------- Media Queries --------------------------------------*/
@media screen and (min-width: 300px) {

	.floating_label textarea:valid ~ label,
	.floating_label textarea:focus ~ label {
		top: -55px;
		left: 0;
		padding: 10px 0;
	}

	.floating_label textarea:read-only ~ label {
		top: -55px;
		left: 0;
		padding: 10px 0;
	}

	.floating_label textarea.active_float ~ label {
		top: -55px;
		left: 0;
		padding: 10px 0;
	}

	body {
	  font-size: calc(14px + (16 - 14) * ((100vw - 300px) / (1600 - 300)));
	}
	
	label.btn-primary {
	  color: #fff;
	  background-color: #007bff;
	  border:none;
	  font-size: 95%;
	}

	label {
	 font-size: calc(18px + (20 - 18) * ((100vw-300px) / (1600 - 300)));
	}

	#navbarIMEC ul li a {
		font-size: calc(15px + (17 - 15) * ((100vw - 300px) / (1600 - 300)));
	}

	h1.instrument-txt {  
	  font-size:calc(1.2*1.2*1.2*1.2 *1rem); 
	}

	h1 {  
	  font-size:calc(1.1*1.1*1.1*1.1 *1rem); 
	}

	h2 {  
	  font-size: calc(1.1*1.1*1.1 *1rem);
	}

	h3 { 
	  font-size: calc(1.1*1.1*1.1 *1rem);
	}

	h4 { 
	  font-size: calc(1.1*1rem);
	}

	h5 { 
	  font-size: calc(1rem);
	}

	.h1 {  
	  font-size:calc(1.1*1.1*1.1*1.1 *1rem); 
	}

	.h2 {  
	  font-size: calc(1.1*1.1*1.1 *1rem);
	}

	.h3 { 
	  font-size: calc(1.1*1.1*1.1 *1rem);
	}

	.h4 { 
	  font-size: calc(1.1*1rem);
	}

	.h5 { 
	  font-size: calc(1rem);
	}
}

@media screen and (min-width: 1000px) {

	.floating_label input:valid ~ label,
	.floating_label input:focus ~ label {
		font-size: 16px;
	}

	.floating_label input:read-only ~ label {
		font-size: 16px;
	}

	.floating_label input.active_float ~ label {
		font-size: 16px;
	}

	.floating_label textarea:valid ~ label,
	.floating_label textarea:focus ~ label {
		font-size: 16px;
	}

	.floating_label textarea:read-only ~ label {
		font-size: 16px;
	}

	.floating_label textarea.active_float ~ label {
		font-size: 16px;
	}

	body {
	  font-size: 16px;
	}

	label.btn-primary {
	  color: #fff;
	  background-color: #007bff;
	  border:none;
	  font-size: 95%;
	}

	label {
	 font-size: 20px;
	}

	h1.instrument-txt {  
	  font-size:calc(1.3*1.3*1.3*1.3 *1rem); 
	}

	h1 {  
	  font-size:calc(1.2*1.2*1.2*1.2 *1rem); 
	}

	h2 {  
	  font-size: calc(1.2*1.2*1.2 *1rem);
	}

	h3 { 
	  font-size: calc(1.2*1.2 *1rem);
	}

	h4 { 
	  font-size: calc(1.2*1rem);
	}

	h5 { 
	  font-size: calc(1.2*1rem);
	}

	.h1.instrument-txt {  
	  font-size:calc(1.3*1.3*1.3*1.3 *1rem); 
	}

	.h1 {  
	  font-size:calc(1.2*1.2*1.2*1.2 *1rem); 
	}

	.h2 {  
	  font-size: calc(1.2*1.2*1.2 *1rem);
	}

	.h3 { 
	  font-size: calc(1.2*1.2 *1rem);
	}

	.h4 { 
	  font-size: calc(1.2*1rem);
	}

	.h5 { 
	  font-size: calc(1.2*1rem);
	}

	label.p {
		text-align: justify;
		font-size: 16px;
	}

}
/* ----------------------------------------
   MODERN HERO SECTION (APPLE MUSIC STYLE)
---------------------------------------- */

.hero-modern {
    position: relative;
    padding: 90px 0 120px 0;
    display: flex;
    align-items: center;
}

.hero-modern .hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(0,0,0,0.55), rgba(0,0,0,0.25), rgba(0,0,0,0));
    z-index: 1;
}

.hero-modern-content {
    position: relative;
    z-index: 2;
    padding-left: 60px;
    max-width: 600px;
}

.hero-modern .subtitle {
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 2px;
    color: #fff;
    opacity: .85;
    margin-bottom: 12px;
    text-transform: uppercase;
}

.hero-modern .title-modern {
    font-size: 52px;
    font-weight: 800;
    color: #fff;
    line-height: 1.12;
    margin-bottom: 20px;
}

.hero-modern .desc-modern {
    font-size: 18px;
    line-height: 1.7;
    color: #ffffffd8;
    margin-bottom: 25px;
}

.hero-modern .meta-modern {
    font-size: 16px;
    color: #ffffffb8;
    margin-bottom: 35px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.hero-modern .meta-modern::before {
    content: "🎵";
    font-size: 18px;
}

.btn-modern {
    padding: 13px 32px;
    border-radius: 50px;
    background: #ff2a83;
    color: #fff !important;
    font-weight: 600;
    font-size: 16px;
    border: none;
    transition: .25s;
}

.btn-modern:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(255, 0, 119, 0.35);
}

/* Responsive */
@media (max-width: 768px) {
    .hero-modern {
        padding: 60px 0 90px 0;
    }
    .hero-modern-content {
        padding-left: 20px;
    }
    .hero-modern .title-modern {
        font-size: 36px;
    }
    .hero-modern .desc-modern {
        font-size: 15px;
    }
}
        body {
            font-family: 'Poppins', sans-serif;
            margin: 0;
            background-color: #f8f8f8;
            padding: 0;
            font-size: 16px; 
        }

        .home-section {
            padding: 0 1rem;
        }

        .section-title {
            font-size: 1.5rem;
            font-weight: 700;
            margin-bottom: 1.25rem;
        }

        /* --- BANNER CONTAINER (Tanpa Perubahan dari yang terakhir) --- */
        .music-banner-container {
            width: 100%;
            padding-bottom: 30%; 
            position: relative;
            overflow: hidden; 
            border-radius: 1.25rem;
            box-shadow: 0 0.625rem 1.25rem rgba(138, 43, 226, 0.3);
            margin-bottom: 2rem; 
        }

        .banner-content {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%; 
            display: flex; 
            align-items: center; 
            background: linear-gradient(135deg, #8A2BE2, #9932CC);
            color: white;
            padding: 2.5rem; 
            box-sizing: border-box;
            z-index: 2;
        }

        /* TEKS DAN TOMBOL */
        .text-area {
            flex: 1.2; 
            padding-right: 2rem; 
            max-width: 60%; 
        }

        .headline {
            font-size: 2.2rem; 
            font-weight: 700;
            line-height: 1.1;
            margin: 0 0 0.8rem 0; 
        }

        .sub-text {
            font-size: 0.95rem; 
            opacity: 0.9;
            margin-bottom: 1.5rem; 
        }

        .explore-button {
            padding: 0.75rem 2rem; 
            background-color: white;
            color: #8A2BE2;
            border: none;
            border-radius: 1.875rem; 
            font-weight: 600;
            cursor: pointer;
            transition: background-color 0.3s, color 0.3s;
            text-decoration: none; 
            display: inline-block; 
            text-align: center;
        }
        
        .explore-button:hover {
            background-color: #f0f0f0;
        }

        .image-person-area {
            flex: 0.8; 
            display: flex;
            justify-content: flex-end; 
            align-items: center; 
            position: relative;
            height: 100%; 
            overflow: visible; 
        }

        .person-image {
            position: absolute;
            bottom: -15%; 
            right: 0%; 
            width: 100%; 
            height: 130%; 
            object-fit: contain; 
            transform-origin: bottom right; 
            z-index: 3; 
        }

        /* ============================ */
        /* --- CARD SECTION STYLES & ANIMATION --- */
        /* ============================ */
        
        @keyframes slideInUp {
            from {
                opacity: 0;
                transform: translateY(30px); 
            }
            to {
                opacity: 1;
                transform: translateY(0); 
            }
        }

        .card-container {
            display: flex;
            gap: 1.5rem; 
            margin-top: 2rem;
            margin-bottom: 2rem;
        }

        .feature-card {
            flex: 1; 
            background-color: white;
            padding: 1.5rem;
            border-radius: 0.75rem;
            box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
            transition: transform 0.3s ease;
            display: flex; 
            flex-direction: column; 
            justify-content: space-between; 
            
opacity: 1 !important;
            animation: slideInUp 0.8s ease-out forwards; 
        }

        .feature-card:hover {
            transform: translateY(-5px); 
            box-shadow: 0 8px 15px rgba(0, 0, 0, 0.1);
        }

        .feature-card:nth-child(1) { animation-delay: 0.1s; }
        .feature-card:nth-child(2) { animation-delay: 0.3s; }
        .feature-card:nth-child(3) { animation-delay: 0.5s; }

        /* --- BARU: STYLE UNTUK GAMBAR DI DALAM CARD --- */
        .card-image {
            width: 100%;
            height: 170px; /* Atur ketinggian gambar */
            background-color: #f0e6ff; /* Warna placeholder */
            margin-bottom: 1rem;
            border-radius: 0.5rem;
            object-fit: cover; /* Pastikan gambar mengisi kotak dengan rapi (jika ada gambar asli) */
            display: block;
        }
        /* ------------------------------------------- */


        .card-title {
            font-size: 1.15rem;
            font-weight: 700;
            color: #8A2BE2; 
            margin-top: 0;
            margin-bottom: 0.75rem;
        }

        .card-body {
            font-size: 0.9rem;
            line-height: 1.5;
            color: #555;
            margin-bottom: 1.5rem; 
            flex-grow: 1; 
        }

        /* ============================ */
        /* --- CARD BUTTON STYLES --- */
        /* ============================ */
        .card-button {
            background-color: #8A2BE2; 
            color: white;
            padding: 0.6rem 1.5rem; 
            border: none;
            border-radius: 1.875rem;
            font-weight: 600;
            cursor: pointer;
            transition: background-color 0.3s, transform 0.2s;
            text-decoration: none; 
            display: inline-block; 
            font-size: 0.9rem;
            align-self: flex-start; 
        }

        .card-button:hover {
            background-color: #9932CC; 
            transform: translateY(-2px);
        }


        /* --- MEDIA QUERY: LAYAR KECIL (untuk Ponsel) --- */
        @media (max-width: 768px) { 
            /* ... (Banner Styles, tidak berubah dari perbaikan sebelumnya) ... */
            .music-banner-container {
                padding-bottom: 0;
                min-height: 250px; 
                height: auto; 
            }

            .banner-content {
                position: static; 
                height: auto;
                flex-direction: column; 
                text-align: center; 
                padding: 1.5rem;
            }

            .text-area {
                order: 2;
                padding-right: 0;
                margin-bottom: 0; 
                max-width: 100%; 
                width: 100%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: center;
            }

            .headline {
                font-size: 1.6rem; 
                margin-top: 0; 
                margin-bottom: 0.5rem;
            }
            
            .sub-text {
                font-size: 0.8rem; 
                margin-bottom: 1rem;
            }

            .image-person-area {
                display: none; 
            }
            
            .explore-button {
                padding: 0.6rem 1.2rem;
                align-self: center; 
            }
            
            /* Card Mobile Styles */
            .card-container {
                flex-direction: column; 
                gap: 1rem;
            }
            
            .feature-card {
                padding: 1rem;
                align-items: center; 
                text-align: center; /* Tambahkan agar teks di card rata tengah di mobile */
            }
            
            /* Tambahkan agar align-self: flex-start untuk tombol di desktop tidak mengganggu */
            .card-button {
                align-self: center; 
            }

            /* Perbaikan gambar card di mobile */
            .card-image {
                height: 150px; /* Sedikit lebih kecil di mobile */
                margin-bottom: 0.75rem;
            }
        }

        /* MEDIA QUERY: LAYAR SANGAT KECIL */
        @media (max-width: 480px) {
            .headline {
                font-size: 1.5rem;
            }
            .sub-text {
                font-size: 0.75rem;
            }
            .card-button {
                font-size: 0.8rem;
                padding: 0.5rem 1rem;
            }
        }



.explore-button {
    padding: 0.75rem 2rem; 
    background-color: white;
    color: #8A2BE2;
    border: none;
    border-radius: 1.875rem; 
    font-weight: 600;
    cursor: pointer;
    transition: background-color 0.3s, color 0.3s, transform 0.3s, box-shadow 0.3s; 
    text-decoration: none; 
    display: inline-block; 
    text-align: center;
}


.explore-button:hover {
    background-color: #f0f0f0;
    transform: translateY(-3px); 
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2); 
}


.card-button {
    background-color: #8A2BE2; 
    color: white;
    padding: 0.6rem 1.5rem; 
    border: none;
    border-radius: 1.875rem;
    font-weight: 600;
    cursor: pointer;

    transition: background-color 0.3s, transform 0.2s, box-shadow 0.3s; 
    text-decoration: none; 
    display: inline-block; 
    font-size: 0.9rem;
    align-self: flex-start; 
}


.card-button:hover {
    background-color: #9932CC; 
    transform: translateY(-3px); 
    box-shadow: 0 4px 12px rgba(138, 43, 226, 0.5); 
}
