*, *:before, *:after { box-sizing: border-box; }
img { max-width: 100%; }

@font-face {
    font-family: "Montserrat";
    src: url("../../assets/fonts/Montserrat/v1/Montserrat-Regular.ttf") format("ttf"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Regular.woff") format("woff"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Regular.woff2") format("woff2"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Regular.otf") format("otf"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Regular.eot") format("eot");
    font-weight: normal;
}
@font-face {
    font-family: "Montserrat";
    src: url("../../assets/fonts/Montserrat/v1/Montserrat-Light.ttf") format("ttf"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Light.woff") format("woff"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Light.woff2") format("woff2"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Light.otf") format("otf"),
    url("../../assets/fonts/Montserrat/v1/Montserrat-Light.eot") format("eot");
    font-weight: 300;
}
@font-face {
    font-family: "Tungsten";
    src: url("../../assets/fonts/Tungsten/v1/Tungsten-Semibold.ttf") format("ttf"),
    url("../../assets/fonts/Tungsten/v1/Tungsten-Semibold.woff") format("woff"),
    url("../../assets/fonts/Tungsten/v1/Tungsten-Semibold.woff2") format("woff2"),
    url("../../assets/fonts/Tungsten/v1/Tungsten-Semibold.otf") format("otf");
    font-weight: normal;
}

@font-face {
    font-family: "TungstenReveal";
    src: url("../../assets/fonts/TungstenReveal/v1/TungstenReveal.ttf") format("ttf"),
    url("../../assets/fonts/TungstenReveal/v1/TungstenReveal.woff") format("woff"),
    url("../../assets/fonts/TungstenReveal/v1/TungstenReveal.woff2") format("woff2"),
    url("../../assets/fonts/TungstenReveal/v1/TungstenReveal.otf") format("otf");
    font-weight: normal;
}

:root {
    --primary-red: #C8102E;
    --primary-blue: #5698D0;
}

body { background: white; color: black; font-family: 'Montserrat', Arial, sans-serif; font-size: 15px; font-weight: 400; margin: 0; }
a { color: var(--primary-red); text-decoration: underline; transition: background-color 0.3s, color 0.3s; }
a:hover { text-decoration: none; }

#main { margin: 0 auto; max-width: 100%;  }

#header_text .block1 { padding: 20px 25px; background: #2C2E31; text-align: right;  }
#header_text .block2 {  color: black; display: flex; align-items: center; max-width: 1920px; margin: 0 auto; justify-content: space-between; }
#header_text .block3 {  color: black; display: flex; align-items: center; max-width: 1440px; margin: 0 auto; padding: 60px 0; justify-content: space-around;}
#header_text .block21 { width: 50%; position: relative; z-index: 2; margin-right: 50px; }
#header_text .block21 img { display: block; }
#header_text .block22 { width: 50%; }
#header_text h1 { font-family: "Tungsten", Arial, sans-serif; font-size: 100px; font-weight: bold; line-height: 0.85; margin: 0 0 30px 0; text-transform: uppercase; position: relative; }
#header_text h1 strong { margin-left: 12px; }
#header_text h1 em { font-family: "TungstenReveal", Arial, sans-serif; font-weight: normal; }
#header_text h1::before {
    background: var(--primary-red);
    border-radius: 4px;
    content: '';
    display: block;
    /* height: calc(100% + 30px); */
    height: 110%;
    width: 4px;
    position: absolute;
    top: -10px;
    left: 25px;
    transform: rotate(-15deg);
}
#header_text h1 .line2 { display: block; margin-left: 35px; }
#header_text h1 .line3 { display: block; margin-left: 45px; }
#header_text h2 { font-size: 26px; font-weight: bold; line-height: 1.1; margin: 0 0 15px 70px; }
#header_text h2 em { color:#C8102E; }
#header_text h2 .line2 { display: block; margin-left: 8px; }
#header_text h2 .line3 { display: block; margin-left: 16px; }
#header_text p { font-size: 20px; margin: 0; }
#header_text p .line2 { display: block; margin-left: 5px; }
#header_text p.subtext { color: white; background: #2E9597; border: 0; border-radius: 30px; color: #fff; cursor: pointer;  font-family: 'Montserrat', Arial, sans-serif; font-size: 19px; font-weight: 500; margin: 0 0 15px 0; padding: 15px; text-align: center; width: 100px; transition: background-color 0.3s; } 
#header_text p.subtext .line2 { display: block; margin-left: 15px; font-size: 14px; margin-top: 15px; }
#header_text p .line3 { display: block; margin-left: 10px; }
#header_text p .line4 { display: block; margin-left: 15px; }
#header_text p .line5 { display: block; margin-left: 20px; }
#header_text p a { color: white; text-decoration: none; }
#header_text p a:hover { text-decoration: none; }

#header_text .block3 p.logo { width: 40%; margin-right: 20px; font-size: 30px; order:1; text-align: left; text-transform: uppercase; }
#header_text .block3 p.subtext { width: 30%; order: 2; line-height: 1.2; }

#content { padding: 30px 0; }
#content h1 { font-size: 24px; font-weight: bold; margin: 0 0 30px 0; text-align: center; }
#content p,
#content ul { margin: 0 0 15px 0; }
#content table { background: #eee; margin: 0 0 15px 0; width: 100%; }
#content td { border: 1px solid #ddd; padding: 10px; }
#content td p { margin: 0; }
.tc-box .tc-box-textarea td { font-size: 15px; }

#form_holder { padding: 15px 0; max-width: 1280px; margin: 0 auto; }
.field-row label { display: inline-block; padding: 10px 5px 10px 0; }
.table-cell input[type="text"], 
.table-cell select { border: 1px solid #B6B9B9; font-family: 'Montserrat', Arial, sans-serif; font-size: 15px; padding: 10px; width: 100%; }
.table-cell select { padding: 10px 5px; }
#submit-div { padding: 30px 0; text-align: center; }
.SubmitButt { background: var(--primary-red); border: 0; color: white; cursor: pointer; font-family: 'Montserrat', Arial, sans-serif; font-size: 24px; margin: 0 0 15px 0; min-width: 165px; padding: 10px; transition: background-color 0.3s; }
.SubmitButt:hover { background: black; }
#form_holder, #info_text_holder { padding: 20px 1%; }

.required { color: var(--primary-red); }
div.required { color: black; font-size: 18px; font-weight: 300; }
div.required span { color: var(--primary-red); }
#a_l_txt_title,
#i_l_txt_payment_method,
#a_l_txt_purchased_products_number,
#a_l_txt_bank_details_international,
#a_l_txt_bank_revolut, #a_l_txt_new_productgroup_all1, #a_l_txt_customer_type { display: block; font-size: 36px; font-weight: bold; margin: 15px 0; }

#a_l_txt_bank_details_international { line-height: 0.6; }
#a_l_txt_bank_details_international strong { font-size: 14px; }
#country_promotion { display: block; font-weight: bold; padding: 10px 0; }
#i_l_txt_payment_method .required { display: none; }
#r_payment_method .table-cell,
#r_purchase_upload_file .table-cell.coll1 { float: none; width: 100%; }
#r_payment_method .cbox_list { float: left; width: 50%; }
#r_date_purchase .table-cell { position: relative; }
.ui-datepicker-trigger { position: absolute; top: 8px; right: 8px; }
#date_purchase_u_info,
#bank_benficiary_individual_u_info,
#bank_beneficiary_rev_u_info,
#bank_benficiary_u_info,
#bank_benficiary_rev_individual_u_info,
div[id^="serial_number"] { color: #B6B9B9; display: inline-block; font-size: 12px; padding: 5px 0; }
#r_purchase_upload_file label,
#r_purchase_upload_file .fileinputs { float: left; width: 50%; }
#promo_content .field-row .inputfile.inputfile__btn + label { background: var(--primary-red); float: none; width: 100%; transition: background-color 0.3s; }
.field-row .inputfile.inputfile__btn + label span { display: block; font-size: 13px; }
#promo_content .field-row .inputfile.inputfile__btn + label:hover { background: black; }
#add_another_product,
#remove_last_product { background: var(--primary-blue); border: 0; border-radius: 0; color: white; cursor: pointer; font-family: 'Montserrat', Arial, sans-serif; font-size: 15px; margin: 0 0 5px 0; padding: 10px; width: 100%; transition: background-color 0.3s; }
#add_another_product.disabled,
#remove_last_product.disabled { display: none; }
#add_another_product:hover,
#remove_last_product:hover { background-color: black; }
#r_terms_conditions_box { margin: 0 0 10px 0; }
#promo_content, #form_holder { background: #FCFCFC; }
#form_intro { margin-bottom: 30px; }
#a_l_txt_bank_details_international { margin-top: 40px; }
#promo_content a.popup { background: var(--primary-red); border-radius: 50%; color: white; display: inline-block; height: 19px; line-height: 19px; text-align: center; text-decoration: none; width: 19px; }
#promo_content a.popup:hover { background: #eee; text-decoration: none; }

#submit-div { padding: 30px 0; text-align: center; }
.next_step, .SubmitButt { background: #2E9597; border: 0; border-radius: 30px; color: #fff; cursor: pointer;  font-family: 'Montserrat', Arial, sans-serif; font-size: 19px; font-weight: 500; margin: 0 0 15px 0; padding: 15px; text-align: center; width: 150px; transition: background-color 0.3s; }
.next_step:hover, .SubmitButt:hover { background-color: #228183; }

#footer { clear: both; color: #b6b9b9; }
#footer a { color: #939393; text-decoration: none; }
#footer a:hover { text-decoration: underline; }
#footer .canon_footer {background: #FCFCFC; }
#footer .block1 { border-top: 1px solid #939393; padding: 25px; background: #FCFCFC; color: #939393;  max-width: 1440px; margin: 0 auto; }
#footer .block3 { padding: 20px 25px; background: #2C2E31; text-align: right;  }
#footer .block1 ul { overflow: hidden; }
#footer .block1 li { float: left; margin: 0 15px 0 0; }
#footer .block1 li.last { float: right; }
#footer .block2 { overflow: hidden; padding: 25px 0; }

#main.ty #printArea,
#main.ty #printArea + p,
#main.ty #header_text .block3 p.subtext { display: none; }
#main.ty #header_text .block3 { justify-content: center; }
#main.ty #header_text .block3 p.logo { text-align: center; width: 100%; }
#main.ty #form_wrapper { font-size: 24px; line-height: 1.5; padding: 100px 0; text-align: center; }

.p18 #main.ty #info_text_holder { display: none; }

.p19 { background: #FCFCFC; }
.p19 #content { max-width: 1440px; margin: 0 auto;  padding-left: 15px; padding-right: 15px; }
.p19 #header_text .block2, .p19 #header_text .block3 { display: none; }
.p19 a { word-break: break-all; }
       
@media (max-width: 1220px) {
    #header_text .block1, #form_holder, #content { padding-left: 15px; padding-right: 15px; }
    #form_holder { padding-left: 35px; padding-right: 35px; }
    #header_text h1 { font-size: 80px; }
    #header_text h1 strong { margin-left: 0px; }
    #header_text h1:before { height: calc(100% + 40px); top: -20px; left: 10px; }
    #header_text h1:after { right: calc(100% - 15px); }
    #header_text h1 .line2 { margin-left: 15px; }
    #header_text h1 .line3 { display: block; margin-left: 29px; }
    #header_text h2 { margin-left: 50px; }
    #header_text p { margin-left: -20px; }
    .first_row.startcol1, .first_row.startcol, .first_row.startgroup1, .second_row { float: none; margin: 0; padding: 0; width: 100%; }
}
@media (max-width: 1100px) {
    #header_text .block22 { padding-left: 5%; }
    #header_text .block3 { justify-content: space-around; }
    #header_text p { font-size: 16px; }
    #header_text .block2 { flex-direction: column; }

    #header_text .block21 { width: 100%; margin-bottom: 35px; }
    #header_text .block22 { width: 100%; }
}
@media (max-width: 799px) {
    #header_text .block1 img { max-width: 125px; }
    #header_text .block2 { position: relative; }
    
    #header_text h1 { font-size: 70px; margin: 0 0 20px 0; }
    #header_text h1:before { height: 120%; top: -10px; left: 10px; }
    #header_text h1 .line2 { margin-left: 17px; }
    #header_text h2 { font-size: 20px; margin-left: 30px; }
    #header_text p { margin-left: 60px; }
    #header_text p.subtext .line2 { font-size: 8px; }
    .field-row .table-cell.coll1,
    .field-row .table-cell,
    #r_purchase_upload_file label,
    #r_purchase_upload_file .fileinputs { float: none; width: 100%; }
    #footer .block1 li,  #footer .block1 li.last  { float: none; margin: 10px 0; }
    #info_text_holder {
        padding: 10px 2%;
    }

    #header_text h2 { font-size: 15px; }

    #promo_content .block3 ul { padding: 30px 0; }
    #promo_content .block3 li,
    #promo_content .block3 li:nth-child(3) { float: none; margin: 0 0 10px 0; text-align: center; width: 100%; }
    #form_holder { width: 100%; }
    #form_holder { padding-left: 15px; padding-right: 15px; }

    #header_text .block2 { flex-direction: column; }
    #header_text .block21 { width: 100%; margin: 0; }
    #header_text .block22 { width: 100%; margin-top: 40px; }

    #header_text .block3 { flex-direction: column; align-items: flex-start; }
    #header_text .block3 p.logo { text-align: left; margin-bottom: 20px; }
    #header_text .block3 p.subtext { width: 80%; margin-left: 50px; }
    #main.ty #header_text .block3 { justify-content: center; align-items: center; }
    #main.ty #header_text .block3 p.logo { margin-left: 0; }
    #a_l_txt_bank_details_international { line-height: 1; }
    #content .table-scroll { overflow-x: auto; }
    #content .table-scroll table { width: 600px; }
}
@media (max-width: 600px) {
    #header_text h1 {
        font-size: 60px;
        margin: 0 0 20px 0;
    }
}
@media (max-width:500px){
    #header_text .block21 { display: block; width: 100%; }
    /* #header_text .block22 { display: none; } */
    #header_text .block22 {
        padding-left: 8%;
    }
}