/* --- Konfigurasi Tema Girly 2026 --- */
:root {
  --navy: #1a234e;
  --navy-light: #2d3865;
  --soft-pink: #FFD5C2;
  --pink-accent: #E8A598;
  --cream: #FFFDF9;
  --white: #FFFFFF;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

/* SMOOTH SCROLLING UNTUK MENU */
html { scroll-behavior: smooth; }

body {
  font-family: 'Montserrat', sans-serif;
  background-color: var(--cream);
  color: var(--navy);
  overflow-x: hidden;
}

/* --- Header & Navigasi --- */
#header {
  position: fixed;
  top: 0; left: 0; width: 100%;
  height: 80px; /* Tinggi header yang konsisten */
  background: rgba(255, 253, 249, 0.85);
  backdrop-filter: blur(12px);
  z-index: 1000;
  box-shadow: 0 4px 20px rgba(26, 35, 78, 0.05);
}

.nav-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding: 0 5%;
  max-width: 1200px;
  margin: auto;
  position: relative;
}

/* 1 & 2. LOGO BESAR MENYENTUH ATAS BAWAH (Di tengah untuk Mobile) */
.logo {
  height: 100%; /* Mengisi penuh tinggi header */
  display: flex;
  align-items: center;
}
.logo img {
  height: 100%; /* Gambar menyentuh mentok atas & bawah */
  object-fit: contain;
  transition: transform 0.3s ease;
}
.logo:hover img { transform: scale(1.05); }

/* 3. MENU AKTIF & HOVER */
.nav-links {
  display: flex;
  list-style: none;
  align-items: center;
  gap: 30px;
}
.nav-links .nav-item {
  text-decoration: none;
  color: var(--navy);
  font-weight: 500;
  font-size: 15px;
  position: relative;
  padding: 5px 0;
  transition: color 0.3s ease;
}
/* Garis Hover */
.nav-links .nav-item::after {
  content: '';
  position: absolute;
  width: 0%; height: 3px;
  bottom: -2px; left: 0;
  background-color: var(--pink-accent);
  border-radius: 5px;
  transition: width 0.3s ease;
}
/* Tampil saat di hover atau saat class .active ditambahkan (ketika diklik) */
.nav-links .nav-item:hover::after, 
.nav-links .nav-item.active::after {
  width: 100%;
}

.btn-wa {
  background: linear-gradient(135deg, var(--pink-accent), var(--soft-pink));
  color: var(--navy) !important;
  padding: 10px 24px;
  border-radius: 50px;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 4px 15px rgba(232, 165, 152, 0.3);
  transition: 0.3s ease;
}
.btn-wa:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(232, 165, 152, 0.5);
}

/* 4 & 5. TOMBOL MOBILE TOGGLE */
.mobile-actions-left {
  display: none;
  align-items: center;
  gap: 15px;
}
.mobile-toggle {
  font-size: 26px; /* Ukuran sama besar */
  color: var(--navy);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: none;
}
.mobile-spacer { display: none; } /* Spacer untuk balancing di HP */

/* Styling Tombol WA Mobile di sebelah Kanan */
.mobile-actions-right {
  display: none; /* Disembunyikan di desktop */
}

.mobile-wa-btn {
  background: linear-gradient(135deg, #25D366, #128C7E); /* Hijau khas WhatsApp */
  color: #ffffff;
  padding: 8px 12px;
  border-radius: 50px;
  font-size: 20px;
  font-weight: 600;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  box-shadow: 0 4px 10px rgba(37, 211, 102, 0.4);
  animation: pulse-wa 2s infinite; /* Efek berdenyut agar terlihat bisa diklik */
}

/* Animasi denyut (pulse) tombol WhatsApp */
@keyframes pulse-wa {
  0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.6); }
  70% { box-shadow: 0 0 0 12px rgba(37, 211, 102, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}

/* --- Hero Section & Teks Slider (Animasi Gulir Layar Penuh) --- */
#hero {
  max-width: 100%;
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: linear-gradient(135deg, #FFFDF9, #FFD5C2);
  /* Hilangkan padding agar container di dalamnya bisa presisi 100% */
  padding: 0; 
}

.hero-content {
  position: absolute;
  /* KUNCI BUGFIX: Kotak ini dimulai persis di bawah header (80px) */
  top: 80px; 
  left: 0;
  width: 100%;
  /* Mengisi sisa ruang layar ke bawah */
  height: calc(100vh - 80px); 
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  /* KUNCI BUGFIX: Teks akan otomatis terpotong/menghilang saat menyentuh batas atas (garis header) ini */
  overflow: hidden; 
  z-index: 10;
  padding: 0 20px;
}

/* --- Hero Mini (Khusus Halaman Kedua/Produk) --- */
#hero-mini {
  position: relative;
  width: 100%;
  max-width: 100%; 
  margin: 0; 
  /* Kita gunakan min-height: 280px agar Teks dan Ombak bernapas lega, 
     karena 80px teratas layar Anda sudah tertutup oleh Header Kaca */
  min-height: 280px; 
  background: linear-gradient(135deg, #FFFDF9, #FFD5C2);
  /* Padding Atas 110px (melewati header), Kiri-Kanan 5%, Bawah 60px (area ombak) */
  padding: 110px 5% 60px; 
  overflow: hidden;
}

/* Mengangkat teks judul ke atas efek gelombang ombak */
#hero-mini .section-title {
  position: relative;
  z-index: 10; /* Kunci presisi: Teks selalu menang / berada di atas gelombang */
  margin-bottom: 0; /* Jarak bawah dibuang agar merapat ke ombak */
}

/* Menenggelamkan ombak ke belakang teks */
#hero-mini .hero-fabric-waves {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 2; /* Ombak di bawah teks, tapi di atas background */
}

/* --- Penyesuaian Jarak Galeri (HANYA untuk halaman produk.html) --- */
#hero-mini + #gallery {
  padding-top: 40px; 
  /* Offset cerdas: Mencegah judul dan ombak tertutup header kaca saat menu diklik */
  scroll-margin-top: 360px; 
}

/* --- Slider Teks (Jendela Asimetris Presisi) --- */
.text-slider {
  position: relative; /* Kunci Bugfix: Diubah jadi relative agar tidak menabrak tombol V */
  width: 100%;
  height: 220px; /* Memberikan ruang khusus untuk teks */
  display: flex;
  align-items: center;
  justify-content: center;
  
  /* Trik Jendela Hebat: 
     -100vh = Membiarkan sisi atas tembus pandang sampai mentok batas header.
     0 = Memotong tajam sisi bawah tepat di garis kotak ini. */
  -webkit-clip-path: inset(-100vh 0 0 0);
  clip-path: inset(-100vh 0 0 0);
  z-index: 2;
}

.slide {
  position: absolute;
  width: 100%;
  opacity: 1; 
  
  /* Teks mengantre sejauh 250px ke bawah. (Aman bersembunyi di balik garis potong bawah) */
  transform: translate3d(0, 250px, 0); 
  
  transition: none; 
  will-change: transform;
}

/* Mengatur kecepatan dorongan (2.2 detik) */
.slide.active, 
.slide.prev {
  transition: transform 2.2s cubic-bezier(0.25, 1, 0.5, 1);
}

/* Posisi Teks Sedang Dibaca */
.slide.active {
  transform: translate3d(0, 0, 0);
}

/* Posisi Teks Keluar */
.slide.prev {
  /* Teks terus meluncur ke atas melewati tombol V dan lenyap tepat di bawah Header */
  transform: translate3d(0, -60vh, 0); 
}

/* --- Pengaturan Tipografi Teks Slider Khusus Fashion --- */
.slide h1 {
  /* Menggunakan Font Fashion Mewah */
  font-family: 'Playfair Display', serif; 
  font-size: 4rem; /* Ukuran dibesarkan sedikit agar lebih megah */
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 20px;
  line-height: 1.15;
  letter-spacing: -1px; /* Merapatkan jarak antar huruf memberi kesan eksklusif & modern */
}

/* Jika Anda menggunakan <br> di Google Sheets, baris kedua bisa diatur agar miring (italic) untuk variasi estetik */
.slide h1 i {
  font-style: italic;
  font-weight: 600;
  color: var(--pink-accent); /* Memberikan warna aksen pada kata tertentu */
}

.slide p {
  /* Tetap pakai Montserrat untuk modernitas dan kemudahan membaca */
  font-family: 'Montserrat', sans-serif; 
  font-size: 1.1rem;
  font-weight: 300; /* Dibuat lebih tipis agar kontras dengan Judul yang tebal */
  color: var(--navy-light);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.7;
  letter-spacing: 0.5px; /* Jarak huruf direnggangkan untuk kesan lega/minimalis */
}

/* KUNCI TAMBAHAN: Pastikan ombak (waves) berada di depan teks yang baru muncul dari bawah */
.hero-fabric-waves {
  position: absolute;
  bottom: 0; left: 0; width: 100%;
  line-height: 0;
  z-index: 15; /* Diberi z-index 15 agar menutupi teks yang baru merangkak naik */
  pointer-events: none; 
}

/* --- Tombol Scroll Bawah (Statis, 3 Susun V) --- */
.btn-scroll-down {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin-top: 30px;
  text-decoration: none;
  background: transparent;
  box-shadow: none; 
  z-index: 20;
}

.chevron-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  transition: transform 0.3s ease;
  /* PENTING: Menambahkan padding agar ruang filter shadow dan ikon tidak terpotong (clipping) */
  padding-bottom: 15px; 
}

.btn-scroll-down:hover .chevron-stack {
  transform: translateY(5px);
}

.chevron-stack i {
  font-size: 42px;
  /* Kembalikan line-height normal agar font utuh/tidak buntung */
  line-height: 1; 
  /* Gunakan margin negatif untuk membuat V saling menumpuk rapat */
  margin-bottom: -22px; 
}

/* Hilangkan margin negatif pada panah paling bawah agar tidak melanggar batas bawah */
.chevron-stack i:last-child {
  margin-bottom: 0;
}

.chevron-top {
  color: rgba(232, 165, 152, 0.4); 
}

.chevron-mid {
  color: rgba(232, 165, 152, 0.7);
}

.chevron-bottom {
  background: linear-gradient(135deg, var(--soft-pink), #ff8fa3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  /* Menggunakan drop-shadow alih-alih box-shadow karena ini menempel pada font */
  filter: drop-shadow(0px 8px 8px rgba(232, 165, 152, 0.4));
}

/* Animasi Lembaran Kain Bawah (Waves) */
.hero-fabric-waves {
  position: absolute;
  bottom: 0; left: 0; width: 100%;
  line-height: 0;
  z-index: 5;
}
.waves {
  position: relative;
  width: 100%;
  height: 15vh;
  min-height: 100px;
  max-height: 150px;
}
.parallax > use {
  animation: move-forever 25s cubic-bezier(.55,.5,.45,.5) infinite;
  will-change: transform; /* Kunci anti-patah-patah pada SVG */
}
.parallax > use:nth-child(1) { animation-delay: -2s; animation-duration: 7s; }
.parallax > use:nth-child(2) { animation-delay: -3s; animation-duration: 10s; }
.parallax > use:nth-child(3) { animation-delay: -4s; animation-duration: 13s; }
.parallax > use:nth-child(4) { animation-delay: -5s; animation-duration: 20s; }
@keyframes move-forever {
  0% { transform: translate3d(-90px, 0, 0); }
  100% { transform: translate3d(85px, 0, 0); }
}

/* --- Global Section Padding --- */
section { padding: 100px 5% 50px; max-width: 1200px; margin: auto; }
.section-title { text-align: center; margin-bottom: 50px; }
.section-title h2 { font-size: 2.5rem; color: var(--navy); margin-bottom: 10px; }
.section-title p { color: var(--navy-light); font-size: 1.1rem; }

/* --- OnlineShop Card --- */
/* --- Tombol Lihat Katalog Produk (Lebar & Lucu) --- */
.catalog-btn-wrapper {
  display: flex;
  justify-content: center;
  margin-top: 50px; /* KUNCI PRESISI: Memberikan jarak ruang napas dari kartu di atasnya */
  margin-bottom: 10px; /* Jarak aman untuk bagian bawah */
  padding: 0 15px;
}

.btn-catalog {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  /* 630px adalah kalkulasi presisi lebar gabungan 2 kartu (300px + 300px + jarak celah 30px) */
  max-width: 630px; 
  /* Gradasi pink-peach yang sangat manis dan eye-catching */
  background: linear-gradient(135deg, #ffb6b9, #fae3d9); 
  color: var(--navy);
  text-decoration: none;
  font-size: 1.15rem;
  font-weight: 800;
  padding: 18px 30px;
  border-radius: 50px;
  border: 4px solid var(--white); /* Bingkai putih tebal ala stiker */
  box-shadow: 0 8px 20px rgba(255, 182, 185, 0.4);
  transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  position: relative;
  overflow: hidden;
  animation: blink-glow 2s infinite ease-in-out;
}

/* Animasi Ikon Goyang (Wiggle) Terus-menerus */
.btn-catalog i {
  font-size: 1.35rem;
  color: #ff6b6b; /* Warna ikon sedikit lebih tua agar kontras */
  animation: wiggle-cute 2s infinite ease-in-out;
}

@keyframes wiggle-cute {
  0%, 100% { transform: rotate(0deg) scale(1); }
  25% { transform: rotate(-12deg) scale(1.1); }
  50% { transform: rotate(12deg) scale(1.1); }
  75% { transform: rotate(-5deg) scale(1.05); }
}

/* --- Animasi Kedipan Tombol Katalog --- */
@keyframes blink-glow {
  0%, 100% { 
    opacity: 1; 
    box-shadow: 0 8px 20px rgba(255, 182, 185, 0.4); 
  }
  50% { 
    opacity: 0.85; /* Tombol sedikit memudar menciptakan efek "kedip" */
    box-shadow: 0 8px 35px rgba(255, 182, 185, 0.9); /* Cahaya pink merona melebar */
  }
}

/* Efek Saat Kursor Menyentuh Tombol (Hover) */
.btn-catalog:hover {
  animation: none;
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 15px 35px rgba(255, 182, 185, 0.6);
  background: var(--white); /* Berubah menjadi putih */
  color: var(--pink-accent); /* Teks berubah pink */
  border-color: #ffb6b9; /* Bingkai berubah pink */
}

.btn-catalog:hover i {
  color: var(--pink-accent);
}

/* Efek Garis Cahaya Berkilau yang Lewat Cepat */
.btn-catalog::after {
  content: '';
  position: absolute;
  top: 0; 
  left: -100%; 
  width: 50%; 
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.8), transparent);
  transform: skewX(-25deg);
  transition: 0.6s ease;
}

.btn-catalog:hover::after {
  left: 150%;
}

/*Area card link ecommerce*/
.shop-grid {
  display: flex;
  justify-content: center;
  gap: 30px;
  flex-wrap: wrap;
}
.shop-card {
  background: var(--white);
  width: 300px;
  padding: 30px;
  border-radius: 24px;
  text-align: center;
  text-decoration: none;
  color: var(--navy);
  box-shadow: 0 10px 30px rgba(232, 165, 152, 0.15);
  transition: all 0.4s ease;
  border: 1px solid rgba(232, 165, 152, 0.3);
}
.shop-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(232, 165, 152, 0.3);
  border-color: var(--pink-accent);
}
/*.shop-img-wrapper img { width: 100px; height: 100px; object-fit: contain; margin-bottom: 20px; }*/
.shop-link { display: inline-block; margin-top: 15px; color: var(--pink-accent); font-weight: 600; }
/* --- Efek Hover Gambar Toko Membesar --- */
.shop-img-wrapper img { 
  width: 100px; 
  height: 100px; 
  object-fit: contain; 
  margin-bottom: 15px; 
  /* Memberikan transisi mulus saat kursor masuk dan keluar */
  transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1);
  will-change: transform;
}

/* Gambar membesar (zoom) saat kartu disentuh mouse */
.shop-card:hover .shop-img-wrapper img {
  transform: scale(1.2);
}

/* --- Teks Link & Username (Mutlak 1 Baris) --- */
.shop-account {
  display: block; 
  text-align: center;
  margin-bottom: 12px;
  /* Kunci Utama: Memaksa teks tidak akan pernah turun ke baris baru */
  white-space: nowrap; 
  /* Jika di layar yang teramat sangat kecil (seperti HP lama), teks berlebih akan jadi titik-titik elegan (...) */
  overflow: hidden; 
  text-overflow: ellipsis; 
}

.url-base {
  font-size: 0.9rem;
  color: #9ca3af; /* Abu-abu pudar */
  font-weight: 500;
}

.url-username {
  font-size: 1rem; /* Jauh lebih besar */
  font-weight: 800; /* Ekstra tebal (Bold) agar sangat mencolok */
  color: var(--navy);
}


/* --- Pengiriman Card --- */
#pengiriman {
  max-width: 1400px; /* Melebarkan area dari 1200px menjadi 1400px agar 4 card bernafas lega */
  /* Jika Anda benar-benar ingin full 100% menyentuh pinggir layar seperti Hero, 
     Anda bisa ganti nilai 1400px di atas menjadi 100% */
}
.pengiriman-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* MEMAKSA 4 card sejajar satu baris di Desktop */
  gap: 20px;
}

.info-card {
  position: relative;
  overflow: hidden; /* Mengunci icon besar yang keluar batas (watermark effect) */
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(10px);
  padding: 40px 20px 30px; /* Padding atas ditambahkan agar teks tidak nabrak icon */
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,0.8);
  box-shadow: 0 10px 30px rgba(26, 35, 78, 0.05);
  transition: 0.3s ease;
  z-index: 1;
}

.info-card:hover { 
  transform: translateY(-5px); 
  background: var(--white); 
}

/* Teks dibuat z-index: 2 agar berada di atas icon */
.info-card h3, .info-card p {
  position: relative;
  z-index: 2; 
}

.info-card h3 { 
  margin-bottom: 15px; 
  font-size: 1.2rem; 
  margin-top: 30px; /* Jarak ekstra ke bawah */
  text-align: center;
}

.info-card p { 
  font-size: 0.95rem; 
  line-height: 1.6; 
  color: var(--navy-light); 
}

/* Icon Besar Pojok Kiri Atas (Tampil 80%) */
.card-icon {
  position: absolute;
  top: -20px; /* Menarik icon ke atas luar batas */
  left: -20px; /* Menarik icon ke kiri luar batas */
  width: 120px; 
  height: 120px;
  background: linear-gradient(135deg, var(--soft-pink), var(--pink-accent));
  border-radius: 50%;
  display: flex; 
  align-items: center; 
  justify-content: center;
  font-size: 60px; /* Ukuran icon dibesarkan */
  color: rgba(255, 255, 255, 0.8);
  z-index: 0;
  opacity: 0.4; /* Dibuat sedikit transparan seperti watermark */
}

/* --- Gallery Grid Wrapper (Struktur Baru) --- */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
}

.gallery-item-wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 24px;
  background: transparent; /* Kunci 1: Diubah jadi transparan agar menyatu dengan celah antar gambar */
  /* Kunci 2: 'overflow: hidden' DIHAPUS agar tombol bisa menonjol keluar dari batas bawah */
}

.gallery-item {
  position: relative; 
  aspect-ratio: 1 / 1; 
  overflow: hidden; /* Kunci 3: Mengamankan gambar agar tetap melengkung */
  background: var(--cream);
  display: block; 
  width: 100%;
  border-radius: 24px; /* Kunci 4: Memindahkan pengaturan sudut membulat langsung ke gambarnya */
}

/* 3. Efek Zoom Gambar Mulus 60fps (Hardware Accelerated) */
.gallery-item img { 
  width: 100%; 
  height: 100%; 
  object-fit: cover; 
  will-change: transform;
  transform: translateZ(0); 
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1); 
}
.gallery-item:hover img { 
  transform: scale(1.15) translateZ(0); 
}

/* --- Tombol E-commerce di Atas Gambar (Desktop) --- */
.gallery-actions {
  position: absolute;
  bottom: 0; /* Titik 0 memastikan posisi sejajar persis dengan garis paling bawah gambar */
  left: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 15px; 
  z-index: 10;
  pointer-events: none; 
  
  /* Posisi awal sembunyi (agak tenggelam di bawah) */
  opacity: 0;
  transform: translateY(70%);
  transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}

/* Memunculkan tombol saat gambar galeri disentuh kursor */
.gallery-item-wrapper:hover .gallery-actions {
  opacity: 1;
  /* KUNCI UTAMA: 50% akan mendorong tombol persis ke tengah garis (Setengah di gambar, setengah di luar) */
  transform: translateY(50%);
}

.btn-gallery-shop {
  pointer-events: auto; 
  /* Transparan kaca (Glassmorphism) saat mouse belum menyentuh tombol */
  background: rgba(255, 255, 255, 0.65); 
  backdrop-filter: blur(8px);
  
  /* Diubah menjadi bentuk kapsul (Pill-shape) untuk Desktop */
  padding: 8px 20px;
  border-radius: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px; /* Jarak imut antara ikon dan teks */
  
  /* Pengaturan Teks */
  text-decoration: none;
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--navy);
  
  /* Cahaya soft-pink di sekitar tombol */
  box-shadow: 0 4px 15px rgba(232, 165, 152, 0.4); 
  transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  border: 1px solid rgba(255, 255, 255, 0.6);
}

.btn-gallery-shop img {
  height: 20px !important; /* Disesuaikan ukurannya agar pas dengan teks */
  width: auto !important;
  margin: 0 !important;
  object-fit: contain;
}

.btn-gallery-shop:hover {
  transform: translateY(-5px) scale(1.08); /* Efek membesar (popping) saat mouse menyentuh tombol */
  background: var(--white); /* Berubah putih solid dan jelas saat disentuh */
  box-shadow: 0 8px 25px rgba(232, 165, 152, 0.8); /* Cahaya pink merona */
  border-color: var(--pink-accent); 
  color: var(--pink-accent); /* Teks juga ikut berubah pink! */
}

/* 1. Murni Transparan (Terbebas dari Bug Hitam) */
.hover-kaca {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  /* Force (paksa) warna tembus pandang 100% untuk membunuh CSS bawaan library */
  background: transparent !important; 
  background-color: transparent !important; 
  display: flex; justify-content: center; align-items: center;
  opacity: 0; 
  transition: opacity 0.4s ease;
  z-index: 2;
}
.gallery-item:hover .hover-kaca { opacity: 1; }

/* 2. Ikon Kaca Pembesar Tembus Pandang yang Elegan */
.hover-kaca i { 
  color: #ffffff !important; 
  /* Memaksa ikon menjadi tembus pandang 60% */
  opacity: 0.6 !important; 
  font-size: 45px; 
  /* Anti-patah untuk animasi ikon membesar */
  will-change: transform;
  transform: scale(0.5) translateZ(0); 
  transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1);
  filter: drop-shadow(0 4px 6px rgba(0,0,0,0.3)); 
}
.gallery-item:hover .hover-kaca i { 
  transform: scale(1) translateZ(0); 
}

/* 4. Efek Loading Lucu (Hati Berdetak Pengganti Shimmer) */
.cute-loader-item {
  aspect-ratio: 1 / 1;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--cream), var(--soft-pink));
  display: flex;
  justify-content: center;
  align-items: center;
  animation: bg-pulse 1.5s infinite alternate ease-in-out;
}

.cute-loader-item i {
  font-size: 45px;
  color: var(--pink-accent);
  /* Animasi detak jantung (Heart-beat) */
  animation: heart-beat 0.8s infinite alternate cubic-bezier(0.25, 1, 0.5, 1);
}

@keyframes bg-pulse {
  0% { opacity: 0.6; }
  100% { opacity: 1; }
}

@keyframes heart-beat {
  0% { transform: scale(0.8); }
  100% { transform: scale(1.15); }
}

/* --- ZOOM MAGNIFIC POPUP (Smooth Fix) --- */
.mfp-with-zoom .mfp-container,
.mfp-with-zoom.mfp-bg {
  opacity: 0;
  /* Transisi khusus opacity agar tidak merusak animasi bawaan Popup */
  transition: opacity 0.4s ease-in-out !important; 
}

.mfp-with-zoom.mfp-ready .mfp-container {
  opacity: 1;
}
.mfp-with-zoom.mfp-ready.mfp-bg { 
  opacity: 0.95; 
  background: var(--navy); 
}

.mfp-with-zoom.mfp-removing .mfp-container,
.mfp-with-zoom.mfp-removing.mfp-bg {
  opacity: 0;
}

/* Memastikan gambar super besar di Popup tidak patah-patah */
img.mfp-img {
  will-change: transform;
  transform: translateZ(0);
}


/* --- Tombol Load More Galeri --- */
.load-more-container {
  text-align: center;
  margin-top: 40px;
  width: 100%;
}

.btn-load-more {
  background: linear-gradient(135deg, var(--soft-pink), var(--pink-accent));
  color: var(--navy);
  border: none;
  padding: 14px 32px;
  border-radius: 50px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  box-shadow: 0 4px 15px rgba(232, 165, 152, 0.4);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.btn-load-more:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(232, 165, 152, 0.6);
  background: var(--white);
  color: var(--pink-accent);
}

/* Kotak angka counter (misal: 6 / 12) */
.btn-counter {
  background: rgba(26, 35, 78, 0.1);
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--navy);
  transition: 0.3s ease;
}

.btn-load-more:hover .btn-counter {
  background: var(--soft-pink);
}

/* State ketika tombol diklik (Memproses Loading) */
.btn-load-more.is-loading {
  pointer-events: none; /* Mematikan klik ganda */
  opacity: 0.8;
}

.btn-load-more.is-loading .btn-text,
.btn-load-more.is-loading .btn-counter {
  display: none; /* Sembunyikan teks saat loading */
}

.btn-load-more.is-loading .loading-icon {
  display: inline-block !important; /* Tampilkan ikon muter-muter */
  font-size: 1.4rem;
  color: var(--navy);
}



/* --- Testimoni Section (Infinite Marquee) --- */
#testimoni {
  max-width: 100%; /* Memaksa container melebar penuh 100% menyentuh pinggir layar */
  padding-left: 0; /* Menghilangkan jarak pembatas kiri */
  padding-right: 0; /* Menghilangkan jarak pembatas kanan */
  overflow: hidden; 
  padding-bottom: 80px;
}
/* Mengamankan Judul agar tetap punya jarak di sisi kiri-kanan dan tidak mentok layar */
#testimoni .section-title {
  padding: 0 5%;
}

.testi-container {
  width: 100%;
  overflow: hidden;
  position: relative;
  padding: 20px 0;
}

/* Efek gradasi pudar di pinggir kiri & kanan (Biar terlihat elegan saat card masuk & keluar layar) */
.testi-container::before, 
.testi-container::after {
  content: '';
  position: absolute;
  top: 0; 
  width: 150px; 
  height: 100%;
  z-index: 2;
  pointer-events: none;
}
.testi-container::before {
  left: 0;
  background: linear-gradient(to right, var(--cream) 0%, transparent 100%);
}
.testi-container::after {
  right: 0;
  background: linear-gradient(to left, var(--cream) 0%, transparent 100%);
}

.marquee-track {
  display: flex;
  width: max-content;
  cursor: grab; /* Menampilkan kursor tangan terbuka (Siap geser) */
  will-change: transform;
}

.marquee-track:active {
  cursor: grabbing; /* Menampilkan kursor tangan menggenggam saat diklik/ditahan */
}

@keyframes marquee-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); } /* Bergeser 50% karena isi datanya akan kita duplikat 2x di JS */
}

/* Desain Kartu Testimoni */
.testi-card {
  width: 340px;
  background: var(--white);
  border-radius: 20px;
  padding: 25px;
  margin: 0 15px;
  box-shadow: 0 10px 30px rgba(232, 165, 152, 0.15);
  border: 1px solid rgba(232, 165, 152, 0.3);
  display: flex;
  flex-direction: column;
  gap: 15px;
  transition: transform 0.3s ease, border-color 0.3s ease;
  white-space: normal; /* Mengembalikan text agar bisa turun baris */
  user-select: none; 
  -webkit-user-select: none;
}

.testi-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(232, 165, 152, 0.3);
  border-color: var(--pink-accent);
}

.testi-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.testi-name {
  font-weight: 700;
  color: var(--navy);
  font-size: 1.1rem;
}

/* Bintang Emas */
.testi-stars {
  color: #FFD700; 
  font-size: 0.9rem;
  margin-top: 5px;
}
/* Bintang Kosong */
.testi-stars .fa-regular {
  color: #e0e0e0;
}

/* Logo Platform (Shopee/TikTok) */
.testi-platform img {
  height: 45px;
  width: auto;
  object-fit: contain;
  opacity: 0.9;
  pointer-events: none;
}

/* Pesan Testimoni */
.testi-msg {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--navy-light);
  font-style: italic;
}

.loader-card {
  justify-content: center;
  align-items: center;
  color: var(--pink-accent);
  font-weight: 600;
  width: auto;
  padding: 20px 40px;
}

/* Responsivitas Mobile Testimoni */
@media (max-width: 768px) {
  .testi-card { width: 280px; padding: 20px; }
  .testi-name { font-size: 1rem; }
  .testi-msg { font-size: 0.9rem; }
  .testi-container::before, .testi-container::after { width: 50px; }
}


/* --- Footer Catchy & Elegant --- */
footer { 
  background: linear-gradient(180deg, var(--navy-light) 0%, var(--navy) 100%);
  color: var(--cream); 
  text-align: center; 
  padding: 80px 5% 40px; 
  position: relative;
  overflow: hidden;
}

/* Dekorasi Bias Cahaya di Background Footer */
footer::before {
  content: ''; position: absolute; top: -50px; left: -50px; width: 250px; height: 250px;
  background: rgba(232, 165, 152, 0.15); filter: blur(70px); border-radius: 50%; z-index: 1;
}
footer::after {
  content: ''; position: absolute; bottom: -50px; right: -50px; width: 300px; height: 300px;
  background: rgba(255, 213, 194, 0.1); filter: blur(90px); border-radius: 50%; z-index: 1;
}

.footer-container {
  max-width: 800px;
  margin: auto;
  position: relative;
  z-index: 2; /* Memastikan konten berada di atas efek cahaya */
}

/* --- Footer Call to Action (CTA) --- */
.footer-cta { margin-bottom: 50px; }
.footer-cta h2 { 
  font-size: 2.8rem; 
  font-weight: 300; /* Font tipis untuk kesan elegan */
  margin-bottom: 15px; 
}
.footer-cta h2 .highlight {
  font-weight: 700;
  color: var(--soft-pink);
  font-style: italic; /* Cetak miring untuk gaya berkelas */
}
.footer-cta p {
  font-size: 1.1rem;
  line-height: 1.6;
  color: rgba(255, 253, 249, 0.85);
  margin-bottom: 35px;
}
.footer-cta p strong {
  color: var(--white);
  font-weight: 700;
  letter-spacing: 1px;
}

.btn-footer-wa {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background-color: var(--soft-pink);
  color: var(--navy) !important;
  padding: 16px 36px;
  border-radius: 50px;
  font-weight: 600;
  font-size: 1.05rem;
  text-decoration: none;
  transition: all 0.4s ease;
  animation: pulse-footer 2s infinite; 
}

.btn-footer-wa:hover {
  background-color: var(--white);
  transform: translateY(-5px) scale(1.02);
  /* Hentikan animasi saat di-hover agar efek hover ini yang bekerja */
  animation: none; 
  box-shadow: 0 15px 30px rgba(255, 255, 255, 0.25);
}

/* Animasi Denyut (Pulse) Khusus Footer dengan Warna Soft Pink */
@keyframes pulse-footer {
  0% {
    /* Bayangan dasar + pendaran awal berwarna peach/pink */
    box-shadow: 0 10px 20px rgba(255, 213, 194, 0.15), 0 0 0 0 rgba(255, 213, 194, 0.7);
  }
  70% {
    /* Pendaran melebar sejauh 15px dan memudar menjadi transparan */
    box-shadow: 0 10px 20px rgba(255, 213, 194, 0.15), 0 0 0 15px rgba(255, 213, 194, 0);
  }
  100% {
    /* Kembali ke posisi awal */
    box-shadow: 0 10px 20px rgba(255, 213, 194, 0.15), 0 0 0 0 rgba(255, 213, 194, 0);
  }
}

/* --- Garis Pembatas --- */
.footer-divider {
  border: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 213, 194, 0.3), transparent);
  margin: 40px 0;
}

/* --- Footer Content Bawah --- */
.footer-logo { 
  height: 70px; 
  margin-bottom: 25px; 
  filter: brightness(0) invert(1); 
  transition: transform 0.4s ease; 
}
.footer-logo:hover { transform: scale(1.08); }

.footer-tagline {
  font-size: 1.05rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 35px;
  line-height: 1.6;
}
.footer-tagline em { color: var(--soft-pink); font-style: italic; }
.footer-tagline span { font-weight: 600; color: var(--white); letter-spacing: 0.5px; }

/* --- Ikon Sosial Media --- */
.social-links { 
  margin-bottom: 35px; 
  display: flex; 
  justify-content: center; 
  gap: 18px; 
}
.social-links a {
  color: var(--navy); 
  background-color: var(--soft-pink); 
  width: 48px; height: 48px;
  display: inline-flex; justify-content: center; align-items: center; 
  border-radius: 50%;
  font-size: 22px; 
  text-decoration: none; 
  transition: all 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.social-links a:hover { 
  background-color: var(--white); 
  color: var(--pink-accent);
  transform: translateY(-8px) rotate(10deg); /* Efek terangkat dan sedikit memutar yang manis */
  box-shadow: 0 8px 20px rgba(255, 255, 255, 0.2);
}

.copyright { 
  font-size: 0.95rem; 
  color: rgba(255, 253, 249, 0.5); 
}
.copyright strong { color: var(--soft-pink); font-weight: 500; }


/* --- Responsivitas Mobile --- */
@media (max-width: 768px) {
  /* --- Penyesuaian Tombol Katalog di Layar Mobile --- */
  .catalog-btn-wrapper {
    margin-top: 35px; /* Jarak atas dirapatkan sedikit agar pas di layar HP */
    margin-bottom: 0;
  }

  .btn-catalog {
    font-size: 1rem; /* Huruf dikecilkan proporsional */
    padding: 14px 20px;
    border-width: 3px; /* Bingkai sedikit dipertipis */
  }

  /* Logo posisikan di tengah mutlak */
  .nav-container { justify-content: center; }
  .logo { position: absolute; left: 50%; transform: translateX(-50%); }
  .logo:hover img { transform: scale(1); }
  
  /* Layout Navbar di HP */
  .nav-container { 
    display: flex;
    justify-content: space-between; /* Menjauhkan toggle ke kiri dan WA ke kanan */
    align-items: center; 
  }
  
  .logo { position: absolute; left: 50%; transform: translateX(-50%); }
  .logo:hover img { transform: scale(1); }
  
  /* Aktifkan panel kiri (Toggle) dan kanan (WA Button) */
  .mobile-actions-left { display: block; z-index: 10; }
  .mobile-actions-right { display: block; z-index: 10; }
  
  /* Pengiriman Card menjadi ke bawah (tidak sejajar lagi) di layar HP */
  .pengiriman-grid {
    grid-template-columns: 1fr; 
  }
  
  .slide h1 { 
    font-size: 2.6rem; 
    line-height: 1.1; 
    letter-spacing: -0.5px; 
  } 
  .text-slider { height: 180px; } /* Di HP, tinggi kotak teks dikecilkan sedikit */
  .btn-scroll-down { margin-top: 15px; } /* Jarak tombol V dipersempit agar proporsional di HP */
  /* --- Penyesuaian Tombol V di Layar Mobile --- */
  .chevron-stack i {
    font-size: 28px; /* Mengecilkan ikon V dari 42px menjadi 28px */
    margin-bottom: -15px; /* Menyesuaikan tumpukan agar tetap rapi pada ukuran 28px */
  }
  
  .chevron-stack i:last-child {
    margin-bottom: 0; /* Memastikan batas bawah tetap aman */
  }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .gallery-item { border-radius: 16px; }

  /* Navbar Mobile Sliding */
  #navbar {
    position: fixed; top: 80px; left: -100%; width: 100%; height: calc(100vh - 80px);
    background: rgba(255, 253, 249, 0.98); backdrop-filter: blur(10px);
    transition: left 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
    display: flex; justify-content: center; align-items: flex-start; padding-top: 50px;
  }
  #navbar.active { left: 0; }
  .nav-links { flex-direction: column; gap: 30px; text-align: center; }
  .nav-links .nav-item { font-size: 20px; }
  .btn-wa { margin-top: 10px; }


  /* --- Penyesuaian Galeri & Tombol E-Commerce di Layar Mobile --- */
  .gallery-item-wrapper {
    border-radius: 16px;
    box-shadow: 0 4px 15px rgba(232, 165, 152, 0.2);
    background: var(--white); /* Mengembalikan warna background putih agar tombol punya alas */
  }
  
  .gallery-item {
    border-radius: 16px 16px 0 0;
  }

  .gallery-actions {
    position: relative; 
    bottom: 0;
    padding: 12px 10px 15px; 
    background: transparent;
    gap: 15px;
    
    /* Selalu tampil di mobile & Kembalikan posisi ke normal (tidak ada efek belah garis) */
    opacity: 1;
    transform: translateY(0);
  }

  /* KUNCI MOBILE: Sembunyikan teksnya agar kembali menjadi ikon bulat di HP */
  .shop-btn-text {
    display: none;
  }
  
  .btn-gallery-shop {
    width: 45px; 
    height: 45px;
    padding: 0; /* Hapus padding kapsul */
    border-radius: 50%; /* Paksa kembali menjadi bulat sempurna */
    background: var(--white); 
    border: 1px solid rgba(232, 165, 152, 0.5); 
    box-shadow: 0 4px 12px rgba(232, 165, 152, 0.3); 
    gap: 0;
  }
  
  .btn-gallery-shop img {
    height: 40px !important;
  }

}