/** * ===================================================== * SUNISA RMT - BOOKING FORM STYLES * ===================================================== *//* ===================================================== CSS VARIABLES (used throughout booking styles) ===================================================== */:root{--border-radius:8px;--border-radius-lg:12px;}/* ===================================================== BOOKING CONTAINER ===================================================== */.booking-container{max-width:800px;margin:0 auto;}/* ===================================================== PROGRESS STEPS ===================================================== */.booking-progress{display:flex;justify-content:space-between;margin-bottom:40px;position:relative;--progress:0%;}.booking-progress::before{content:'';position:absolute;top:20px;left:50px;right:50px;height:3px;background:var(--border);z-index:0;}.booking-progress::after{content:'';position:absolute;top:20px;left:50px;right:50px;height:3px;background:var(--accent);z-index:0;/* The key trick:we scale only the X axis from 0 to 1,using --progress to control how far it goes */ transform:scaleX(var(--progress));transform-origin:left center;transition:transform 0.5s cubic-bezier(0.4,0,0.2,1);}.progress-step{display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;flex:1;}.step-number{width:40px;height:40px;border-radius:50%;background:var(--white);border:3px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;color:var(--text-muted);margin-bottom:10px;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);}.step-label{font-size:13px;color:var(--text-muted);text-align:center;transition:all 0.3s cubic-bezier(0.4,0,0.2,1);}.progress-step.active .step-number{background:var(--primary);border-color:var(--primary);color:var(--white);box-shadow:0 0 0 4px rgba(74,93,82,0.15);}.progress-step.active .step-label{color:var(--primary);font-weight:600;}.progress-step.completed .step-number{background:var(--accent);border-color:var(--accent);color:transparent;font-size:0;cursor:pointer;}.progress-step.completed .step-number::after{content:'\2713';font-size:14px;color:var(--white);}.progress-step.completed .step-label{color:var(--accent);cursor:pointer;}.progress-step.completed:hover .step-number{transform:scale(1.1);box-shadow:0 0 0 4px rgba(201,168,108,0.2);}/* ===================================================== BOOKING FORM CARD ===================================================== */.booking-card{background:var(--white);border-radius:var(--border-radius-lg);box-shadow:0 10px 40px var(--shadow);overflow:hidden;}.booking-header{background:var(--primary);color:var(--white);padding:25px 30px;}.booking-header h2{color:var(--white);margin-bottom:5px;font-size:1.5rem;}.booking-header p{opacity:0.8;margin:0;font-size:14px;}.booking-body{padding:30px;}.booking-footer{padding:20px 30px;background:var(--background);border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}/* ===================================================== FORM STYLES ===================================================== */.booking-form .form-group{margin-bottom:20px;}.booking-form label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text);}.booking-form input,.booking-form select,.booking-form textarea{width:100%;padding:14px 18px;border:2px solid var(--border);border-radius:var(--border-radius);font-size:15px;font-family:inherit;transition:var(--transition);background:var(--white);}.booking-form input:focus,.booking-form select:focus,.booking-form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(74,93,82,0.1);}.booking-form input.error,.booking-form select.error{border-color:#dc3545;}.form-error{color:#dc3545;font-size:13px;margin-top:5px;}.form-hint{color:var(--text-muted);font-size:13px;margin-top:5px;}/* ===================================================== PERSON CARDS ===================================================== */.persons-list{display:flex;flex-direction:column;gap:15px;}.person-card{background:var(--background);border:2px solid var(--border);border-radius:var(--border-radius);padding:20px;transition:var(--transition);}.person-card:hover{border-color:var(--primary);}.person-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;}.person-card-header h4{font-size:16px;display:flex;align-items:center;gap:8px;}.person-card-header .badge{background:var(--accent);color:var(--white);padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;}.remove-person{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:20px;padding:5px;transition:var(--transition);}.remove-person:hover{color:#dc3545;}.person-card .form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px;}.add-person-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;border:2px dashed var(--border);border-radius:var(--border-radius);background:transparent;color:var(--text-light);cursor:pointer;transition:var(--transition);width:100%;font-size:15px;}.add-person-btn:hover{border-color:var(--primary);color:var(--primary);background:rgba(74,93,82,0.05);}.first-visit-toggle{display:flex;align-items:center;gap:10px;margin-top:10px;}.first-visit-toggle input[type="checkbox"]{width:20px;height:20px;cursor:pointer;}.first-visit-toggle label{margin:0;cursor:pointer;font-weight:normal;}/* ===================================================== CALENDAR ===================================================== */.calendar-wrapper{background:var(--background);border-radius:var(--border-radius);padding:20px;}.calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}.calendar-nav h3{font-size:18px;margin:0;}.calendar-nav button{background:var(--white);border:1px solid var(--border);border-radius:var(--border-radius);padding:8px 15px;cursor:pointer;transition:var(--transition);}.calendar-nav button:hover{border-color:var(--primary);color:var(--primary);}.calendar-grid-mini{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}.calendar-day-header{text-align:center;font-size:12px;font-weight:600;color:var(--text-muted);padding:10px 0;}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius);font-size:14px;cursor:pointer;transition:var(--transition);background:var(--white);border:1px solid var(--border);}.calendar-day:hover:not(.disabled):not(.selected){border-color:var(--primary);color:var(--primary);}.calendar-day.selected{background:var(--primary);color:var(--white);border-color:var(--primary);}.calendar-day.today{border-color:var(--accent);font-weight:600;}.calendar-day.disabled{background:var(--background);color:var(--text-muted);cursor:not-allowed;opacity:0.5;}.calendar-day.empty{background:transparent;border:none;cursor:default;}/* ===================================================== TIME SLOTS ===================================================== */.time-slots-container{margin-top:25px;}.time-slots-header{margin-bottom:15px;}.time-slots-header h4{font-size:16px;margin-bottom:5px;}.time-slots-header p{color:var(--text-muted);font-size:14px;margin:0;}.time-slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}.time-slot{padding:12px;text-align:center;border:2px solid var(--border);border-radius:var(--border-radius);background:var(--white);cursor:pointer;transition:var(--transition);font-size:14px;}.time-slot:hover:not(.disabled):not(.selected){border-color:var(--primary);color:var(--primary);}.time-slot.selected{background:var(--primary);color:var(--white);border-color:var(--primary);}.time-slot.disabled{background:var(--background);color:var(--text-muted);cursor:not-allowed;text-decoration:line-through;opacity:0.5;}.time-slots-loading{text-align:center;padding:30px;color:var(--text-muted);}.no-slots-message{text-align:center;padding:30px;background:#fff3cd;border-radius:var(--border-radius);color:#856404;}/* ===================================================== SUMMARY ===================================================== */.booking-summary{background:var(--background);border-radius:var(--border-radius);padding:25px;}.summary-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border);}.summary-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none;}.summary-section h4{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;}.summary-section p{margin:5px 0;font-size:15px;}.summary-section strong{color:var(--text);}.summary-persons{list-style:none;}.summary-persons li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--border);}.summary-persons li:last-child{border-bottom:none;}.summary-total{background:var(--primary);color:var(--white);padding:20px;border-radius:var(--border-radius);display:flex;justify-content:space-between;align-items:center;margin-top:20px;}.summary-total span{font-size:16px;}.summary-total strong{font-size:28px;}/* ===================================================== SUCCESS STATE ===================================================== */.booking-success{text-align:center;padding:60px 30px;}.success-icon{width:80px;height:80px;background:#d4edda;color:#28a745;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;margin:0 auto 25px;}.booking-success h2{color:#28a745;margin-bottom:15px;}.booking-success p{color:var(--text-light);font-size:16px;max-width:400px;margin:0 auto 30px;}.confirmation-details{background:var(--background);border-radius:var(--border-radius);padding:25px;text-align:left;max-width:400px;margin:0 auto 30px;}.confirmation-details p{display:flex;justify-content:space-between;margin:10px 0;font-size:15px;}.spam-notice{display:flex;align-items:flex-start;gap:10px;background:#fff3cd;border:1px solid #ffc107;border-radius:var(--border-radius);padding:12px 16px;margin:20px auto;max-width:400px;text-align:left;font-size:13px;color:#856404;line-height:1.4;}.spam-notice-icon{flex-shrink:0;font-size:16px;}/* ===================================================== STEP 4 — CONFIRMATION REDESIGN ===================================================== */.bk-top-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;}.bk-box{background:var(--background);border-radius:var(--border-radius);padding:16px 18px;border:1px solid var(--border);}.bk-box-title{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:6px;}.bk-box p{font-size:14px;color:var(--text);margin:3px 0;line-height:1.5;display:flex;align-items:center;gap:6px;}.bk-apt-date{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--text);margin:8px 0 2px;}.bk-apt-time{font-size:14px;color:var(--accent);font-weight:600;}.bk-person-card{background:var(--background);border-radius:var(--border-radius);padding:14px 18px;border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:8px;}.bk-person-left{display:flex;align-items:center;gap:12px;}.bk-person-avatar{width:44px;height:44px;border-radius:50%;background:#4A5D52;display:flex;align-items:center;justify-content:center;color:white;font-weight:600;font-size:16px;flex-shrink:0;}.bk-person-name{font-weight:600;font-size:15px;color:var(--text);}.bk-person-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:600;background:var(--primary);color:white;margin-left:6px;vertical-align:1px;}.bk-person-badge-first{background:var(--accent);}.bk-person-details{font-size:13px;color:var(--text-muted);margin-top:3px;}.bk-person-details span{margin-right:10px;}.bk-person-price{text-align:right;flex-shrink:0;}.bk-person-price-amount{font-size:20px;font-weight:700;color:var(--text);}.bk-person-price-label{font-size:11px;color:var(--text-muted);}.bk-notes{margin:16px 0;}.bk-notes label{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--text);margin-bottom:6px;}.bk-notes textarea{width:100%;padding:14px 18px;border:1px solid var(--border);border-radius:var(--border-radius);font-family:inherit;font-size:14px;resize:vertical;min-height:70px;color:var(--text);box-sizing:border-box;}.bk-notes textarea:focus{outline:none;border-color:var(--primary);}.bk-notes textarea::placeholder{color:#bbb;}.bk-total-hst{text-align:right;font-size:13px;color:var(--text-muted);margin-bottom:10px;}.bk-total{background:var(--primary);color:white;padding:16px 20px;border-radius:var(--border-radius);display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}.bk-total span{font-size:15px;font-weight:500;}.bk-total strong{font-size:26px;font-weight:700;}.bk-account-opt{background:var(--background);border:2px solid var(--accent);border-radius:var(--border-radius);padding:16px 18px;margin-bottom:4px;}.bk-account-check{display:flex;align-items:flex-start;gap:10px;cursor:pointer;}.bk-account-check input[type="checkbox"]{width:18px;height:18px;margin-top:2px;accent-color:var(--primary);flex-shrink:0;}.bk-account-check-text strong{font-size:14px;color:var(--text);}.bk-account-check-text p{font-size:12px;color:var(--text-muted);margin-top:3px;line-height:1.5;}.bk-account-pw{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);}.bk-account-pw > label{font-size:12px;font-weight:500;color:var(--text);margin-bottom:4px;display:block;}.bk-account-pw .field-pw{position:relative;}.bk-account-pw .field-pw input{width:100%;padding:10px 44px 10px 14px;border:1px solid var(--border);border-radius:var(--border-radius);font-family:inherit;font-size:13px;color:var(--text);}.bk-account-pw .field-pw input:focus{outline:none;border-color:var(--primary);}.bk-account-pw .pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#9CA3AF;padding:4px;display:flex;align-items:center;justify-content:center;transition:color 0.15s;}.bk-account-pw .pw-toggle:hover{color:#4A5D52;}.bk-account-pw .hint{font-size:11px;color:var(--text-muted);margin-top:3px;}/* ===================================================== RESPONSIVE ===================================================== */@media (max-width:768px){.booking-progress{margin-bottom:30px;}.booking-progress::before,.booking-progress::after{left:20px;right:20px;}.step-number{width:35px;height:35px;font-size:14px;}.step-label{font-size:11px;}.progress-step.active .step-number{box-shadow:0 0 0 3px rgba(74,93,82,0.15);}.booking-header,.booking-body,.booking-footer{padding:20px;}.person-card .form-row{grid-template-columns:1fr;}.time-slots-grid{grid-template-columns:repeat(3,1fr);}.booking-footer{flex-direction:column;gap:15px;}.booking-footer .btn{width:100%;}.bk-top-grid{grid-template-columns:1fr;}.bk-person-card{flex-direction:column;align-items:flex-start;gap:10px;}.bk-person-price{text-align:left;display:flex;align-items:baseline;gap:6px;}}@media (max-width:480px){.time-slots-grid{grid-template-columns:repeat(2,1fr);}.calendar-day{font-size:12px;}}/* ===================================================== TRUST BADGES + MICRO-TESTIMONIALS — Booking page ===================================================== */.booking-trust{margin-top:-24px;margin-bottom:32px;}.trust-badges{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:24px;}.trust-badge{display:flex;align-items:center;gap:8px;background:#f8f9f4;border:1px solid #d4e0d0;border-radius:24px;padding:8px 16px;font-size:13px;font-weight:500;color:#4A5D52;}.trust-badge svg{color:#4A5D52;flex-shrink:0;}.trust-testimonials{display:grid;grid-template-columns:1fr 1fr;gap:16px;}.mini-testimonial{background:#fff;border:1px solid #e8ede8;border-radius:12px;padding:16px;text-align:center;}.mini-stars{color:#C4A86B;font-size:16px;margin-bottom:8px;letter-spacing:2px;}.mini-testimonial p{font-size:13px;color:#555;font-style:italic;margin-bottom:6px;line-height:1.5;}.mini-testimonial span{font-size:12px;color:#888;font-weight:500;}@media (max-width:600px){.trust-testimonials{grid-template-columns:1fr;}.trust-badges{gap:8px;}.trust-badge{font-size:12px;padding:6px 12px;}}/* ===================================================== SCROLL-TO-FORM ARROW — Page header ===================================================== */.scroll-to-form{display:none;margin-top:20px;background:none;border:2px solid rgba(74,93,82,0.3);border-radius:50%;width:48px;height:48px;cursor:pointer;color:var(--primary,#4A5D52);align-items:center;justify-content:center;animation:bounce-arrow 1.8s ease-in-out infinite;transition:border-color 0.2s,background 0.2s;}.scroll-to-form:hover{background:rgba(74,93,82,0.08);border-color:rgba(74,93,82,0.6);}@keyframes bounce-arrow{0%,100%{transform:translateY(0);}50%{transform:translateY(6px);}}@media (max-width:768px){.scroll-to-form{display:flex;}}/* ===================================================== UPSELL 90 MIN HINT ===================================================== */.upsell-hint{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 14px;background:#f5f9f0;border:1px solid #c8dfc0;border-radius:8px;font-size:13px;flex-wrap:wrap;}.upsell-text{flex:1;color:#3d6b4a;line-height:1.4;min-width:0;}.upsell-btn{background:#4A5D52;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background 0.2s;}.upsell-btn:hover{background:#3a4d42;}