:root {
    --primary-color: #1E40AF; /* Deep Blue */
    --active-color: #3B82F6; /* Vibrant Blue */
    --completed-color: #059669; /* Emerald Green */
    --light-gray: #F1F5F9; /* Slate 100 */
    --border-color: #E2E8F0; /* Slate 200 */
    --text-color: #1E293B; /* Slate 800 */
    --light-text-color: #64748B; /* Slate 500 */
    --danger-color: #EF4444; /* Red */
    --danger-hover-color: #DC2626;
}
body { margin: 0; font-family: 'Outfit', sans-serif; font-size: 14px; color: var(--text-color); background-color: #F8FAFC; line-height: 1.5; }
.container { max-width: 1200px; margin: 20px auto; padding: 0 15px; }
.top-bar { background-color: var(--primary-color); color: white; padding: 10px 0; font-size: 0.9em; }
.top-bar-container { display: flex; justify-content: space-between; align-items: center; max-width: 1200px; margin: auto; padding: 0 15px; }
.top-logo img { height: 40px; }

.menu-toggle {
    display: none;
    background: none;
    border: none;
    color: white;
    font-size: 24px;
    cursor: pointer;
    padding: 5px;
    z-index: 10;
}
.top-nav {
    align-self: flex-end; 
}
.top-nav ul { margin: 0; padding: 0; list-style: none; display: flex; gap: 25px; transition: transform 0.3s ease-out; }
.top-nav a { color: white; text-decoration: none; font-weight: 500; }
.top-nav a:hover { text-decoration: underline; }

.progress-bar { display: flex; width: 100%; margin: 30px 0; }
.progress-step { flex: 1; text-align: center; padding: 12px 15px; background-color: #ffffff; color: #a0a0a0; position: relative; border: 1px solid var(--border-color); border-right: none; }
.progress-step:last-child { border-right: 1px solid var(--border-color); }
.progress-step.active { background-color: var(--active-color); color: white; font-weight: bold; border-color: var(--active-color); }
.progress-step.active::after { content: ''; position: absolute; right: -12px; top: 0; border-style: solid; border-width: 21.5px 0 21.5px 12px; border-color: transparent transparent transparent var(--active-color); z-index: 1; }
.progress-step.completed { background-color: var(--completed-color); color: white; font-weight: bold; border-color: var(--completed-color);}
.main-content-grid { display: grid; grid-template-columns: 250px 1fr; gap: 30px; align-items: start; }
.form-sidebar { background-color: #fff; padding: 20px; border-radius: 5px; position: sticky; top: 20px; }
.sidebar-nav { list-style: none; padding: 0; margin: 0; }
.sidebar-step { padding: 12px 0; border-bottom: 1px solid var(--border-color); font-weight: bold; color: #888; display: flex; align-items: center; gap: 10px; }
.sidebar-step:last-child { border-bottom: none; }
.sidebar-step .status-icon { width: 12px; height: 12px; border-radius: 50%; background-color: #ccc; transition: background-color 0.3s; }
.sidebar-step.active { color: var(--active-color); }
.sidebar-step.active .status-icon { background-color: var(--active-color); }
.sidebar-step.completed { color: var(--completed-color); }
.sidebar-step.completed .status-icon { background-color: var(--completed-color); }
.visa-form-container { background-color: #fff; border-radius: 5px; border: 1px solid var(--border-color); }
.form-section { border-bottom: 1px solid var(--border-color); margin-bottom: 0; }
.form-section:last-child { border-bottom: none; }
.form-section-header { background-color: var(--light-gray); padding: 12px 15px; font-size: 1.2em; font-weight: bold; color: #444; border-bottom: 1px solid var(--border-color); display: flex; justify-content: space-between; align-items: center; }
.form-section-header .check-mark { color: var(--completed-color); font-size: 1.2em; display: none; }
.form-section-body { padding: 20px; background-color: #fff;}
.form-section-body > p { margin-top: 0; margin-bottom: 20px; color: #555; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px 60px; }
.form-group { display: flex; flex-direction: column; position: relative; }
.form-group label { margin-bottom: 5px; font-weight: bold; }
.form-group label .required-star { color: red; }

.form-group input[type="text"], .form-group input[type="email"], .form-group input[type="tel"], .form-group input[type="file"], .form-group input[type="hidden"], .flatpickr-input { box-sizing: border-box; width: 100%;}
.form-group input[type="text"], .form-group input[type="email"], .form-group input[type="tel"], .flatpickr-input { height: 40px !important; padding: 0 10px; border: 1px solid #ccc; border-radius: 4px; font-size: 1em; line-height: 40px; }

.form-group input[file] { padding: 5px; }
.form-group input.error { border-color: red; }
.gender-group.error { border: 1px solid red; border-radius: 4px; padding: 0 10px; }
.form-group .field-description { font-size: 0.8em; color: #888; margin-top: 5px; font-style: italic; }
.gender-group { display: flex; gap: 20px; align-items: center; height: 40px; }
.contact-number-group { display: flex; align-items: stretch; }
.contact-number-group .choices { width: 35%; }
.contact-number-group .choices .choices__inner { border-top-right-radius: 0; border-bottom-right-radius: 0; border-right-width: 0; }
.contact-number-group input { width: 65%; border-top-left-radius: 0; border-bottom-left-radius: 0; }
.form-actions { text-align: right; margin-top: 20px; }
.next-btn, .continue-btn { background-color: var(--completed-color); color: white; border: none; padding: 10px 30px; font-size: 1.1em; font-weight: bold; border-radius: 4px; cursor: pointer; }
.next-btn:hover, .continue-btn:hover { background-color: #047857; }

.hidden { display: none !important; }

.datepicker-input { background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" fill="currentColor"%3E%3Cpath d="M14 2h-1V1h-2v1H5V1H3v1H2a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V4a2 2 0 0 0-2-2zM2 4h12v2H2V4zm0 10V8h12v6H2z"/%3E%3C/svg%3E'); background-repeat: no-repeat; background-position: right 10px center; background-size: 16px; }
.modal-overlay { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0,0,0,0.5); justify-content: center; align-items: center; }
.modal-content { background-color: #fefefe; margin: auto; padding: 20px; border: 1px solid #888; width: 80%; max-width: 600px; border-radius: 5px; position: relative; }
.modal-close { color: #aaa; float: right; font-size: 28px; font-weight: bold; position: absolute; top: 10px; right: 20px; }
.modal-close:hover, .modal-close:focus { color: black; text-decoration: none; cursor: pointer; }
.modal-content h2 { margin-top: 0; }
.modal-content ol { padding-left: 20px; }
.modal-content li { margin-bottom: 10px; }
.applicant-summary-card { border: 1px solid #ccc; border-radius: 5px; padding: 15px; margin-bottom: 15px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.applicant-summary-card-main { display: flex; align-items: center; gap: 20px; flex-grow: 1; }
.applicant-summary-card img { width: 60px; height: 80px; object-fit: cover; border-radius: 4px; }
.applicant-summary-info h4 { margin: 0 0 5px 0; }
.applicant-summary-info p { margin: 0; color: #555; font-size: 0.9em; }
.choices { border: 1px solid #ccc; border-radius: 4px; }
.choices__inner { min-height: 40px; height: 40px; padding: 0; font-size: 1em; border: none; border-radius: 0; }
.choices[data-type*="select-one"] .choices__inner { padding-bottom: 0; }
.choices__input { background-color: transparent !important; height: auto; }
.choices__list--single { padding: 8px 16px 8px 4px; }
.choices.is-open .choices__list--dropdown { border-color: #a0a0a0; z-index: 5; }
.choices__list--dropdown .choices__item--selectable { padding-right: 10px; }
.choices__list--dropdown .choices__item { font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.form-group .choices.error { border-color: red !important; }
.main-footer { background-color: var(--primary-color); color: #ffffff; padding: 15px 15px; margin-top: 40px; }
.footer-grid { display: grid; grid-template-columns: 1fr 1fr 1fr 1.5fr; gap: 40px; align-items: start; }
.footer-col h4 { font-size: 1.1em; margin-bottom: 15px; border-bottom: 1px solid #3c6c94; padding-bottom: 10px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li a { color: #e0e0e0; text-decoration: none; font-size: 0.9em; line-height: 2; }
.footer-col li a:hover { text-decoration: underline; }
.footer-disclaimer-col { font-size: 0.75em; color: #e0e0e0; }
.footer-disclaimer-col .footer-logo { max-height: 40px; margin-bottom: 15px; margin-top: 20px; }
.footer-disclaimer-col p { margin-top: 0; margin-bottom: 15px; line-height: 1.7; }
.footer-disclaimer-col a { color: #ffffff; text-decoration: underline; font-weight: bold; }
.ssl-info { display: flex; align-items: center; gap: 10px; margin-top: 15px; }
.ssl-info img { width: 40px; height: 40px; flex-shrink: 0; }
.footer-bottom { background-color: #002a4d; color: #cccccc; padding: 20px 15px; text-align: center; font-size: 0.8em; }
.footer-bottom p { margin: 0; }
.payment-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 30px; align-items: start; padding: 20px;}
.payment-form-container { background-color: #fff; border: 1px solid var(--border-color); border-radius: 5px; }
.payment-form-header { padding: 15px 20px; font-size: 1.2em; font-weight: bold; border-bottom: 1px solid var(--border-color); background-color: var(--primary-color); color: white; border-top-left-radius: 5px; border-top-right-radius: 5px; }
.payment-form-body { padding: 20px; }
#payment-element { border: 1px solid #ccc; padding: 10px; border-radius: 4px; }
.submit-btn { background-color: var(--completed-color); color: white; width: 100%; border: none; padding: 12px; font-size: 1.2em; font-weight: bold; border-radius: 4px; cursor: pointer; margin-top: 10px; transition: background-color 0.3s; }
.submit-btn:disabled { background-color: #a0a0a0; cursor: not-allowed; }
#payment-message { text-align: center; color: red; margin-top: 10px; font-weight: bold; }
.summary-box { background-color: #fff; border: 1px solid var(--border-color); border-radius: 5px; margin-bottom: 20px; }
.summary-header { background-color: var(--light-gray); padding: 12px 15px; font-size: 1.1em; font-weight: bold; border-bottom: 1px solid var(--border-color); }
.summary-body { padding: 15px; }
.summary-body hr { border: 0; border-top: 1px solid var(--border-color); margin: 15px 0; }
.total-row { display: flex; justify-content: space-between; font-weight: bold; font-size: 1.2em; }
.applicant-list .applicant { display: flex; justify-content: space-between; margin-bottom: 8px; }
.loader { display: none; border: 3px solid #f3f3f3; border-top: 3px solid var(--active-color); border-radius: 50%; width: 20px; height: 20px; animation: spin 1s linear infinite; margin: 0 auto; }
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
.btn-loading .btn-text { visibility: hidden; }
.btn-loading .loader { display: block; position: absolute; top: 50%; left: 50%; margin-top: -10px; margin-left: -10px; }
.continue-btn { position: relative; }
.applicant-actions { display: flex; gap: 10px; align-items: center; }
.delete-applicant-btn { background-color: var(--danger-color); }
.delete-applicant-btn:hover { background-color: var(--danger-hover-color); }
.applicant-actions .next-btn { width: 80px; padding: 5px 10px; font-size: 0.9em; text-align: center; }
@media (max-width: 992px) { 
    .main-content-grid { grid-template-columns: 1fr; } 
    .form-sidebar { display: none; } 
    .payment-grid { grid-template-columns: 1fr; } 
    .footer-grid { grid-template-columns: repeat(2, 1fr); text-align: left; } 
    .top-bar-container { position: relative; }
    .top-nav {
        position: absolute; 
        top: 60px; 
        right: 15px; 
        left: 15px; 
        width: auto; 
        z-index: 5;
    }
    .top-nav ul {
        flex-direction: column;
        width: 100%;
        margin: 0;
        padding: 0 15px 15px 15px; 
        background-color: var(--active-color); 
        border-radius: 0 0 5px 5px;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
        display: none; 
    }
    .top-nav.open ul { display: flex; }
    .top-nav ul li { width: 100%; padding: 10px 0; border-bottom: 1px solid #005f9b; }
    .top-nav ul li:last-child { border-bottom: none; }
    .menu-toggle { display: block; }
}
@media (max-width: 768px) { 
    .form-grid { grid-template-columns: 1fr; gap: 20px; } 
    .progress-step { font-size: 0.8em; padding: 12px 5px; } 
    .progress-step.active::after { display: none; } 
    .footer-grid { grid-template-columns: 1fr; text-align: center; } 
    .footer-col, .footer-disclaimer-col { text-align: center; } 
    .ssl-info { justify-content: center; } 
    
    .contact-number-group .choices { width: 45%; }
    .contact-number-group input { width: 55%; }
    .choices__inner, .choices__list--dropdown .choices__item { font-size: 13px; padding-left: 5px; }
}
