.form-card {            
	margin: 25px auto;
	border-radius: 16px;
	border: none;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
	overflow: hidden;
}
#Banner{
	padding:30px !important;
}
.header-banner{
	padding: 8px 0px 8px 0px;
  text-align: center;
}
.header-banner h1 {
  font: 500 40px/44px var(--siteFont);
  color: var(--themeOneBg);
}
.card-body {
	padding: 22px !important;
}

.main-title {
	color: #1a2b4c;
	font: 700 24px/30px var(--headingFont);
	text-align: center;
	margin-bottom: 22px;
}

.section-title {
	font-weight: 700;
	margin-bottom: 12px;
	color: #1a2b4c;
	border-left: 4px solid #7b2cff;
	padding-left: 10px;
	font-size: 16px;
}

.sub-section-title {
	font-weight: 700;
	color: #253858;
	margin: 0 0 10px;
	font-size: 15px;
}

.box {
	background: #ffffff;
	padding: 16px;
	border-radius: 12px;
	border: 1px solid #e6e9ef;
	margin-bottom: 16px;
}

.instructions-box {
	background: #f8fafc;
	padding: 14px 16px;
	border-radius: 10px;
	border: 1px solid #ebeff5;
	font-size: 13px;
	color: #555;
	margin-bottom: 16px;
}

.instructions-box p,
.instructions-box li {
	margin-bottom: 0;
	line-height: 1.7;
	font-size: 13px;
}

.instructions-box ol {
	padding-left: 18px;
	margin-bottom: 0;
}

.form-label {
	font-weight: 600;
	font-size: 13px;
	color: #34495e;
	margin-bottom: 4px;
}

.form-control,
.form-select {
	border-radius: 8px;
	padding: 6px 10px;
	font-size: 13px;
	border: 1px solid #d8dee8 !important;
	height: 36px;
}

.form-control:focus,
.form-select:focus {
	box-shadow: 0 0 0 3px rgba(123, 44, 255, 0.10);
	border-color: #7b2cff;
}

textarea.form-control {
	min-height: 70px;
	height: auto;
}

.radio-group,
.checkbox-group {
	padding-top: 4px;
}

.form-check {
	margin-right: 18px;
	margin-bottom: 6px;
}

.dynamic-section-card {
	background: #fff;
	border: 1px solid #e7ebf0;
	border-radius: 14px;
	padding: 16px;
	margin-bottom: 16px;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.03);
}

.dynamic-item {
	background: #f8fafc;
	border: 1px solid #e8edf3;
	border-radius: 10px;
	padding: 12px;
	margin-bottom: 10px;
position:relative;
}

.btn-add-more {
background: #f4ecff;
color: #322e2e;
border: 1px dashed #7b2cff;
border-radius: 8px;
padding: 7px 0px;
font-weight: 500;
font-size: 13px;
transition: 0.2s ease;
cursor: pointer;
width: 242px;
}

.btn-add-more:hover {
	background: #7b2cff;
	color: #fff;
}

.btn-remove {
	background: #fff0f0;
	color: #d63333;
	border: 1px solid #f1c5c5;
	border-radius: 8px;
	width: 100%;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	cursor:pointer;
}

.btn-remove:hover {
	background: #d63333;
	color: #fff;
}

.btn-submit-main {
/*display: inline-block;
margin-left: 12px;
padding: 10px 22px;
border-radius: 24px;
background: #8451a3;
border-color: #8451a3;
color: #fff;
font-weight: 700;
text-decoration: none;
transition: all 0.2s ease;
cursor:pointer;
font-size: 1rem;*/
	height: 56px;
    border-radius: 14px;
    border: none;
    background: #8451a3;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.3px;
    box-shadow: 0 10px 24px rgba(13, 110, 253, 0.22);
    transition: all 0.25s ease;
	text-decoration: none;
	color: #fff;
	margin-left: 12px;
padding: 10px 22px;
cursor:pointer;
}

.btn-submit-main:hover {
	background: #5d1ed4;
	border-color: #5d1ed4;
	color: #fff;
}

.required {
	color: #dc3545;
}

.small-note {
	font-size: 13px;
	color: #6c757d;
	margin-top: 4px;
}

.inline-date-box {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

.inline-date-box .date-box {
	display: flex;
	align-items: center;
	gap: 10px;
}
.registration-success-wrap {
	min-height: 70vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 60px 20px;
	background: #f8fafc;
}

.registration-success-card {
	width: 100%;   
	background: #ffffff;
	border-radius: 22px;
	padding: 50px 40px;
	text-align: center;
	box-shadow: 0 18px 50px rgba(15, 23, 42, 0.08);
	border: 1px solid #e5e7eb;
}

.success-icon {		
margin: 0 auto 24px;
border-radius: 50%;		
color: #16a34a;
display: flex;
align-items: center;
justify-content: center;
font-size: 66px;		
}

.success-title {
	font-size: 40px;
	font-weight: 700;
	color: #166534;
	margin-bottom: 18px;
	line-height: 1.2;
}

.success-text {
	font-size: 20px;
	line-height: 1.7;
	color: #1f2937;
	margin-bottom: 14px;
}

.success-subtext {
	font-size: 18px;
	line-height: 1.7;
	color: #6b7280;
	max-width: 620px;
	margin: 0 auto 30px;
}

.success-actions {
	display: flex;
	justify-content: center;
	gap: 14px;
	flex-wrap: wrap;
	margin-top: 10px;
}

.btn-success-home,
.btn-success-outline {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 180px;
	padding: 13px 24px;
	border-radius: 999px;
	font-size: 15px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.25s ease;
}

.btn-success-home {
	background: linear-gradient(90deg, #7c3aed, #2563eb);
	color: #fff;
	box-shadow: 0 10px 24px rgba(124, 58, 237, 0.22);
}

.btn-success-home:hover {
	transform: translateY(-2px);
	color: #fff;
}

.btn-success-outline {
	background: #fff;
	color: #1f2937;
	border: 1px solid #d1d5db;
}

.btn-success-outline:hover {
	background: #f9fafb;
	color: #111827;
}

.gcaptcha{
	width:27%;
	margin:0 auto;
}

/* Edit Profile */
	
	/* Desktop */
	.single-pref-box{
		border:1px solid #e5e9f0;
		border-radius:14px;
		overflow:hidden;
		background:#fff;
	}

	.pref-head-row,
	.pref-data-row{
		display:grid;
		grid-template-columns: 2fr 1fr 1fr 1fr;
		align-items:center;
	}

	.pref-head-row{
		background:#f8fafc;
		font-weight:700;
		color:#16355c;
		border-bottom:1px solid #dfe5ec;
	}

	.pref-data-row{
		border-bottom:1px solid #dfe5ec;
	}

	.pref-data-row:last-child{
		border-bottom:none;
	}

	.pref-head-row > div,
	.pref-data-row > div{
		padding:14px 16px;
	}

	.pref-col-label{
		font-weight:500;
	}

	.pref-col-option{
		text-align:center;
	}

	.pref-col-option input[type="radio"]{
		transform:scale(1.05);
	}


	/* Tablet */
	@media (max-width: 991px){

		.pref-head-row,
		.pref-data-row{
			grid-template-columns: 1.8fr 1fr 1fr 1fr;
		}

		.pref-head-row > div,
		.pref-data-row > div{
			padding:12px 10px;
			font-size:14px;
		}
	}


	/* Mobile */
	@media (max-width: 767px){

		.single-pref-box{
			border-radius:10px;
		}

		.pref-head-row,
		.pref-data-row{
			grid-template-columns: 1.6fr .8fr .8fr .8fr;
		}

		.pref-head-row > div,
		.pref-data-row > div{
			padding:10px 6px;
			font-size:13px;
		}

		.pref-col-label{
			line-height:1.3;
			word-break:break-word;
		}

		.pref-col-option input[type="radio"]{
			transform:scale(0.95);
		}
	}


	/* Very Small Mobile */
	@media (max-width: 480px){
       
		.pref-head-row,
		.pref-data-row{
			grid-template-columns: 1.5fr .75fr .75fr .75fr;
		}

		.pref-head-row > div,
		.pref-data-row > div{
			padding:8px 4px;
			font-size:12px;
		}

		.pref-col-label{
			font-size:12px;
		}
	}


/* end */


@media (max-width: 767px) {
	.registration-success-card {
		padding: 36px 22px;
		border-radius: 18px;
	}

	.success-title {
		font-size: 30px;
	}

	.success-text {
		font-size: 17px;
	}

	.success-subtext {
		font-size: 15px;
	}

	.success-icon {
		width: 70px;
		height: 70px;
		font-size: 28px;
	}
}

@media (max-width: 768px) {
	.card-body {
		padding: 16px !important;
	}

	.main-title {
		font-size: 22px;
		line-height: 28px;
	}
}
		
/* Name + Edit row */
.profile-title-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:15px;
    flex-wrap:wrap;
}

/* Edit link */
.edit-profile-link{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:2px 8px;
    border:1px solid #d9e2ec;
    border-radius:8px;
    background:#fff;
    color:#16355c;
    font-size:14px;
    font-weight:600;
    text-decoration:none;
    transition:all .2s ease;
}

.edit-profile-link:hover{
   background: #93afdf;
    color: #fff !important;
    text-decoration:none;
}

/* Mobile */
@media(max-width:767px){

    .profile-title-row{
        text-align:center;
        flex-direction:column;
    }

    .edit-profile-link{
       display:none;
    }
}
@media(max-width:480px){
    .gcaptcha {
        width: 100% !important;
    }
}
