/* =========================================================
   Clovia — penyempurnaan tampilan (aesthetic). File terpisah
   agar mudah dirawat & tidak menyentuh stylesheet template.
   ========================================================= */

/* 1. Latar section berselang — pink-krem muda, tepi atas & bawah memudar ke
   putih agar transisi ke section putih di sebelahnya halus (tanpa garis tegas) */
.section-soft {
    background: linear-gradient(
        180deg,
        #ffffff 0,
        #fef4f8 130px,
        #fef4f8 calc(100% - 130px),
        #ffffff 100%
    );
}

/* 2. Footer hangat — plum gelap (bukan hitam pekat) */
.footer { background-color: #43303b !important; }

/* Item fasilitas: overlay template (putih, persegi) diganti jadi MEMBULAT +
   isian SOFT PINK — menghilangkan "kotak putih" di sudut sekaligus memberi
   background pink lembut pada oval/ikon. Hover tetap berubah penuh warna. */
.facility-item .facility-icon::before,
.facility-item .facility-text::before {
    border-radius: 100%;
    background: rgba(252, 225, 238, .92);
}

/* 4. Kartu: soft shadow + efek hover terangkat */
.classes-item .bg-light,
.testimonial-item {
    box-shadow: 0 .5rem 1.5rem rgba(236, 95, 165, .10);
    transition: box-shadow .3s ease;
}
.classes-item,
.testimonial-item,
.facility-item { transition: transform .3s ease; }
.classes-item:hover,
.testimonial-item:hover { transform: translateY(-8px); }
.facility-item:hover { transform: translateY(-6px); }
.classes-item:hover .bg-light,
.testimonial-item:hover {
    box-shadow: 0 1rem 2.5rem rgba(236, 95, 165, .20);
}

/* 5. Aksen garis pink di bawah judul section (untuk judul rata-tengah) */
.section-title { position: relative; display: inline-block; padding-bottom: .7rem; }
.section-title::after {
    content: "";
    position: absolute; left: 50%; bottom: 0;
    transform: translateX(-50%);
    width: 60px; height: 4px; border-radius: 999px;
    background: linear-gradient(90deg, #ec5fa5, #f9b4d4);
}

/* =========================================================
   6. Navbar — tipografi & interaksi menu lebih aesthetic
   (font Quicksand + garis bawah gradien pink yang tumbuh halus)
   ========================================================= */
.navbar .navbar-nav .nav-link {
    font-family: 'Quicksand', 'Heebo', sans-serif;
    font-weight: 600;
    font-size: 1.02rem;
    letter-spacing: .015em;
    color: #5b4a53;                 /* plum-gray hangat, lebih lembut dari hitam */
    position: relative;
    transition: color .3s ease;
}

/* garis bawah gradien pink, tumbuh dari tengah saat hover / halaman aktif */
.navbar .navbar-nav .nav-link::after {
    content: "";
    position: absolute;
    left: 15px; right: 15px; bottom: 24px;
    height: 3px; border-radius: 999px;
    background: linear-gradient(90deg, #ec5fa5, #f9b4d4);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .35s cubic-bezier(.4, 0, .2, 1);
}
.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link.active { color: #ec5fa5; }
.navbar .navbar-nav .nav-link:hover::after,
.navbar .navbar-nav .nav-link.active::after { transform: scaleX(1); }

/* tombol CTA "Booking Sekarang": sedikit terangkat + bayangan pink saat hover */
.navbar .btn-primary {
    font-family: 'Quicksand', 'Heebo', sans-serif;
    font-weight: 700;
    letter-spacing: .015em;
    box-shadow: 0 .4rem 1rem rgba(236, 95, 165, .25);
    transition: transform .25s ease, box-shadow .25s ease;
}
.navbar .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 .6rem 1.4rem rgba(236, 95, 165, .35);
}

/* mobile (menu menumpuk): underline jadi aksen pendek rata kiri */
@media (max-width: 991.98px) {
    .navbar .navbar-nav .nav-link::after {
        left: 0; right: auto; bottom: 6px;
        width: 26px; transform-origin: left;
    }
}

/* === Sticky mobile action bar === */
@media (max-width: 991.98px) {
    /* beri ruang agar konten/footer tidak tertutup bar */
    body { padding-bottom: calc(64px + env(safe-area-inset-bottom)); }
}
.clovia-mobile-bar {
    display: flex;
    gap: .5rem;
    padding: .5rem .75rem calc(.5rem + env(safe-area-inset-bottom));
    background: #fff;
    box-shadow: 0 -.25rem .75rem rgba(0, 0, 0, .08);
    z-index: 1030;
}
.clovia-mobile-bar__btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: .75rem;
    border-radius: 50rem;
    font-weight: 600;
    text-decoration: none;
}
.clovia-mobile-bar__btn--wa   { flex: 1.4; background: #25D366; color: #fff; }
.clovia-mobile-bar__btn--book { background: #ec5fa5; color: #fff; }

/* =========================================================
   Booking wizard (multi-step). Progressive enhancement:
   tanpa JS semua step tampil (form panjang biasa). Saat JS
   aktif, <form> dapat class .js-wizard → hanya step aktif tampil.
   ========================================================= */
.js-wizard .wizard-step { display: none; }
.js-wizard .wizard-step.is-active { display: block; animation: cloviaFade .25s ease; }
@keyframes cloviaFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* Progress: angka + label */
.booking-steps {
    list-style: none;
    display: flex;
    gap: .25rem;
    padding: 0;
    margin: 0 0 .5rem;
}
.booking-steps li {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .25rem;
    font-size: .72rem;
    font-weight: 600;
    color: #b9a7af;
    text-align: center;
    line-height: 1.1;
}
.booking-steps li span {
    width: 30px; height: 30px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: #f0e3ea; color: #b9a7af;
    font-size: .85rem;
    transition: background .2s, color .2s;
}
.booking-steps li.is-active span { background: #ec5fa5; color: #fff; }
.booking-steps li.is-active { color: #ec5fa5; }
.booking-steps li.is-done span { background: #f6c8df; color: #ec5fa5; }

.booking-progress { height: 5px; background: #f0e3ea; border-radius: 50rem; overflow: hidden; margin-bottom: 1.5rem; }
.booking-progress__bar { display: block; height: 100%; width: 33.33%; background: #ec5fa5; border-radius: 50rem; transition: width .3s ease; }

/* Step 1 — kartu layanan */
.service-picker { display: flex; flex-direction: column; gap: .6rem; }
.service-card {
    position: relative;
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .6rem;
    background: #fff;
    border: 2px solid #eee;
    border-radius: 14px;
    cursor: pointer;
    margin: 0;
    transition: border-color .15s, box-shadow .15s;
}
.service-card:focus-within { box-shadow: 0 0 0 .2rem rgba(236, 95, 165, .25); }
.service-card input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.service-card > img { width: 56px; height: 56px; border-radius: 12px; object-fit: cover; flex-shrink: 0; }
.service-card__body { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.service-card__name { font-weight: 700; color: #444; line-height: 1.2; }
.service-card__meta { display: flex; flex-wrap: wrap; gap: .25rem .75rem; font-size: .72rem; color: #9a8f93; margin-top: .15rem; }
.service-card__meta i { color: #ec5fa5; }
.service-card__price { font-size: .8rem; font-weight: 600; color: #ec5fa5; margin-top: .15rem; }
.service-card__tick { position: absolute; top: .5rem; right: .6rem; color: #ec5fa5; opacity: 0; transition: opacity .15s; }
.service-card.is-selected,
.service-card:has(input:checked) { border-color: #ec5fa5; background: #fff7fb; }
.service-card.is-selected .service-card__tick,
.service-card:has(input:checked) .service-card__tick { opacity: 1; }

/* Step 2 — slot waktu */
.time-slots { display: flex; flex-wrap: wrap; gap: .5rem; }
.time-slot {
    border: 1.5px solid #e7d7df;
    background: #fff;
    color: #6b5d63;
    border-radius: 50rem;
    padding: .45rem 1rem;
    font-weight: 600;
    font-size: .9rem;
    cursor: pointer;
    transition: all .15s;
}
.time-slot:hover { border-color: #ec5fa5; color: #ec5fa5; }
.time-slot.is-selected { background: #ec5fa5; border-color: #ec5fa5; color: #fff; }
.time-slots__empty { color: #9a8f93; font-size: .85rem; }

/* Navigasi & validasi */
.wizard-nav { display: flex; justify-content: space-between; align-items: center; gap: .75rem; margin-top: 1.5rem; }
.wizard-error { color: #dc3545; font-size: .825rem; margin-top: .4rem; }
.wizard-step .form-control.is-invalid { border-color: #dc3545; }
.booking-recap {
    background: #fff7fb;
    border: 1px solid #f6c8df;
    border-radius: 12px;
    padding: .85rem 1rem;
    margin-top: 1.25rem;
    font-size: .875rem;
    color: #6b5d63;
}
.booking-recap strong { color: #444; }
