/* ═══════════════════════════════════════
   RG Booking — Frontend Styles
   ═══════════════════════════════════════ */
.rgb-booking{max-width:800px;margin:0 auto;font-family:system-ui,-apple-system,sans-serif;color:#1a1a2e;font-size:15px;}

/* Progress */
.rgb-progress{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:32px;}
.rgb-step-dot{width:32px;height:32px;border-radius:50%;background:#e0e0e0;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;transition:background .3s;}
.rgb-step-dot.rgb-active{background:var(--rgas-accent, #0048FE);}
.rgb-step-dot.rgb-done{background:#2e7d32;}
.rgb-step-line{width:40px;height:2px;background:#e0e0e0;}

/* Step titles */
.rgb-step-title{font-size:20px;font-weight:700;margin:0 0 20px;color:#1a1a2e;}

/* Services grid */
.rgb-services-grid{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;}
.rgb-service-card{background:#fff;border:2px solid #e0e0e0;border-radius:14px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;flex-direction:column;width:260px;flex-shrink:0;}
.rgb-service-card:hover{transform:translateY(-3px);box-shadow:0 4px 16px rgba(0,0,0,.08);}
.rgb-service-card.rgb-selected{border-color:var(--rgas-accent, #0048FE);box-shadow:0 0 0 3px rgba(0,72,254,.15);}
.rgb-service-image{width:100%;aspect-ratio:16/10;overflow:hidden;background:#f5f7fa;}
.rgb-service-image img{width:100%;height:100%;object-fit:cover;display:block;}
.rgb-service-body{padding:16px 20px;}
.rgb-service-name{font-size:16px;font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:8px;}
.rgb-service-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.rgb-service-duration{display:inline-block;background:#f0f4ff;color:var(--rgas-accent, #0048FE);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:8px;}
.rgb-service-desc{font-size:13px;color:#686868;line-height:1.5;}

/* Calendar */
.rgb-calendar{background:#fff;border-radius:14px;padding:20px;box-shadow:0 1px 4px rgba(0,0,0,.06);}
.rgb-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.rgb-cal-nav button{background:none;border:none;cursor:pointer;font-size:20px;padding:6px 12px;border-radius:8px;color:#1a1a2e;}
.rgb-cal-nav button:hover{background:#f0f0f0;}
.rgb-cal-month{font-size:16px;font-weight:700;}
.rgb-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center;}
.rgb-cal-day-label{font-size:11px;font-weight:600;color:#999;padding:6px 0;}
.rgb-cal-day{padding:10px 0;border-radius:10px;font-size:14px;cursor:default;color:#ccc;transition:background .2s;}
.rgb-cal-day.rgb-available{color:#1a1a2e;cursor:pointer;font-weight:600;}
.rgb-cal-day.rgb-available:hover{background:#f0f4ff;}
.rgb-cal-day.rgb-selected{background:var(--rgas-accent, #0048FE);color:#fff;}
.rgb-cal-day.rgb-today{box-shadow:inset 0 0 0 2px var(--rgas-accent, #0048FE);}
.rgb-cal-loading{text-align:center;padding:30px;color:#999;}

/* Slots grid */
.rgb-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;}
.rgb-slot-btn{background:#fff;border:2px solid #e0e0e0;border-radius:10px;padding:12px;text-align:center;cursor:pointer;font-size:14px;font-weight:600;transition:border-color .2s,background .2s;}
.rgb-slot-btn:hover{border-color:var(--rgas-accent, #0048FE);background:#f0f4ff;}
.rgb-slot-btn.rgb-selected{border-color:var(--rgas-accent, #0048FE);background:var(--rgas-accent, #0048FE);color:#fff;}
.rgb-no-slots{text-align:center;padding:30px;color:#999;font-size:14px;}

/* Operators grid */
.rgb-operators-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;}
.rgb-operator-card{background:#fff;border:2px solid #e0e0e0;border-radius:14px;padding:18px;text-align:center;cursor:pointer;transition:border-color .2s,transform .2s;}
.rgb-operator-card:hover{transform:translateY(-2px);border-color:var(--rgas-accent, #0048FE);}
.rgb-operator-name{font-size:15px;font-weight:700;}

/* Summary */
.rgb-summary{background:#f0f4ff;border-radius:12px;padding:16px 20px;margin-bottom:20px;font-size:14px;line-height:1.7;}
.rgb-summary strong{color:var(--rgas-accent, #0048FE);}

/* Form */
.rgb-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.rgb-field{margin-bottom:16px;}
.rgb-field label{display:block;font-weight:600;margin-bottom:6px;font-size:14px;}
.rgb-field input,.rgb-field textarea{width:100%;padding:11px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:15px;font-family:inherit;box-sizing:border-box;transition:border-color .2s;}
.rgb-field input:focus,.rgb-field textarea:focus{outline:none;border-color:var(--rgas-accent, #0048FE);}

/* Privacy */
.rgb-privacy{margin:20px 0;font-size:13px;line-height:1.5;}
.rgb-privacy label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;}
.rgb-privacy input{margin-top:3px;accent-color:var(--rgas-accent, #0048FE);flex-shrink:0;}
.rgb-privacy a{color:var(--rgas-accent, #0048FE);}

/* Buttons */
.rgb-btn{padding:11px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:background .2s,transform .15s;}
.rgb-btn:active{transform:scale(.97);}
.rgb-btn--back{background:#f0f0f0;color:#1a1a2e;}
.rgb-btn--back:hover{background:#e4e4e4;}
.rgb-btn--submit{background:var(--rgas-accent, #0048FE);color:#fff;padding:13px 36px;font-size:15px;}
.rgb-btn--submit:hover{background:var(--rgas-accent-hover, #0036c8);}
.rgb-btn--submit:disabled{opacity:.6;cursor:not-allowed;}
.rgb-form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:10px;}

/* Messages */
.rgb-message{margin-top:16px;padding:14px 18px;border-radius:8px;font-weight:600;font-size:14px;text-align:center;}
.rgb-message.rgb-error{background:#fce4ec;color:#c62828;}
.rgb-message.rgb-ok{background:#e8f5e9;color:#2e7d32;}

/* Success */
.rgb-success{text-align:center;padding:40px 20px;}
.rgb-success svg{margin-bottom:10px;}
.rgb-success h3{font-size:18px;color:#2e7d32;font-weight:700;}

/* Responsive */
@media(max-width:600px){
    .rgb-form-row{grid-template-columns:1fr;}
    .rgb-services-grid{grid-template-columns:1fr;}
    .rgb-slots-grid{grid-template-columns:repeat(3,1fr);}
    .rgb-cal-grid{gap:2px;}
    .rgb-cal-day{padding:8px 0;font-size:13px;}
}
