/* FORM STYLE ONLY */
input[type=text],
input[type=password],
.chosen-container-multi .chosen-choices li.search-field input[type="text"] {
    border-radius: 1.5rem;
    color: var(--color-black);
    font-size: 1rem;
    line-height: 1.5;
    height: 2.5rem;
    padding-left: 1rem;
    width: 97%;
}
.index_registrations_autotech .landing-page input[type=text],
.index_registrations_autotech .landing-page input[type=password] {
    border-radius: 3rem;
    color: var(--color-black);
    font-size: 1rem;
    line-height: 1.5;
    height: 100%;
    width: 80%;
}

input[type=checkbox],
input[type=radio] {
    margin-right: 8px;
    transform: scale(1.5);
}

select, 
.form-control, 
.inside-page .content form select,
.form-control:not([id^="cybersource_"]),
.inside-page .chosen-container.chosen-container-single a.chosen-single {
    text-align: left;
    border-radius: 1.5rem;
    font-size: 1rem !important;
    height: auto;
    min-height: 2.2rem;
    position: relative;
    width: 80.5%;
}
select option,
select.writeInQuestion option,
.inside-page .content form select option {
    font-size: 1rem !important;
    line-height: 1.5 !important;
}
.inside-page .chosen-container-multi .chosen-choices {
    border-radius: 1.5rem;
}
label,
.textElement-label {
    display: block;
    font-weight: 700;
    line-height: 1.4;
    padding-left: 0;
    text-align: left;
}

/* REQUIRED SYMBOL */
.inlineSymbol.requiredSymbolClass {
	color: var(--color-red);
    font-size: 1.2rem;
    visibility: hidden;
    position: relative;
}

.inlineSymbol.requiredSymbolClass:after {
    visibility: visible;
    position: absolute;
    top: 0;
    left: 0;
    content: "*";
}

.requiredSymbol,
.notRequiredSymbolClass,
.requiredSymbolClass:not(.inlineSymbol) {
	display: none !important;
}

label[isrequired="1"]:before {
	color: var(--color-red);
	content: "*";
    display: inline-block;
    font-size: 1.2rem;
    margin-left: -1rem;
    margin-right: .3rem;
    position: relative;
}

.ip-elementPackage .reqAQ label[isrequired="1"]:before {
    margin-left: -.6em;
}

/* LOGIN BOX */
.login-box form {
    width: 100%;
    padding: 0;
}
.login-box label {
    display: inline-block;
    font-weight: 700;
    line-height: 0;
    margin-left: 15px;
    clear: both;
}
.login-box input[type=text] {
    width: 65%;
}
.login-box form input[type="text"] {
    width: 100%;
}
.login-box .btn-cancel {
    display: none;
}
.login-box .btn {
    margin-top: 0;
}

/* PROGRESS MENU + PUBLIC MENU */
#progressMenu {
    left: 0rem;
    position: absolute;
    top: 13.75rem;
    width: 100%;
}
#progressMenu ul {
    gap: 2px;
}
#progressMenu ul li {
    flex-basis: 33.33%;
    padding: 0.75em 0;
    border-bottom: unset;
}
#progressMenu ul,
#publicMenu {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 5px;
    justify-content: space-evenly;
    list-style: none;
}
#public.index_registrations_groupreview .inside-page main#main ul#publicMenu, #public.index_registrations_grouppayment .inside-page main#main ul#publicMenu {
    flex-wrap: wrap;
    position: absolute;
    top: 15.5rem;
    width: 94%;
}
#public.index_registrations_review .inside-page main ul#publicMenu,  #public.index_registrations_review .inside-page main:has(#publicMenu) ul#publicMenu, #public.index_registrations_profile .inside-page main ul#publicMenu,  #public.index_registrations_review .inside-page main:has(#publicMenu) ul#publicMenu {
    flex-wrap: wrap;
    position: absolute;
    top: 22rem;
    width: 94%;
}
.index_registrations_changepassword .inside-page main:has(#publicMenu) ul#publicMenu {
    flex-wrap: wrap;
    position: absolute;
    top: 14rem;
    width: 94%;
}

body[class*="forgot-password"] div:has(input) label,
body[class*="forgot-password"] .ip-buttonBar {
    margin-left: 1rem;
}

#progressMenu ul li,
#publicMenu li {
    display: block;
    text-align: center;
    padding: 0.625em 0;
}

#progressMenu ul li.completedStep {
    color: #333;
}

@media screen and (min-width: 1200px) {
    #publicMenu {
        display: flex;
        gap: 10px;
        flex-wrap: wrap;
        flex-direction: row;
        justify-content: flex-start;
    }
    #publicMenu li {
        flex-basis: 20%;
        border-bottom: unset;
        padding: unset;
    }

    #publicMenu li a {
        display: block;
        padding: 0.75em;
        height: 100%;
    }
    #public.index_registrations_profile .inside-page main:has(#publicMenu) ul#publicMenu:not(.publicMenuGroupReview.firstMenuItem), #public.index_profile .inside-page main:has(#publicMenu) ul#publicMenu:not(.publicMenuGroupReview.firstMenuItem) {
        position: absolute;
        top: 22rem;
        width: 94%;
    }
    
    #public:has([class="index_registrations_review"], [class="index_registrations_profile"]) .inside-page main:has(ul#publicMenu, li.publicMenuGroupReview, #progressMenu) header#header {
        padding-bottom: 21rem !important;
    }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
    #public.index_registrations_review .inside-page main:has(#publicMenu) ul#publicMenu:not(.publicMenuGroupReview.firstMenuItem), #public.index_profile .inside-page main:has(#publicMenu) ul#publicMenu:not(.publicMenuGroupReview.firstMenuItem) {
        position: absolute;
        top: 22rem;
        width: 94%;
    }
    #public.index_registrations_profile .inside-page main#main:has(li.publicMenuGroupReview.firstMenuItem) header#header {
        padding-bottom: 24rem !important;
    }
    #public.index_registrations_profile .inside-page main#main:not(li.publicMenuGroupReview.firstMenuItem)) header#header {
        padding-bottom: 18.5rem !important;
    }
    #public.index_registrations_groupreview .inside-page main ul#publicMenu, #public.index_registrations_grouppayment .inside-page main ul#publicMenu {
        flex-wrap: wrap;
        top: 15.5rem;
    }
     
    #progressMenu ul li {
        flex-basis: 33.33%;
        padding: 0.75em 0;
        border-bottom: unset;
    }

    #publicMenu li {
        flex-basis: 20%;
        border-bottom: unset;
        padding: unset;
    }

    #publicMenu li a {
        display: block;
        padding: 0.75em;
        height: 100%;
    }
}
@media screen and (max-width: 768px) {
    div#progressMenu {
        position: absolute;
        top: 13.75rem;
        width: 88%;
    }
    #publicMenu {
        flex-direction: column;
    }
    #public[class$="review"] .inside-page main ul#publicMenu, .index_registrations_profile .inside-page main:has(#publicMenu) ul#publicMenu {
        left: -.5rem;
        position: absolute;
        top: 22.5rem;
        width: 94%;
    }
    #public[class*="review"] .inside-page main:not(div#progressMenu) ul#publicMenu:has(li.publicMenuGroupReview){
        top: 13.75rem;
    }
    #public[class*="review"] .inside-page main:has(div#progressMenu) ul#publicMenu:has(li.publicMenuGroupReview){
        top: 21.75rem;
    }
    #public[class^="index_registrations"] .inside-page main:has(li.publicMenuGroupReview):not(#progressMenu) header#header {
        padding-bottom: 38rem !important;
    }
    /*#public[class^="index_registrations"] .inside-page main:has(li.publicMenuGroupReview, #progressMenu) header#header {
        padding-bottom: 35rem !important;
    }*/
    .ip-elementPackages.ip-elementPackagesNoWrap {
        grid-template: auto / auto !important;
    }
}
@media screen and (max-width: 470px) {
    div#progressMenu {
        left: -1.25rem;
        position: absolute;
        top: 15.75rem;
        width: 95%;
    }
    div#progressMenu ul li span {
        font-size: .7rem;
    }
    #publicMenu li {
        width: 95%;
    }
    #public[class*="review"] .inside-page main:not(div#progressMenu) ul#publicMenu:has(li.publicMenuGroupReview){
        top: 15.75rem;
    }
}
/* PHONE NUMBER + PASSWORD INPUTS */

.iti--separate-dial-code,
.ip-elm-password,
.ip-elm-confirmpassword,
.ip-elm-textbox {
    width: 83%;
    text-align: left;
}
/*Profile -- keep in touch SECTION */
.index_registrations_profile .ip-elm-radio-multi:not([style="display: none;"]):has(input[type=radio]) {
    display: flex !important;
    flex-direction: row;
}
.index_registrations_profile .ip-elm-radio-multi span.ip-elementContent {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    margin-top: -2px;
}

.index_registrations_profile .ip-elm-radio-multi span.ip-elementContent:has( #Gxnfax38-970, #fUGdVO46-974) {
    margin-left: 10.65%;
}
.index_registrations_profile .ip-elm-radio-multi span.ip-elementContent:has(#jewEFf22-954, #mmeGSV61-956) {
    margin-left: 11%;
}

/* PACKAGES */

.ip-elementPackages.ip-elementPackagesNoWrap {
    display: grid;
    grid-template: auto / 50% 50%;
    gap: 3px;
}

.ip-elementPackages.ip-elementPackagesNoWrap .ip-elementPackage {
    display: block;
    margin: 0;
    width: 100%;
}

.ip-elementPackageDescriptionContainerTitle {
    display: none;
}

@media screen and (min-width: 519px) and (max-width: 767px) {
    .ip-elementPackages.ip-elementPackagesNoWrap .ip-elementPackage {
        border-radius: 1.5rem;
        flex-basis: calc(50% - 2px);
        padding: 0;
    }
}

@media screen and (min-width: 768px) and (max-width: 1199px) {

    .ip-elementPackages.ip-elementPackagesNoWrap .ip-elementPackage:nth-child(-n+3) {
        border-radius: 1.5rem;
        flex-basis: calc(33.33% - 2px);
        padding: 0;
    }

    .ip-elementPackages.ip-elementPackagesNoWrap .ip-elementPackage:nth-child(n+4) {
        border-radius: 1.5rem;
        flex-basis: calc(50% - 2px);
        padding: 0;
    }
}

@media screen and (min-width: 1200px) {
    .ip-elementPackages.ip-elementPackagesNoWrap {
        gap: 10px;
    }

    .ip-elementPackages.ip-elementPackagesNoWrap .ip-elementPackage {
        border-radius: 1.5rem;
        flex-basis: calc(40% - 1px);
        padding: 0;
    }
}

.ip-elementPackages .ip-elementPackage {
    margin: 0;
    padding: 0;
}

.ip-elementPackages .ip-elementPackage label {
    background: var(--primaryColor);
    border-radius: 1.5rem 1.5rem 0 0 ;
    color: var(--color-white);
    display: block;
    min-height: 64.78px;
    padding: 10px 15px;
    width: 100%;
}

.ip-elementPackages .ip-elementPackage label input {
    margin-left: -5px;
    margin-right: 7px;
}

.ip-elementPackages .ip-elementPackage .ip-elementPackageDescription {
    padding: 10px;
    text-align: left;
}

/* PACKAGE SELECT */

#wOfgnS74-packageID-30 select {
    background: #00e2ff;
    width: 100%;
}

/******/

.ip-buttonBar a.btn {
    margin-right: 20px;
    background: initial;
    color: #333;
    font-weight: bold;
}

.index_registrations_additional_events .ip-elm-radio-multi span.ip-elementContent {
    display: flex;
    margin-top: 5px;
}

.index_registrations_additional_events .ip-elm-radio-multi .questionResponse {
    margin-right: 5px;
}

/* Purchasable Item */

.purchasableItemElementParent {
	display: flex;
	column-gap: 1.5em;
	justify-content: flex-start;
	align-items: stretch;
	margin-top: -10px;
}

.purchasableItemElementParent label {
	line-height: 1em;
}

.purchasableItemElement {
	order: 1;
}

.purchasableItemInputBox {
	order: 2;
}

.purchasableItemElement > .form-group,
.purchasableItemInputBox > .form-group {
    display: flex;
    margin-bottom: 0;
	justify-content: flex-start;
	align-items: center;
	height: 100%
}

.purchasableItemElement > .form-group label,
.purchasableItemInputBox > .form-group span {
    margin-left: 5px;
    order: 2;
}

.purchasableItemElement > .form-group span,
.purchasableItemInputBox > .form-group label {
    order: 1;
}

.purchasableItemInputBox input[type=text] {
    width: 2em;
    line-height: 1em;
    height: auto;
}

.purchasableItemElement > .form-group label,
.purchasableItemInputBox > .form-group label {
	font-weight: normal;
}

.purchasableItemInputBox > .form-group label {
	font-style: italic;
}
/* PAYMENT -- CC FORM */
.form-control:has([class$="copyAddressContainer"]) {
    width: 100%;
}
.form-control .ip-copyAddressContainer .ip-addressContainer {
    padding-left: 3rem;
}
.form-control .ip-copyAddressContainer .ip-addressContainer * {
    display: inline-block;
}
.form-control .ip-copyAddressContainer .ip-addressContainer *:not([class*="Seperator"],[class$="city"]) {
    padding-right: .25rem;
}

/* TABLES */
.ip-elementContentTable .workshopName span {
}

.ip-elementContentTable .workshopName .ip-workshopTitle + .ip-workshopPrice:before {
	content: " \2013\00a0";
}

.ip-elementContentTable .workshopName span:last-of-type {
	margin-right: 0;
}

/* MULTIPLE REG LIST */

#MultipleRegList {
 border-color: #666;
 border-width: 1px 0;
 border-style: dotted;
 padding: .75em 0;
 margin: 1.25rem 0 0 0;
}

#MultipleRegList ul {
	padding: 0;
	margin-bottom: 0;
}

#MultipleRegList li {
	display: inline;
}

#MultipleRegList li:before {
	content: "\2022\00a0";
	color: #666;
}

#MultipleRegList li:not(:first-of-type) {
	padding-left: .5em;
}

#MultipleRegList .ip-sectionTitle {
	font-weight: 700;
	text-transform: uppercase;
}

#MultipleRegList li.ip-registrant-inactive,
#MultipleRegList li.ip-registrant-inactive:before {
	color: #666;
}

#MultipleRegList li.ip-registrant-active,
#MultipleRegList li.ip-registrant-active:before {
	font-weight: 500;
}

/* CHOSEN CONTAINER */

.chosen-container .chosen-results li {
	line-height: unset;
}
.chosen-container .chosen-results li.active-result {
    font-size: 1rem !important;
}

/* EXHIBITOR PROFILE */

.index_exhibitorreg_portal form {
    float: none;
    width: 70%;
    padding: 0;
}

.index_exhibitorreg_portal .login-box label {
    margin-left: 0;
    width: 100%;
}

/* MULTIPLE REGISTRATIONS */

.ip-containerBody[class*='ip-registrant-'] + .ip-containerBody[class*='ip-registrant-'] {
	border-top: 1px dotted #999;
	padding-top: 2rem;
}