@import url('https://fonts.googleapis.com/css2?family=UnifrakturMaguntia&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Inter:wght@300;400;500;600&display=swap');
:root {
  --bg: #0a0a0e; --bg2: #0e0e14; --bg-card: rgba(255,255,255,0.03);
  --border: rgba(255,255,255,0.06); --border-accent: rgba(255,20,147,0.2);
  --text: #ece8f0; --text2: #b0abb8; --muted: #6b6575;
  --rose: #ff1493; --pink: #ff69b4; --champagne: #f5a5c8; --gold: #ff1493;
  --text-muted: #6b6575;
  --gradient: linear-gradient(135deg,#ff1493,#ff69b4);
  --font-display: 'Playfair Display',serif; --font-gothic: 'UnifrakturMaguntia',cursive; --font: 'Inter',sans-serif;
  --radius: 12px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}

/* ── NAV ── */
.book-nav{display:flex;justify-content:space-between;align-items:center;padding:16px 32px;border-bottom:1px solid var(--border);background:rgba(10,10,14,0.95);backdrop-filter:blur(20px);position:sticky;top:0;z-index:100}
.nav-logo{font-family:var(--font-gothic);font-size:1.4rem;color:var(--rose);text-decoration:none}
.nav-title{color:var(--champagne);font-size:.8rem;letter-spacing:3px;text-transform:uppercase}

/* ── PROGRESS ── */
.progress-bar{max-width:700px;margin:32px auto 40px;padding:0 24px}
.progress-track{position:relative;height:3px;background:var(--border);border-radius:2px;margin-bottom:16px}
.progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--gradient);border-radius:2px;transition:width .5s ease}
.progress-steps{display:flex;justify-content:space-between}
.step-dot{background:none;border:none;color:var(--muted);font-size:.75rem;cursor:pointer;padding:0;letter-spacing:1px;transition:color .3s}
.step-dot.active{color:var(--rose)}
.step-dot.completed{color:var(--champagne)}
.step-dot span{text-transform:uppercase}

/* ── CONTAINER ── */
.booking-container{max-width:700px;margin:0 auto;padding:0 24px 100px}

/* ── STEPS ── */
.step-panel{display:none}
.step-panel.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.step-title{font-family:var(--font-display);font-size:1.6rem;color:var(--champagne);margin-bottom:4px}
.step-subtitle{color:var(--text2);font-size:.9rem;margin-bottom:24px}

/* ── CATEGORY TABS ── */
.category-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.cat-tab{padding:6px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;color:var(--text2);font-size:.8rem;cursor:pointer;transition:all .3s;font-family:var(--font)}
.cat-tab.active{background:rgba(255,20,147,0.1);border-color:var(--rose);color:var(--champagne)}
.cat-tab:hover{border-color:var(--border-accent)}

/* ── SERVICE CARDS (JS-generated) ── */
.services-grid{display:flex;flex-direction:column;gap:8px}
.services-grid .service-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .3s}
.services-grid .service-card:hover{border-color:var(--border-accent);background:rgba(255,20,147,0.03)}
.services-grid .service-card.selected{border-color:var(--rose);background:rgba(255,20,147,0.06)}
.svc-checkbox{width:22px;height:22px;border:2px solid var(--border);border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;color:#fff;transition:all .2s}
.service-card.selected .svc-checkbox{border-color:var(--rose);background:var(--rose)}
.svc-info{flex:1;min-width:0}
.svc-name{font-size:.95rem;font-weight:500;margin-bottom:2px}
.svc-desc{color:var(--text2);font-size:.8rem;line-height:1.4}
.svc-meta{text-align:right;flex-shrink:0}
.svc-price{font-size:1.1rem;font-weight:700;color:var(--rose)}
.svc-duration{font-size:.75rem;color:var(--muted)}

/* ── STEP FOOTER ── */
.step-footer{display:flex;gap:12px;justify-content:flex-end;align-items:center;margin-top:32px;flex-wrap:wrap}
.booking-summary{flex:1;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;min-width:200px}
.summary-services{color:var(--text2)}
.summary-details{display:flex;gap:16px;align-items:center}
.summary-duration{display:flex;align-items:center;gap:4px;color:var(--muted);font-size:.8rem}
.summary-duration svg{opacity:.6}
.summary-price{font-size:1.1rem;font-weight:700;color:var(--rose)}

/* ── BUTTONS ── */
.btn-next{padding:12px 28px;background:var(--gradient);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.85rem;cursor:pointer;letter-spacing:1px;transition:all .3s;font-family:var(--font)}
.btn-next:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px rgba(255,20,147,0.3)}
.btn-next:disabled{opacity:.4;cursor:not-allowed}
.btn-back{padding:12px 28px;background:transparent;color:var(--text2);border:1px solid var(--border);border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .3s;font-family:var(--font)}
.btn-back:hover{border-color:var(--rose);color:var(--text)}
.btn-confirm{padding:14px 32px;background:var(--gradient);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:1rem;cursor:pointer;letter-spacing:1px;transition:all .3s;font-family:var(--font)}
.btn-confirm:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 24px rgba(255,20,147,0.4)}
.btn-confirm:disabled{opacity:.4;cursor:not-allowed}

/* ── DATE PICKER ── */
.date-picker-wrap{margin-bottom:24px}
.date-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.date-month{font-family:var(--font-display);font-size:1.1rem;color:var(--champagne)}
.date-arrow{padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text2);cursor:pointer;font-size:.9rem;transition:all .3s;font-family:var(--font)}
.date-arrow:hover{border-color:var(--rose);color:var(--champagne)}
.date-row{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.date-cell{padding:12px 4px;text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .3s}
.date-cell:hover:not(.disabled){border-color:var(--border-accent)}
.date-cell.selected{border-color:var(--rose);background:rgba(255,20,147,0.1)}
.date-cell.today{border-color:rgba(255,20,147,0.3)}
.date-cell.disabled{opacity:.25;cursor:not-allowed;pointer-events:none}
.date-day{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.date-num{font-size:1.1rem;font-weight:600}
.date-cell.selected .date-num{color:var(--rose)}

/* ── TIME SLOTS ── */
.time-slots-wrap{margin-bottom:16px}
.slots-label{font-family:var(--font-display);font-size:1rem;margin-bottom:12px;color:var(--champagne)}
.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}
.time-slot{padding:10px;text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .3s;font-size:.85rem;color:var(--text);font-family:var(--font)}
.time-slot:hover{border-color:var(--border-accent)}
.time-slot.selected{border-color:var(--rose);background:rgba(255,20,147,0.1);color:var(--rose)}
.no-slots{text-align:center;color:var(--muted);padding:24px;font-size:.85rem}
.loading-spinner{text-align:center;color:var(--muted);padding:24px;font-size:.85rem}

/* ── CLIENT FORM ── */
.info-form{display:grid;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.form-group input,.form-group textarea{padding:12px 16px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;font-family:var(--font);transition:border-color .3s}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--rose)}
.form-group textarea{resize:vertical;min-height:80px}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted)}

/* ── CONFIRMATION ── */
.confirm-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.confirm-section{padding:20px 24px;border-bottom:1px solid var(--border)}
.confirm-section:last-child{border-bottom:none}
.confirm-section h3{font-family:var(--font-display);margin-bottom:8px;color:var(--champagne);font-size:.95rem}
.confirm-date{font-size:1rem;font-weight:600}
.confirm-time{color:var(--text2);font-size:.9rem}
.confirm-services{list-style:none;padding:0}
.confirm-services li{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,0.03);font-size:.85rem}
.confirm-services li:last-child{border-bottom:none}
.confirm-total{display:flex;justify-content:space-between;padding-top:12px;margin-top:8px;border-top:1px solid var(--border);font-size:1rem}
.confirm-total strong{color:var(--rose);font-size:1.2rem}
.confirm-note{padding:20px 24px;border-top:1px solid var(--border)}
.confirm-note h3{font-family:var(--font-display);margin-bottom:8px;color:var(--champagne);font-size:.95rem}

/* ── SUCCESS ── */
.success-card{text-align:center;padding:48px 24px}
.success-icon{font-size:3.5rem;margin-bottom:16px}
.success-card h2{font-family:var(--font-display);font-size:2rem;margin-bottom:8px;color:var(--champagne)}
.success-subtitle{color:var(--text2);margin-bottom:24px}
.success-details{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin:0 auto 24px;max-width:400px;text-align:left}
.success-details p{padding:4px 0;font-size:.9rem}
.success-actions{display:flex;gap:12px;justify-content:center;margin-bottom:20px}
.btn-calendar{display:inline-flex;align-items:center;gap:6px;padding:12px 24px;background:rgba(255,20,147,0.1);border:1px solid var(--border-accent);border-radius:8px;color:var(--champagne);text-decoration:none;font-size:.85rem;transition:all .3s}
.btn-calendar:hover{background:rgba(255,20,147,0.15);transform:translateY(-2px)}
.btn-home{display:inline-flex;align-items:center;padding:12px 24px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text2);text-decoration:none;font-size:.85rem;transition:all .3s}
.btn-home:hover{border-color:var(--rose);color:var(--text)}
.success-note{color:var(--muted);font-size:.8rem;max-width:400px;margin:0 auto}

/* ── RESPONSIVE ── */
@media(max-width:600px){
  .form-row{grid-template-columns:1fr}
  .date-row{gap:3px}
  .date-cell{padding:8px 2px}
  .date-day{font-size:.55rem}
  .date-num{font-size:.9rem}
  .step-footer{flex-direction:column}
  .booking-summary{width:100%}
  .time-slots{grid-template-columns:repeat(3,1fr)}
}

/* ADD-ON CORNER RIBBON */
.services-grid .service-card[data-category="addon"]{position:relative;overflow:hidden}
.services-grid .service-card[data-category="addon"]::after{content:'ADD-ON';position:absolute;bottom:12px;right:-30px;background:linear-gradient(135deg,#ff1493,#c0115a);color:#fff;font-size:.55rem;font-weight:700;letter-spacing:2px;padding:4px 40px;transform:rotate(-35deg);box-shadow:0 2px 8px rgba(255,20,147,.3);z-index:2}
