/* SK Booking System – Public Styles */
:root {
    /*--sk-primary: #4f46e5; # */
    --sk-primary: #d32f2f;
    --sk-primary-dark: #4338ca;
    --sk-primary-light: #eef2ff;
    --sk-primary-glow: rgba(79, 70, 229, 0.18);
    --sk-success: #10b981;
    --sk-danger: #ef4444;
    --sk-gray-50: #f9fafb;
    --sk-gray-100: #f3f4f6;
    --sk-gray-200: #e5e7eb;
    --sk-gray-300: #d1d5db;
    --sk-gray-400: #9ca3af;
    --sk-gray-500: #6b7280;
    --sk-gray-700: #374151;
    --sk-gray-900: #111827;
    --sk-radius: 12px;
    --sk-radius-lg: 18px;
    --sk-shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --sk-shadow-lg: 0 10px 40px rgba(0,0,0,.1);
    --sk-transition: all .25s cubic-bezier(.4,0,.2,1);
}

/* Styling for available slots */
.sk-slot {
    cursor: pointer;
    /* your existing styles (padding, background, etc) */
}

/* Styling for booked or past slots */
.sk-slot.sk-slot-disabled {
    background-color: #d32f2f; /* Light gray */
    color: #fefefe;            /* Muted text */
    cursor: not-allowed;       /* Show stop icon on hover */
    opacity: 0.6;
    border-color: #e5e7eb;
    pointer-events: none;      /* Prevents the click event from firing */
}
.sk-slot{
    color:#090909;
    border:solid 0.5px #388e3c;
}


/* Wrap */
.sk-booking-wrap {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    max-width: 700px;
    margin: 0 auto;
    padding: 0;
}

/* Header */
.sk-booking-header { text-align: center; margin-bottom: 32px; }
.sk-booking-title { font-size: 28px; font-weight: 700; color: var(--sk-gray-900); margin: 0 0 8px; letter-spacing: -.5px; }
.sk-booking-subtitle { color: var(--sk-gray-500); font-size: 15px; margin: 0; }

/* Steps indicator */
.sk-booking-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 32px;
}
.sk-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.sk-step span { font-size: 12px; font-weight: 500; color: var(--sk-gray-400); transition: var(--sk-transition); }
.sk-step.active span { color: var(--sk-primary); }
.sk-step.completed span { color: var(--sk-success); }
.sk-step-dot {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: var(--sk-gray-100);
    border: 2px solid var(--sk-gray-200);
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; font-weight: 600; color: var(--sk-gray-400);
    transition: var(--sk-transition);
}
.sk-step.active .sk-step-dot {
    background: var(--sk-primary);
    border-color: var(--sk-primary);
    color: #fff;
    box-shadow: 0 0 0 4px var(--sk-primary-glow);
}
.sk-step.completed .sk-step-dot {
    background: var(--sk-success);
    border-color: var(--sk-success);
    color: #fff;
}
.sk-step-line {
    flex: 1;
    height: 2px;
    background: var(--sk-gray-200);
    margin: 0 12px;
    margin-bottom: 22px;
    min-width: 40px;
    transition: background .4s;
}
.sk-step-line.completed { background: var(--sk-success); }

/* Form card */
.sk-booking-form {
    background: #fff;
    border: 1px solid var(--sk-gray-200);
    border-radius: var(--sk-radius-lg);
    padding: 32px;
    box-shadow: var(--sk-shadow-lg);
}

/* Step content */
.sk-booking-step-content h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--sk-gray-900);
    margin: 0 0 20px;
}

/* Services */
.sk-services-grid { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.sk-service-card { cursor: pointer; display: block; }
.sk-service-card input { position: absolute; opacity: 0; pointer-events: none; }
.sk-service-card-inner {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    border: 2px solid var(--sk-gray-200);
    border-radius: var(--sk-radius);
    transition: var(--sk-transition);
    position: relative;
    background: #fff;
}
.sk-service-card-inner:hover { border-color: var(--sk-primary); background: var(--sk-primary-light); }
.sk-service-card input:checked ~ .sk-service-card-inner {
    border-color: var(--sk-primary);
    background: var(--sk-primary-light);
    box-shadow: 0 0 0 3px var(--sk-primary-glow);
}
.sk-service-color {
    width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
    box-shadow: 0 0 0 3px rgba(0,0,0,.07);
}
.sk-service-info { flex: 1; }
.sk-service-name { font-size: 15px; font-weight: 600; color: var(--sk-gray-900); }
.sk-service-desc { font-size: 13px; color: var(--sk-gray-500); margin-top: 2px; }
.sk-service-duration { display: flex; align-items: center; gap: 4px; font-size: 12px; color: var(--sk-gray-400); margin-top: 5px; }
.sk-service-check {
    opacity: 0;
    color: var(--sk-primary);
    transform: scale(0.5);
    transition: var(--sk-transition);
}
.sk-service-card input:checked ~ .sk-service-card-inner .sk-service-check {
    opacity: 1;
    transform: scale(1);
}
.sk-no-services { text-align: center; padding: 30px; color: var(--sk-gray-400); border: 2px dashed var(--sk-gray-200); border-radius: var(--sk-radius); }

/* Date & Time */
.sk-datetime-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
.sk-date-section label, .sk-time-section label { display: block; font-size: 13px; font-weight: 500; color: var(--sk-gray-700); margin-bottom: 8px; }

/* Flatpickr override */
.sk-date-input {
    width: 100%; padding: 11px 14px; border: 1.5px solid var(--sk-gray-200);
    border-radius: var(--sk-radius); font-size: 14px; cursor: pointer;
    transition: var(--sk-transition); background: #fff; color: var(--sk-gray-900);
    box-sizing: border-box;
}
.sk-date-input:focus { outline: none; border-color: var(--sk-primary); box-shadow: 0 0 0 3px var(--sk-primary-glow); }

/* Slots */
.sk-slots-container { min-height: 120px; }
.sk-slots-placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    height: 120px; color: var(--sk-gray-300); text-align: center; gap: 8px;
    border: 2px dashed var(--sk-gray-200); border-radius: var(--sk-radius);
}
.sk-slots-placeholder p { margin: 0; font-size: 13px; }
.sk-slots-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: 8px; }
.sk-slot {
    padding: 9px 8px; text-align: center; font-size: 13px; font-weight: 500;
    border: 1.5px solid var(--sk-gray-200); border-radius: 8px; cursor: pointer;
    transition: var(--sk-transition); color: var(--sk-gray-700); background: #fff;
}
.sk-slot:hover { border-color: var(--sk-primary); color: var(--sk-primary); background: var(--sk-primary-light); }
.sk-slot.selected {
    background: var(--sk-primary); border-color: var(--sk-primary); color: #fff;
    box-shadow: 0 3px 10px rgba(79,70,229,.35);
}
.sk-slots-loading { display: flex; align-items: center; gap: 10px; padding: 30px; justify-content: center; color: var(--sk-gray-400); }
.sk-spinner { width: 20px; height: 20px; border: 2px solid var(--sk-gray-200); border-top-color: var(--sk-primary); border-radius: 50%; animation: sk-spin .7s linear infinite; }
@keyframes sk-spin { to { transform: rotate(360deg); } }
.sk-no-slots { text-align: center; padding: 30px; color: var(--sk-gray-400); font-size: 14px; border: 2px dashed var(--sk-gray-200); border-radius: var(--sk-radius); }

/* Summary */
.sk-booking-summary {
    background: var(--sk-primary-light);
    border: 1px solid #c7d2fe;
    border-radius: var(--sk-radius);
    padding: 16px 20px;
    margin-bottom: 22px;
    display: flex;
    gap: 0;
    flex-wrap: wrap;
}
.sk-summary-item { flex: 1; min-width: 150px; padding: 4px 0; }
.sk-summary-label { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: #6366f1; font-weight: 600; }
.sk-summary-value { display: block; font-size: 14px; font-weight: 600; color: var(--sk-primary-dark); margin-top: 2px; }

/* Customer fields */
.sk-customer-fields { display: flex; flex-direction: column; gap: 16px; margin-bottom: 20px; }
.sk-field-group label { display: block; font-size: 13px; font-weight: 500; color: var(--sk-gray-700); margin-bottom: 6px; }
.sk-required { color: var(--sk-danger); }
.sk-input-wrap { position: relative; }
.sk-input-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--sk-gray-300); pointer-events: none; }
.sk-booking-input {
    width: 100%; padding: 11px 14px 11px 38px;
    border: 1.5px solid var(--sk-gray-200); border-radius: var(--sk-radius);
    font-size: 14px; color: var(--sk-gray-900); transition: var(--sk-transition);
    box-sizing: border-box; background: #fff; font-family: inherit;
}
.sk-textarea { padding-left: 14px; resize: vertical; min-height: 100px; }
.sk-textarea ~ .sk-input-icon { display: none; }
.sk-booking-input:focus { outline: none; border-color: var(--sk-primary); box-shadow: 0 0 0 3px var(--sk-primary-glow); }

/* Alerts */
.sk-alert { padding: 14px 18px; border-radius: var(--sk-radius); font-size: 14px; margin-bottom: 16px; display: flex; align-items: flex-start; gap: 10px; }
.sk-alert-error { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.sk-alert-success { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }

/* Navigation buttons */
.sk-step-nav { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 24px; border-top: 1px solid var(--sk-gray-100); padding-top: 24px; }
.sk-btn-back, .sk-btn-next, .sk-btn-submit {
    display: inline-flex; align-items: center; gap: 8px; padding: 11px 22px;
    border-radius: 9px; font-size: 14px; font-weight: 600; cursor: pointer;
    border: none; transition: var(--sk-transition); font-family: inherit;
}
.sk-btn-back { background: var(--sk-gray-100); color: var(--sk-gray-700); margin-right: auto; }
.sk-btn-back:hover { background: var(--sk-gray-200); }
.sk-btn-next { background: var(--sk-primary); color: #fff; margin-left: auto; }
.sk-btn-next:hover { background: var(--sk-primary-dark); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(79,70,229,.4); }
.sk-btn-next:disabled { background: var(--sk-gray-200); color: var(--sk-gray-400); cursor: not-allowed; transform: none; box-shadow: none; }
.sk-btn-submit { background: var(--sk-success); color: #fff; margin-left: auto; }
.sk-btn-submit:hover { background: #059669; transform: translateY(-1px); box-shadow: 0 4px 14px rgba(16,185,129,.4); }
.sk-btn-submit.loading { opacity: .7; pointer-events: none; }
.sk-btn-submit.loading::after { content: ''; display: inline-block; width: 14px; height: 14px; border: 2px solid rgba(255,255,255,.4); border-top-color: #fff; border-radius: 50%; animation: sk-spin .7s linear infinite; margin-left: 6px; }

/* Flatpickr custom */
.flatpickr-calendar { box-shadow: 0 10px 40px rgba(0,0,0,.12) !important; border-radius: 14px !important; border: 1px solid var(--sk-gray-200) !important; font-family: inherit !important; }
.flatpickr-day.selected, .flatpickr-day.selected:hover { background: var(--sk-primary) !important; border-color: var(--sk-primary) !important; }
.flatpickr-day:hover { background: var(--sk-primary-light) !important; }

/* Modal Background */
.sk-modal-overlay {
    position: fixed; top:0; left:0; width:100%; height:100%;
    background: rgba(0,0,0,0.7);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none; transition: 0.3s; z-index: 9999;
}
.sk-modal-overlay.active { opacity: 1; pointer-events: auto; }

/* Ticket Design */
button#sk-close-modal {
    color: #fff;
    font-family: 'Cinzel', serif;
    border: solid 2px white;
    padding: 5px 10px;
    border-radius: 5px;
}


.ticket {
    background: white; width:100%;
    border-radius: 15px;
    overflow: hidden;
    border: solid 1px #d32f2f;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3); font-family: sans-serif;
}

.ticket-header h3{
	color:#fff;
	margin:0px;
}
.ticket-header {
    background: rgb(211 47 47); color: white; padding: 20px; text-align: center;
    border-bottom: 2px dashed #eee;
}
.ticket-body { padding: 20px; color: #333; position: relative; }
.tkt-row { margin-bottom: 15px; }
.tkt-split { display: flex; justify-content: space-between; margin-bottom: 15px; }
.label { display: block; font-size: 10px; color: #888; letter-spacing: 1px; }
.val { font-weight: bold; font-size: 14px; text-transform: uppercase; }

/* Barcode decoration */
.barcode {
    height: 40px; width: 100%; margin-top: 15px;
    background: repeating-linear-gradient(90deg, #333, #333 2px, transparent 2px, transparent 4px);
    opacity: 0.7;
}

.modal-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    padding: 0 20px 20px;
    margin: 21px 0px;
}

/* Buttons */

.btn-cal, .btn-dl { 
    padding: 10px; border: none; border-radius: 5px; cursor: pointer; font-weight: 600;
}
.btn-cal { background: #e8f0fe; color: #1a73e8; }
.btn-dl { background: #333; color: white; }
.close-modal { background: none; border: none; color: #888; cursor: pointer; margin-top: 10px; width: 100%; }

@media print {
    body * { visibility: hidden; }
    .ticket, .ticket * { visibility: visible; }
    .ticket { position: absolute; left: 0; top: 0; width: 100%; box-shadow: none; }
}



/* Responsive */
@media ( max-width: 580px ) {
    .sk-booking-form {padding: 20px 10px;margin: -10px;}
    .sk-datetime-wrap { grid-template-columns: 1fr; }
    .sk-booking-summary { flex-direction: column; gap: 10px; }
    .sk-booking-title { font-size: 22px; }
    .sk-step-line { min-width: 20px; }
    .sk-booking-wrap {
        padding: 20px 10px !important;
    }
}

