
@font-face {
  font-family: 'ZYNDisplay';
  src: url('https://www.winwithzyn.co.za/doc/woff/ZYNDisplay_W_Rg') format('woff'),
       url('https://www.winwithzyn.co.za/doc/woff2/ZYNDisplay_W_Rg') format('woff2');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'ZYNXBD';
  src: url('https://www.winwithzyn.co.za/doc/woff/ZYNSans_W_XBd') format('woff'),
       url('https://www.winwithzyn.co.za/doc/woff2/ZYNDSans_W_XBd') format('woff2');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'ZYNBD';
  src: url('https://www.winwithzyn.co.za/doc/woff/ZYNSans_W_Bd') format('woff'),
       url('https://www.winwithzyn.co.za/doc/woff2/ZYNSans_W_Bd') format('woff2');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'ZYNMD';
  src: url('https://www.winwithzyn.co.za/doc/woff/ZYNSans_W_Md') format('woff'),
       url('https://www.winwithzyn.co.za/doc/woff2/ZYNSans_W_Md') format('woff2');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'ZYNLT';
  src: url('https://www.winwithzyn.co.za/doc/woff/ZYNSans_W_Lt') format('woff'),
       url('https://www.winwithzyn.co.za/doc/woff2/ZYNDSans_W_Lt') format('woff2');
  font-weight: normal;
  font-style: normal;
}

body {
/*    background-color: #02a1e2 !important;*/
    background-color: #00b9f2 !important;
    line-height: 1.4;
    letter-spacing: 0.5px;
    font-family: "ZYNBD", "Saira", sans-serif;
    color: white;
}

.error {
    color: red;
    margin-top: 2px;
    margin-bottom: 2px;
}

.page-banner {
    width: 100vw;
    /*! position
    width: absolute; */
    display: inline-block;
    top: 0;
    left: 0;
    position: relative;
/*    margin-top: -14px;*/
    margin-left: -57px;

}

.page-banner-logo {
    width: 20vh;
    padding: 20px 0px 20px 0px;

}

a {
    color: #02a1e2;
    text-decoration: underline;
    text-decoration-thickness: 2px; /* optional */
    text-underline-offset: 9px;     /* move underline lower */
}

.panel-body {
    margin-left: -27px;
}

.panel-body {
	background-color: white;
	color: black;
	padding: 20px;
	width: 100vw;
	margin-left: -50px;
        margin-top: 20px;
        position: fixed;
        bottom: 0;
        min-height:10vh;
        padding-left: 5px;
        padding-right: 5px;
        container-type: inline-size;
}

.footer-disclaimer {
    font-size: clamp(2cqh, 2cqw, 3cqw);
}

.page-banner img {
    width: 100%;
    height: auto;
    display: block;
}

.faa-parent, .animated-hover{
    display: none;
}

.card {
    box-shadow: none;
}

.card-header {
    border-color: transparent !important;
}

.fa-share-from-square::before, .fa-share-square::before {
	content: None !important;
}

.btn-primary {
	color: #fff;
	background-color: #002a4a;
	border-color: #002a4a;
        border-radius: 13px;
	box-shadow: none;
}

.card-header {
        padding-top: 0px;
        padding-bottom: 0px;
}

.card-body {
        padding-top: 0px;
        padding-bottom: 0px;
}

.box-footer {
    font-size: 0; /* Hides all text including nbsp */
}

.box-footer * {
    font-size: 1rem; /* Restore font size for child elements */
}

label:not(.form-check-label):not(.custom-file-label) {
    font-weight: inherit;
    font-family: "ZYNBD"
}

.content-wrapper {
 /*   background-color: #02a1e2;*/
    background-color: #00b9f2
}

@media (min-width: 576px) {
    .col-sm-9 {
        -ms-flex: 0 0 75%;
        flex: 0 0 75%;
        max-width: 100%;
    }
}

.card {
    background-color: #FFF0 !important;
}

.card-header {
    background-color: #FFF0 !important;
}

.tlc-container-parent {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    flex-flow: column wrap;
}

.tlc-container-child {
    margin: auto;
    width: 25%;
    justify-content: center;
    align-items: center;
    align-content: center
}

@media (min-width: 576px) {
    .tlc-container-child {
        margin: auto;
        width: 80vw;
        justify-content: center;
        align-items: center;
        align-content: center
    }
}
@media (min-width: 768px) {
    .tlc-container-child {
        margin: auto;
        width: 50vw;
        justify-content: center;
        align-items: center;
        align-content: center
    }
}

@media (min-width: 992px) {
    .tlc-container-child {
        margin: auto;
        width: 40vw;
        justify-content: center;
        align-items: center;
        align-content: center
    }
}

@media (min-width: 1200px) {
    .tlc-container-child {
        margin: auto;
        width: 30vw;
        justify-content: center;
        align-items: center;
        align-content: center
    }
}


.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
        color: white !important;
        background: transparent;
        border-radius: 20px;
        padding: 0px;
        margin: 0px;
}

h1 {
    font-family: "ZYNDisplay"
}

button[name="_submit"] {
  position: relative !important;
  display: block !important;
  margin-left: auto;
  margin-right: auto;
  width: 150px;
  right: 0px !important;
  margin-bottom: 18vh;
}

.card-primary:not(.card-outline) > .card-header {
   color: #000 !important;
}

.btn {
  width: 150px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}


[id^="form_element_Confirm"] [id$="group"] .form-group {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
}

[id^="form_element_Confirm"] .form-group > .col-sm-12.text-left {
    order: 2;
    flex: 1;
    width: auto;
    padding-left: 0;
    display: flex;
    align-items: flex-start;
    margin-left: -15px;
}

[id^="form_element_Confirm"] .form-group > .col-sm-12.col-xs-12 {
    order: 1;
    flex: 0 0 auto;
    width: auto;
    padding-right: 0px;
    padding-left: 15px;
    display: flex;
    align-items: flex-start;
}

[id^="form_element_Confirm"] .form-group > .col-sm-12.col-xs-12 .text-left {
    display: flex;
    align-items: center;
}

/* Align the checkbox itself */
[id^="form_element_Confirm"] .checkbox {
    margin: 0;
    display: flex;
    align-items: center;
}

/* Target the label that creates the checkbox visual */
[id^="form_element_Confirm"] label[id$="_check"] {
    margin: None;
    padding: 0;
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

/* Align the ::before pseudo-element (the checkbox visual) */
[id^="form_element_Confirm"] label[id$="_check"]::before,
[id^="form_element_Confirm"] label[id$="_check"]::after,
 {
    margin: None;
    vertical-align: middle;
}

[id^="form_element_Confirm"] .form-group > div[class*="col-"] {
    padding-left: 0;
}

[id^="form_element_Confirm"] .form-group > .col-sm-12.col-xs-12 {
    padding-left: 0px;
}


/* Key: Use hanging indent on the label text */
[id^="form_element_Confirm"] .form-group > .col-sm-12.text-left label {
    display: block;
    padding-left: 0px; /* Indent all lines by checkbox width + padding */
    text-indent: 26px; /* Pull first line back to align with checkbox */
    margin-left: -26px; /* Pull entire block left so wrapped lines start at left edge */
}

[id^="form_element_Confirm"]:has(label[id^="_form_Confirm"][id$="error"].error:not([style*="display: none"]):not([style*="display:none"])) .form-group > .col-sm-12.text-left label {
    display: block;
    padding-left: 0px;
    text-indent: 195px;
    margin-left: -195px;
}

[id^="form_element_Confirm"]:has(label[id^="_form_Confirm"][id$="error"].error:not([style*="display: none"]):not([style*="display:none"])) label[for^="_form_Confirm"][for$="_check"]:not([class]) {
    opacity: 0;
}

.abc-checkbox label::before {
	width: 20px;
	height: 20px;
	margin-top: -1px;
}

/* Make the parent container a flex container with column direction */
.SumoSelect {
    display: inline-flex !important; /* Override inline-block */
    flex-direction: column;
    text-align: center;
}

/* Ensure error label comes after the p element */
.SumoSelect label.error {
    order: 3; /* Place error label last */
    display: block; /* Make it take full width */
}

.SumoSelect p.CaptionCont {
    order: 2; /* Place p element second */
}

.SumoSelect select {
    order: 1; /* Keep select first (though it's hidden) */
}

.SumoSelect .optWrapper {
    order: 4; /* Keep dropdown options last */
}

p.CaptionCont.SelectBox {
    line-height: 25px;
    padding-top: 6px;
    padding-bottom: 6px;
    padding-left: 38px;
    text-align: center;
    color: #151617;
    border-radius: 5px;
}


/*.abc-checkbox label::before {	*/
/*	top: -8px;		*/
/*	bottom: 0px;		*/
/*}				*/


/* Center Form Control Placeholder Text*/
[id^="_form_"] .form-control {
    text-align: center;
    color: #151617;
}

.placeholder {
    text-align: center;    
}

/* Style Placeholder Text*/
.form-control::placeholder {
	color: #676c71;
	opacity: 1;
}


/* Overide Query Dropdown Style */
.SumoSelect > .CaptionCont > span.placeholder {
	color: #676c71 !important;
	font-style: normal !important;
	padding: 0px;
        padding-right: 26px
}

li.opt {
        color: #676c71 !important;
        text-align: center
}


#_form_Dobgroup .text-left {
    text-align: center !important;
}



/* Remove Tick */
.abc-checkbox-success input[type="checkbox"]:checked + label::after, .abc-checkbox-success input[type="radio"]:checked + label::after {
	color: #f9f9f900 !important;
}

.abc-checkbox input[type="checkbox"][id$="_check"].valid ~ label[for]:not([id])::before {
    background-color: #5cb85c;
    border-color: #5cb85c;
}


.hidden-print {
    text-align: center;
}


/* responsive banner */

        .banner-mb0 {
		display: none
        }
        .banner-mb1 {
		display: none
        }
        .banner-mb2 {
		display: none
        }


        /* Desktop view - changes image */
        @media (min-width: 768px) {
            .banner-mb0 {
		display: inline-block
            }
            .banner-mb1 {
		display: none
            }
            .banner-mb2 {
		display: none
            }
        }

        /* Tablet view - changes image */
        @media (max-width: 768px) {
            .banner-mb0 {
		display: none
            }
            .banner-mb1 {
		display: inline-block
            }
            .banner-mb2 {
		display: none
            }

        }

        /* Mobile view - changes image again */
        @media (max-width: 480px) {
            .banner-mb0 {
		display: none
            }
            .banner-mb1 {
		display: none
            }
            .banner-mb2 {
		display: inline-block;
                margin-top: -30px;

            }
        }

.MultiControls {
    color: black;
}
