﻿/* =============================================
   HomeClik — Booking Page CSS (booking.css)
   ============================================= */

/* ---- Page base ---- */
.booking-body { background: var(--bg); }

/* ---- Booking Hero Banner ---- */
.bk-hero {
  position: relative; height: 360px;
  display: flex; align-items: flex-end;
  overflow: hidden;
}
.bk-hero-bg { position: absolute; inset: 0; }
.bk-hero-img { width:100%; height:100%; object-fit:cover; transform:scale(1.05); }
.bk-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(10,10,15,0.7) 0%, rgba(10,10,15,0.92) 100%);
}
.bk-hero-content {
  position: relative; z-index: 2;
  width: 100%; padding: 0 60px 40px;
}
.breadcrumb { color: var(--text-muted); font-size:0.8rem; margin-bottom:10px; }
.breadcrumb a { color:var(--gold); text-decoration:none; }
.breadcrumb span { margin: 0 8px; }
.bk-hero-title {
  font-family:'Playfair Display',serif;
  font-size: clamp(1.8rem,4vw,3rem); line-height:1.2;
  margin-bottom:10px;
}
.bk-hero-sub { color:var(--text-muted); font-size:0.95rem; margin-bottom:28px; }

/* Progress Pills */
.step-pills {
  display: flex; align-items: center; gap: 0; flex-wrap: wrap; gap: 6px;
}
.pill {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 16px; border-radius: 50px;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  font-size: 0.78rem; color: var(--text-muted); transition: all 0.4s;
  cursor: default;
}
.pill.active { background: var(--gold); border-color: var(--gold); color: #000; }
.pill.done { background: rgba(var(--primary-rgb), 0.15); border-color: rgba(var(--primary-rgb), 0.4); color: var(--gold); }
.pill-num {
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(255,255,255,0.15); display: flex; align-items:center; justify-content:center;
  font-weight: 700; font-size: 0.75rem;
}
.pill.active .pill-num { background: rgba(0,0,0,0.2); }
.pill-line { width: 28px; height: 1px; background: rgba(255,255,255,0.15); flex-shrink:0; }

/* ---- Main Layout ---- */
.bk-main { padding: 48px 0 80px; }
.bk-container {
  max-width: 1200px; margin: 0 auto; padding: 0 40px;
  display: grid; grid-template-columns: 1fr 340px; gap: 40px; align-items: start;
}

/* ---- Step Panels ---- */
.bk-step { display: none; animation: step-slide 0.5s cubic-bezier(0.16,1,0.3,1) both; }
.bk-step.active { display: block; }
@keyframes step-slide {
  from { opacity:0; transform: translateX(40px); }
  to { opacity:1; transform: translateX(0); }
}
.bk-step.slide-back { animation: step-slide-back 0.5s cubic-bezier(0.16,1,0.3,1) both; }
@keyframes step-slide-back {
  from { opacity:0; transform: translateX(-40px); }
  to { opacity:1; transform: translateX(0); }
}

.step-head { margin-bottom: 36px; }
.step-badge {
  display: inline-block; background: rgba(var(--primary-rgb), 0.12);
  border: 1px solid rgba(var(--primary-rgb), 0.3); color: var(--gold);
  padding: 4px 14px; border-radius:50px; font-size:0.75rem; font-weight:700;
  letter-spacing: 1.5px; text-transform:uppercase; margin-bottom: 12px;
}
.step-head h2 { font-family:'Playfair Display',serif; font-size:clamp(1.5rem,3vw,2.2rem); margin-bottom:10px; }
.step-head p { color:var(--text-muted); font-size:0.9rem; line-height:1.6; }

/* ---- Package Selection Grid ---- */
.pkg-grid { display: flex; flex-direction:column; gap: 14px; margin-bottom:24px; }
.pkg-card {
  position: relative; cursor: none;
  border: 1px solid var(--border); border-radius: 14px;
  overflow: hidden; transition: border-color 0.3s, box-shadow 0.3s;
  background: var(--surface);
}
.pkg-card:hover { border-color: rgba(var(--primary-rgb), 0.4); box-shadow: 0 8px 24px rgba(0,0,0,0.3); }
.pkg-radio { position:absolute; opacity:0; width:0; height:0; }
.pkg-card:has(.pkg-radio:checked) {
  border-color: var(--gold);
  background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.08), var(--surface));
  box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.3), 0 12px 30px rgba(0,0,0,0.3);
}
.pkg-inner {
  display: flex; align-items: center; gap: 18px;
  padding: 20px 22px; position:relative;
}
.pkg-check {
  position:absolute; top:14px; right:14px;
  width: 26px; height: 26px; border-radius:50%;
  border: 2px solid rgba(var(--primary-rgb), 0.3);
  display: flex; align-items:center; justify-content:center;
  font-size:0.8rem; color: transparent;
  transition: all 0.3s; background: transparent;
}
.pkg-card:has(.pkg-radio:checked) .pkg-check {
  background: var(--gold); border-color: var(--gold); color: #000; font-weight:700;
}
.pkg-popular-tag {
  position: absolute; top: 0; left: 0;
  background: linear-gradient(135deg, var(--gold-dark), var(--gold));
  color: #000; font-size:0.65rem; font-weight:700;
  padding: 3px 10px; letter-spacing:1px;
  border-radius: 13px 0 8px 0;
}
.pkg-icon { font-size: 2rem; flex-shrink:0; }
.pkg-info { flex:1; }
.pkg-info h3 { font-size:1rem; font-weight:600; margin-bottom:6px; }
.pkg-tags { display:flex; gap:6px; margin-bottom:8px; flex-wrap:wrap; }
.pkg-tags span {
  background: rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.1);
  padding:2px 10px; border-radius:50px; font-size:0.7rem; color:var(--text-muted);
}
.pkg-card:has(.pkg-radio:checked) .pkg-tags span {
  background: rgba(var(--primary-rgb), 0.12); border-color:rgba(var(--primary-rgb), 0.3); color:var(--gold);
}
.pkg-info p { color:var(--text-muted); font-size:0.82rem; line-height:1.5; }
.pkg-price-badge {
  font-family:'Playfair Display',serif; font-size:1.05rem;
  color:var(--gold); font-weight:700; white-space:nowrap;
  background: rgba(var(--primary-rgb), 0.1); padding: 6px 14px; border-radius:8px;
}
.pkg-err { color:#ff6b6b; font-size:0.85rem; margin-top:-12px; margin-bottom:16px; }
.pkg-err.hidden { display:none; }

/* ---- Form Fields ---- */
.bk-fields { display:flex; flex-direction:column; gap:0; margin-bottom:32px; }
.bk-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.bk-fg { display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.bk-fg label { font-size:0.78rem; font-weight:600; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-muted); }
.req { color: var(--gold); }
.bk-fg input, .bk-fg select, .bk-fg textarea {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text); border-radius:10px; padding:13px 16px;
  font-size:0.9rem; font-family:'Inter',sans-serif; outline:none;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.bk-fg input:focus, .bk-fg select:focus, .bk-fg textarea:focus {
  border-color: rgba(var(--primary-rgb), 0.6);
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.1);
}
.bk-fg input::placeholder, .bk-fg textarea::placeholder { color: rgba(155,153,176,0.5); }
.bk-fg input.error, .bk-fg select.error { border-color: #ff6b6b; }
.bk-fg textarea { resize:vertical; }

/* Radio group (location type) */
.radio-group { display:flex; gap:12px; flex-wrap:wrap; }
.radio-opt { cursor:none; flex:1; min-width:140px; }
.radio-opt input { display:none; }
.radio-box {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding:16px 12px; border:1px solid var(--border);
  border-radius:12px; background:var(--surface);
  font-size:0.82rem; text-align:center; color:var(--text-muted);
  transition: all 0.3s;
}
.radio-opt:has(input:checked) .radio-box {
  border-color:var(--gold); background:rgba(var(--primary-rgb), 0.1); color:var(--text);
  box-shadow: 0 0 0 2px rgba(var(--primary-rgb), 0.2);
}
.r-icon { font-size:1.6rem; }

/* ---- Navigation buttons ---- */
.step-nav { display:flex; justify-content:space-between; align-items:center; margin-top:8px; }
.btn-next {
  background: linear-gradient(135deg, var(--gold-dark), var(--gold));
  color:#000; border:none; padding:14px 30px; border-radius:50px;
  font-size:0.95rem; font-weight:700; cursor:none;
  transition: transform 0.3s, box-shadow 0.3s;
}
.btn-next:hover { transform:translateY(-2px); box-shadow:0 12px 28px rgba(var(--primary-rgb), 0.4); }
.btn-back {
  background:transparent; border:1px solid var(--border); color:var(--text-muted);
  padding:13px 24px; border-radius:50px; font-size:0.9rem; cursor:none;
  transition:all 0.3s;
}
.btn-back:hover { border-color:var(--gold); color:var(--text); }
.btn-confirm {
  background: linear-gradient(135deg, #2d6a2d, #4caf50);
  color:#fff; border:none; padding:14px 34px; border-radius:50px;
  font-size:1rem; font-weight:700; cursor:none;
  display:flex; align-items:center; gap:10px;
  transition: transform 0.3s, box-shadow 0.3s;
}
.btn-confirm:hover { transform:translateY(-2px); box-shadow:0 12px 28px rgba(76,175,80,0.4); }
.btn-confirm:disabled { opacity:0.6; cursor:default; }
.btn-spinner {
  width:18px; height:18px; border:2px solid rgba(255,255,255,0.4);
  border-top-color:#fff; border-radius:50%;
  animation:spin 0.8s linear infinite;
}
.btn-spinner.hidden { display:none; }

/* T&C checkbox */
.tc-label {
  display:flex; align-items:flex-start; gap:12px;
  margin-bottom:24px; cursor:none; font-size:0.85rem; color:var(--text-muted);
  line-height:1.5;
}
.tc-label input { display:none; }
.tc-box {
  width:20px; height:20px; min-width:20px;
  border:2px solid var(--border); border-radius:5px;
  background:var(--surface); display:flex; align-items:center; justify-content:center;
  transition:all 0.3s; margin-top:1px;
}
.tc-label:has(input:checked) .tc-box {
  background:var(--gold); border-color:var(--gold); color:#000;
}
.tc-label:has(input:checked) .tc-box::after { content:'✓'; font-size:0.75rem; font-weight:700; }
.gold-link { color:var(--gold); text-decoration:none; }
.gold-link:hover { text-decoration:underline; }

/* ---- Review Card ---- */
.review-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:16px; overflow:hidden; margin-bottom:24px;
}
.review-section { padding:20px 24px; border-bottom:1px solid var(--border); }
.review-section:last-child { border-bottom:none; }
.review-section h4 { font-size:0.8rem; text-transform:uppercase; letter-spacing:1.5px; color:var(--gold); margin-bottom:14px; }
.review-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:6px 0; font-size:0.88rem;
}
.review-row span { color:var(--text-muted); }
.review-row strong { color:var(--text); text-align:right; max-width:60%; }
.review-note {
  display:flex; gap:12px; align-items:flex-start;
  background:rgba(var(--primary-rgb), 0.07); border:1px solid rgba(var(--primary-rgb), 0.2);
  padding:14px 18px; border-radius:10px; margin:0 24px 20px; font-size:0.82rem; color:var(--text-muted);
}
.review-note span { font-size:1.2rem; flex-shrink:0; }

/* ---- SUCCESS SCREEN ---- */
.success-screen { text-align:center; padding:40px 20px; }
.success-burst {
  position:relative; width:100px; height:100px;
  margin:0 auto 32px;
}
.burst-ring {
  position:absolute; border-radius:50%; border:2px solid var(--gold);
  animation: burst-anim 1.2s ease-out forwards;
}
.r1 { inset:0; animation-delay:0s; }
.r2 { inset:-12px; animation-delay:0.15s; }
.r3 { inset:-24px; animation-delay:0.3s; }
@keyframes burst-anim {
  0% { opacity:0.8; transform:scale(0.5); }
  100% { opacity:0; transform:scale(1.2); }
}
.success-icon {
  position:absolute; inset:0; border-radius:50%;
  background:linear-gradient(135deg, #2d6a2d,#4caf50);
  display:flex; align-items:center; justify-content:center;
  font-size:2.5rem; color:#fff; z-index:1;
  animation: pop-in 0.5s 0.2s cubic-bezier(0.175,0.885,0.32,1.275) both;
}
.success-screen h2 { font-family:'Playfair Display',serif; font-size:clamp(1.5rem,4vw,2.5rem); margin-bottom:16px; }
.success-sub { color:var(--text-muted); font-size:1rem; max-width:500px; margin:0 auto 24px; line-height:1.7; }
.success-ref {
  display:inline-block; background:rgba(var(--primary-rgb), 0.1); border:1px solid rgba(var(--primary-rgb), 0.3);
  border-radius:8px; padding:10px 24px; font-size:0.9rem; margin-bottom:28px; color:var(--text-muted);
}
.success-ref strong { color:var(--gold); font-size:1rem; }
.success-summary {
  background:var(--surface); border:1px solid var(--border);
  border-radius:12px; padding:20px 28px; margin:0 auto 32px;
  max-width:420px; text-align:left;
}
.ss-row { display:flex; justify-content:space-between; padding:7px 0; font-size:0.88rem; }
.ss-row span { color:var(--text-muted); }
.ss-row strong { color:var(--text); }
.success-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:32px; }
.social-share p { color:var(--text-muted); font-size:0.85rem; margin-bottom:12px; }
.share-btns { display:flex; gap:12px; justify-content:center; }
.share-btn {
  padding:10px 20px; border-radius:50px; font-size:0.85rem; font-weight:600;
  text-decoration:none; transition:transform 0.3s;
}
.share-btn:hover { transform:translateY(-2px); }
.share-btn.ig { background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045); color:#fff; }
.share-btn.wa { background:#25d366; color:#fff; }

/* ---- Right Sidebar ---- */
.bk-sidebar { position:sticky; top:100px; display:flex; flex-direction:column; gap:20px; }
.sidebar-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:16px; padding:24px; overflow:hidden;
}
.sb-title { font-family:'Playfair Display',serif; font-size:1.1rem; margin-bottom:18px; }
.sb-service { display:flex; align-items:center; gap:14px; margin-bottom:4px; }
.sb-svc-icon { font-size:2rem; }
.sb-svc-name { font-weight:600; font-size:0.95rem; color:var(--text); }
.sb-svc-price { color:var(--gold); font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; margin-top:4px; }
.sb-divider { height:1px; background:var(--border); margin:18px 0; }
.sb-includes h4 { font-size:0.75rem; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); margin-bottom:12px; }
#sb-features { list-style:none; display:flex; flex-direction:column; gap:8px; }
#sb-features li { font-size:0.85rem; color:var(--text-muted); display:flex; align-items:center; gap:8px; }
#sb-features li::before { content:'✓'; color:var(--gold); font-weight:700; }
#sb-features li.muted::before { display:none; }
.sb-why h4 { font-size:0.75rem; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); margin-bottom:12px; }
.sb-why-item { display:flex; gap:8px; font-size:0.82rem; color:var(--text-muted); margin-bottom:8px; align-items:center; }
.sb-contact p { color:var(--text-muted); font-size:0.82rem; margin-bottom:10px; }
.sb-call-btn {
  display:block; text-align:center; text-decoration:none;
  background:rgba(201,168,76,0.12); border:1px solid rgba(201,168,76,0.3);
  color:var(--gold); padding:10px; border-radius:10px; font-weight:600; font-size:0.88rem;
  transition:background 0.3s, transform 0.3s;
}
.sb-call-btn:hover { background:var(--gold); color:#000; transform:translateY(-2px); }

/* Sidebar step tracker */
.sb-progress { background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:24px; }
.sp-step { display:flex; align-items:center; gap:14px; }
.sp-dot {
  width:32px; height:32px; min-width:32px;
  border-radius:50%; border:2px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:0.8rem; font-weight:700; color:var(--text-muted);
  transition:all 0.4s;
}
.sp-step.active .sp-dot { border-color:var(--gold); background:var(--gold); color:#000; }
.sp-step.done .sp-dot { border-color:var(--gold); background:rgba(201,168,76,0.2); color:var(--gold); }
.sp-info strong { display:block; font-size:0.85rem; color:var(--text-muted); }
.sp-step.active .sp-info strong { color:var(--text); }
.sp-step.done .sp-info strong { color:var(--gold); }
.sp-info small { font-size:0.75rem; color:rgba(155,153,176,0.6); }
.sp-line { width:2px; height:24px; background:var(--border); margin:4px 0 4px 15px; transition:background 0.4s; }
.sp-line.done { background:var(--gold); }

/* Minimal footer override */
.bk-footer { padding: 0; }
.bk-footer .footer-bottom { padding: 20px 0; }

/* Validation shake */
@keyframes shake {
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-6px)}
  40%,80%{transform:translateX(6px)}
}
.shake { animation:shake 0.4s ease; }

/* ---- Responsive ---- */
@media (max-width:1024px) {
  .bk-container { grid-template-columns:1fr; }
  .bk-sidebar { position:static; flex-direction:row; flex-wrap:wrap; }
  .sidebar-card, .sb-progress { flex:1; min-width:280px; }
  .bk-hero-content { padding: 0 30px 40px; }
}
@media (max-width:768px) {
  .bk-hero { height:auto; padding-top:90px; }
  .bk-hero-content { padding:0 20px 30px; }
  .bk-container { padding:0 20px; }
  .bk-row { grid-template-columns:1fr; }
  .step-pills { gap:4px; }
  .pill { padding:6px 10px; font-size:0.7rem; }
  .pill-label { display:none; }
  .bk-sidebar { flex-direction:column; }
}

/* Enable theme transitions for booking client components */
.pill, .pkg-card, .pkg-check, .pkg-tags span, .pkg-price-badge, .bk-fg input, .bk-fg select, .bk-fg textarea, .radio-box, .btn-next, .btn-back, .btn-confirm, .tc-box, .review-card, .review-note, .success-ref, .success-summary, .sidebar-card, .sb-progress, .sp-dot, .sp-line {
  transition: var(--theme-transition);
}

