/* ═══════════════════════════════════════════════════
   AC Booking — Frontend Styles
   Design: deep crimson/pink + white cards + navy CTA
═══════════════════════════════════════════════════ */

#acb-wrap {
	--c-primary:     #8C1B4A;
	--c-primary-d:   #7A1640;
	--c-primary-dd:  #631232;
	--c-navy:        #1B2A4A;
	--c-navy-d:      #0F1D35;
	--c-white:       #FFFFFF;
	--c-green:       #27ae60;
	--c-w10:         rgba(255,255,255,0.10);
	--c-w20:         rgba(255,255,255,0.20);
	--c-w30:         rgba(255,255,255,0.30);
	--c-w60:         rgba(255,255,255,0.60);
	--c-w80:         rgba(255,255,255,0.80);
	--c-border:      rgba(255,255,255,0.22);
	--r:             8px;
	--r-sm:          6px;
	--font:          'Poppins', 'Inter', -apple-system, sans-serif;
}

/* ── Wrapper ──────────────────────────────────── */
.acb-wrap {
	font-family:   var(--font);
	background:    var(--c-primary);
	border-radius: 10px;
	overflow:      hidden;
	box-shadow:    0 8px 40px rgba(0,0,0,0.18);
	max-width:     920px;
	margin:        0 auto;
}

/* ── Step Progress Bar ────────────────────────── */
.acb-steps-bar {
	display:       flex;
	background:    var(--c-primary-dd);
	border-bottom: 1px solid var(--c-w10);
}

.acb-step {
	flex:1;display:flex;flex-direction:column;align-items:center;
	justify-content:center;gap:5px;padding:13px 6px;
	color:var(--c-w60);position:relative;transition:all .2s;
}

.acb-step:not(:last-child)::after {
	content:'';position:absolute;right:0;top:20%;
	height:60%;width:1px;background:var(--c-w10);
}

.acb-step-icon { display:flex;align-items:center;opacity:.5;transition:opacity .2s; }
.acb-step-label { font-size:11px;font-weight:500;text-align:center;line-height:1.3; }

.acb-step.active { color:var(--c-white); }
.acb-step.active .acb-step-icon { opacity:1; }
.acb-step.active .acb-step-label { font-weight:700; }
.acb-step.active::before {
	content:'';position:absolute;bottom:0;left:10%;width:80%;
	height:3px;background:var(--c-white);border-radius:2px 2px 0 0;
}
.acb-step.done { color:var(--c-w80); }
.acb-step.done .acb-step-icon { opacity:.7; }

/* ── Panels ───────────────────────────────────── */
.acb-panel { background:var(--c-primary);min-height:440px;display:flex;flex-direction:column; }
.acb-panel-inner { flex:1;padding:24px; }
.acb-panel-title { color:var(--c-white);font-size:18px;font-weight:700;margin:0 0 16px;letter-spacing:-.01em; }

/* ── Filter Tabs ──────────────────────────────── */
.acb-filter-tabs { display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px; }
.acb-filter-btn {
	padding:5px 15px;border-radius:50px;font-size:13px;font-weight:600;
	cursor:pointer;transition:all .2s;border:2px solid var(--c-w30);
	background:transparent;color:var(--c-w80);font-family:var(--font);
}
.acb-filter-btn:hover { border-color:var(--c-w60);color:var(--c-white); }
.acb-filter-btn.active { background:var(--c-navy);border-color:var(--c-navy);color:var(--c-white); }

/* ── Service Group Heading ────────────────────── */
.acb-group-wrap { margin-bottom:22px; }
.acb-group-title { color:var(--c-white);font-size:14px;font-weight:700;margin:0 0 10px;letter-spacing:.01em; }

/* ── Service Cards Grid ───────────────────────── */
.acb-cards-grid { display:grid;grid-template-columns:1fr 1fr;gap:10px; }
@media(max-width:580px){ .acb-cards-grid { grid-template-columns:1fr; } }

/* ── Individual Card ──────────────────────────── */
.acb-card {
	background:var(--c-white);border-radius:var(--r);
	padding:12px;cursor:pointer;border:2px solid transparent;
	transition:all .2s;position:relative;display:flex;flex-direction:column;gap:8px;
}
.acb-card:hover { border-color:var(--c-primary-d);box-shadow:0 3px 14px rgba(0,0,0,.14);transform:translateY(-1px); }
.acb-card.selected { border-color:var(--c-navy); }

.acb-card-head { display:flex;align-items:flex-start;gap:10px; }
.acb-card-img { width:60px;height:60px;border-radius:var(--r-sm);object-fit:cover;flex-shrink:0;background:#ececec;display:flex;align-items:center;justify-content:center;font-size:22px; }
.acb-card-info { flex:1;min-width:0; }
.acb-card-title { font-size:13px;font-weight:700;color:#1a1a2e;margin:0 0 4px;line-height:1.3; }
.acb-card-desc { font-size:11.5px;color:#555;line-height:1.55;margin:0; }

.acb-price-row { display:flex;align-items:center;gap:8px;margin-top:auto; }
.acb-price-lbl { font-size:12px;color:#666;font-weight:500; }
.acb-price-badge { background:var(--c-navy);color:var(--c-white);font-size:12px;font-weight:700;padding:3px 10px;border-radius:50px; }

.acb-card-tick {
	position:absolute;top:8px;right:8px;width:22px;height:22px;
	background:var(--c-green);border-radius:50%;display:none;
	align-items:center;justify-content:center;
}
.acb-card-tick svg { color:#fff; }
.acb-card.selected .acb-card-tick { display:flex; }

/* ── Options Expand Panel ─────────────────────── */
.acb-options-panel {
	background:var(--c-primary-d);border-radius:var(--r);
	padding:16px;margin:14px 0;border:1px solid var(--c-w20);
	animation:acb-fadein .25s ease;
}

.acb-opt-row {
	display:flex;align-items:center;justify-content:space-between;
	padding:9px 0;border-bottom:1px solid var(--c-w10);
}
.acb-opt-row:last-child { border-bottom:none; }
.acb-opt-lbl { color:var(--c-white);font-size:14px;font-weight:600; }

.acb-opt-sel {
	appearance:none;background:var(--c-primary);border:1px solid var(--c-w30);
	border-radius:var(--r-sm);color:var(--c-white);font-size:13px;font-weight:600;
	padding:7px 30px 7px 12px;cursor:pointer;min-width:160px;font-family:var(--font);
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='white' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat:no-repeat;background-position:right 10px center;
}
.acb-opt-sel option { background:var(--c-primary-d); }

/* Stepper */
.acb-stepper { display:flex;align-items:center;overflow:hidden;border:1px solid var(--c-w30);border-radius:var(--r-sm); }
.acb-stepper-btn { background:var(--c-primary);border:none;color:var(--c-white);width:32px;height:34px;font-size:18px;cursor:pointer;transition:background .15s;font-weight:600;display:flex;align-items:center;justify-content:center; }
.acb-stepper-btn:hover { background:var(--c-primary-dd); }
.acb-stepper-val { color:var(--c-white);font-weight:700;font-size:14px;min-width:44px;text-align:center;background:var(--c-primary-d);height:34px;line-height:34px; }

/* Add-on */
.acb-addon-wrap { display:flex;align-items:center;gap:10px; }
.acb-addon-cb { width:16px;height:16px;accent-color:var(--c-navy);cursor:pointer; }
.acb-addon-lbl { color:var(--c-white);font-size:13px;font-weight:500;cursor:pointer; }
.acb-addon-price { color:var(--c-white);font-weight:700;font-size:13px; }
.acb-addon-stepper { opacity:.35;transition:opacity .2s; }
.acb-addon-stepper.active { opacity:1; }

/* ── Step 1 Bottom Bar ────────────────────────── */
.acb-step1-bar {
	display:flex;align-items:center;justify-content:space-between;
	padding:14px 24px 18px;border-top:1px solid var(--c-w20);
	background:var(--c-primary);
}
.acb-step1-actions { display:flex;gap:10px; }

/* ── Step Footer ──────────────────────────────── */
.acb-footer {
	display:flex;align-items:center;justify-content:space-between;
	padding:14px 24px 18px;border-top:1px solid var(--c-w20);
	background:var(--c-primary);
}

/* ── Buttons ──────────────────────────────────── */
.acb-btn {
	display:inline-flex;align-items:center;gap:6px;
	font-family:var(--font);font-weight:600;font-size:14px;line-height:1;
	padding:10px 18px;border-radius:var(--r-sm);cursor:pointer;
	transition:all .2s;border:2px solid transparent;text-decoration:none;white-space:nowrap;
}
.acb-btn-cta { background:var(--c-navy);color:var(--c-white);border-color:var(--c-navy); }
.acb-btn-cta:hover { background:var(--c-navy-d);border-color:var(--c-navy-d); }
.acb-btn-cta:disabled { opacity:.6;cursor:not-allowed; }
.acb-btn-ghost { background:transparent;color:var(--c-w80);border-color:transparent; }
.acb-btn-ghost:hover { color:var(--c-white);background:var(--c-w10); }
.acb-btn-outline { background:transparent;color:var(--c-white);border-color:var(--c-w30); }
.acb-btn-outline:hover { background:var(--c-w10);border-color:var(--c-w60); }

.acb-spinner {
	width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
	border-radius:50%;animation:acb-spin .6s linear infinite;margin-left:4px;display:inline-block;
}

/* ── Step 2 Form ──────────────────────────────── */
.acb-form-grid { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
@media(max-width:600px){ .acb-form-grid { grid-template-columns:1fr; } }
.acb-field-full { grid-column:1/-1; }
.acb-field { display:flex;flex-direction:column;gap:5px; }
.acb-label { color:var(--c-white);font-size:13.5px;font-weight:600;display:block; }
.acb-req { color:#ff9999; }
.acb-input {
	background:rgba(255,255,255,.08);border:1.5px solid var(--c-border);
	border-radius:var(--r-sm);color:var(--c-white);font-size:15px;
	font-family:var(--font);padding:11px 14px;width:100%;box-sizing:border-box;
	transition:border-color .2s,background .2s;outline:none;
}
.acb-input::placeholder { color:rgba(255,255,255,.28); }
.acb-input:focus { border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.12); }
.acb-input.error { border-color:#ff6b6b; }
.acb-textarea { resize:vertical;min-height:100px;line-height:1.6; }
.acb-err { color:#ff9999;font-size:12px;font-weight:500; }

/* ── Step 3 Cart ──────────────────────────────── */
.acb-cart-inner { padding:18px 24px; }
.acb-cart-header { display:flex;align-items:center;justify-content:space-between;margin-bottom:16px; }
.acb-cart-title-row { display:flex;align-items:center;gap:10px; }
.acb-cart-badge { background:var(--c-navy);color:var(--c-white);font-size:11px;font-weight:700;padding:3px 10px;border-radius:50px; }

.acb-cart-item { padding:14px 0;border-bottom:1px solid var(--c-w20); }
.acb-cart-item-top { display:flex;align-items:center;gap:10px;justify-content:space-between; }
.acb-cart-item-left { display:flex;align-items:center;gap:10px;flex:1; }
.acb-cart-remove { background:transparent;border:none;color:var(--c-w60);cursor:pointer;padding:4px;border-radius:50%;transition:all .2s;display:flex;align-items:center; }
.acb-cart-remove:hover { color:#ff9999;background:rgba(255,100,100,.1); }
.acb-cart-thumb { width:44px;height:44px;border-radius:var(--r-sm);object-fit:cover;background:var(--c-w10);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px; }
.acb-cart-name { color:var(--c-white);font-size:14px;font-weight:600;flex:1; }
.acb-cart-price { color:var(--c-white);font-weight:700;font-size:15px;white-space:nowrap; }

.acb-cart-details { display:flex;gap:18px;padding:8px 0 0 54px;flex-wrap:wrap; }
.acb-detail-col { display:flex;flex-direction:column;gap:1px; }
.acb-detail-key { color:var(--c-w60);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em; }
.acb-detail-val { color:var(--c-white);font-size:13px;font-weight:600; }

.acb-cart-total-row {
	display:flex;justify-content:space-between;align-items:center;
	padding:14px 0 0;border-top:1px solid var(--c-w30);
}
.acb-cart-total-row>span:first-child { color:var(--c-white);font-size:14px;font-weight:700; }
#acb-grand-total { color:var(--c-white);font-size:18px;font-weight:700; }

/* ── Step 4 Overview ──────────────────────────── */
.acb-overview-section { margin-bottom:18px; }
.acb-overview-heading { color:var(--c-white);font-size:14px;font-weight:700;margin:0 0 10px;padding-bottom:7px;border-bottom:1px solid var(--c-w20); }
.acb-overview-row { display:flex;gap:12px;padding:7px 0;border-bottom:1px solid var(--c-w10); }
.acb-overview-row:last-child { border-bottom:none; }
.acb-ov-key { color:var(--c-w60);font-size:13px;min-width:120px;flex-shrink:0; }
.acb-ov-val { color:var(--c-white);font-size:13px;font-weight:500; }
.acb-ov-total { display:flex;justify-content:space-between;padding:12px 0;border-top:2px solid var(--c-w30);margin-top:6px; }
.acb-ov-total span { color:var(--c-white);font-size:16px;font-weight:700; }

/* ── Success ──────────────────────────────────── */
.acb-success-wrap { text-align:center;padding:50px 20px;display:flex;flex-direction:column;align-items:center;gap:12px; }
.acb-success-check { width:68px;height:68px;color:#4ade80;margin-bottom:6px;animation:acb-pop .4s ease; }
.acb-success-wrap h2 { color:var(--c-white);font-size:24px;font-weight:700;margin:0; }
.acb-ref,.acb-success-wrap p { color:var(--c-w80);font-size:14px;margin:0;max-width:400px; }
.acb-conf-email { color:var(--c-w60)!important;font-size:13px!important; }

/* ── Loading ──────────────────────────────────── */
.acb-loading { text-align:center;padding:50px 20px;color:var(--c-w60);font-size:14px; }
.acb-spin { width:36px;height:36px;border:3px solid var(--c-w20);border-top-color:var(--c-white);border-radius:50%;margin:0 auto 12px;animation:acb-spin .8s linear infinite; }
.acb-no-services { color:var(--c-w60);text-align:center;padding:40px;font-size:14px; }

/* ── Stripe Payment ───────────────────────────── */
.acb-payment-box {
	background:    var(--c-primary-d);
	border:        1px solid var(--c-w20);
	border-radius: var(--r);
	padding:       20px;
	margin:        20px 0 0;
}
.acb-payment-title {
	color:       var(--c-white);
	font-size:   15px;
	font-weight: 700;
	margin:      0 0 16px;
}
#acb-stripe-element {
	background:    rgba(255,255,255,0.08);
	border:        1.5px solid var(--c-border);
	border-radius: var(--r-sm);
	padding:       14px;
	min-height:    48px;
	transition:    border-color .2s;
}
#acb-stripe-element.StripeElement--focus { border-color: rgba(255,255,255,.55); }
#acb-stripe-element.StripeElement--invalid { border-color: #ff6b6b; }
.acb-stripe-err {
	color:      #ff9999;
	font-size:  13px;
	margin-top: 8px;
	font-weight: 500;
}
.acb-stripe-note {
	color:     var(--c-w60);
	font-size: 12px;
	margin:    12px 0 0;
}
/* ── Admin payment badge ──────────────────────── */
.acb-pay-badge { display:inline-block;padding:2px 10px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em; }
.acb-pay-unpaid  { background:#ffeaa7;color:#b7791f; }
.acb-pay-paid    { background:#d4edda;color:#155724; }
.acb-pay-failed  { background:#f8d7da;color:#721c24; }
.acb-pay-refunded{ background:#e2e3e5;color:#383d41; }

/* ── Animations ───────────────────────────────── */
@keyframes acb-spin { to { transform:rotate(360deg); } }
@keyframes acb-pop  { 0%{transform:scale(0);opacity:0} 70%{transform:scale(1.15)} 100%{transform:scale(1);opacity:1} }
@keyframes acb-fadein { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.acb-fade { animation:acb-fadein .3s ease forwards; }

/* ── Responsive ───────────────────────────────── */
@media(max-width:600px){
	.acb-step-label { font-size:9px; }
	.acb-panel-inner,.acb-cart-inner { padding:16px 14px; }
	.acb-footer,.acb-step1-bar { padding:12px 14px; }
	.acb-step1-bar { flex-direction:column;gap:10px; }
	.acb-step1-actions { width:100%;justify-content:flex-end; }
	.acb-opt-row { flex-direction:column;align-items:flex-start;gap:8px; }
	.acb-cart-details { padding-left:0; }
}
