.st-1-progress-bar { display: flex; justify-content: space-between; align-items: center; background-color: white; padding: 20px 5% 10px 5%; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); } @keyframes stepPop { 0% { transform: scale(0.4); opacity: 0; } 60% { transform: scale(1.15); opacity: 1; } 100% { transform: scale(1); } } @keyframes stepTick { 0% { content: ""; opacity: 0; } 100% { opacity: 1; } } @keyframes lineGrow { 0% { width: 0; } 100% { width: var(--line-grow-width); } } .return-trip { background: #f9fafb; border-radius: 10px; padding: 10px 12px; margin-top: 10px; margin-bottom: 10px !important; } .return-trip .detail-icon { color: #000080; } .detail-sub { font-size: 13px; color: #555; margin-top: 2px; } .night-badge { background: #fee2e2; color: #b91c1c; font-size: 11px; padding: 4px 8px; border-radius: 20px; margin-left: 6px; font-weight: 500; } .animate-step .st-1-step-number, .animate-step.st-1-step-number { animation: stepPop 0.4s ease-out forwards; } .st-1-step.st-1-completed .st-1-step-number::after { animation: stepTick 0.3s ease-in forwards; } .st-1-step { display: flex; flex-direction: column; align-items: center; flex: 1; position: relative; } .st-1-step:not(:last-child)::after { content: ""; position: absolute; top: 20px; left: 60%; width: 80%; height: 2px; background-color: #ddd; transition: none; } .st-1-help-text { transition: color 0.2s ease; } .st-1-form-group>.error-msg { position: relative; top: auto; left: auto; width: 100%; display: block; font-size: 13px; font-weight: 500; color: #d9534f; margin-top: 5px; opacity: 0; transition: opacity 0.15s ease; } .st-1-form-group>.error-msg.show { opacity: 1; } .disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; filter: grayscale(30%); } .st-1-help-text.st-1-help-error { color: #dc2626; } .st-1-step.st-1-completed:not(.animate-step)::after { background-color: #4caf50; } .st-1-step.st-1-completed.animate-step:not(:last-child)::after { width: 0; background-color: #4caf50; animation: lineGrow 0.5s ease forwards; } .st-1-step.st-1-active:not(:last-child)::after { background-color: #ddd !important; } .st-1-step-number { font-size: 15px; width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 500; margin-bottom: 5px; background-color: white; border: 2px solid #ddd; } .st-1-step.st-1-completed .st-1-step-number { background-color: #4caf50; color: white; border-color: #4caf50; } .st-1-step.st-1-completed .st-1-step-number::after { content: "✓"; } .st-1-step.st-1-active .st-1-step-number { background-color: #000000; color: white; border-color: #000000; } .st-1-step-label { font-weight: 500; font-size: 13px; color: #000000; } .st-1-container { max-width: 1200px; margin: 30px auto; padding: 0 20px; display: flex; gap: 30px; } .st-1-main-content { flex: 2; } .st-1-sidebar { flex: 1; } .st-1-card { background: white; border-radius: 8px; padding: 30px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); margin-bottom: 20px; } .st-1-card h2 { font-size: 24px; margin-bottom: 10px; font-weight: 500; } .journey-header h3 { font-weight: 500; } .st-1-subtitle { color: #666; font-size: 14px; margin-bottom: 30px; } .st-1-form-row { display: flex; gap: 20px; margin-bottom: 20px; } .st-1-form-group { flex: 1; display: flex; flex-direction: column; } .b-s-1-label label { font-size: 14px; font-weight: 500; margin-bottom: 8px; color: #333; } .st-1-required::after { content: " *"; color: #d32f2f; } .st-1-input-wrapper { position: relative; display: flex; align-items: center; } .st-1-input-icon { position: absolute; left: 12px; color: #999; font-size: 18px; } input:focus { outline: none; border-color: #4caf50; } .st-1-phone-input { display: flex; gap: 10px; } .st-1-country-code { width: 100px; padding: 12px; border: 1px solid #ddd; border-radius: 4px; font-size: 14px; background: white; } .st-1-phone-number { flex: 1; padding: 12px; border: 1px solid #ddd; border-radius: 4px; font-size: 14px; } .st-1-help-text { font-size: 14px; color: #333; margin-top: 5px; font-weight: 500; } .st-1-info-box { display: flex; gap: 10px; padding: 12px; background: linear-gradient(135deg, #f8f9ff 0%, #f0f2ff 100%); border-radius: 8px; margin: 24px 0; transition: transform 0.2s ease, box-shadow 0.2s ease; } .st-1-info-icon { overflow: hidden; min-width: 24px; height: 24px; background: #4361ee; color: white; border-radius: 50%; } .st-1-info-text { flex: 1; } .st-1-info-text strong { display: block; color: #2d3748; font-size: 16px; font-weight: 600; margin-bottom: 12px; line-height: 1.4; } .st-1-info-text ul { list-style: none; margin: 0; padding: 0; } .st-1-info-text li { position: relative; padding-left: 20px; margin-bottom: 5px; color: #4a5568; font-size: 13px; line-height: 1.5; transition: color 0.2s ease; } .st-1-info-text li:hover { color: #2d3748; } .st-1-info-text li:before { content: "•"; position: absolute; left: 8px; color: #4361ee; font-size: 14px; font-weight: bold; } .st-1-info-text li:last-child { margin-bottom: 0; } @media (max-width: 768px) { .st-1-info-box { padding: 16px; gap: 12px; } .st-1-info-text strong { font-size: 15px; } .st-1-info-text li { font-size: 14px; } } .st-1-info-text li::before { content: "• "; } .st-1-button-group { display: flex; justify-content: space-between; margin-top: 30px; } .st-1-btn { padding: 12px 30px; border-radius: 4px; font-size: 16px; font-weight: 500; cursor: pointer; transition: all 0.3s; border: none; } .st-1-btn-back { padding: 12px; border-radius: 50%; background: #00007b; color: #ffffff; border: 1px solid #ddd; } .st-1-btn-back:hover { background: var(--hover-color); transform: translateY(-2px); } .st-1-btn-primary { border-radius: 20px; background: var(--orange); color: white; } .st-1-btn-primary:hover { background: var(--hover-color); transform: translateY(-2px); } .st-1-booking-summary h3 { font-size: 20px; margin-bottom: 20px; } .journey-container { width: 100%; overflow: hidden; } .journey-header { display: flex; justify-content: space-between; align-items: center; padding-bottom: 10px; } .journey-title { font-weight: 500; font-size: 14px; text-transform: uppercase; color: #777777; letter-spacing: 0.5px; display: flex; align-items: center; gap: 8px; } .journey-title i { color: var(--orange); } .edit-btn { background-color: #f8f9fa; border: 1px solid #e0e6ed; border-radius: 8px; padding: 8px 12px; color: #5a6c7d; font-size: 14px; cursor: pointer; transition: all 0.2s ease; display: flex; align-items: center; gap: 6px; } .edit-btn:hover { background-color: var(--orange); color: white; border-color: var(--orange); } .route-container { position: relative; margin-bottom: 12px; } .route-line { position: absolute; left: 12px; top: 25px; bottom: 25px; width: 2px; background: linear-gradient(to bottom, #000000, #ff9f43); z-index: 1; } .route-point { display: flex; align-items: flex-start; margin-bottom: 28px; position: relative; z-index: 2; } .route-point:last-child { margin-bottom: 0; } .point-marker { width: 25px; height: 25px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-right: 15px; flex-shrink: 0; z-index: 3; font-size: 12px; } .point-start { background-color: #000000; color: white; } .point-end { background-color: #ff9f43; color: white; } .point-content { flex-grow: 1; } .location-name { font-weight: 500; font-size: 14px; color: #2c3e50; } .location-code { font-size: 11px; color: #7f8c8d; font-weight: 500; } .route-arrow { position: absolute; left: 19px; top: 40px; color: #ff9f43; font-size: 20px; z-index: 3; background-color: white; border-radius: 50%; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; } .journey-details { background-color: #f2f7ff; border-radius: 12px; padding: 12px; margin-bottom: 12px; } .detail-row { display: flex; align-items: center; margin-bottom: 4px; } .detail-row:last-child { margin-bottom: 0; } .detail-icon { width: 30px; color: #5a6c7d; font-size: 16px; } .detail-text { color: #2c3e50; font-size: 13px; font-weight: 500; } .detail-highlight { font-weight: 500; } .free-cancellation { display: flex; align-items: center; background-color: rgba(76, 175, 80, 0.1); border: 1px solid rgba(76, 175, 80, 0.2); border-radius: 8px; padding: 5px 15px; color: #2e7d32; } .cancel-icon { font-size: 12px; background-color: #4caf50; color: white; width: 20px; height: 20px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-right: 10px; flex-shrink: 0; } .cancel-text { font-weight: 500; font-size: 12px; } .journey-date { display: inline-block; background-color: var(--orange); color: white; padding: 4px 10px; border-radius: 20px; font-size: 13px; margin-top: 5px; } .fleet-container { display: flex; gap: 20px; justify-content: space-between; margin: 20px 0; } .st-1-vehicle-info { flex: 1; align-items: center; text-align: center; gap: 15px; border-radius: 10px; } .st-1-vehicle-image img { height: 55px; object-fit: cover; border-radius: 8px; } .st-1-vehicle-name { font-size: 10px; color: #666; } .fleet-btn-container { display: flex; justify-content: center; margin-top: 20px; } .fleet-btn { border: none; background: var(--orange); color: #fff !important; padding: 8px 22px; border-radius: 20px; font-weight: 600; transition: 0.3s ease; cursor: pointer; } .fleet-btn:hover { background: #0f0d97; } .st-1-price-info { padding: 12px 0; border-top: 1px solid #eee; border-bottom: 1px solid #eee; text-align: right; margin-top: 20px; } .st-1-price-label { font-size: 12px; color: #666; margin-bottom: 5px; } .st-1-price { font-size: 22px; font-weight: bold; color: var(--orange); } .st-1-included-section h4 { font-size: 16px; margin-bottom: 15px; } .st-1-included-list { padding: 0; list-style: none; } .st-1-included-list li { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; font-size: 14px; color: #666; } .st-1-check-icon { color: #4caf50; } .st-1-payment-methods { margin-top: 20px; } .st-1-payment-methods h4 { font-size: 14px; margin-bottom: 10px; } .st-1-payment-icons { display: flex; gap: 8px; flex-wrap: wrap; } .st-1-payment-icon { width: 45px; height: 30px; border: 1px solid #ddd; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 10px; color: #666; background: white; } .st-1-payment-icon img { width: 26px; height: 26px; object-fit: contain; display: inline-block; } .stp-3-container-for-btn { max-width: 800px; background-color: white; margin: 30px auto; padding: 0px 20px; } @media (max-width: 768px) { .st-1-container { flex-direction: column; } .st-1-card { padding: 14px; } .st-1-form-row { flex-direction: column; } .st-1-container { padding: 0 8px; } .st-1-card { box-shadow: none; border-width: 2px; border-style: solid; border-color: rgba(17, 18, 23, 0.04); } .st-1-step-label { font-size: 11px; } } @media (max-width: 480px) { .st-1-step:not(:last-child)::after { left: 68%; width: 65%; } .location-name { font-size: 13px; } .stp-3-container-for-btn { padding: 0; margin: 0px auto; } .st-1-button-group { bottom: 0; padding: 12px; width: 100%; max-width: 760px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; gap: 12px; background: #fff; z-index: 10; } .stp-3-container-for-btn { position: sticky; bottom: 0; width: 100%; max-width: 760px; display: flex; justify-content: space-between; align-items: center; gap: 12px; background: #fff; border-top: 1px solid #e5e7eb; z-index: 10; } }