@import url('https://fonts.googleapis.com/css2?family=Livvic:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,900&family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap');
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/7.0.1/css/all.min.css");

:root {
	--body-bg: rgba(12, 53, 98, 0.03);

	--body-font: "Livvic", sans-serif;
	--font-awesome: "Font Awesome 7 Free";
	--base-size: 1.2rem;

	--content-shadow: 0 3px 18px rgba(0, 0, 0, .05);
	--transition: all .7s cubic-bezier(.25, .8, .25, 1);

	--menu-shadow: 0 3px 10px rgba(00, 00, 00, 0.1);

	--box-shadow: 0px 0px 0px rgba(00, 00, 00, 0.0);
	--box-shadow-hover: 0px 5px 18px rgba(00, 00, 00, 0.1);

	--transform: scale(1) translateY(0px);
	--transform-hover: scale(1.01) translateY(-3px);

	--required: rgba(192, 57, 43, 1.0);

	--brand-blue: rgba(44, 52, 137, 1);
	--brand-red: rgba(234, 38, 46, 1);

	--base-weight:400;
}

@keyframes pulse {
	0% {
		transform: translate(-50%, -50%) scale(1);
		opacity: 1;
	}

	50% {
		transform: translate(-50%, -50%) scale(1.08);
		opacity: 0.85;
	}

	100% {
		transform: translate(-50%, -50%) scale(1);
		opacity: 1;
	}
}

div[data-group="member-verify"]{
	display:none;	
}
div[data-group="membernumber"] .form-group div:first-of-type{
	display:flex;
	align-items:center;
	gap:0.3rem;
}

div[data-group="membernumber"] .form-group div:first-of-type button.btn{
	border-radius: 7px !important;
    font-size: 1.5rem;
    padding: 0 1rem !important;
    height: stretch;
    line-height: 2rem !important;
    align-items: center;	
}

.bio-content {
    max-width: 70%;
    box-shadow: 0px 18px 32px rgba(00, 00, 00, 0.2);
    border-radius: 25px;
    padding: 1rem 2rem 3rem 2rem;
    width: 100%;
}
.bio-content p{
	margin:1rem 0;	
}
.full-bio-content{
	display:none;	
}
.help-block {
	margin: 0 !important;
}
.card h2 i {
    font-size: 1.7rem;
    color: #cf2e2e;
}
.btn {
	transition: var(--transition);
	box-shadow: var(--box-shadow);
	transform: var(--transform);
	padding: 18px 36px !important;
	border-radius: 999px;
}

.btn:hover {
	box-shadow: var(--box-shadow-hover);
	transform: var(--transform-hover);
}

.row {
	margin: 0;
}

.banner .banner-wrapper {
	max-width: 100%;
	margin: 1rem auto;
	text-align: center;
	background: #f4f4f4;
}

.banner .banner-wrapper img {
	width: 85% !important;
}

.de_required {
	color: var(--required);
}

.alert.alert-success {
	display: none !important;
}

.fancybox-caption-wrap {
	display: none !important;
}

.fancybox-slide {
	background: transparent !important;
}

.fancybox-bg,
.speaker-modal .modal-overlay{
	opacity: 1 !important;
	background: rgba(255, 255, 255, 0.2) !important;
	backdrop-filter: blur(10px);
}

.modalPopUp {
	max-width: 75%;
	width: 100%;
	padding: 1.3rem;
	border-radius: 25px;
	box-shadow: 0px 4px 18px rgba(0, 0, 0, 0.2);
	display: none;
}

.modalPopUp h1 {
	font-weight: bold;
}

.modalPopUp p {
	margin: 1rem;
}

.pageinfo {
	padding: 1rem;
	border-radius: 12px;
	font-size: 0.875rem;
	background-color: #2c3489;
	color: rgba(255, 255, 255, 0.9);
	margin: 1rem 0 !important;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
}

body {
	background: var(--body-bg);
	font-family: var(--body-font);
	font-size: var(--base-size) !important;
	line-height: normal;
}


#menu {
	position: sticky;
	top: 0;
	box-shadow: var(--menu-shadow);
	border-radius: 0;
	z-index: 999;
}

.panel {
	border: none;
	padding: 0;
	margin: 0;
}

#content {
	font-size: var(--base-size);
	background-color: #fff;
	border: 1px solid transparent;
	border-radius: 20px;
	-webkit-box-shadow: var(--content-shadow);
	box-shadow: var(--content-shadow);
	margin: 1.5rem auto;
	padding: 2rem;
	width:100% !important;
	max-width: 88% !important;
}

.form-group h2 {
	margin: 0 0 1rem 0;
	background: #cf2e2e;
	color: #ffffff;
	padding: .75rem 1rem;
	font-size: 1.5rem;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	box-shadow: 0px 3px 14px rgba(207, 46, 46, 0.1);
}

.form-group h2 i {
	transform: rotate(9deg);
	font-size: 1.8rem;
	text-shadow: 2px 3px 8px rgba(0, 0, 0, .1);
}

.navbar .links-wrapper .navbar-nav>* {
	border-radius: 21px;
	padding: 0.75rem 1.2rem;
}

.navbar {
	border-radius: 0;
}

.navbar .logo-wrapper img {
	height: 5rem;
}

.membernumber a {
	color: white !important;
}

.text-editable[data-id="97499"] {
	width: 100% !important;
}

.body-wrapper h3,
#regForm h3 {
	font-size: 1.25rem;
	margin-bottom: 0;
	font-weight: 600;
	line-height: 1.75;
	color: #0c355f;
	padding: 0.25rem 1rem;
	background: rgba(0, 154, 191, 0.1);
	border-left: 5px solid #0c355f;
	width: 100%;
}

.sponsor h3 {
	font-size: 1.25rem;
	margin: 2rem 0;
	font-weight: 600;
	line-height: 1.75;
	color: #0c355f;
	padding: 0.25rem 1rem;
	background: rgba(0, 154, 191, 0.1);
	border-left: 5px solid #0c355f;
}

section#header section#menu {
	order: unset;
}

#siteNav {
	box-shadow: none;
}

#header.small {
	font-size: 100%;
}

.btn-success {
	color: #fff;
	background-color: #5cb85c;
	border-color: #4cae4c;
}

.btn-success:hover {
	color: #fff;
	background-color: #449d44;
	border-color: #398439;
}

.btn-group-sm>.btn,
.btn-sm {
	padding: 5px 10px;
	font-size: 12px;
	line-height: 1.5;
	border-radius: 3px;
}

#app-layout div.form-group-tags {
	margin: 0 !important;
	margin-right: 1rem !important;
	margin-bottom: 1rem !important;
	width: 100%;
}

#app-layout select.filter-by-tag {
	padding: 0.375rem 0.75rem !important;
	border-radius: 0.5rem !important;
}

[data-id="134913"] {
	display: none;
}

#app-layout [data-activity-id="5342"] a[data-target="#sessionSummary"],
#app-layout [data-activity-id="5431"] a[data-target="#sessionSummary"],
#app-layout [data-activity-id="5432"] a[data-target="#sessionSummary"],
#app-layout [data-activity-id="5433"] a[data-target="#sessionSummary"],
#app-layout [data-activity-id="5434"] a[data-target="#sessionSummary"],
#app-layout .session-item-right span+span,
#app-layout [data-activity-id="5436"] a[data-target="#sessionSummary"],
#app-layout .session-item-right .session-date-time {
	display: none !important;
}

.session-item-left {
	flex-direction: column;
}

form[name=regForm] .body-wrapper a {
	color: white;
}

#app-layout #alpha-b,
#app-layout #alpha-a .col-lg-3.col-md-4:nth-child(2) {
	display: none;
}

.button-wrapper,
form[name=regForm] #button {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: space-between;
	margin: 1rem 0;
}

form[name=regForm] #button {
	justify-content: center;
	gap: 2rem;
	margin: 2rem 0;
}

.button-wrapper a,
form[name=regForm] #button input,
form[name=regForm] #button button {
	padding: 1rem 2rem !important;
	border-radius: 999px !important;
	margin: 0px;
	font-size: 1.2rem !important;
	font-weight: 400 !important;
	transition: var(--transition) !important;
	box-shadow: var(--box);
	transform: var(--transform);
	will-change: transform, box-shadow;
}

.button-wrapper a:hover,
form[name=regForm] #button input:hover,
form[name=regForm] #button button:hover {
	transition: var(--transition) !important;
	box-shadow: var(--box-shadow);
	transform: var(--transform-hover);
}

form[name=regForm] #button input[name="navigate[submit]"] {
	background: rgba(39, 174, 96, 1.0);
	border-color: rgba(39, 174, 96, 1.0);
	color: #ffffff;
	font-size: 1.4rem !important;
	padding: 1.3rem 2.4rem !important;
}

form[name=regForm] #button input[name="navigate[submit]"]:hover,
form[name=regForm] #button input[name="navigate[submit]"]:focus {
	background: rgba(46, 204, 113, 1.0);
	border-color: rgba(39, 174, 96, 1.0);
}

/* Reg Form */
form[name=regForm] fieldset {
	display: grid;
	flex-wrap: wrap;
	width: 100%;
	grid-template-columns: 32% 66%;
	gap: 2rem;
}

form[name=regForm] fieldset legend {
	width: 100%;
	float: left;
	font-weight: normal;
	margin: 0;
	padding: 0;
	font-size: var(--base-size);
}

form[name=regForm] fieldset div.de_fieldset {
	width: 100%;
}

.record-notice{
	display: flex;
	gap: 0.5rem;
	padding: 1rem !important;
	border-radius: 10px;
	background: rgba(241, 196, 15, 0.1);
	border-left: 3px solid rgba(241, 196, 15, 1.0);
	border-right: 3px solid rgba(241, 196, 15, 1.0);
	box-shadow: 0px 3px 6px rgba(00, 00, 00, 0.05);
	font-size: 1.1rem;
	justify-content: center;
	line-height:normal;
	color:rgba(230, 126, 34,1.0);
}
.record-notice span{
	width:100%;	
}
.record-notice span span{
	display: grid;
	width: 100%;
}
.record-notice i{
	font-size: 1.3rem;	
	line-height:normal;
}
.record-notice span b{
	font-weight:600 !important;	
}
#content .panel,
#content .panel .panel-body,
#content .row.panel-body,
#singleTab>.row {
	padding: 0;
	margin: 0 !important;
}

.form-group>label,
.form-group fieldset>legend {
	padding: 0 0 0 1rem !important;
}

div[data-group="note"] .form-group {
	grid-template-columns: 100% !important;
}

div.field>div.form-group.checkradio {
	display: block !important;
}

div[data-group="note"] .text-editable {
	width: 100% !important;
}

div.field>div.form-group.checkradio fieldset .de_fieldset {
	display: flex;
	justify-self: flex-start;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: stretch;
}

div.field fieldset span.de_cols_1 {
	width: 100%;
	max-width: 100%;
	margin: 0;
	clear: none;
	float: none;
	display: grid !important;
}

#regForm input[type="checkbox"],
#regForm input[type="radio"] {
	opacity: 0 !important;
	position: absolute;
}

.de_quantity {
	display: none;
}

div.field div.form-group fieldset div.de_fieldset span.de_cols_1 label {
	width: 100% !important;
	padding: 1rem;
	background: #ffffff;
	display: flex;
	align-items: center;
	justify-content: space-between;
	transition: var(--transition);
	box-shadow: 0px 3px 6px rgba(00, 00, 00, 0.04);
	transform: var(--transform);
	border: 2px solid rgba(0, 0, 0, 0.05);
	border-radius: 18px;
	margin: 0;
	will-change: transform;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

div.field div.form-group fieldset div.de_fieldset span.de_cols_1 label:hover {
	transition: var(--transition);
	box-shadow: 0px 5px 12px rgba(00, 00, 00, 0.065);
	transform: var(--transform-hover);
	border-color: rgba(0, 0, 0, 0.1);
}

div.field div.form-group fieldset div.de_fieldset span.de_cols_1 label .de_quantity {
	display: none !important;
}

[type="radio"]:checked+label,
[type="checkbox"]:checked+label {
	transition: var(--transition);
	box-shadow: 0px 5px 12px rgba(00, 00, 00, 0.065) !important;
	transform: var(--transform-hover) !important;
	border-color: rgba(39, 174, 96, 1.0) !important;
}

[type="radio"]+label:after,
[type="checkbox"]+label:after {
	transform: scale(1) rotate(-12deg) translateY(0px);
	z-index: 99;
	transition: var(--transition);
}

[type="radio"]:checked+label:after,
[type="checkbox"]:checked+label:after {
	font-family: var(--font-awesome);
	display: inline-block;
	font-weight: 900;
	content: "\f058";
	font-size: 1.2rem;
	color: rgba(39, 174, 96, 1.0);
	transform: scale(1.3) rotate(0deg) translateY(-2px);
	z-index: 99;
	transition: var(--transition);
	left: -7px;
	top: -4px;
	position: absolute;
	background: #ffffff;
	border-radius: 9999px;
	box-shadow: 0px 3px 10px rgba(000, 00, 00, 0.2);
}

div[data-group="note"] p {
	display: none;
}

div[data-group="note"] .text-editable p {
	display: block;
}

div[data-group="membernumber"] p {
	display: none;
}

div[data-group="membernumber"] div:nth-of-type(2) {
	width: 100% !important;
}

div[data-group="membernumber"] div p.membernumber:before {
	display: block;
	content: "";
	width: 47%;
}

div[data-group="membernumber"] div p.membernumber {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}

div[data-group="membernumber"] div p.membernumber a {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 500;
	font-size: 1rem;
	margin: 1rem 0 0 0 !important;
	transition: var(--transition);
	box-shadow: 0px 0px 4px rgba(00, 00, 00, 0.03);
	transform: var(--transform);
	will-change: transform, box-shadow;
}

div[data-group="membernumber"] div p.membernumber a:hover {
	transition: var(--transition);
	box-shadow: 0px 4px 10px rgba(00, 00, 00, 0.075);
	transform: var(--transform-hover);
}

div[data-group="membernumber"] div p.membernumber a i {
	font-size: 1.3rem;
	transition: var(--transition);
	transform: var(--transform);
	will-change: transform;
}

div[data-group="membernumber"] div p.membernumber a:hover i {
	transition: var(--transition);
	transform: scale(1) translateY(-1px);
}

.click-to-select {
	font-size: 0.8rem;
	font-weight: normal;
	display: inline-flex;
	color: #555555;
	margin: 0.7rem 0 0 0;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem 0.5rem 0.5rem;
	background: rgba(255, 255, 255, 0.5);
	border-radius: 9px;
	width: auto;
	justify-content: center;
	font-style: italic;
	box-shadow: 0px 3px 8px rgba(00, 00, 00, 0.05);
}

.click-to-select i {
	color: rgba(52, 152, 219, 1.0);
}

div[data-group="terms-and-conditions"] fieldset legend .click-to-select i {
	color: rgba(211, 84, 0, 1.0);
}

.review .btn-wrapper {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}

.review .btn-wrapper .btn {
	padding: 0.85rem 1.4rem;
	font-size: 1.2rem;
	font-weight: normal;
}

/* Loading */
div#mycs-loading-mask {
	display:none;
	background: rgba(44, 52, 137, 0.05);
	opacity: 1 !important;
	backdrop-filter: blur(10px);
}

#mycs-spinner {
	background: url('https://mycs-cdn.myconferencesuite.com/other/Project/3930/b8/e7/b8e73c347e7649636c81a6341e380704bbb9721ed6ed9d853347a6ad93ecdf5f.gif') no-repeat center center / contain !important;
	position: fixed !important;
	top: 50% !important;
	left: 50% !important;
	transform: translate(-50%, -50%) scale(1);
	width: 150px !important;
	height: 150px !important;
	display: flex;
	align-items: center;
	justify-content: center;
	animation: pulse 1.8s ease-in-out infinite;
	filter: drop-shadow(0px 2px 10px rgba(00, 00, 00, 0.25));
}

div[data-group="registrant-fee"] .de_fee {
	background: #0c355f;
	color: #ffffff;
	font-size: 0.9rem;
	padding: 0.3rem 0.75rem;
	border-radius: 8px;
	font-weight: 600;
	box-shadow: 0px 3px 10px rgba(00, 00, 00, 0.2);
}

fieldset legend .de_fee {
	display: none !important;
}

.col-sm-3 .body-wrapper {
	position: sticky;
	top: 105px;
}
/*
.col-sm-9 .body-wrapper{
margin-bottom: 2rem;
display: grid;
grid-template-columns: 50% 50%;
gap: 1rem;
}
.col-sm-9 .body-wrapper .card{
background: #fff;
border-radius: 16px;
overflow: hidden;
box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}*/

/****************************
Text, select, textarea
****************************/
input[type="text"],
input[type="email"],
select,
textarea {
	padding: 12px 16px !important;
	font-size: 1.1rem !important;
	line-height: normal !important;
	border: 2px solid #ccc !important;
	border-radius: 12px !important;
	outline: none !important;
	transition: all 0.3s ease !important;
	background: #fff !important;
	height: auto !important;
	transition: var(--transition);
	transform: scale(1) translateY(0px);
	box-shadow: 0 0px 0px rgba(0, 0, 0, 0.0) !important;
}

input[type="text"]:focus,
textarea:focus,
select:focus {
	border-color: #4CAF50;
	box-shadow: 0 0 8px rgba(44, 52, 137, 0.2);
	transition: var(--transition);
	transform: scale(1) translateY(-2px);
	box-shadow: 0 2px 10px rgba(44, 52, 137, 0.05) !important;
	border-color: rgba(44, 52, 137, 0.5) !important;
}

input[type="text"]:hover,
textarea:hover,
select:hover {
	transform: scale(1) translateY(-2px);
	box-shadow: 0 2px 10px rgba(44, 52, 137, 0.05) !important;
	border-color: rgba(44, 52, 137, 0.5) !important;
}

/*****************************
payment page
******************************/
form#paymentForm #manualInfo {
	border: 1px solid #ddd;
	margin-top: 1rem;
	border-radius: 25px;
	padding: 1rem;
	background: #ffffff;
	box-shadow: 0px 3px 18px rgba(00, 00, 00, 0.05);
	z-index: 999;
	position: relative;
}
#breakdown_body input[type="checkbox"],
#breakdown_body input[type="radio"] {
	position: absolute;
	opacity: 0;
	display: none;
}

#billinfoTable {
	width: 100% !important;
}

#cvdInfo,
.cvdModalLink {
	display: flex;
	text-indent: -99999px;
}

#cvdInfo:before,
.cvdModalLink:before {
	display: inline-flex;
	font: normal normal normal 14px / 1 FontAwesome;
	font-size: inherit;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	content: "\f129";
	text-indent: 0;
	width: 30px;
	height: 30px;
	background: rgb(0, 117, 183);
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, 1);
	box-shadow: 1px 1px 8px rgba(var(--black), 0.2);
	color: rgba(255, 255, 255, 1);
	align-items: center;
	justify-content: center;
	transition: all 0.3s ease;
	transform: scale(1);
}

#cvdInfo:hover:before,
.cvdModalLink:hover:before {
	transition: all 0.3s ease;
	transform: scale(1.1);
	text-shadow: 2px 2px 8px rgba(var(--black), 0.2);
	box-shadow: 1px 1px 12px rgba(var(--black), 0.2);
}

#infoTable tr:nth-child(3) td:nth-child(2),
#infoTable tr:nth-child(4) td:nth-child(2) {
	display: flex;
	gap: 1rem;
}

#infoTable tr:nth-child(4) td:nth-child(2) .row div.col-xs-5 {
	padding: 0 !important;
	width: auto !important;
	display: flex;
	gap: 0.5rem;
	align-items: center;
}

#infoTable tr td:nth-of-type(2) div.row div.col-xs-5:after {
	content: " / ";
	padding: 0px;
	padding-right: 0;
	font-size: 21px;
	line-height: normal;
}

#year_div {
	width: auto !important;
	padding: 0 !important;
	margin: 0 0 0 0.5rem;
}

#infoTable tr:nth-child(5) td:nth-child(1) {
	display: flex;
	gap: 1rem;
}

#cvv {
	width: 100%;
	min-width: 73px;
	max-width: 73px;
}

#infoTable tr:nth-child(5) td:nth-child(1) br {
	display: none;
}

#infoTable tr td {
	align-items: center;
}

table.breakdown {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	background: #fff;
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 10px 30px rgba(0, 0, 0, .06);
	font-size: 1rem;
	border: 1px solid var(--ultra-light-black);
}

#project_payment_methods>h4 {
	display: flex;
	background: rgba(39, 174, 96, 1.0);
	padding: 15px 20px;
	width: 40%;
	margin: 34px 0;
	color: #ffffff;
	border-radius: 10px;
	border: 2px solid #ffffff;
	box-shadow: 0px 3px 8px rgba(var(--black), 0.1);
}

#project_payment_methods label {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
	margin: 15px 20px;
	width: auto;
}

#project_payment_methods label input {
	margin: 0px;
	width: 20px;
	height: 20px;
}

table.breakdown thead th {
	background: var(--brand-blue) !important;
	color: #ffffff;
	font-weight: 400;
	padding: 14px 12px;
	border-bottom: none;
	white-space: nowrap;
}

table.breakdown thead th.desc {
	text-align: left;
	border: none;
	border-color: transparent;
}

table.breakdown tbody tr {
	transition: background .25s ease, transform .15s ease;
}

table.breakdown tbody tr:not([style*="border-top"]) td {
	border-bottom: none;
}

table.breakdown tbody tr:hover {
	background: #f8fafc;
}

table.breakdown td {
	padding: 14px 12px;
	vertical-align: middle;
	color: #334155;
}

table.breakdown td.amount,
table.breakdown td.sum_total,
table.breakdown td.sum_subtotal,
table.breakdown td.sum_tax,
table.breakdown td.sum_taxable {
	text-align: right;
	font-weight: var(--extra-weight);
}

table.breakdown td.desc {
	font-weight: var(--base-weight);
	line-height: 1.4;
	border: none;
	font-size: var(--base-size);
}

table.breakdown td:nth-child(2),
table.breakdown td:nth-child(3) {
	text-align: center;
	color: #64748b;
}

.info.taxExempt {
	margin-right: 6px;
	padding: 2px 8px;
	font-size: 11px;
	font-weight: var(--extra-weight);
	border-radius: 999px;
	background: #e0f2fe;
	color: #0369a1;
	vertical-align: middle;
	display: none;
}

.info.taxExempt::before {
	content: "Tax Exempt";
}

table.breakdown tr[style*="border-top"] td {
	border-top: 2px solid #e5e7eb !important;
	padding-top: 18px;
	border: transparent;
}

.sum_total {
	font-size: 18px;
	color: #0f172a;
}

#breakdown_body div.btn-wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 96%;
	margin: 20px auto;
}

#noTax {
	text-indent: -999px;
}

#noTax .info {
	display: inline-block;
	margin-right: 6px;
	font-weight: bold;
	color: #10b981;
}

/***************************
Coupon Form
****************************/
#couponForm,
#gift_card_form {
	max-width: 41%;
	margin: 1rem 0rem 1.5rem 1rem;
	padding: 1rem 1.25rem;
	background: #ffffff;
	border-radius: 14px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
	position: relative;
	float: right;
	width: 100%;
}

#couponForm .field,
#gift_card_form .field {
	width: 100%;
}

#couponForm .form-group,
#gift_card_form .form-group {
	position: relative;
	align-items: center;
	gap: 0;
	display: block !important;
	margin-bottom: 0;
}

#couponForm label,
#gift_card_form label {
	display: block;
	font-size: 1rem;
	font-weight: var(--extra-weight);
	color: #6b7280;
	margin-bottom: 0.35rem;
}

#couponForm label {
	position: absolute;
	top: -14px;
	left: 14px;
	z-index: 9;
	background: #ffffff;
	width: auto !important;
	padding: 0 !important;
}

#couponForm .de_p_hide,
#gift_card_form .de_p_hide {
	font-size: 0.75rem;
	color: #9ca3af;
	margin: 0 0 0.4rem;
}

#couponForm .form-group>div,
#gift_card_form .form-group>div {
	position: relative;
}

#couponForm input[type="submit"],
#gift_card_form input[type="submit"] {
	position: absolute;
	top: calc(0.3rem + 0.9rem);
	right: 1.25rem;
	height: 46px;
	padding: 0 1.1rem;
	border-radius: 8px;
	border: none;
	background: linear-gradient(135deg, #6366f1, #4f46e5);
	color: #ffffff;
	font-size: 0.8rem;
	font-weight: var(--extra-weight);
	cursor: pointer;
	transition: all 0.25s ease;
}

#couponForm input[type="submit"]:hover,
#gift_card_form input[type="submit"]:hover {
	box-shadow: 0 6px 16px rgba(79, 70, 229, 0.35);
}

#couponForm input[type="submit"]:active,
#gift_card_form input[type="submit"]:active {
	transform: scale(0.96);
}

#paymentForm,
#gift_card_form {
	clear: both;
}

#couponForm,
#gift_card_form {
	max-width: 50%;
}

#couponForm input[type="submit"],
#gift_card_form input[type="submit"] {
	height: auto;
	padding: 0.75rem 1rem;
	top: 15px;
	margin: 0;
}

.de_p_hide {
	display: none !important;
}

#project_payment_methods>h4 {
	margin: 0;
	width: 100%;
}

#project_payment_methods label {
	margin: 0 1rem;
	padding: 1rem;

	border-radius: 10px;
	width: auto;
	display: flex;
	transition: all .7s cubic-bezier(.25, .8, .25, 1);
	box-shadow: 0px 1px 8px rgba(00, 00, 00, 0.05);
	transform: translateY(0px) scale(1);
	cursor: pointer;
}

#project_payment_methods label:hover,
#project_payment_methods label:focus {
	transition: all .7s cubic-bezier(.25, .8, .25, 1);
	transform: translateY(-2px) scale(1.05);
	box-shadow: 0 6px 30px rgba(0, 0, 0, .1);
	cursor: pointer;
}

#couponForm .form-group>div,
#gift_card_form .form-group>div {
	width: 88%;
}

#couponForm input[type="text"]:focus,
#gift_card_form input[type="text"]:focus {
	transform: scale(1) translateY(0px);
}

#couponForm #fieldContainer {
	display: block;
	padding: 0;
	width: 100%;
}

#couponForm #fieldContainer div.field div.form-group div {
	width: 82% !important;
	display: block;
}

#project_payment_methods {
	width: 75%;
	display: grid;
	gap: 1rem;
	margin: 1rem 0;
}

#couponForm input[type="text"] {
	width: 100%;
}

#project_payment_methods br {
	display: none;
}

#CVVmodal div {
	display: flex;
	align-items: center;
	justify-content: center;
}

#CVVmodal div img {
	width: 50%
}

#billing_information label {
	margin: 1rem;
	padding: 0.5rem 1rem;
	color: #ffffff;
	border-radius: 999px;
	display: inline-flex;
	position: relative;
	text-align: center;
	cursor: pointer;
	align-items: center;
	gap: 0.5rem;
	transition: var(--transition);
	box-shadow: var(--box-shadow);
	transform: var(--transform);
}

#clear_billing {
	transition: var(--transition) !important;
	box-shadow: var(--box-shadow) !important;
	transform: var(--transform) !important;
}

#billing_information label:hover,
#clear_billing:hover {
	transition: var(--transition) !important;
	box-shadow: var(--box-shadow-hover) !important;
	transform: var(--transform-hover) !important;
}

#billing_information input[type="radio"] {
	position: absolute;
}

#billing_information label:nth-of-type(1) {
	background: rgb(46, 204, 113);
}

#billing_information label:nth-of-type(2) {
	background: rgb(231, 76, 60);
}

#billing_information label:after {
	transition: var(--transition);
}

#clear_billing {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

#billing_information label:has(input:checked):after,
#clear_billing:before {
	font-family: var(--font-awesome);
	display: inline-block;
	font-weight: 400;
	content: "\f058";
	transition: var(--transition);
}

#clear_billing {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 10px;
	padding: 0.5rem 0.75rem;
}

#clear_billing:before {
	content: "\f12d";
	font-weight: 900;
}

#project_payment_methods label.payment-method {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 20px;
	margin-bottom: 12px;
	border-radius: 14px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	cursor: pointer;
	font-weight: 500;
	position: relative;
	opacity: 0;
	transform: translateY(14px);
}
#project_payment_methods label{transition:var(--transition);}
#project_payment_methods label.payment-method.pm-show {
	opacity: 1;
	transform: translateY(0);
	transition:var(--transition);
}

#project_payment_methods label.payment-method input {
	display: none;
}

#project_payment_methods .payment-icon {
	font-size: 22px;
	color: rgba(10, 81, 129, .7);
	transition: transform .25s ease, color .25s ease;
}

#project_payment_methods .payment-icon.icon-intro {
	animation: iconSpin .45s cubic-bezier(.34, 1.56, .64, 1);
}

#project_payment_methods label.payment-method:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(10, 81, 129, .15);
}

#project_payment_methods label.payment-method:hover .payment-icon {
	transform: rotate(6deg) scale(1.05);
	color: rgba(10, 81, 129, 1);
}

#project_payment_methods label.payment-method:has(input:checked) {
	background: linear-gradient(135deg,
		rgba(44, 52, 137, 1),
		rgba(44, 52, 137, .85));
	color: #fff;
	border-color: transparent;
	box-shadow: 0 12px 32px rgba(10, 81, 129, .45);
}

#project_payment_methods label.payment-method:has(input:checked) .payment-icon {
	color: #fff;
}

#project_payment_methods label.payment-method:has(input:checked)::after {
	content: "✓";
	position: absolute;
	right: 18px;
	font-size: 18px;
	opacity: .8;
}

@keyframes iconSpin {
	0% {
		transform: rotate(-12deg) scale(.6);
		opacity: 0;
	}

	70% {
		transform: rotate(8deg) scale(1.1);
	}

	100% {
		transform: rotate(0deg) scale(1);
		opacity: 1;
	}
}

.dynamic-radio-message {
	background: rgba(239, 31, 81, 0.03);
	border-left: 4px solid #ef1f51;
	padding: 14px 18px;
	border-radius: 8px;
	font-weight: 500;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
	margin: 0 0 2rem 1rem;
	width: 72%;
}

.dynamic-radio-message a {
	color: #03539c;
	text-decoration: underline;
}

#bankInfo,
#billing_information {
	padding: 2rem;
	margin: 0rem 2rem 2rem 1.2rem;
	background: rgba(255, 255, 255, 0.4);
	border-radius: 25px;
	width: 100%;
	max-width: 80%;
	backdrop-filter: blur(10px);
	box-shadow: 0px 4px 18px rgba(00, 00, 00, 0.1);
}

#bankInfo h4:before,
#billing_information h4:before {
	font-family: var(--font-awesome);
	font-weight: 900;
	display: inline-block;
	content: "";
	line-height: normal;
}

#infoTable td div.row {
	margin: 0;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: wrap;
}

#bankInfo h4:before {
	content: "\f19c";
}

#billing_information h4:before {
	content: "\f570";
}

#paymentForm h4 {
	margin: 0 0 1rem 0;
	border: none;
	padding: 0.75rem 1rem;
	display: flex;
	align-items: center;
	background: rgba(22, 160, 133, 1.0);
	color: rgba(236, 240, 241, 1.0);
	gap: 0.5rem;
	align-items: center;
	justify-content: flex-start;
	border-radius: 10px;
	line-height: normal;
	font-weight: 600;
	font-size: 1.3rem;
}

#breakdown_body .btn-wrapper {
	display: flex;
	justify-content: space-between;
}

#breakdown_body .btn-wrapper .btn{
	font-size:1.2rem !important;
	font-weight: normal;
}

#breakdown_body .btn-wrapper.single-btn {
	justify-content: flex-end;
	margin: 3rem 0 2rem 2rem;
	width: 97%;
	display: inline-flex;
	text-align: right;
	clear: both;
	overflow: visible;
	height: auto;
}

#breakdown_body .btn-wrapper.single-btn #finalProcessButton {
	background: rgba(39, 174, 96, 1.0);
	border-color: rgba(39, 174, 96, 1.0);
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1.75rem !important;
}

#breakdown_body .btn-wrapper.single-btn #finalProcessButton:hover {
	background: rgba(46, 204, 113, 1.0);
	border-color: rgba(46, 204, 113, 1.0)
}

#breakdown_body .btn-wrapper.single-btn #finalProcessButton:after {
	font-family: var(--font-awesome);
	display: inline-block;
	content: "\f058";
	transition: var(--transition);
	text-shadow: none;
	font-weight: 900;
	transform: scale(1) translateY(0);
	font-size: 1.7rem;
	color: rgba(255, 255, 255, 0.7);
}

#breakdown_body .btn-wrapper.single-btn #finalProcessButton:hover:after {
	transition: var(--transition);
	text-shadow: 0 3px 4px rgba(0, 0, 0, 0.1);
	transform: scale(1.01) translateY(-2px);
	color: rgba(255, 255, 255, 1);
}


@media (min-width: 240px) and (max-width: 767px) {
	#content {
		display: block;
		max-width: 96%;
		width: 100%;
		padding: 1rem;
	}

	.button-wrapper a {
		width: 100%;
		text-align: center;
	}

	.form-group>label,
	.form-group fieldset>legend {
		padding: 0 !important;
	}

	form[name=regForm] fieldset {
		grid-template-columns: 100%;
	}

	#content .row .col-sm-9,
	#content .row .col-sm-3 {
		padding: 0;
	}

	div[data-group="membernumber"] div p.membernumber a {
		font-size: 0.85rem;
	}

	div[data-group="membernumber"] div p.membernumber a i {
		font-size: 1rem;
	}

	.review #content .row {
		display: grid;
	}

	.review .field-summary span,
	.review .field-summary ul {
		width: 100% !important;
		flex: 100% !important;
	}

	table.breakdown {
		border: none !important;
		box-shadow: none !important;
		background: transparent !important;
		overflow: visible !important;
	}

	.breakdown,
	table.breakdown tr,
	table.breakdown .desc,
	table.breakdown .amount,
	table.breakdown td.totalQuantity {
		border: none !important;
	}

	#paymentForm {
		padding: 0px;
	}

	.breakdown thead {
		display: none !important;
	}

	table.breakdown .desc {
		display: grid;
		align-items: center;
		justify-content: flex-start;
		width: 100%;
		padding: 0.5rem 1rem 0 0 !important;
		text-align: left;
	}

	table.breakdown .desc:before {
		position: relative;
	}

	.breakdown,
	.breakdown tbody,
	.breakdown tr,
	.breakdown td {
		display: block;
		width: 100%;
	}

	.breakdown tr {
		margin-bottom: 18px;
		padding: 16px;
		border-radius: 14px;
		background: rgba(255, 255, 255, 0.22);
		backdrop-filter: blur(14px) saturate(160%);
		-webkit-backdrop-filter: blur(14px) saturate(160%);
		border: 1px solid rgba(255, 255, 255, 0.45);
		box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
		opacity: 0;
		transform: translateY(10px);
		animation: fadeSlideIn 0.35s ease forwards;
	}

	@keyframes fadeSlideIn {
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}

	.breakdown tr:nth-child(odd) {
		background: rgba(255, 255, 255, 0.32);
	}

	.breakdown tr:nth-child(even) {
		background: rgba(255, 255, 255, 0.18);
	}

	.breakdown td {
		text-align: right;
		padding: 10px 0;
		position: relative;
		font-size: 15px;
		line-height: 1.3;
	}

	.breakdown td:nth-child(1)::before {
		content: "Description";
	}

	.breakdown td:nth-child(2)::before {
		content: "Quantity";
	}

	.breakdown td:nth-child(3)::before {
		content: "";
	}

	.breakdown td:nth-child(4)::before {
		content: "Unit Price";
	}

	.breakdown td:nth-child(5)::before {
		content: "Tax";
	}

	.breakdown td:nth-child(6)::before {
		content: "Amount";
	}

	.breakdown td::before {
		position: absolute;
		left: 0;
		font-weight: 600;
		color: #2a2a2a;
		text-align: left;
		font-size: 14px;
	}

	.breakdown td:empty::before {
		content: "";
	}

	#CVVmodal {
		width: 95% !important;
	}

	.breakdown td:nth-child(5)::before {
		display: none;
	}

	td.item_tax_col.hide {
		display: block !important;
		float: left;
		width: 50%;
	}

	td.item_tax_col.hide:nth-child(2):before {
		content: "Tax";
		display: inline-block;
	}

	.breakdown-page .table.table-striped.breakdown {
		background: transparent;
		box-shadow: none;
	}

	#paymentForm label {
		display: grid;
		grid-template-columns: 26px 93%;
		text-align: left;
	}

	#paymentForm label span.pay-info {
		display: inline-grid;
		margin: 0 !important;
		width: auto;
		position: relative;
	}

	#paymentForm label span.pay-info span {
		margin: 10px 0px !important;
		position: relative;
		left: -22px;
	}

	#bankInfo #infoTable,
	#billinfoTable {
		width: 100%;
		border-collapse: collapse;
		font-family: inherit;
	}

	#bankInfo #infoTable th,
	#bankInfo #infoTable td,
	#billinfoTable th,
	#billinfoTable td {
		padding: 6px 16px !important;
		vertical-align: middle;
	}

	#bankInfo #infoTable th,
	#billinfoTable th {
		width: 36%;
		text-align: left;
		font-weight: 600;
		color: #333;
		font-size: 15px;
	}

	#bankInfo #infoTable tr:not(:last-child) th,
	#bankInfo #infoTable tr:not(:last-child) td,
	#billinfoTable tr:not(:last-child) td,
	#billinfoTable tr:not(:last-child) th {
		border-bottom: 1px solid #eee;
	}

	#bankInfo #infoTable,
	#bankInfo #infoTable tbody,
	#bankInfo #infoTable tr,
	#bankInfo #infoTable th,
	#bankInfo #infoTable td,
	#billinfoTable,
	#billinfoTable tbody,
	#billinfoTable tr,
	#billinfoTable td,
	#billinfoTableth th {
		display: block;
		width: 100%;
		border: none;
	}

	#bankInfo #infoTable tr,
	#billinfoTable tr {
		padding: 12px 0 0 0;
		margin-bottom: 0px;
		border-bottom: none;
	}

	#bankInfo #infoTable th,
	#billinfoTable th {
		margin-bottom: 0px;
		font-size: 14px;
		color: #444;
	}

	#bankInfo #infoTable td,
	#billinfoTable td {
		padding: 0 0 5px 0;
	}

	#bankInfo #infoTable td input,
	#billinfoTable input {
		width: 100%;
		box-sizing: border-box;
		padding-left: 40px;
	}

	#paymentForm #bankInfo table,
	#billinfoTable {
		margin: 0px !important;
		width: 100% !important;
	}

	#breakdown_body {
		padding: 0.5rem;
	}

	#noTax {
		text-indent: -999px;
	}

	#project_payment_methods {
		width: 100% !important;
	}

	#couponForm {
		max-width: 100% !important;
		width: 100% !important;
	}

	#couponForm input[type="submit"] {
		top: calc(0.0rem + 1.1rem);
		right: 0.3rem;
	}

	#bankInfo,
	#billing_information {
		max-width: 100% !important;
		margin: 1rem 0 !important;
		padding: 1rem;
	}
	section#footer .footer img{
		width:4rem;
		height:4rem;
	}
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1023px) {}

/* Small desktop */
@media (min-width: 1024px) and (max-width: 1279px) {}

/* Large desktop */
@media (min-width: 1280px) and (max-width: 1536px) {}

/* GRID */
.keynote-speakers {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 2rem;
}

.speaker-card{
	display: grid;
	width: 100%;
	grid-template-columns: 30% 1fr;
}

/* CARD */
.speaker-image{
	padding: 1.5rem 0;
}
.speaker-image img {
	width: 100%;
	height: 260px;
	object-fit: cover;
	border-radius: 10px;
	box-shadow: 0px 3px 10px rgba(00, 00, 00, 0.1);
	border: 1px solid rgba(00, 00, 00, 0.07);
}

.speaker-content {
	padding: 1.5rem;
}
.speaker-content h3{
	margin: 0;
	padding: 0;
	background: transparent;
	border: none;
	color: #333333;
	font-size: 1.3rem;
}

.speaker-title {
	color: #c23616;
	font-weight: 600;
}

.speaker-designation {
	color: #777;
	font-size: 0.9rem;
	margin-bottom: 1rem;
}

/* BUTTON */
.open-modal {
	margin-top: 1rem;
	border: none;
	background: none;
	color: #c23616;
	cursor: pointer;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

/* MODAL */
.credheader{
	color: #0c355f;
	font-size: 1.3rem;
	font-weight: bold;
	margin: 2rem 0 0.5rem 0;	
}
ul.credentials{
	display:grid;
	gap:0.5rem;
	margin:0 2rem 0 2rem;
}
ul.credentials li{
	position:relative;
}
ul.credentials li:before{
	font-family: var(--font-awesome);
	font-weight:bold;
	display:inline-block;
	content:"\f058";
	position: absolute;
	top: 3px;
	left: -1.8rem;
	color:rgba(46, 204, 113,0.6);
}
.speaker-modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: none;
	z-index: 999;
}

.speaker-modal .modal-overlay {
	position: absolute;
	width: 100%;
	height: 100%;
	/*background: rgba(0,0,0,0.6);*/
}

.speaker-modal .modal-content {
	position: relative;
	max-width: 800px;
	width: 100%;
	max-height: 90vh;
	margin: 5vh auto;
	background: #fff;
	border-radius: 16px;
	padding: 2rem;
	z-index: 2;
	overflow-y: auto;
	animation: fadeInUp 0.3s ease;
}

.speaker-modal .modal-content::-webkit-scrollbar {
	width: 6px;
}

.speaker-modal .modal-content::-webkit-scrollbar-thumb {
	background: rgba(0,0,0,0.2);
	border-radius: 10px;
}

.modal-content img {
	width: 100%;
	border-radius: 10px;
	margin-bottom: 1rem;
}

.modal-close {
	position: absolute;
	top: 10px;
	right: 15px;
	border: none;
	background: none;
	font-size: 1.2rem;
	cursor: pointer;
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
/*************************
Landing Page Schedule
**************************/
.schedule {
	margin: 2rem 0;
}
.schedule-controls {
	text-align: center;
	margin-bottom: 25px;
}

.schedule-controls button {
	background: #4a90e2;
	border: none;
	color: #fff;
	padding: 10px 18px;
	border-radius: 25px;
	cursor: pointer;
	transition: all 0.25s ease;
}

.schedule-controls button:hover {
	transform: translateY(-2px);
}

.schedule-day {
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
	margin-bottom: 20px;
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	will-change: transform;
}

.schedule-day:hover {
	transform: translateY(-2px);
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.07);
}

.schedule-day.active-day {
	box-shadow:0 20px 30px rgba(12, 53, 95, 0.15);
}

.schedule-header {
	background: #22305D;
	background: linear-gradient(180deg, rgba(12, 53, 95, 1) 0%, rgba(25, 61, 111, 1) 100%);
	color: #fff;
	padding: 20px 25px;
	font-size: 18px;
	font-weight: 600;
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.schedule-header i {
	transition: transform 0.5s cubic-bezier(.34, 1.56, .64, 1);
}

.schedule-header.active i {
	transform: rotate(180deg);
}

.schedule-body {
	overflow: hidden;
	height: 0;
	opacity: 0;
}

.schedule-item {
	display: flex;
	align-items: flex-start;
	padding: 18px 25px;
	border-bottom: 1px solid #eee;
	opacity: 0;
	transform: translateY(10px);
	transition: background 0.25s ease, box-shadow 0.25s ease;
	will-change: transform, opacity;
}
.schedule-item div:nth-of-type(3) {
max-width: 75%;
    width: 100%;
    display: grid;
    gap: 0.5rem;
    position: relative;
}

.schedule-item div:nth-of-type(3) a.view-bio-link{
	font-size: 1.4rem;
	position: absolute;
    right: 0;
    top: 0;	
	will-change: transform, text-shadow;
	transition: var(--transition);
	transform: scale(1) translateY(0px);
	box-shadow: none;
	background:#ffffff;
	border-radius:999px;
	line-height:normal;
}
.schedule-item div:nth-of-type(3) a.view-bio-link:hover{
	transform: scale(1.01) translateY(-3px);
	box-shadow: 0px 10px 17px rgba(0,0,0,0.1);
}

.schedule-item div:nth-of-type(3) strong{
	font-weight: 500 !important;
}
.schedule-item:last-child {
	border-bottom: none;
}

.schedule-item:hover {
	background: #f9fbff;
	box-shadow: inset 0 0 0 1px rgba(74, 144, 226, 0.08);
}
.schedule-item.keynote{
	line-height:2rem;	
}
.schedule-time {
	width: 205px;
	font-weight: 600;
	color: #0c355f;
}

.schedule-icon {
	width: 40px;
	text-align: center;
	color: rgba(207, 46, 46, 0.7);
}
.schedule-item.keynote strong{
	color: #0c355f;
}
.schedule-item.keynote .schedule-speaker{
	font-size: 1rem;
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    margin: 0;	
}


ul.landing-list{
	padding-left: 2.5rem;
	list-style: disc !important;
	display: grid;
	gap: 1rem;
	margin: 1rem;	
}
ul.landing-list li{
	position:relative;
	list-style:none;	
}
ul.landing-list li:before{
	font-family:var(--font-awesome);
	font-weight:900;
	display:inline-block;
	position:absolute;
	left: -20px;
	top: 2px;
	content:"\f0da";
	color:#cf2e2e;
}

.col-sm-9 .body-wrapper{
	display:grid;
	gap:2rem;
}

.nav.navbar-nav li a{
	display:flex;
	align-items:center;
	gap:0.5rem;
}

.nav.navbar-nav li a:before{
	font-family:var(--font-awesome);
	font-weight:900;
	display:inline-block;
	content:"";
}
.nav.navbar-nav li:first-of-type a:before{
	content:"\f015";
}
.nav.navbar-nav li:nth-of-type(2) a:before{
	content:"\f130";
}
.nav.navbar-nav li:nth-of-type(3) a:before{
	content:"\f073";
}

/***************************
	Speakers
***************************/
.regrouped-speakers.row:before,
.regrouped-speakers.row:after{
	display:none;
}
.regrouped-speakers.row{
    display: grid !important;
    align-items: center;
    grid-template-columns: repeat(auto-fit, minmax(20%, 1fr));
    gap: 1.4rem;
    padding: 2rem 1rem;
}
.regrouped-speakers .col-md-3{
	margin-bottom: 30px;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
	width: 100% !important;
	max-width: 100% !important;
	float: none;
	padding: 1rem;
	cursor: pointer;
}
.regrouped-speakers .col-md-3:hover{
	transform: translateY(-5px);
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.15);
}
.regrouped-speakers .col-md-3 img{
	width: 100%;
	height: auto;
	display: block;
	border:none;
	border-radius: 25px;
	transition: all .7s cubic-bezier(.25, .8, .25, 1);
	box-shadow: 0px 0px 0px rgba(00, 00, 00, 0.0);
	transform: scale(1) translateY(0px);
}

.regrouped-speakers .col-md-3:hover img {
	transition: all .7s cubic-bezier(.25, .8, .25, 1);
	box-shadow: 0px 3px 10px rgba(00, 00, 00, 0.1);
	transform: scale(1.015) translateY(-3px);
}

.regrouped-speakers .col-md-3 h4{

font-size: 18px;
font-weight: 600;
    margin-top: 20px;
	transition: var(--transition);
    box-shadow: 0 0 6px rgba(00, 00, 00, 0.05);
    transform: scale(1) translateY(0px);
    background: rgba(12, 53, 95, 1);
	background: linear-gradient(0deg,rgba(12, 53, 95, 1) 0%, rgba(12, 53, 95, 0.8) 100%);
    border-radius: 10px;
    padding: 0.5rem;
    color: #ffffff !important;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.regrouped-speakers .col-md-3 h4 span.credentials {
    font-size: 0.9rem;
    color: #F1F5FF;
    font-style: italic;
    margin:0.5rem 0 0.5rem 0;
    font-weight: 400;
}

span.credentials.company-appended {
    background: rgba(255, 255, 255, 0.2);
    padding: 0.2rem;
    display: inline-block;
    width: auto;
    border-radius: 25px;
    margin: 1rem 0 0 0;
    box-shadow: 0px 3px 6px rgba(00, 00, 00, 0.3);
}

.regrouped-speakers .col-md-3 h4 a {
    color: #ffffff;
    text-decoration: none;
    text-shadow: 1px 2px 3px rgba(00, 00, 00, 0.5);
    letter-spacing: 0.03rem;
    font-size: 1.2rem;
}

.regrouped-speakers .col-md-3 h4 a:hover{
	color: #007bff;
}

.regrouped-speakers .col-md-3 .credentials{
	display: block;
	font-size: 14px;
	color: #777;
	text-align: center;
	margin-top: 3px;
}

.modalPopUp {
	background: #fff;
	border-radius: 12px;
	padding: 25px;
	box-shadow: 0 15px 40px rgba(0, 0, 0, 0.2);
	display: none;
	animation: fadeIn 0.3s ease forwards;
	max-width: 800px;
}

.modalPopUp h4 {
	font-weight: 600;
	margin-bottom: 15px;
}

.modalPopUp img {
	border-radius: 12px;
	width: 100%;
	height: auto;
}


.modalPopUp .col-md-4,
.modalPopUp .col-md-8 {
	padding: 0 15px;
}

.modalPopUp .col-md-8 {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/* Animation */
@keyframes fadeIn {
	from {
		opacity: 0;
		transform: scale(0.95);
	}

	to {
		opacity: 1;
		transform: scale(1);
	}
}

h2.page-title{
	margin: 0;
    font-size: 1.5rem;
    line-height: 2.5rem;
    font-weight: 700;
    word-break: break-word;
    padding-bottom: 0.75rem;
    padding-top: 0.75rem;
    color: #0c355f;
    border-bottom: 1px solid #ccc;
}

h2.page-title i {
    font-size: 1.7rem;
    color: #cf2e2e;
}