@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&display=swap');

html {
    background-color: #FFF;
}

body {
    font-family: 'Noto Serif JP', Arial, Helvetica, sans-serif;
    font-weight: normal;
    font-style: normal;
    color: #000;
    overflow-x: hidden;
    font-size: 18px;
}

h1, h2, h3, h4 {
    margin: 0;
    padding: 0;
}

ul, li {
    margin: 0;
    padding: 0;
}

p {
    margin: 0;
    padding: 0;
    font-size: 20px;
    line-height: 30px;
}
  
img {
    display: block;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

.ultra-container {
    width: 904px;
    margin: 0 auto;
    position: relative;
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background-color: #FFF;
    height: 90px;
    z-index: 99;
    filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.16));
}

.header-container {
    width: 1024px;
    margin: 0 auto;
    position: relative;
}

.navbar {
    padding: 0;
    position: relative;
    align-items: center;
    height: 90px;
    -webkit-transition: all 0.3s ease-out 0s;
    transition: all 0.3s ease-out 0s;
}

.navbar-collapse {
    justify-content: end;
}

.navbar-nav {
    column-gap: 20px;
    align-items: center;
}

.navbar-nav li a {
    font-weight: 600;
    font-size: 16px;
    line-height: 32px;
    color: #2A3665;
    text-align: center;
    text-decoration: none;
    transition: 0.3s;
}

.navbar-nav li a.header-contact-button {
    display: block;
    width: 180px;
    height: 50px;
    background-color: #0F4E8C;
    border-radius: 50px;
    font-weight: 700;
    font-size: 14px;
    line-height: 50px;
    color: #FFFFFF;
}

.navbar-nav li a:hover {
    opacity: 0.7;
}

.mobile-menu-btn {
    position: absolute;
    right: 2.4vw;
    padding: 0px;
}

.mobile-menu-btn:focus {
    text-decoration: none;
    outline: none;
    -webkit-box-shadow: none;
            box-shadow: none;
}

.mobile-menu-btn .toggler-icon {
    width: 6vw;
    height: 1vw;
    border-radius: 1vw;
    background-color: #0F4E8C;
    display: block;
    margin: 1.5vw 0;
    position: relative;
    -webkit-transition: all 0.3s ease-out 0s;
    transition: all 0.3s ease-out 0s;
}

.mobile-menu-btn .toggler-icon:nth-of-type(1), .mobile-menu-btn .toggler-icon:nth-of-type(3) {
    margin: 0;
}

.mobile-menu-btn.active .toggler-icon:nth-of-type(1) {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    top: 2.4vw;
}

.mobile-menu-btn.active .toggler-icon:nth-of-type(2) {
    opacity: 0;
}

.mobile-menu-btn.active .toggler-icon:nth-of-type(3) {
    -webkit-transform: rotate(135deg);
            transform: rotate(135deg);
    top: -2.4vw;
}

.navbar-brand {
    display: block;
    width: 200px;
    padding: 0;
    margin: 0;
}

.navbar-brand img {
    width: 100%;
}

main {
    padding-top: 90px;
}

#banner {
    background: url('../assets/banner-bg.jpg');
    background-size: 1920px;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    width: 100%;
    height: 900px;
    position: relative;
}

.banner-title {
    width: 238px;
    position: absolute;
    top: 124px;
    right: 0;
}

.banner-title img {
    width: 100%;
}

.banner-text {
    width: 19px;
    position: absolute;
    top: 124px;
    right: 274px;
}

.banner-text img {
    width: 100%;
}

.banner-text p {
    display: none;
}

.banner-icon {
    background: url('../assets/banner-icon.png');
    background-size: contain;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    position: absolute;
    width: 204px;
    height: 200px;
    left: -60px;
    top: 621px;
}

.banner-icon p {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-10deg);
    width: 100%;
    font-weight: 500;
    font-size: 24px;
    line-height: 34px;
    color: #FFF;
    text-align: center;
}

#sidebar {
    position: fixed;
    right: calc(50% - 772px);
    bottom: 63px;
    z-index: 99;
}

.sidebar-card {
    position: relative;
    width: 260px;
    height: 200px;
    background-color: #fff;
    border-radius: 20px;
    border: 1px solid #8A9595;
    filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.16));
    padding: 26px;
}

.sidebar-text {
    margin: 0 0 20px;
}

.sidebar-text p {
    font-weight: 600;
    font-size: 16px;
    line-height: 24px;
    color: #2A3665;
    text-align: center;
}

.sidebar-button a {
    display: block;
    width: 220px;
    height: 50px;
    background-color: #0F4E8C;
    border-radius: 50px;
    font-weight: 600;
    font-size: 16px;
    line-height: 50px;
    color: #FFFFFF;
    margin: 0 auto;
    text-align: center;
    border: none;
    text-decoration: none;
    transition: 0.3s;
}

.sidebar-button a:hover {
    opacity: 0.7;
}

.sidebar-close {
    position: absolute;
    width: 25px;
    height: 25px;
    border-radius: 25px;
    background-color: #8A9595;
    top: 10px;
    right: 10px;
    padding: 7.5px;
    border: none;
    transition: 0.3s;
}

.sidebar-close:hover {
    opacity: 0.7;
}

.sidebar-close img {
    width: 100%;
}

#chat {
    padding: 113px 0 63px;
    position: relative;
    background: linear-gradient(#D7E8F8, #fff);
}

ul.chat-list {
    width: 782px;
    margin: 0 auto;
    list-style: none;
}

ul.chat-list li {
    margin: 0 0 38px;
    width: 500px;
    background: #fff;
    border-radius: 100px;
    position: relative;
    padding: 14px;
    filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.16));
}

ul.chat-list li:nth-child(2) {
    margin-left: auto;
}

ul.chat-list li:last-child {
    margin: 0 0 0 90px;
}

ul.chat-list li p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 18px;
    line-height: 32px;
    color: #2A3665;
    text-align: center;
}

ul.chat-list li::after {
    content: '';
    width: 0;
    height: 0;
    position: absolute;
    left: 57px;
    bottom: 0;
    transform: translate(0, 100%);
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 18px solid #fff;
}

ul.chat-list li:nth-child(2)::after {
    left: auto;
    right: 57px;
}

#system {
    background: url('../assets/system-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 114px 0 230px;
    position: relative;
}

#system::before {
    content: '';
    margin: 0 auto;
    width: 100%;
    height: 200px;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    background: linear-gradient(#fff, transparent)
  }

.system-title {
    position: relative;
    margin: 0 0 46px;
}

.system-title-mobile {
    display: none;
}

.system-title h2 {
    font-weight: 500;
    font-size: 38px;
    line-height: 52px;
    color: #2A3665;
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: center;
    align-items: center;
}

.system-title h2 img {
    width: 154px;
}

.system-title > img {
    width: 614px;
    position: absolute;
    top: 21px;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 1;
}

.system-title > img:nth-child(2n) {
    width: 301px;
    top: 71px;
}

.system-text {
    margin: 0 0 52px;
}

.system-text p {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
    text-align: center;
}

.system-list-content {
    width: 220px;
}

.system-list-image {
    width: 220px;
    margin: 0 auto 20px;
    background: #E6EDF3;
    border-radius: 220px;
}

.system-list-image img {
    width: 100%;
}

.system-list-title {
    margin: 0 0 20px;
}

.system-list-title h3 {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
    text-align: center;
}

.system-list-label {
    width: 220px;
    height: 28px;
    margin: 0 auto 20px;
    background: #0F4E8C;
    border-radius: 28px;
}

.system-list-label p {
    font-weight: 600;
    font-size: 16px;
    line-height: 28px;
    color: #FFF;
    text-align: center;
}

.system-list-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #2A3665;
}

.system-list {
    position: relative;
}

.system-list > .owl-dots {
    display: none;
}

.system-list.owl-carousel .owl-nav button.owl-prev,
.system-list.owl-carousel .owl-nav button.owl-next {
    margin: 0;
    background: #0F4E8C;
    color: #fff;
    width: 38px;
    height: 38px;
    border-radius: 38px;
    position: relative;
}

.system-list.owl-carousel .owl-nav {
    position: absolute;
    top: 210px;
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin: 0;
}

.system-list.owl-carousel .owl-nav button.owl-prev span,
.system-list.owl-carousel .owl-nav button.owl-next span {
    position: absolute;
    top: 35%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    font-weight: 500;
    font-size: 38px;
    line-height: 38px;
}

.system-list.owl-carousel .owl-stage-outer {
    width: 828px;
    left: 38px;
    overflow: initial;
}

/*
.system-list.owl-carousel .owl-stage {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -moz-backface-visibility: hidden;
}
*/

.system-list.owl-carousel .owl-item {
    opacity: 0.5;
    transition: opacity 0.3s ease-in-out;
}

.system-list.owl-carousel .owl-item.active {
    opacity: 1;
}

#feature {
    background: url('../assets/feature-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 120px 0;
    position: relative;
}

.feature-title {
    position: relative;
    margin: 0 0 40px;
}

.feature-title h2 {
    font-weight: 500;
    font-size: 38px;
    line-height: 55px;
    color: #FFF;
    text-align: center;
    position: relative;
    z-index: 2;
}

.feature-title img {
    width: 388px;
    margin: 0 auto;
    position: absolute;
    top: 10px;
    left: 0;
    right: 0;
    z-index: 1;
}

.feature-text {
    margin: 0 0 70px;
}

.feature-text p {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #FFF;
    text-align: center;
}

ul.feature-list {
    list-style: none;
}

ul.feature-list li {
    display: flex;
    justify-content: space-between;
    margin: 0 0 60px;
}

ul.feature-list li:last-child {
    margin: 0;
}

.feature-list-image {
    order: 1;
    width: 420px;
}

ul.feature-list li:nth-child(2n) .feature-list-image {
    order: 2;
}

.feature-list-image img {
    width: 100%;
}

.feature-list-content {
    order: 2;
    width: 420px;
}

ul.feature-list li:nth-child(2n) .feature-list-content {
    order: 1;
}

.feature-list-title {
    width: 420px;
    margin: 0 0 30px;
}

.feature-list-title h3 {
    font-weight: 500;
    font-size: 32px;
    line-height: 50px;
    color: #FFF;
}

.feature-list-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #FFF;
}

.feature-list-note {
    margin: 30px 0 0;
}

.feature-list-note p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 12px;
    line-height: 22px;
    color: #FFF;
}

.feature-list-button {
    margin: 30px 0 0;
}

.feature-list-button a {
    width: 270px;
    height: 50px;
    display: block;
    font-weight: 600;
    font-size: 16px;
    line-height: 50px;
    border-radius: 50px;
    color: #0F4E8C;
    background-color: #fff;
    text-align: center;
    text-decoration: none;
    transition: 0.3s;
}

.feature-list-button a:hover {
    opacity: 0.7;
}

#why {
    background: url('../assets/why-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 90px 0;
    position: relative;
}

.why-title {
    position: relative;
    margin: 0 0 36px;
}

.why-title h2 {
    font-weight: 500;
    font-size: 38px;
    line-height: 52px;
    color: #2A3665;
    position: relative;
    z-index: 2;
}

.why-title img {
    width: 227px;
    position: absolute;
    top: 19px;
    left: -34px;
    z-index: 1;
}

.why-title img:nth-child(2n+1) {
    width: 548px;
    top: 75px;
}

.why-text {
    margin: 0 0 30px;
}

.why-text p {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
}

ul.why-list {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    list-style: none;
    row-gap: 24px;
}

ul.why-list li {
    width: 280px;
    background: #0F4E8C;
    border-radius: 10px;
    padding: 13px 0;
}

ul.why-list li p {
    font-weight: 600;
    font-size: 16px;
    line-height: 22px;
    color: #FFFFFF;
    text-align: center;
}

#step {
    background: url('../assets/step-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 110px 0 125px;
    position: relative;
}

.step-title {
    position: relative;
    margin: 0 0 60px;
}

.step-title h2 {
    font-weight: 500;
    font-size: 38px;
    line-height: 52px;
    color: #2A3665;
    text-align: center;
    position: relative;
    z-index: 2;
}

.step-title img {
    width: 548px;
    margin: 0 auto;
    position: absolute;
    top: 17.5px;
    left: 0;
    right: 0;
    z-index: 1;
}

ul.step-list {
    list-style: none;
    display: flex;
    justify-content: space-between;
    margin: 0 0 28px;
}

ul.step-list li {
    width: 160px;
    position: relative;
}

ul.step-list li:last-child {
    width: max-content;
}

.step-list-number {
    position: absolute;
    top: -10px;
    left: -10px;
    width: 30px;
    height: 30px;
    border-radius: 30px;
    background-color: #0F4E8C;
    z-index: 2;
}

.step-list-number p {
    font-size: 18px;
    line-height: 30px;
    color: #FFF;
    text-align: center;
}

.step-list-image {
    width: 100%;
    background: #E6EDF3;
    border-radius: 20px;
    margin: 0 0 20px;
}

.step-list-image img {
    width: 100%;
}

.step-list-text p {
    font-weight: 600;
    font-size: 18px;
    line-height: 22px;
    color: #2A3665;
    text-align: center;
}

.step-list-title {
    width: max-content;
}

.step-list-title h3 {
    font-weight: 500;
    font-size: 24px;
    line-height: 160px;
    color: #2A3665;
    text-align: center;
}

.step-list-divider {
    width: 0;
    height: 0;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 10px solid #95B5DE;
    margin-top: 70px;
}

.step-line {
    width: 660px;
    margin-left: 68px;
}

.step-line img {
    width: 100%;
    margin: 0 0 20px;
}

.step-line p {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
    text-align: center;
}

#example {
    background: url('../assets/example-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 175px 0;
    position: relative;
}

.example-title {
    position: relative;
    margin: 0 0 40px;
}

.example-title h2 {
    font-weight: 500;
    font-size: 38px;
    line-height: 52px;
    color: #2A3665;
    text-align: center;
    position: relative;
    z-index: 2;
}

.example-title img {
    width: 442px;
    margin: 0 auto;
    position: absolute;
    top: 12px;
    left: 0;
    right: 0;
    z-index: 1;
}

.example-text {
    margin: 0 0 60px;
}

.example-text p {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
    text-align: center;
}

ul.example-list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 62px;
    row-gap: 50px;
}

ul.example-list li {
    width: 260px;
}

.example-list-image {
    background: #fff;
    border-radius: 20px;
    width: 100%;
    margin: 0 0 20px;
}

.example-list-image img {
    width: 100%;
}

.example-list-title {
    margin: 0 0 20px;
}

.example-list-title h3 {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
    text-align: center;
}

.example-list-label {
    width: 220px;
    height: 28px;
    margin: 0 auto 20px;
    background: #0F4E8C;
    border-radius: 28px;
}

.example-list-label p {
    font-weight: 600;
    font-size: 16px;
    line-height: 28px;
    color: #FFF;
    text-align: center;
}

.example-list-text {
    height: 112px;
    margin: 0 0 20px;
}

.example-list-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #2A3665;
}

.example-list-button a {
    width: 100%;
    height: 50px;
    display: block;
    font-weight: 600;
    font-size: 16px;
    line-height: 50px;
    border-radius: 50px;
    color: #0F4E8C;
    border: 1px solid #0F4E8C; 
    text-align: center;
    text-decoration: none;
    transition: 0.3s;
}

.example-list-button a:hover {
    background-color: #0F4E8C;
    color: #fff;
}

#plan {
    background: url('../assets/plan-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 160px 0;
    position: relative;
}

.plan-title {
    position: relative;
    margin: 0 0 40px;
}

.plan-title h2 {
    font-weight: 500;
    font-size: 38px;
    line-height: 52px;
    color: #2A3665;
    text-align: center;
    position: relative;
    z-index: 2;
}

.plan-title img {
    width: 548px;
    margin: 0 auto;
    position: absolute;
    top: 22px;
    left: 0;
    right: 0;
    z-index: 1;
}

.plan-text {
    margin: 0 0 50px;
}

.plan-text p {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
    text-align: center;
}

.plan-list {
    display: flex;
    justify-content: space-between;
    margin: 0 0 20px;
}

.plan-left {
    width: 420px;
}

#personal-license {
    background: #E6EDF3;
    border-radius: 20px;
    margin: 0 0 20px;
}

#environmental-license {
    background: #FDF7E9;
    border-radius: 20px;
}

.plan-right {
    width: 440px;
}

#free-trial {
    background: #ECF7F0;
    border-radius: 20px;
}

.plan-list-header {
    border-radius: 20px 20px 0 0;
    height: 80px;
    margin: 0 0 20px;
}

#personal-license .plan-list-header {
    background: #0F4E8C;
}

#environmental-license .plan-list-header {
    background: #E5B32D;
}

.plan-list-header h3 {
    font-weight: 500;
    font-size: 28px;
    line-height: 80px;
    color: #fff;
    text-align: center; 
}

.plan-list-title {
    padding: 24px 0 0;
    margin: 0 0 25px;
}

.plan-list-title h3 {
    font-weight: 500;
    font-size: 38px;
    line-height: 52px;
    color: #49AC6B;
    text-align: center;
}

.plan-list-text {
    padding: 0 0 18px;
}

#free-trial .plan-list-text {
    padding: 0 0 24px;
}

.plan-list-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #2A3665;
    text-align: center;
}

.personal-license-content {
    width: 380px;
    margin: 0 auto 15px;
    border-bottom: 1px solid #0F4E8C;
}

.plan-list-label {
    background: #fff;
    height: 30px;
    border-radius: 30px;
}

.plan-list-label p {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    text-align: center;
    color: #0F4E8C;
}

.plan-list-price {
    margin: 0 0 15px;
}

.plan-list-price p {
    font-weight: 900;
    font-size: 32px;
    line-height: 50px;
    text-align: center;
    color: #D0474A;
}

.plan-list-price p span {
    font-weight: 500;
    font-size: 24px;
    line-height: 50px;
    text-align: center;
    color: #2A3665;
}

.free-trial-content {
    width: 380px;
    margin: 0 auto 25px;
}

ul.free-trial-list {
    list-style: none;
    position: relative;
}

ul.free-trial-list li {
    height: 50px;
    background-color: #49AC6B;
    border-radius: 50px;
    margin: 0 0 30px;
    font-weight: 500;
    font-size: 24px;
    line-height: 50px;
    color: #fff;
    text-align: center;
}

ul.free-trial-list li:last-child {
    margin: 0;
}

.free-trial-arrow {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 30px;
    height: calc(100% - 50px);
    background: rgba(73, 172, 107, 0.2);
}

.free-trial-arrow::after {
    content: '';
    margin: 0 auto;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    border-left: 15px solid #ECF7F0;
    border-right: 15px solid #ECF7F0;
    border-top: 14px solid transparent;
}

.plan-note p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 12px;
    line-height: 22px;
    color: #2A3665;
}

#flow {
    background: url('../assets/feature-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 112px 0;
    position: relative;
}

.flow-title {
    position: relative;
    margin: 0 0 50px;
}

.flow-title h2 {
    font-weight: 500;
    font-size: 32px;
    line-height: 50px;
    color: #FFF;
    text-align: center;
    position: relative;
    z-index: 2;
}

.flow-title img {
    width: 370px;
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1;
}

ul.flow-list {
    display: flex;
    justify-content: space-between;
    list-style: none;
}

ul.flow-list li {
    width: 240px;
}

.flow-image {
    width: 100%;
    margin: 0 0 20px;
}

.flow-image img {
    width: 100%;
}

.flow-number {
    margin: 0 0 20px;
}

.flow-number p {
    font-weight: 500;
    font-size: 28px;
    line-height: 40px;
    color: #FFF;
    text-align: center;
}

.flow-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #FFF;
}

.flow-list-divider {
    width: 0;
    height: 0;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 10px solid #FFF;
    margin-top: 110px;
}

#contactus {
    background: url('../assets/contactus-bg.png');
    background-size: cover;
    background-position-x: center;
    background-position-y: center;
    background-repeat: no-repeat;
    padding: 140px 0;
    position: relative;
}

.contactus-title {
    margin: 0 0 50px;
}

.contactus-title h2 {
    font-weight: 500;
    font-size: 32px;
    line-height: 50px;
    color: #2A3665;
    display: flex;
    justify-content: center;
    align-items: center;
}

.contactus-title img {
    width: 154px;
}

.contactus-title-mobile {
    display: none;
}

ul.contactus-list {
    width: 720px;
    margin: 0 auto 50px;
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    justify-content: center;
    column-gap: 50px;
    row-gap: 30px;
    border: 1px solid #005DAD;
    padding: 32px 150px;
}

ul.contactus-list li {
    font-weight: 600;
    font-size: 18px;
    line-height: 30px;
    color: #2A3665;
    display: flex;
}

ul.contactus-list li::before {
    content: "";
    display: block;
    background: url("../assets/contactus-list.svg") no-repeat;
    background-size: contain;
    width: 30px;
    height: 30px;
    margin: 0 10px 0 0;
}

.contactus-button {
    margin: 0 0 50px;
}

.contactus-button a {
    display: block;
    width: 400px;
    height: 70px;
    background-color: #0F4E8C;
    border-radius: 70px;
    font-weight: 600;
    font-size: 18px;
    line-height: 70px;
    color: #FFFFFF;
    margin: 0 auto;
    text-align: center;
    border: none;
    text-decoration: none;
    transition: 0.3s;
}

.contactus-button a:hover {
    opacity: 0.7;
}

.contactus-number {
    width: 720px;
    background: rgba(0, 93, 173, 0.1);
    border-radius: 20px;
    padding: 25px;
    margin: 0 auto;
}

.contactus-number-label p {
    font-size: 18px;
    line-height: 26px;
    color: #0F4E8C;
    text-align: center;
}

.contactus-number-text {
    display: flex;
    justify-content: center;
    align-items: center;
}

.contactus-number-text img {
    width: 40px;
}

.contactus-number-text p {
    font-weight: 700;
    font-size: 38px;
    line-height: 55px;
    color: #0F4E8C;
    text-align: center;
}

#footer {
    background: rgba(42, 54, 101, 0.1);
    padding: 56px 0;
}

.footer-logo {
    width: 323px;
    margin: 0 auto 30px;
}

.footer-logo img {
    width: 100%;
}

.footer-copyright p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 12px;
    line-height: 17px;
    color: #2A3665;
    text-align: center;
}

/* CONTACT PAGE */
#contact {
    background: #FFF;
    padding: 100px 0 110px;
}

.contact-title {
    margin: 0 0 50px;
}

.contact-title h1 {
    font-size: 38px;
    line-height: 52px;
    font-weight: 500;
    color: #2A3665;
    text-align: center;
}

.contact-card {
    width: 100%;
    background: rgba(73, 172, 107, 0.1);
    border-radius: 20px;
    padding: 28px;
    margin: 0 0 30px;
}

.contact-card-title {
    margin: 0 0 10px;
}

.contact-card-title h2 {
    font-size: 28px;
    line-height: 38px;
    font-weight: 500;
    color: #49AC6B;
}

.contact-card-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #2A3665;
}

.contact-content {
    display: flex;
    justify-content: space-between;
}

.contact-detail {
    width: 420px;
}

.contact-text {
    margin: 0 0 20px;
}

.contact-text img {
    width: 150px;
    margin: 0 auto 30px;
}

.contact-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #2A3665;
}

.contact-number {
    width: 100%;
    background: rgba(0, 93, 173, 0.1);
    border-radius: 20px;
    padding: 20px;
    margin: 0 0 30px;
}

.contact-number-label p {
    font-size: 18px;
    line-height: 26px;
    color: #000;
    text-align: center;
}

.contact-number-text {
    display: flex;
    justify-content: center;
    align-items: center;
}

.contact-number-text img {
    width: 40px;
}

.contact-number-text p {
    font-weight: 700;
    font-size: 38px;
    line-height: 55px;
    color: #005DAD;
    text-align: center;
}

.contact-list {
    width: 100%;
    border: 2px solid #2A3665;
    border-radius: 20px;
    padding: 34px 38px;
}

.contact-list-title {
    margin: 0 0 20px;
}

.contact-list-title h2 {
    font-weight: 600;
    font-size: 18px;
    line-height: 24px;
    color: #2A3665;
    text-align: center;
}

.contact-list ul {
    list-style: none;
}

.contact-list ul li {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #2A3665;
}

.contact-form {
    width: 420px;
}

.contact-form-text {
    margin: 0 0 20px;
}

.contact-form-name {
    display: flex;
    column-gap: 20px;
}

.contact-form-input > input[type="text"],
.contact-form-input > input[type="email"] {
    width: 100%;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    line-height: 24px;
    background-color: #fff;
    border: 0.5px solid #000;
    padding: 13px 20px;
    color: #000;
}

.contact-form-option {
    margin: 0 0 20px;
}

.contact-form-option > .contact-form-label {
    margin: 0 0 10px;
}

.contact-form-option > .contact-form-label > label {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 18px;
    line-height: 26px;
    color: #000;
}

.contact-form-option > .contact-form-input label {
    width: 180px;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    line-height: 20px;
    color: #000000;
    margin: 0 20px 15px 0;
    padding-left: 30px;
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.contact-form-option > .contact-form-input {
    display: flex;
    flex-wrap: wrap;
}

.contact-form-option > .contact-form-input input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 20px;
    width: 20px;
    background-color: #fff;
    border: 0.5px solid #000;
}

.checkmark:after {
    content: "";
    position: absolute;
    display: none;
    width: 10px;
    height: 10px;
    background: url("../assets/checklist.svg") no-repeat;
    background-size: contain;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.contact-form-option > .contact-form-input input:checked ~ .checkmark:after {
    display: block;
}

.contact-form-textarea {
    margin: 0 0 20px;
}

.contact-form-input > textarea {
    width: 100%;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    line-height: 24px;
    border: 0.5px solid #000;
    padding: 13px 20px;
    height: 180px;
}

.form-check {
    padding: 0;
    margin: 0 0 10px;
}

.contact-agreement > label {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    line-height: 20px;
    color: #000;
    padding-left: 30px;
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.contact-agreement > label input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

.contact-agreement > label input:checked ~ .checkmark:after {
    display: block;
}

.contact-form-note {
    margin: 0 0 20px;
}

.contact-form-note p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 20px;
    color: #000;
}

.contact-form-note a {
    color: #005DAD;
}

input#submit {
    display: block;
    width: 220px;
    height: 50px;
    background-color: #0F4E8C;
    border-radius: 50px;
    font-weight: 700;
    font-size: 16px;
    line-height: 50px;
    color: #FFFFFF;
    margin: 0 auto;
    text-align: center;
    border: none;
    text-decoration: none;
    transition: 0.3s;
}

input#submit:hover {
    opacity: 0.7;
}

button[type=submit] {
    display: block;
    width: 220px;
    height: 50px;
    background-color: #0F4E8C;
    border-radius: 50px;
    font-weight: 700;
    font-size: 16px;
    line-height: 50px;
    color: #FFFFFF;
    margin: 0 auto;
    text-align: center;
    border: none;
    text-decoration: none;
    transition: 0.3s;
}

button[type=submit]:hover {
    opacity: 0.7;
}

/* THANKS PAGE */

#thanks {
    background: #FFF;
    padding: 153px 0 251px;
}

.thanks-title {
    margin: 0 0 50px;
}

.thanks-title h2 {
    font-weight: 500;
    font-size: 38px;
    line-height: 52px;
    color: #2A3665;
    text-align: center;
}

.thanks-text {
    margin: 0 0 50px;
}

.thanks-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    line-height: 28px;
    color: #2A3665;
    text-align: center;
}

.thanks-button a {
    display: block;
    width: 220px;
    height: 50px;
    background-color: #0F4E8C;
    border-radius: 50px;
    font-weight: 700;
    font-size: 16px;
    line-height: 50px;
    color: #FFFFFF;
    margin: 0 auto;
    text-align: center;
    text-decoration: none;
    transition: 0.3s;
}

.thanks-button a:hover {
    opacity: 0.7;
}

.split-mobile {
    display: none;
}

.desktop-only {
    display: inline-block;
    line-height: 1px !important;
    height: 1px;
}

.mobile-only {
    display: none;
}

.image-mobile {
    display: none;
}

.grecaptcha-badge {
    display: none !important;
}

#recaptcha-holder > .grecaptcha-badge {
    display: block !important;
    visibility: visible !important;
    position: static !important;
    margin: 0 0 20px;
}

@media (max-width: 1669px) and (min-width: 1024px) {
    #sidebar {
        right: 60px;
    }
}

@media (max-width: 1023px) and (min-width: 640px) {
    .ultra-container {
        width: 88.28125vw;
    }
    
    .header {
        height: 8.79vw;
        filter: drop-shadow(0 0.29vw 0.59vw rgba(0, 0, 0, 0.16));
    }
    
    .header-container {
        width: 100vw;
    }
    
    .navbar {
        height: 8.79vw;
    }
        
    .navbar-nav {
        column-gap: 1.95vw;
        padding-right: 2.25vw;
    }
    
    .navbar-nav li a {
        font-size: 1.56vw;
        line-height: 3.125vw;
    }
    
    .navbar-nav li a.header-contact-button {
        width: 17.58vw;
        height: 4.88vw;
        border-radius: 4.88vw;
        font-size: 1.37vw;
        line-height: 4.88vw;
    }
            
    .navbar-brand {
        width: 19.53vw;
    }

    main {
        padding-top: 8.79vw;
    }

    #banner {
        background-size: 187.5vw;
        height: 87.89vw;
    }
    
    .banner-title {
        width: 23.24vw;
        top: 12.11vw;
    }
        
    .banner-text {
        width: 1.86vw;
        top: 12.11vw;
        right: 26.76vw;
    }
        
    .banner-icon {
        width: 19.92vw;
        height: 19.53vw;
        left: -5.86vw;
        top: 60.64vw;
    }
    
    .banner-icon p {
        font-size: 2.34vw;
        line-height: 3.32vw;
    }

    #sidebar {
        right: 5.86vw;
        bottom: 5.86vw;
    }
    
    .sidebar-card {
        width: 25.39vw;
        height: 19.53vw;
        border-radius: 1.95vw;
        border: 0.1vw solid #8A9595;
        filter: drop-shadow(0 0.29vw 0.59vw rgba(0, 0, 0, 0.16));
        padding: 2.54vw;
    }
    
    .sidebar-text {
        margin: 0 0 1.95vw;
    }
    
    .sidebar-text p {
        font-size: 1.56vw;
        line-height: 2.34vw;
    }
    
    .sidebar-button a {
        width: 21.48vw;
        height: 4.88vw;
        border-radius: 4.88vw;
        font-size: 1.56vw;
        line-height: 4.88vw;
    }
        
    .sidebar-close {
        width: 2.44vw;
        height: 2.44vw;
        border-radius: 2.44vw;
        top: 0.98vw;
        right: 0.98vw;
        padding: 0.73vw;
    }

    #chat {
        padding: 11.04vw 0 6.15vw;
    }
    
    ul.chat-list {
        width: 76.37vw;
    }
    
    ul.chat-list li {
        margin: 0 0 3.71vw;
        width: 48.83vw;
        border-radius: 9.77vw;
        padding: 1.37vw;
        filter: drop-shadow(0 0.29vw 0.59vw rgba(0, 0, 0, 0.16));
    }
    
    ul.chat-list li:nth-child(2) {
        margin-left: auto;
    }
    
    ul.chat-list li:last-child {
        margin: 0 0 0 8.79vw;
    }
    
    ul.chat-list li p {
        font-size: 1.76vw;
        line-height: 3.125vw;
    }
    
    ul.chat-list li::after {
        left: 5.57vw;
        border-left: 0.98vw solid transparent;
        border-right: 0.98vw solid transparent;
        border-top: 1.76vw solid #fff;
    }
    
    ul.chat-list li:nth-child(2)::after {
        left: auto;
        right: 5.57vw;
    }

    #system {
        padding: 11.13vw 0 22.46vw;
    }
    
    #system::before {
        width: 100%;
        height: 19.53vw;
    }
    
    .system-title {
        margin: 0 0 4.49vw;
    }
    
    .system-title h2 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }
    
    .system-title h2 img {
        width: 15.04vw;
    }
    
    .system-title > img {
        width: 59.96vw;
        top: 2.05vw;
    }
    
    .system-title > img:nth-child(2n) {
        width: 29.39vw;
        top: 6.93vw;
    }
    
    .system-text {
        margin: 0 0 5.08vw;
    }
    
    .system-text p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    .system-list-content {
        width: 21.48vw;
    }
    
    .system-list-image {
        width: 21.48vw;
        margin: 0 auto 1.95vw;
        border-radius: 21.48vw;
    }
    
    .system-list-title {
        margin: 0 0 1.95vw;
    }
    
    .system-list-title h3 {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    .system-list-label {
        width: 21.48vw;
        height: 2.73vw;
        margin: 0 auto 1.95vw;
        border-radius: 2.73vw;
    }
    
    .system-list-label p {
        font-size: 1.56vw;
        line-height: 2.73vw;
    }
    
    .system-list-text p {
        font-size: 1.37vw;
        line-height: 2.73vw;
    }
        
    .system-list.owl-carousel .owl-nav button.owl-prev,
    .system-list.owl-carousel .owl-nav button.owl-next {
        width: 3.71vw;
        height: 3.71vw;
        border-radius: 3.71vw;
    }
    
    .system-list.owl-carousel .owl-nav {
        top: 20.51vw;
    }
    
    .system-list.owl-carousel .owl-nav button.owl-prev span,
    .system-list.owl-carousel .owl-nav button.owl-next span {
        font-size: 3.71vw;
        line-height: 3.71vw;
    }
    
    .system-list.owl-carousel .owl-stage-outer {
        width: 80.86vw;
        left: 3.71vw;
    }

    #feature {
        padding: 11.72vw 0;
    }
    
    .feature-title {
        margin: 0 0 3.91vw;
    }
    
    .feature-title h2 {
        font-size: 3.72vw;
        line-height: 5.37vw;
    }
    
    .feature-title img {
        width: 37.89vw;
        top: 0.98vw;
    }
    
    .feature-text {
        margin: 0 0 6.84vw;
    }
    
    .feature-text p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    ul.feature-list li {
        margin: 0 0 5.86vw;
    }
    
    ul.feature-list li:last-child {
        margin: 0;
    }
    
    .feature-list-image {
        width: 41.02vw;
    }
        
    .feature-list-content {
        width: 41.02vw;
    }
    
    .feature-list-title {
        width: 41.02vw;
        margin: 0 0 2.93vw;
    }
    
    .feature-list-title h3 {
        font-size: 3.125vw;
        line-height: 4.88vw;
    }
    
    .feature-list-text p {
        font-size: 1.37vw;
        line-height: 2.74vw;
    }
    
    .feature-list-note {
        margin: 2.93vw 0 0;
    }
    
    .feature-list-note p {
        font-size: 1.17vw;
        line-height: 2.15vw;
    }
    
    .feature-list-button {
        margin: 2.93vw 0 0;
    }
    
    .feature-list-button a {
        width: 26.37vw;
        height: 4.88vw;
        font-size: 1.56vw;
        line-height: 4.88vw;
        border-radius: 4.88vw;
    }

    #why {
        padding: 8.79vw 0;
    }
    
    .why-title {
        margin: 0 0 3.52vw;
    }
    
    .why-title h2 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }
    
    .why-title img {
        width: 22.17vw;
        top: 1.86vw;
        left: -3.32vw;
    }
    
    .why-title img:nth-child(2n+1) {
        width: 53.52vw;
        top: 7.32vw;
    }
    
    .why-text {
        margin: 0 0 2.93vw;
    }
    
    .why-text p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    ul.why-list {
        row-gap: 2.34vw;
    }
    
    ul.why-list li {
        width: 27.34vw;
        border-radius: 0.98vw;
        padding: 1.27vw 0;
    }
    
    ul.why-list li p {
        font-size: 1.56vw;
        line-height: 2.15vw;
    }

    #step {
        padding: 10.74vw 0 12.21vw;
    }
    
    .step-title {
        margin: 0 0 5.86vw;
    }
    
    .step-title h2 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }
    
    .step-title img {
        width: 53.52vw;
        top: 1.71vw;
    }
    
    ul.step-list {
        margin: 0 0 2.73vw;
    }
    
    ul.step-list li {
        width: 15.625vw;
    }
        
    .step-list-number {
        top: -0.98vw;
        left: -0.98vw;
        width: 2.93vw;
        height: 2.93vw;
        border-radius: 2.93vw;
    }
    
    .step-list-number p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    .step-list-image {
        border-radius: 1.95vw;
        margin: 0 0 1.95vw;
    }
    
    .step-list-text p {
        font-size: 1.76vw;
        line-height: 2.15vw;
    }
    
    .step-list-title h3 {
        font-size: 2.34vw;
        line-height: 15.625vw;
    }
    
    .step-list-divider {
        border-top: 0.98vw solid transparent;
        border-bottom: 0.98vw solid transparent;
        border-left: 0.98vw solid #95B5DE;
        margin-top: 6.84vw;
    }
    
    .step-line {
        width: 64.45vw;
        margin-left: 6.64vw;
    }
    
    .step-line img {
        margin: 0 0 1.95vw;
    }
    
    .step-line p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }

    #example {
        padding: 17.09vw 0;
    }
    
    .example-title {
        margin: 0 0 3.91vw;
    }
    
    .example-title h2 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }
    
    .example-title img {
        width: 43.16vw;
        top: 1.17vw;
    }
    
    .example-text {
        margin: 0 0 5.86vw;
    }
    
    .example-text p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    ul.example-list {
        column-gap: 6.05vw;
        row-gap: 4.88vw;
    }
    
    ul.example-list li {
        width: 25.39vw;
    }
    
    .example-list-image {
        border-radius: 1.95vw;
        margin: 0 0 1.95vw;
    }
        
    .example-list-title {
        margin: 0 0 1.95vw;
    }
    
    .example-list-title h3 {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    .example-list-label {
        width: 21.48vw;
        height: 2.73vw;
        margin: 0 auto 1.95vw;
        border-radius: 2.73vw;
    }
    
    .example-list-label p {
        font-size: 1.56vw;
        line-height: 2.73vw;
    }
    
    .example-list-text {
        height: 10.9375vw;
        margin: 0 0 1.95vw;
    }
    
    .example-list-text p {
        font-size: 1.37vw;
        line-height: 2.74vw;
    }
    
    .example-list-button a {
        height: 4.88vw;
        font-size: 1.56vw;
        line-height: 4.88vw;
        border-radius: 4.88vw;
        border: 0.1vw solid #0F4E8C; 
    }

    #plan {
        padding: 15.625vw 0;
    }
    
    .plan-title {
        margin: 0 0 3.91vw;
    }
    
    .plan-title h2 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }
    
    .plan-title img {
        width: 53.52vw;
        top: 2.15vw;
    }
    
    .plan-text {
        margin: 0 0 4.88vw;
    }
    
    .plan-text p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    .plan-list {
        margin: 0 0 1.95vw;
    }
    
    .plan-left {
        width: 41.02vw;
    }
    
    #personal-license {
        border-radius: 1.95vw;
        margin: 0 0 1.95vw;
    }
    
    #environmental-license {
        border-radius: 1.95vw;
    }
    
    .plan-right {
        width: 42.97vw;
    }
    
    #free-trial {
        border-radius: 1.95vw;
    }
    
    .plan-list-header {
        border-radius: 1.95vw 1.95vw 0 0;
        height: 7.8125vw;
        margin: 0 0 1.95vw;
    }
        
    .plan-list-header h3 {
        font-size: 2.73vw;
        line-height: 7.8125vw;
    }
    
    .plan-list-title {
        padding: 2.34vw 0 0;
        margin: 0 0 2.44vw;
    }
    
    .plan-list-title h3 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }
    
    .plan-list-text {
        padding: 0 0 1.76vw;
    }
    
    #free-trial .plan-list-text {
        padding: 0 0 2.34vw;
    }
    
    .plan-list-text p {
        font-size: 1.37vw;
        line-height: 2.73vw;
    }
    
    .personal-license-content {
        width: 37.11vw;
        margin: 0 auto 1.46vw;
        border-bottom: 0.1vw solid #0F4E8C;
    }
    
    .plan-list-label {
        height: 2.93vw;
        border-radius: 2.93vw;
    }
    
    .plan-list-label p {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    .plan-list-price {
        margin: 0 0 1.46vw;
    }
    
    .plan-list-price p {
        font-size: 3.125vw;
        line-height: 4.88vw;
    }
    
    .plan-list-price p span {
        font-size: 2.34vw;
        line-height: 4.88vw;
    }
    
    .free-trial-content {
        width: 37.11vw;
        margin: 0 auto 2.44vw;
    }
    
    ul.free-trial-list li {
        height: 4.88vw;
        border-radius: 4.88vw;
        margin: 0 0 2.93vw;
        font-size: 2.34vw;
        line-height: 4.88vw;
    }
    
    .free-trial-arrow {
        width: 2.93vw;
        height: calc(100% - 4.88vw);
    }
    
    .free-trial-arrow::after {
        border-left: 1.46vw solid #ECF7F0;
        border-right: 1.46vw solid #ECF7F0;
        border-top: 1.37vw solid transparent;
    }
    
    .plan-note p {
        font-size: 1.17vw;
        line-height: 2.15vw;
    }
    
    #flow {
        padding: 10.9375vw 0;
    }
    
    .flow-title {
        margin: 0 0 4.88vw;
    }
    
    .flow-title h2 {
        font-size: 3.125vw;
        line-height: 4.88vw;
    }
    
    .flow-title img {
        width: 36.13vw;
    }
        
    ul.flow-list li {
        width: 23.4375vw;
    }
    
    .flow-image {
        margin: 0 0 1.95vw;
    }
    
    .flow-number {
        margin: 0 0 1.95vw;
    }
    
    .flow-number p {
        font-size: 2.73vw;
        line-height: 3.91vw;
    }
    
    .flow-text p {
        font-size: 1.37vw;
        line-height: 2.74vw;
    }
    
    .flow-list-divider {
        border-top: 0.98vw solid transparent;
        border-bottom: 0.98vw solid transparent;
        border-left: 0.98vw solid #FFF;
        margin-top: 10.74vw;
    }

    #contactus {
        padding: 13.67vw 0;
    }
    
    .contactus-title {
        margin: 0 0 4.88vw;
    }
    
    .contactus-title h2 {
        font-size: 3.125vw;
        line-height: 4.88vw;
    }
    
    .contactus-title img {
        width: 15.04vw;
    }
    
    ul.contactus-list {
        width: 70.3125vw;
        margin: 0 auto 4.88vw;
        column-gap: 4.88vw;
        row-gap: 2.93vw;
        border: 0.1vw solid #005DAD;
        padding: 3.125vw 14.65vw;
    }
    
    ul.contactus-list li {
        font-size: 1.76vw;
        line-height: 2.93vw;
    }
    
    ul.contactus-list li::before {
        width: 2.93vw;
        height: 2.93vw;
        margin: 0 0.98vw 0 0;
    }
    
    .contactus-button {
        margin: 0 0 4.88vw;
    }
    
    .contactus-button a {
        width: 39.0625vw;
        height: 6.84vw;
        border-radius: 6.84vw;
        font-size: 1.76vw;
        line-height: 6.84vw;
    }
        
    .contactus-number {
        width: 70.3125vw;
        border-radius: 1.95vw;
        padding: 2.44vw;
    }
    
    .contactus-number-label p {
        font-size: 1.76vw;
        line-height: 2.54vw;
    }
    
    .contactus-number-text img {
        width: 3.91vw;
    }
    
    .contactus-number-text p {
        font-size: 3.71vw;
        line-height: 5.37vw;
    }

    #footer {
        padding: 5.47vw 0;
    }
        
    .footer-logo {
        width: 31.54vw;
        margin: 0 auto 2.93vw;
    }
        
    .footer-copyright p {
        font-size: 1.17vw;
        line-height: 1.66vw;
    }

    /* CONTACT PAGE */
    #contact {
        padding: 9.77vw 0 10.74vw;
    }

    .contact-title {
        margin: 0 0 4.88vw;
    }

    .contact-title h1 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }

    .contact-card {
        border-radius: 1.95vw;
        padding: 2.73vw;
        margin: 0 0 2.93vw;
    }

    .contact-card-title {
        margin: 0 0 0.98vw;
    }

    .contact-card-title h2 {
        font-size: 2.73vw;
        line-height: 3.71vw;
    }

    .contact-card-text p {
        font-size: 1.37vw;
        line-height: 2.73vw;
    }

    .contact-detail {
        width: 41.02vw;
    }

    .contact-text {
        margin: 0 0 1.95vw;
    }

    .contact-text img {
        width: 14.65vw;
        margin: 0 auto 2.93vw;
    }

    .contact-text p {
        font-size: 1.37vw;
        line-height: 2.73vw;
    }

    .contact-number {
        border-radius: 1.95vw;
        padding: 1.95vw;
        margin: 0 0 2.93vw;
    }

    .contact-number-label p {
        font-size: 1.76vw;
        line-height: 2.54vw;
    }

    .contact-number-text img {
        width: 3.91vw;
    }

    .contact-number-text p {
        font-size: 3.71vw;
        line-height: 5.37vw;
    }

    .contact-list {
        border: 0.2vw solid #2A3665;
        border-radius: 1.95vw;
        padding: 3.32vw 3.71vw;
    }

    .contact-list-title {
        margin: 0 0 1.95vw;
    }

    .contact-list-title h2 {
        font-size: 1.76vw;
        line-height: 2.34vw;
    }

    .contact-list ul li {
        font-size: 1.37vw;
        line-height: 2.73vw;
    }
    
    .contact-form {
        width: 41.02vw;
    }
    
    .contact-form-text {
        margin: 0 0 1.95vw;
    }
    
    .contact-form-name {
        column-gap: 1.95vw;
    }
    
    .contact-form-input > input[type="text"],
    .contact-form-input > input[type="email"] {
        font-size: 1.56vw;
        line-height: 2.34vw;
        border: 0.05vw solid #000;
        padding: 1.27vw 1.95vw;
    }
    
    .contact-form-option {
        margin: 0 0 1.95vw;
    }
    
    .contact-form-option > .contact-form-label {
        margin: 0 0 0.98vw;
    }
    
    .contact-form-option > .contact-form-label > label {
        font-size: 1.76vw;
        line-height: 2.54vw;
    }
    
    .contact-form-option > .contact-form-input label {
        width: 17.58vw;
        font-size: 1.56vw;
        line-height: 1.95vw;
        margin: 0 1.95vw 1.46vw 0;
        padding-left: 2.93vw;
    }
    
    .checkmark {
        height: 1.95vw;
        width: 1.95vw;
        border: 0.05vw solid #000;
    }
    
    .checkmark:after {
        width: 0.98vw;
        height: 0.98vw;
    }
    
    .contact-form-textarea {
        margin: 0 0 1.95vw;
    }
    
    .contact-form-input > textarea {
        font-size: 1.56vw;
        line-height: 2.34vw;
        border: 0.05vw solid #000;
        padding: 1.27vw 1.95vw;
        height: 17.58vw;
    }
    
    .form-check {
        margin: 0 0 0.98vw;
    }
    
    .contact-agreement > label {
        font-size: 1.56vw;
        line-height: 1.95vw;
        padding-left: 2.93vw;
    }
    
    .contact-form-note {
        margin: 0 0 1.95vw;
    }
    
    .contact-form-note p {
        font-size: 1.37vw;
        line-height: 1.95vw;
    }
    
    input#submit {
        width: 21.48vw;
        height: 4.88vw;
        border-radius: 4.88vw;
        font-size: 1.56vw;
        line-height: 4.88vw;
    }
    
    button[type=submit] {
        width: 21.48vw;
        height: 4.88vw;
        border-radius: 4.88vw;
        font-size: 1.56vw;
        line-height: 4.88vw;
    }

    /* THANKS PAGE */
    
    #thanks {
        padding: 14.94vw 0 24.51vw;
    }
    
    .thanks-title {
        margin: 0 0 4.88vw;
    }
    
    .thanks-title h2 {
        font-size: 3.71vw;
        line-height: 5.08vw;
    }
    
    .thanks-text {
        margin: 0 0 4.88vw;
    }
    
    .thanks-text p {
        font-size: 1.37vw;
        line-height: 2.73vw;
    }
    
    .thanks-button a {
        width: 21.48vw;
        height: 4.88vw;
        border-radius: 4.88vw;
        font-size: 1.5625vw;
        line-height: 4.88vw;
    }
}

@media (max-width: 639px) {
    .ultra-container {
        width: 84vw;
    }

    .header {
        height: 18.67vw;
        filter: drop-shadow(0 0.8vw 1.6vw rgba(0, 0, 0, 0.16));
    }
    
    .header-container {
        width: 84vw;
    }
    
    .navbar {
        height: 18.67vw;
    }
        
    .navbar-collapse {
        width: 100vw;
        height: calc(100vh - 18.67vw);
        background: #fff;
        margin: 0 -8vw;
        padding: 8vw;
    }
    
    .navbar-nav li {
        margin: 0 0 10.67vw;
    }

    .navbar-nav li:last-child {
        margin: 0;
    }

    .navbar-nav li a {
        font-size: 4.8vw;
        line-height: 6.4vw;
    }
    
    .navbar-nav li a.header-contact-button {
        width: 69.33vw;
        height: 13.33vw;
        border-radius: 13.33vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
    }
    
    .navbar-brand {
        width: 26.67vw;
        padding: 0;
    }

    .navbar-brand img {
        display: none;
    }

    main {
        padding-top: 18.67vw;
    }

    #banner {
        background: url('../assets/banner-bg-mobile.png');
        background-size: cover;
        background-position-x: center;
        background-position-y: center;
        background-repeat: no-repeat;
        height: 128vw;
        padding: 18.4vw 0 0;
    }
    
    .banner-title {
        width: 32.44vw;
        position: static;
        margin: 0 auto 9.6vw;
    }
        
    .banner-text {
        width: 100%;
        position: static;
    }
    
    .banner-text img {
        display: none;
    }
    
    .banner-text p {
        display: block;
        font-weight: 600;
        font-size: 3.73vw;
        line-height: 6.4vw;
        color: #fff;
        text-align: center;
    }
    
    .banner-icon {
        display: none;
    }

    #sidebar {
        right: 8vw;
        bottom: 8vw;
        z-index: 98;
    }
    
    .sidebar-card {
        width: 50.67vw;
        height: 37.33vw;
        border-radius: 5.33vw;
        border: 0.27vw solid #8A9595;
        filter: drop-shadow(0 0.8vw 1.6vw rgba(0, 0, 0, 0.16));
        padding: 4vw 3vw;
    }
    
    .sidebar-text {
        margin: 0 0 2.67vw;
    }
    
    .sidebar-text p {
        font-size: 4.27vw;
        line-height: 6.4vw;
    }
    
    .sidebar-button a {
        width: 40vw;
        height: 8vw;
        border-radius: 8vw;
        font-size: 3.2vw;
        line-height: 8vw;
    }
        
    .sidebar-close {
        width: 6.67vw;
        height: 6.67vw;
        border-radius: 6.67vw;
        top: 2.67vw;
        right: 2.67vw;
        padding: 2vw;
    }

    #chat {
        padding: 13.86vw 0 7.2vw;
    }
    
    ul.chat-list {
        width: 84vw;
    }
    
    ul.chat-list li {
        margin: 0 0 7.47vw;
        width: 66.67vw;
        border-radius: 26.4vw;
        padding: 3.2vw;
        filter: drop-shadow(0 0.8vw 1.6vw rgba(0, 0, 0, 0.16));
    }
    
    ul.chat-list li:nth-child(2) {
        margin-left: auto;
    }
    
    ul.chat-list li:last-child {
        margin: 0;
    }
    
    ul.chat-list li p {
        font-size: 3.73vw;
        line-height: 7.47vw;
    }
    
    ul.chat-list li::after {
        left: 9.6vw;
        border-left: 2.67vw solid transparent;
        border-right: 2.67vw solid transparent;
        border-top: 4.8vw solid #fff;
    }
    
    ul.chat-list li:nth-child(2)::after {
        left: auto;
        right: 9.6vw;
    }

    #system {
        padding: 20vw 0 29.6vw;
    }
    
    #system::before {
        width: 100%;
        height: 24vw;
    }

    .system-title {
        display: none;
    }
    
    .system-title-mobile {
        display: block;
        position: relative;
        margin: 0 0 8vw;
    }
    
    .system-title-mobile h2 {
        font-weight: 500;
        font-size: 6.4vw;
        line-height: 9.07vw;
        color: #2A3665;
        position: relative;
        z-index: 2;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    
    .system-title-mobile h2 img {
        width: 24.8vw;
    }
    
    .system-title-mobile > img {
        width: 44vw;
        position: absolute;
        top: 4.36vw;
        left: 0;
        right: 0;
        margin: 0 auto;
        z-index: 1;
    }
    
    .system-title-mobile > img:nth-child(3n-1) {
        width: 69.6vw;
        top: 13.96vw;
    }

    .system-title-mobile > img:nth-child(3n) {
        width: 44vw;
        top: 23vw;
    }
    
    .system-text {
        margin: 0 0 13.33vw;
    }
    
    .system-text p {
        font-size: 4.27vw;
        line-height: 8.53vw;
    }

    .system-list-content {
        width: 48vw;
    }
    
    .system-list-image {
        width: 48vw;
        margin: 0 auto 5.33vw;
        border-radius: 48vw;
    }
        
    .system-list-title {
        margin: 0 0 5.33vw;
    }
    
    .system-list-title h3 {
        font-size: 4.8vw;
        line-height: 8vw;
    }
    
    .system-list-label {
        width: 48vw;
        height: 7.47vw;
        margin: 0 auto 5.33vw;
        border-radius: 7.47vw;
    }
    
    .system-list-label p {
        font-size: 4.27vw;
        line-height: 7.47vw;
    }
    
    .system-list-text p {
        font-size: 3.73vw;
        line-height: 7.47vw;
    }
    
    .system-list {
        width: 48vw;
    }
        
    .system-list.owl-carousel .owl-nav button.owl-prev,
    .system-list.owl-carousel .owl-nav button.owl-next {
        width: 8vw;
        height: 8vw;
        border-radius: 8vw;
    }
    
    .system-list.owl-carousel .owl-nav {
        top: 48vw;
        width: 84vw;
    }
    
    .system-list.owl-carousel .owl-nav button.owl-prev span,
    .system-list.owl-carousel .owl-nav button.owl-next span {
        font-size: 8vw;
        line-height: 8vw;
    }
    
    .system-list.owl-carousel .owl-stage-outer {
        width: 48vw;
        left: 18vw;
        /* overflow: initial; */
        overflow: hidden;
    }

    #feature {
        padding: 27.2vw 0;
    }
    
    .feature-title {
        margin: 0 0 8vw;
    }
    
    .feature-title h2 {
        font-size: 6.4vw;
        line-height: 9.6vw;
    }
    
    .feature-title img {
        display: none;
        width: 55.512vw;
        top: 4vw;
    }
    
    .feature-text {
        margin: 0 0 13.33vw;
    }
    
    .feature-text p {
        font-size: 4.27vw;
        line-height: 8.53vw;
    }
    
    ul.feature-list li {
        display: block;
        margin: 0 0 13.33vw;
    }
    
    ul.feature-list li:last-child {
        margin: 0;
    }
    
    .feature-list-image {
        width: 100%;
        margin: 0 0 8vw;
    }
    
    .feature-list-content {
        width: 100%;
    }
        
    .feature-list-title {
        width: 100%;
        margin: 0 0 8vw;
    }
    
    .feature-list-title h3 {
        font-size: 4.8vw;
        line-height: 8vw;
        text-align: center;
    }
    
    .feature-list-text p {
        font-size: 3.73vw;
        line-height: 7.47vw;
    }
    
    .feature-list-note {
        margin: 8vw 0 0;
    }
    
    .feature-list-note p {
        font-size: 3.2vw;
        line-height: 5.87vw;
    }
    
    .feature-list-button {
        margin: 8vw 0 0;
    }
    
    .feature-list-button a {
        width: 72vw;
        height: 13.33vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
        border-radius: 13.33vw;
        margin: 0 auto;
    }

    #why {
        background: url('../assets/why-bg-mobile.png');
        background-size: cover;
        background-position-x: center;
        background-position-y: center;
        background-repeat: no-repeat;
        padding: 20vw 0 14.4vw;
    }
    
    .why-title {
        margin: 0 0 8.8vw;
    }
    
    .why-title h2 {
        font-size: 6.4vw;
        line-height: 9.07vw;
        text-align: center;
    }
    
    .why-title img {
        display: none;
        width: 36.8vw;
        top: 4vw;
        left: 0;
        right: 0;
        margin: 0 auto;
    }
    
    .why-title img:nth-child(2n+1) {
        width: 84vw;
        top: 14vw;
    }
    
    .why-text {
        margin: 0 0 13.33vw;
    }
    
    .why-text p {
        font-size: 4.27vw;
        line-height: 8.53vw;
        text-align: center;
    }
    
    ul.why-list {
        row-gap: 5.33vw;
    }
    
    ul.why-list li {
        width: 39.2vw;
        border-radius: 2.67vw;
        padding: 3.47vw 0;
    }
    
    ul.why-list li p {
        font-size: 4.27vw;
        line-height: 5.87vw;
    }

    #step {
        padding: 20vw 0;
    }
    
    .step-title {
        margin: 0 0 8vw;
    }
    
    .step-title h2 {
        font-size: 6.4vw;
        line-height: 9.07vw;
    }
    
    .step-title img {
        display: none;
        width: 84vw;
        top: 4.8vw;
    }
    
    ul.step-list {
        display: block;
        margin: 0 0 0 17.6vw;
        width: 42.67vw;
    }
    
    ul.step-list li {
        padding-top: 2.67vw;
        width: 42.67vw;
    }
    
    ul.step-list li:last-child {
        padding-top: 0;
        width: 42.67vw;
    }
    
    .step-list-number {
        top: -2.67vw;
        left: -2.67vw;
        width: 8vw;
        height: 8vw;
        border-radius: 8vw;
    }
    
    .step-list-number p {
        font-size: 4.27vw;
        line-height: 8vw;
    }
    
    .step-list-image {
        border-radius: 5.33vw;
        margin: 0 0 5.33vw;
    }
        
    .step-list-text p {
        font-size: 4.8vw;
        line-height: 5.87vw;
    }
    
    .step-list-title {
        width: 100%;
    }
    
    .step-list-title h3 {
        font-size: 6.4vw;
        line-height: 9.07vw;
    }
    
    .step-list-divider {
        margin: 5.33vw auto;
        border-left: 2.67vw solid transparent;
        border-right: 2.67vw solid transparent;
        border-top: 2.67vw solid #95B5DE;
        border-bottom: none;
    }

    .step-content {
        display: flex;
        justify-content: space-between;
    }
    
    .step-line {
        width: 16.8vw;
        margin: 0;
    }
    
    .step-line img {
        display: none;
        width: 100%;
        margin: 21.6vw 0 0;
    }
    
    .step-line p {
        display: none;
    }

    #example {
        padding: 20vw 0;
    }
    
    .example-title {
        margin: 0 0 8vw;
    }
    
    .example-title h2 {
        font-size: 6.4vw;
        line-height: 9.07vw;
    }
    
    .example-title img {
        display: none;
        width: 68.92vw;
        top: 4vw;
    }
    
    .example-text {
        margin: 0 0 13.33vw;
    }
    
    .example-text p {
        font-size: 4.27vw;
        line-height: 8.53vw;
        letter-spacing: -1px;
    }
    
    ul.example-list {
        display: block;
    }
    
    ul.example-list li {
        width: 69.33vw;
        margin: 0 auto 13.33vw;
    }

    ul.example-list li:last-child {
        margin: 0 auto;
    }
    
    .example-list-image {
        border-radius: 5.33vw;
        width: 53.33vw;
        margin: 0 auto 5.33vw;
    }
        
    .example-list-title {
        margin: 0 0 5.33vw;
    }
    
    .example-list-title h3 {
        font-size: 4.8vw;
        line-height: 8vw;
    }
    
    .example-list-label {
        width: 58.67vw;
        height: 7.47vw;
        margin: 0 auto 5.33vw;
        border-radius: 7.47vw;
    }
    
    .example-list-label p {
        font-size: 4.27vw;
        line-height: 7.47vw;
    }
    
    .example-list-text {
        height: auto;
        margin: 0 0 5.33vw;
    }
    
    .example-list-text p {
        font-size: 3.73vw;
        line-height: 7.47vw;
        text-align: left;
    }
    
    .example-list-button a {
        height: 13.33vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
        border-radius: 13.33vw;
        border: 0.27vw solid #0F4E8C; 
    }

    #plan {
        padding: 19.2vw 0;
    }
    
    .plan-title {
        margin: 0 0 8vw;
    }
    
    .plan-title h2 {
        font-size: 6.4vw;
        line-height: 9.07vw;
    }
    
    .plan-title img {
        display: none;
        width: 84vw;
        top: 4.27vw;
    }
    
    .plan-text {
        margin: 0 0 13.33vw;
    }
    
    .plan-text p {
        font-size: 4.27vw;
        line-height: 8.53vw;
    }
    
    .plan-list {
        display: block;
        margin: 0 0 8vw;
    }
    
    .plan-left {
        width: 100%;
        margin: 0 0 8vw;
    }
    
    #personal-license {
        border-radius: 5.33vw;
        margin: 0 0 8vw;
    }
    
    #environmental-license {
        border-radius: 5.33vw;
    }
    
    .plan-right {
        width: 100%;
    }
    
    #free-trial {
        border-radius: 5.33vw;
    }
    
    .plan-list-header {
        border-radius: 5.33vw 5.33vw 0 0;
        height: 16vw;
        margin: 0 0 6.4vw;
    }
    
    .plan-list-header h3 {
        font-size: 6.4vw;
        line-height: 16vw;
    }
    
    .plan-list-title {
        padding: 10.4vw 0 0;
        margin: 0 0 8vw;
    }
    
    .plan-list-title h3 {
        font-size: 6.4vw;
        line-height: 9.07vw;
    }
    
    .plan-list-text {
        padding: 0 0 6.4vw;
    }
    
    #free-trial .plan-list-text {
        padding: 0 0 10.4vw;
    }
    
    .plan-list-text p {
        font-size: 3.73vw;
        line-height: 7.47vw;
    }
    
    .personal-license-content {
        width: 67.2vw;
        margin: 0 auto 4vw;
        border-bottom: 0.27vw solid #0F4E8C;
    }
    
    .plan-list-label {
        height: 8vw;
        border-radius: 8vw;
    }
    
    .plan-list-label p {
        font-size: 4.27vw;
        line-height: 8vw;
    }
    
    .plan-list-price {
        margin: 0 0 4vw;
    }
    
    .plan-list-price p {
        font-size: 8.53vw;
        line-height: 13.33vw;
    }
    
    .plan-list-price p span {
        font-size: 6.4vw;
        line-height: 13.33vw;
    }
    
    .free-trial-content {
        width: 67.2vw;
        margin: 0 auto 8vw;
    }
        
    ul.free-trial-list li {
        height: 13.33vw;
        border-radius: 13.33vw;
        margin: 0 0 8vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
    }
    
    .free-trial-arrow {
        width: 8vw;
        height: calc(100% - 13.33vw);
    }
    
    .free-trial-arrow::after {
        border-left: 4vw solid #ECF7F0;
        border-right: 4vw solid #ECF7F0;
        border-top: 3.73vw solid transparent;
    }
    
    .plan-note p {
        font-size: 3.2vw;
        line-height: 5.87vw;
    }
    
    #flow {
        padding: 21.6vw 0;
    }
    
    .flow-title {
        margin: 0 0 8vw;
    }
    
    .flow-title h2 {
        font-size: 6.4vw;
        line-height: 9.07vw;
    }
    
    .flow-title img {
        display: none;
        width: 55.512vw;
        top: 4vw;
    }
    
    ul.flow-list {
        display: block;
    }
    
    ul.flow-list li {
        width: 64vw;
        margin: 0 auto 8vw;
    }

    ul.flow-list li:last-child {
        margin: 0 auto;
    }
    
    .flow-image {
        width: 53.33vw;
        margin: 0 auto 5.33vw;
    }
    
    .flow-number {
        margin: 0 0 5.33vw;
    }
    
    .flow-number p {
        font-size: 6.4vw;
        line-height: 9.07vw;
    }
    
    .flow-text p {
        font-size: 3.73vw;
        line-height: 7.47vw;
    }
    
    .flow-list-divider {
        display: none;
    }
    
    #contactus {
        background: url('../assets/contactus-bg-mobile.png');
        background-size: cover;
        background-position-x: center;
        background-position-y: center;
        background-repeat: no-repeat;
        padding: 21.6vw 0;
    }
    
    .contactus-title {
        display: none;
    }

    .contactus-title-mobile {
        display: block;
        margin: 0 0 8vw;
    }
    
    .contactus-title-mobile h2 {
        font-size: 4.8vw;
        line-height: 8vw;
        font-weight: 500;
        color: #2A3665;
        display: flex;
        justify-content: center;
        align-items: center;
        letter-spacing: -1px;
    }
    
    .contactus-title-mobile img {
        width: 25vw;
    }
    
    ul.contactus-list {
        width: 100%;
        margin: 0 auto 8vw;
        display: block;
        border: 0.27vw solid #005DAD;
        padding: 7.2vw;
    }
    
    ul.contactus-list li {
        font-size: 4.27vw;
        line-height: 8.53vw;
        justify-content: center;
        align-items: center;
        margin: 0 0 2.67vw;
    }

    ul.contactus-list li:last-child {
        margin: 0;
    }
    
    ul.contactus-list li::before {
        width: 5.33vw;
        height: 5.33vw;
        margin: 0 2.67vw 0 0;
    }
    
    .contactus-button {
        margin: 0 0 8vw;
    }
    
    .contactus-button a {
        width: 69.33vw;
        height: 13.33vw;
        border-radius: 13.33vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
    }
        
    .contactus-number {
        width: 100%;
        border-radius: 5.33vw;
        padding: 8vw;
    }
    
    .contactus-number-label p {
        font-size: 4.27vw;
        line-height: 8.53vw;
    }
        
    .contactus-number-text img {
        width: 8vw;
        margin-right: 1.6vw;
    }
    
    .contactus-number-text p {
        font-size: 8.53vw;
        line-height: 13.33vw;
    }

    #footer {
        padding: 8.53vw 0;
    }
        
    .footer-logo {
        width: 45.33vw;
        margin: 0 auto 5.33vw;
    }
        
    .footer-copyright p {
        font-size: 2.67vw;
        line-height: 4vw;
    }

    /* CONTACT PAGE */
    #contact {
        padding: 13.6vw 0;
    }

    .contact-title {
        margin: 0 0 8vw;
    }

    .contact-title h1 {
        font-size: 6.4vw;
        line-height: 8.53vw;
    }

    .contact-content {
        display: block;
    }

    .contact-detail {
        width: 100%;
    }

    .contact-card {
        border-radius: 5.33vw;
        padding: 5.6vw 8vw;
        margin: 0 0 8vw;
    }

    .contact-card-title {
        margin: 0 0 2.67vw;
    }

    .contact-card-title h2 {
        font-size: 4.8vw;
        line-height: 6.4vw;
        text-align: center;
    }

    .contact-card-text p {
        font-size: 3.73vw;
        line-height: 7.47vw;
    }

    .contact-text {
        margin: 0 0 8vw;
        display: flex;
        justify-content: space-between;
    }

    .contact-text img {
        order: 2;
        width: 25.33vw;
        margin: 0;
        height: 14.66vw;
    }

    .contact-text p {
        order: 1;
        width: 52.53vw;
        font-size: 3.73vw;
        line-height: 7.47vw;
    }

    .contact-number {
        border-radius: 5.33vw;
        padding: 8vw;
        margin: 0 0 8vw;
    }
    
    .contact-number-label p {
        font-size: 4.27vw;
        line-height: 6.4vw;
    }
    
    .contact-number-text img {
        width: 8vw;
    }
    
    .contact-number-text p {
        font-size: 8.53vw;
        line-height: 12.27vw;
    }

    .contact-list {
        border: 0.53vw solid #005DAD;
        border-radius: 5.33vw;
        padding: 7.2vw 10vw;
        margin: 0 0 8vw;
    }
    
    .contact-list-title {
        margin: 0 0 2.4vw;
    }
    
    .contact-list-title h2 {
        font-size: 4.8vw;
        line-height: 8.53vw;
    }
        
    .contact-list ul li {
        font-size: 3.73vw;
        line-height: 7.47vw;
    }
    
    .contact-form {
        width: 100%;
    }
    
    .contact-form-text {
        margin: 0 0 8vw;
    }
    
    .contact-form-name {
        display: block;
    }
    
    .contact-form-input > input[type="text"],
    .contact-form-input > input[type="email"] {
        font-size: 4.27vw;
        line-height: 6.4vw;
        border: 0.13vw solid #000;
        padding: 3.47vw 5.33vw;
    }
    
    .contact-form-option {
        margin: 0 0 8vw;
    }
    
    .contact-form-option > .contact-form-label {
        margin: 0 0 2.67vw;
    }
    
    .contact-form-option > .contact-form-label > label {
        font-size: 4.8vw;
        line-height: 6.93vw;
    }
    
    .contact-form-option > .contact-form-input {
        display: block;
    }
    
    .contact-form-option > .contact-form-input label {
        width: 100%;
        font-size: 4.27vw;
        line-height: 5.33vw;
        margin: 0 0 4vw;
        padding-left: 8vw;
    }

    .contact-form-option > .contact-form-input label[for="option7"] {
        display: none;
    }
        
    .checkmark {
        height: 5.33vw;
        width: 5.33vw;
        border: 0.13vw solid #000;
    }
    
    .checkmark:after {
        width: 2.67vw;
        height: 2.67vw;
    }
    
    .contact-form-textarea {
        margin: 0 0 8vw;
    }
    
    .contact-form-input > textarea {
        width: 100%;
        font-size: 4.27vw;
        line-height: 6.4vw;
        border: 0.13vw solid #000;
        padding: 3.47vw 5.33vw;
        height: 48vw;
      }
    
    .form-check {
        padding: 0;
        margin: 0 0 8vw 5.6vw;
    }
    
    .contact-agreement > label {
        font-size: 4.27vw;
        line-height: 5.33vw;
        padding-left: 8vw;
    }
        
    .contact-form-note {
        margin: 0 0 8vw;
    }
    
    .contact-form-note p {
        font-size: 3.73vw;
        line-height: 7.47vw;
        text-align: center;
    }
        
    input#submit {
        width: 58.67vw;
        height: 13.33vw;
        border-radius: 13.33vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
    }
    
    button[type=submit] {
        width: 58.67vw;
        height: 13.33vw;
        border-radius: 13.33vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
    }

    /* THANKS PAGE */
    
    #thanks {
        padding: 13.87vw 0 13.33vw;
    }
    
    .thanks-title {
        margin: 0 0 13.33vw;
    }
    
    .thanks-title h2 {
        font-size: 6.4vw;
        line-height: 8.53vw;
    }
    
    .thanks-text {
        margin: 0 0 13.33vw;
    }
    
    .thanks-text p {
        font-size: 3.73vw;
        line-height: 7.47vw;
        text-align: left;
    }
    
    .thanks-button a {
        width: 58.67vw;
        height: 13.33vw;
        border-radius: 13.33vw;
        font-size: 4.27vw;
        line-height: 13.33vw;
    }

    .split-mobile {
        display: block;
    }

    .split-desktop {
        display: none;
    }

    .mobile-only {
        display: inline-block;
        line-height: 1px !important;
        height: 1px;
        width: 3.2vw;
    }

    .desktop-only {
        display: none;
    }

    img.image-mobile {
        display: block;
    }

}