*,
*: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;
  --primary-green: #2e9597;
  --primary-grey: #4a4e52;
}

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 {
  background: #2c2e31;
  color: #b6b9b9;
  font-size: 11px;
  padding: 40px 25px;
  text-align: right;
}
#header_text .block2,
form {
  max-width: 1140px;
  margin: 0 auto;
  position: relative;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  gap: 50px;
}
form {
  max-width: calc(1140px + 2rem);
  gap: 1rem;
  padding: 0 1rem;
}
form h1 {
  font-size: 1rem;
  font-weight: bold;
}
#header_text .block2 img {
  display: block;
}
#header_text .block2 h1 {
  font-family: "Tungsten", Arial, sans-serif;
  font-size: 95px;
  font-weight: bold;
  line-height: 0.85;
  text-transform: uppercase;
  position: relative;
}
#header_text .block2 h1 em {
  font-family: "TungstenReveal", Arial, sans-serif;
  font-weight: normal;
}
#header_text .block2 h1::before {
  background: var(--primary-red);
  border-radius: 6px;
  content: "";
  display: block;
  height: 110%;
  width: 5px;
  position: absolute;
  top: -6px;
  left: 16px;
  transform: rotate(-15deg);
}
#header_text .block2 h1 .line2 {
  display: block;
  margin-left: 30px;
}
#header_text .block2 .roundel {
  background: var(--primary-red);
  border-radius: 50%;
  color: white;
  font-size: 21px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  height: 152px;
  padding: 20px;
  text-align: center;
  width: 153px;
  position: absolute;
  bottom: 50px;
  right: 0;
  font-weight: 300;
  font-family: "Montserrat", Arial, sans-serif;
}
#header_text .block2 .block22 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
#header_text .block2 .roundel strong {
  font-size: 33px;
  font-weight: 500;
}
#header_text .block3 {
  max-width: 1140px;
  margin: 50px auto;
}
#header_text .block2 .logo {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#header_text .block23 {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
#header_text .block22 a {
  background: var(--primary-green);
  border-radius: 30px;
  color: white;
  display: inline-block;
  padding: 15px 30px;
  text-decoration: none;
  text-transform: uppercase;
  text-align: center;
}
#header_text .block22 a:hover {
  background: var(--primary-red);
}
#header_text .block22 a.btn-grey {
  background: var(--primary-grey);
  border-radius: 30px;
  color: white;
  display: inline-block;
  padding: 15px 30px;
  text-decoration: none;
  text-transform: uppercase;
}
#header_text .block22 a.btn-grey:hover {
  background: #b6b9b9;
}

#r_purchase_upload_file.field-row.err_msg_valid .table-cell.coll1 {
  display: flex;
  width: 100%;
}
select,
input[type="text"] {
  border-radius: 0;
}

p.subtext {
  width: 100%;
  margin: 40px 0 30px 0;
  font: 400 18px "Montserrat", sans-serif;
}
p.subtext_button {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

#promo_content,
#extend_content {
  background: #fcfcfc;
}

#content {
  margin: 0 auto;
  max-width: 1440px;
  padding: 50px 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 {
  margin: 10px 0;
}
.tc-box .tc-box-textarea td {
  font-size: 15px;
}

#form_holder {
  background: transparent;
}
#form_wrapper {
  margin: 0 auto;
  max-width: 1140px;
}
.second_row {
  float: right;
}
.table-cell label {
  display: inline-block;
  padding: 10px 5px 10px 0;
}
#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;
  font-weight: 300;
  margin: 0 0 15px 0;
  min-width: 165px;
  padding: 10px;
  transition: background-color 0.3s;
}
.SubmitButt:hover {
  background: var(--primary-grey);
}

.required {
  color: var(--primary-red);
}
div.required {
  color: black;
  font: 400 18px "Montserrat", sans-serif;
}
div.required span {
  color: var(--primary-red);
}
#a_l_txt_customer_type,
#a_l_txt_bank_details_international,
#a_l_txt_purchased_products_number,
#a_l_txt_title {
  color: #000000;
  display: block;
  font-size: 36px;
  font-weight: bold;
  margin: 30px 0 15px 0;
}
#r_customer_type .cbox_list {
  margin: 5px 0;
}
#date_birth_u_info,
div[id^="serial_number"],
div[id^="date_purchase"],
div[id^="purchase_upload_file"],
#bank_benficiary_u_info,
#bank_benficiary_individual_u_info {
  display: block;
  font-size: 13px;
  padding: 5px 0;
}
#r_date_birth .table-cell {
  position: relative;
}
.ui-datepicker-trigger {
  cursor: pointer;
  position: absolute;
  right: 5px;
  top: 5px;
}
#promo_content a.popup {
  background: var(--primary-red);
  border-radius: 50%;
  color: white;
  display: inline-block;
  height: 21px;
  line-height: 21px;
  text-align: center;
  text-decoration: none;
  width: 21px;
}
#promo_content a.popup:hover {
  background: var(--primary-blue);
  color: white !important;
  text-decoration: none;
}
#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-grey);
  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: var(--primary-blue);
}
#add_another_product,
#remove_last_product {
  background: #7da1c4;
  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_subscribe + div {
  display: none;
  background: #fff;
  border-radius: 15px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.25);
  color: #333;
  font-size: 15px;
  padding: 20px 10px 30px 10px;
  text-align: left;
  width: 1140px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}
#r_subscribe + div ul {
  counter-reset: item;
  list-style-type: decimal;
  margin: 0 0 15px 15px;
}
#r_subscribe + div a {
  font-size: 14px;
  position: absolute;
  top: 15px;
  right: 30px;
}
#r_terms_conditions,
#r_subscribe {
  position: relative;
  line-height: 18px;
  padding: 0 0 0 23px;
}
#r_terms_conditions {
  margin: 15px 0 30px 0;
}
#r_terms_conditions input,
#r_subscribe input {
  position: absolute;
  top: 0;
  left: 0;
}

#r_subscribe + div p {
  font-size: 25px;
  margin: 0 100px 50px 100px;
  text-align: center;
}
#r_subscribe + div li {
  display: block;
  float: left;
  font-size: 13px;
  line-height: 1.2;
  padding: 110px 10px 0 45px;
  width: 25%;
  position: relative;
}
#info_text .block1 p {
  text-align: left;
}
#info_text .block1 strong {
  background: var(--primary-red);
  border-radius: 15px;
  color: #fff;
  float: left;
  font-size: 20px;
  height: 32px;
  line-height: 32px;
  margin: 0 10px 0 0;
  text-align: center;
  width: 32px;
  position: relative;
  top: -2px;
}
#r_subscribe + div li:nth-child(1) {
  background: url(../images/icon1.gif) top center no-repeat;
}
#r_subscribe + div li:nth-child(2) {
  background: url(../images/icon2.gif) top center no-repeat;
}
#r_subscribe + div li:nth-child(3) {
  background: url(../images/icon3.gif) top center no-repeat;
}
#r_subscribe + div li:nth-child(4) {
  background: url(../images/icon4.gif) top center no-repeat;
}
#r_subscribe + div li:before {
  content: counters(item, ".") " ";
  counter-increment: item;
  color: #fff;
  background: #c00;
  width: 32px;
  text-align: center;
  display: block;
  float: left;
  line-height: 32px;
  margin: 0 10px 0 0;
  border-radius: 15px;
  font-size: 20px;
  position: absolute;
  top: 110px;
  left: 0;
}
#footer .block1 li,
#footer .block1 li a {
  font: 400 12px "Montserrat", sans-serif;
}
#footer .block1 li a:hover {
  text-decoration: none;
  color: #5d5d5d;
}
#footer .block1 li {
  color: #5d5d5d;
}

#footer {
  background: #fcfcfc;
  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: 2px solid #939393;
  padding: 25px 0;
  color: #939393;
  max-width: 1200px;
  margin: 0 auto;
}
#footer .block3 {
  padding: 20px 25px;
  background: #2c2e31;
  text-align: right;
}
#footer .block1 ul {
  overflow: hidden;
}
#footer .block1 li {
  float: right;
  margin: 0 15px 0 0;
}
#footer .block1 li.last {
  float: left;
}
#footer .block2 {
  background: #2c2e31;
  font-size: 11px;
  padding: 40px 25px;
  text-align: right;
}

#main.ty #header_text .block3,
#main.ty #header_text .block22 {
  display: none;
}
#main.ty #form_wrapper {
  font-size: 18px;
  line-height: 1.5;
  padding: 100px 0;
  text-align: center;
}
#main.ty #form_wrapper h2 {
  font-size: 24px;
  font-weight: bold;
  margin: 0 0 30px 0;
}

#header_text .block2 h1 .line2 em {
  margin-left: -5px;
}
#header_text .block2 h1.fr-ch em {
  margin-left: -9px;
}
#header_text .block2 h1.fr-ch em:nth-child(2) {
  margin-left: 13px;
}
#header_text .block2 h1.fr-ch .line2 em {
  margin-left: -5px;
}
#header_text .block2 h1.fr-ch .line2 {
  margin-left: 28px;
}
#header_text .block2 h1.fr-ch {
  margin-left: 30px;
}
#header_text .block2 .block21 {
  max-width: 1300px;
  width: 100%;
}

@media (max-width: 1200px) {
  #header_text .block2 h1::before {
    left: 15px;
  }
  #header_text .block2 h1 .line2 {
    margin-left: 25px;
  }
  #header_text .block2 .block22 {
    margin: 0 15px;
  }
  #form_holder,
  #content {
    padding-left: 15px;
    padding-right: 15px;
  }
  #r_subscribe + div {
    width: 100%;
  }
  #r_subscribe + div li {
    width: 100%;
  }
  #footer .block1 {
    margin: 0 25px;
  }
}
@media (max-width: 1040px) {
  #header_text .block2 .block22 {
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    gap: 2rem;
    padding-bottom: 84px;
  }
  #header_text .block22 a {
    position: absolute;
    bottom: 0;
  }
}
@media (max-width: 1000px) {
  #header_text .block2 h1 {
    font-size: 80px;
  }
  #header_text .block3 {
    padding-left: 15px;
    padding-right: 15px;
  }
  #header_text .block2 h1 em {
    margin-left: 4px;
  }
  .first_row.startcol1,
  .first_row.startcol,
  .first_row.startgroup1,
  .second_row {
    float: none;
    margin: 15px 0;
    padding: 0;
    width: 100%;
  }
}
@media (max-width: 800px) {
  form {
    margin-top: 2rem;
  }
  #header_text .block21 img {
    width: 100%;
  }
  #header_text .block2 {
    flex-direction: column;
  }
  #header_text .block2 h1 {
    font-size: 60px;
    min-width: auto;
  }
  #header_text .block2 h1 {
    margin-left: 10px;
  }
  #header_text .block2 h1::before {
    left: 8px;
    height: 120%;
    width: 4px;
  }
  #header_text .block2 h1:before {
    box-shadow: -6px 0 0 2px white;
  }
  #header_text .block2 .roundel {
    position: relative;
    bottom: 0;
    margin: 0 30px 0 0;
  }
  #header_text .block2 h1 .line2 {
    margin-left: 15px;
  }
  #header_text .block2 h1 em {
    margin-left: 0px;
  }
  #header_text .block2 h1 .line2 em {
    margin-left: -9px;
  }

  #header_text .block2 h1.fr-ch em {
    margin-left: 0px;
  }
  #header_text .block2 h1.fr-ch .line2 {
    margin-left: 12px;
  }

  p.subtext {
    width: 100%;
    margin: 10px 10px 10px 0;
    text-align: center;
  }
  p.subtext_button {
    order: 1;
    width: 100%;
    padding: 0 10px 0 0;
  }

  #header_text .block2 h1.fr-ch em:nth-child(2),
  #header_text .block2 h1.fr-ch em:nth-child(2)::before,
  #header_text .block2 h1.fr-ch em:nth-child(2)::after {
    all: unset; /* removes all styles, pseudo-elements, and inherited props */
    display: inline !important;
    font-style: normal !important;
    color: inherit !important;
  }

  #header_text .block2 .block22 {
    justify-content: flex-start;
    margin: 0 0 0 10px;
    gap: 30px;
  }
  #header_text .block3 .logo {
    flex-direction: column;
    align-items: flex-start;
    row-gap: 15px;
  }
  #footer .block1 {
    border: none;
  }
  #footer .block1 li,
  #footer .block1 li.last {
    float: left;
    margin: 15px 0 0;
  }
  #footer .block1 li.last {
    border-top: 2px solid #939393;
    line-height: 50px;
    width: 100%;
  }
  #footer .block1 li:first-child {
    margin-right: 15px;
  }
}
@media (max-width: 640px) {
  #header_text .block2 h1.fr-ch em {
    margin-left: -8px;
  }
  #header_text .block2 h1.fr-ch .line2 {
    margin-left: 17px;
  }
}

@media (max-width: 600px) {
  #header_text .block2 h1 .line2 {
    margin-left: 22px;
  }
  #header_text .block2 h1 em {
    margin-left: 0;
  }
  #header_text .block2 h1.fr-ch em:nth-child(2),
  #header_text .block2 h1.fr-ch em:nth-child(2)::before,
  #header_text .block2 h1.fr-ch em:nth-child(2)::after {
    margin-left: 7px;
  }
  #header_text .block3 {
    margin-top: 50px;
  }
  .field-row .table-cell.coll1,
  .field-row .table-cell {
    float: none;
    width: 100%;
  }
  #content td {
    padding: 5px;
  }
  #content .table-scroll {
    overflow-x: auto;
  }
  #content .table-scroll table {
    width: 600px;
  }
}

@media (max-width: 480px) {
  #header_text .block2 h1 {
    font-size: 44px;
  }
}
