:root {
  --steel-blue: #3b99d9;
  --steel-blue-2: #2e80b6;
  --dark-khaki: #a8d069;
  --medium-sea-green: #30ad64;
  --light-sea-green: #25ccbf;
  --light-sea-green-2: #20ac99;
  --sandy-brown: #f8c740;
  --goldenrod: #e2a62b;
  --khaki: #face6a;
  --sandy-brown-2: #e4b962;
  --salmon: #fd7072;
  --indian-red: #cf404d;
  --tan: #d39f9a;
  --dim-gray: #735260;
  --indian-red-2: #af4173;
  --brown: #822e50;
  --tomato: #e64c40;
  --firebrick: #bf3a30;
  --salmon-2: #fc7d64;
  --white-smoke: #ecf0f1;
  --silver: #bec3c7;
  --dim-gray-2: #49647b;
  --dark-slate-gray: #2d3e4f;
  --dark-slate-gray-2: #404047;
  --white-smoke-2: #f0f0f0;
  --white-smoke-3: #edeff2;
  --cadet-blue: #668cad;
  --pale-turquoise: #bfe0ff;
  --light-sky-blue: #69b9ff;
  --dodger-blue: #2e9dff;
  --black: #192024;
  --dim-gray-3: #676770;
  --light-slate-gray: #8e8e9c;
}

.w-layout-hflex {
  flex-direction: row;
  align-items: flex-start;
  display: flex;
}

.w-layout-vflex {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

h1 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 38px;
  font-weight: 700;
  line-height: 44px;
}

h2 {
  color: #676770;
  text-align: center;
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 32px;
  font-weight: 300;
  line-height: 36px;
}

h3 {
  color: #676770;
  letter-spacing: 7px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 20px;
  font-weight: 300;
  line-height: 30px;
}

h4 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: 700;
  line-height: 24px;
}

h5 {
  color: #676770;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 20px;
  font-size: 18px;
  font-weight: 300;
  line-height: 20px;
}

h6 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
}

p {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 14px;
  font-weight: 300;
  line-height: 25px;
}

.button {
  color: #fff;
  text-align: center;
  letter-spacing: 2px;
  text-transform: uppercase;
  background-color: #69b9ff;
  border-radius: 4px;
  margin-left: 10px;
  margin-right: 10px;
  padding: 12px 30px;
  font-size: 16px;
  font-weight: 300;
  line-height: 21px;
  text-decoration: none;
  transition: background-color .3s;
  display: inline-block;
}

.button:hover {
  background-color: #2e9dff;
}

.button.w--current {
  background-color: #2e80b6;
}

.button.full-width {
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  display: block;
}

.button.tab {
  background-color: #92a0ad;
  border-radius: 8px 8px 0 0;
  margin-left: 1px;
  margin-right: 1px;
}

.button.tab:hover {
  background-color: #0376c9;
}

.button.tab.w--current {
  background-color: #0376c9;
  border-radius: 8px 8px 0 0;
  margin-left: 1px;
  margin-right: 1px;
}

.button.tab.w--current:hover {
  background-color: #0376c9;
}

.navigation-link {
  color: #000;
  padding: 10px 15px 8px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 21px;
  transition: all .3s ease-in-out;
  display: block;
  position: static;
}

.navigation-link:hover {
  color: #0276c9;
}

.navigation-link.w--current {
  color: #000;
  width: 75px;
  max-width: none;
  padding: 10px 15px 8px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 21px;
  display: block;
  position: static;
}

.navigation-link.w--current:hover {
  color: #0276c9;
}

.navigation-link.contact {
  width: 100px;
}

.navigation-link.ear {
  width: 75px;
}

.navigation-link.saarvice {
  width: 90px;
}

.navigation-link.contents {
  width: 160px;
  display: block;
}

.navigation-bar {
  background-color: #fff;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 15px;
  display: flex;
  position: fixed;
  box-shadow: 0 4px 4px #00000040;
}

.navigation-menu {
  justify-content: center;
  align-items: center;
  width: auto;
  max-width: none;
  display: inline-flex;
}

.brand-text {
  color: #69b9ff;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Open Sans, sans-serif;
  font-size: 25px;
  font-weight: 300;
  line-height: 25px;
}

.brand-link {
  padding-top: 16px;
  padding-bottom: 16px;
}

.brand-link.w--current {
  margin-right: 3%;
}

.section {
  text-align: center;
  background-color: #fff;
  border-top: 1px #e4ebf3;
  border-bottom: 1px #fff;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 80px 10px 40px;
  position: relative;
}

.section.accent {
  background-color: #fff;
}

.section.pickup {
  background-color: #fff;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
}

.section.flow {
  background-color: #f6fbfe;
}

.section.blue {
  background-color: #f6fbfe;
  background-image: url('../images/Group-103.svg');
  background-position: 50%;
  background-size: cover;
  border-top-style: solid;
  border-top-color: #e4ebf3;
  border-bottom-style: solid;
  border-bottom-color: #e4ebf3;
  margin-top: 0;
  margin-right: auto;
  padding-bottom: 80px;
}

.section.teikibintop {
  padding: 70px 0 0;
  display: block;
}

.section.teikibin {
  background-image: url('../images/bg.svg');
  background-position: 50%;
  background-size: cover;
  height: auto;
  padding: 70px 0 120px;
}

.white-box {
  text-align: center;
  background-color: #fff;
  border: 3px solid #0376c9;
  border-radius: 8px;
  padding: 50px 20px 20px;
  position: relative;
  box-shadow: 5px 5px 5px #0003;
}

.white-box.transparent {
  background-color: #fff0;
  border-style: none;
  border-radius: 8px;
  padding: 0;
}

.white-box.transparent.value {
  box-shadow: none;
  max-width: 100%;
}

.hero-section {
  padding-top: 242px;
  padding-bottom: 242px;
}

.hero-section.centered {
  text-align: center;
  background-image: linear-gradient(#2e9dff80, #2e9dff38), url('../images/photo-1416359658663-73a3834895eb.jpg');
  background-position: 0 0, 50%;
  background-size: auto, cover;
  border-bottom: 4px solid #69b9ff;
  padding-top: 195px;
  padding-bottom: 195px;
  display: none;
}

.hero-heading {
  color: #fff;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-bottom: 30px;
  font-size: 60px;
  font-weight: 300;
  line-height: 60px;
}

.hero-subheading {
  color: #2e9dff;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 40px;
  font-size: 25px;
  font-weight: 300;
  line-height: 25px;
}

.hollow-button {
  color: #fff;
  letter-spacing: 2px;
  text-transform: uppercase;
  border: 1px solid #fff;
  border-radius: 4px;
  margin-left: 10px;
  margin-right: 10px;
  padding: 10px 30px;
  font-weight: 300;
  line-height: 21px;
  text-decoration: none;
  transition: background-color .3s, border .3s, color .3s;
  display: inline-block;
}

.hollow-button:hover {
  color: #2e9dff;
  border-color: #2e9dff;
}

.hollow-button.all-caps {
  text-transform: uppercase;
}

.section-heading {
  margin-top: 0;
  margin-bottom: 16px;
}

.section-heading.centered {
  color: #000;
  text-align: center;
  letter-spacing: 5px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 30px;
  font-weight: 700;
}

.section-heading.centered.white {
  color: #fff;
}

.section-heading.centered.blue {
  color: #0376c9;
  line-height: 50px;
}

.section-heading.centered.flow {
  padding-bottom: 60px;
}

.section-subheading.center {
  color: #8e8e9c;
  text-align: center;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-size: 18px;
  font-weight: 300;
}

.section-subheading.center.off-white {
  color: #e8e8e8;
  padding-bottom: 0;
}

.section-title-group {
  margin-bottom: 40px;
}

.form-field {
  border: 0 solid #000;
  border-radius: 3px;
  height: 45px;
  margin-bottom: 17px;
  box-shadow: 0 0 0 1px #4040474d;
}

.form-field.text-area {
  height: 110px;
}

.footer {
  padding-top: 35px;
  padding-bottom: 35px;
}

.footer.center {
  text-align: center;
  background-color: #000;
  border-top: 1px solid #dbdbdb;
}

.footer.none {
  display: none;
}

.footer-text {
  color: #fff;
  margin-top: 5px;
  margin-bottom: 5px;
  font-size: 16px;
}

.grid-image {
  background-color: #69b9ff;
  border: 10px solid #fff;
  border-radius: 50%;
  width: 35%;
  margin: 20px auto;
  padding: 20px;
  display: block;
  box-shadow: 0 0 0 1px #2e9dff;
}

.info-icon {
  float: left;
}

.footer-link {
  color: #668cad;
  border-bottom: 1px solid #d5d5e0;
  margin-bottom: 6px;
  padding-bottom: 10px;
  font-size: 14px;
  font-weight: 300;
  text-decoration: none;
  display: block;
}

.footer-link:hover {
  color: #008cffd6;
}

.footer-link.with-icon {
  margin-left: 30px;
}

.tab-menu {
  text-align: center;
  margin-bottom: 0;
}

.tabs-wrapper {
  text-align: center;
}

.fullwidth-image {
  width: 100%;
  margin-bottom: 0;
  padding: 0 0 0 40px;
  display: block;
  position: relative;
}

.fullwidth-image.heart {
  height: 100%;
  padding-top: 10px;
  padding-left: 50px;
  padding-right: 50px;
}

.fullwidth-image.shadow {
  box-shadow: 5px 2px 5px #0003;
}

.fullwidth-image.flow, .fullwidth-image.support, .fullwidth-image.buy {
  padding-left: 0;
}

.fullwidth-image.buy.syuccyou {
  max-width: 338px;
}

.fullwidth-image.buy.syuccyou.none {
  display: block;
}

.fullwidth-image.value {
  height: auto;
  max-height: none;
  padding-left: 0;
  display: inline-block;
}

.fullwidth-image.box, .fullwidth-image.box.last {
  padding: 20px 40px;
}

.fullwidth-image.none {
  display: none;
}

.white-text {
  color: #fff;
  margin-bottom: 20px;
}

.form {
  margin-top: 40px;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

.column {
  padding-left: 0;
}

.container {
  border-color: #0376c9;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  max-width: 100%;
  display: flex;
}

.slide {
  width: 100%;
}

.slider {
  width: 100%;
  max-width: 960px;
  height: 360px;
  margin-left: auto;
  margin-right: auto;
  box-shadow: 5px 5px 5px #0003;
}

.body {
  background-color: #fff;
}

.pickuptext {
  font-size: 12px;
  line-height: 18px;
}

.tabs-content {
  width: 100%;
  max-width: 100%;
}

.container-2 {
  max-width: 100%;
}

.flex-block {
  background-color: #fff0;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 1100px;
  margin-top: 0;
  margin-left: auto;
  margin-right: auto;
  padding-top: 60px;
  padding-bottom: 60px;
}

.div-block {
  background-color: #0376c9;
  width: 100%;
  max-width: 100%;
}

.div-block-2 {
  background-color: #fff;
  border-radius: 8px;
  margin-left: 20px;
  margin-right: 20px;
  padding: 20px;
  box-shadow: 5px 5px 5px #0003;
}

.logos-without-title {
  background-color: #fff;
  border: 2px #000;
  padding: 30px;
  position: relative;
}

.container-3 {
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.clients-wrapper-three {
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: center;
  width: 100%;
  margin-bottom: -10px;
  display: flex;
}

.clients-image-three {
  width: 100%;
  max-width: 180px;
  margin-bottom: 10px;
  margin-left: 5px;
  margin-right: 5px;
  display: block;
}

.container-4 {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 100%;
  display: flex;
}

.container-4.spnav {
  display: none;
}

.paragraph {
  color: #000;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
  line-height: 28px;
}

.paragraph.title {
  margin: 0;
}

.paragraph-2, .paragraph-3 {
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
}

.heading {
  color: #000;
  font-family: Noto Sans JP, sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 26px;
}

.flowtitle {
  color: #000;
  margin-top: 20px;
  margin-bottom: 20px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 40px;
}

.column-2 {
  padding: 10px;
}

.bluebutton {
  background-color: #0376c9;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 180px;
  margin-top: 20px;
  margin-right: 20px;
  padding: 19px 0;
  font-family: Noto Sans JP, sans-serif;
  display: flex;
}

.bluebutton.red {
  text-align: left;
  background-color: #fc524c;
  flex-flow: column;
  margin-top: 0;
  display: flex;
}

.bluebutton.red.teikibin {
  margin-left: auto;
  margin-right: auto;
}

.bluebutton.red.top {
  margin-top: 20px;
}

.bluebutton.green {
  background-color: #01a700;
}

.bluebutton.syuccyou {
  color: #0376c9;
  background-color: #fff;
  border: 3px solid #0376c9;
}

.bluebutton.header {
  font-size: 12px;
  line-height: 18px;
}

.minibutton {
  color: #fff;
  background-color: #0376c9;
  border: 3px #0376c9;
  border-radius: 50px;
  width: 100%;
  padding: 15px 60px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
}

.minibutton.red {
  background-color: #fc524c;
}

.flowtext {
  color: #000;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 16px;
  font-weight: 600;
  line-height: 32px;
}

.flowtext.under {
  margin-top: 30px;
  padding-bottom: 20px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
}

.flowtext.top {
  padding-bottom: 20px;
  font-weight: 400;
}

.image {
  width: 100%;
  max-width: 14px;
  rotate: 270deg;
}

.div-block-3 {
  text-align: center;
  background-color: #0376c9;
}

.flex-block-2 {
  border: 3px solid #000;
  border-radius: 8px;
  height: 140px;
}

.column-3 {
  padding-left: 0;
  padding-right: 15px;
}

.column-4 {
  padding-left: 15px;
  padding-right: 0;
}

.topbutton {
  border: 3px solid #0376c9;
  border-radius: 8px;
  justify-content: space-between;
  width: 100%;
  display: flex;
}

.div-block-5 {
  justify-content: space-between;
  display: flex;
}

.div-block-6 {
  background-color: #0376c9;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 10%;
  display: flex;
}

.image-2 {
  width: 100%;
  max-width: 50%;
}

.div-block-7 {
  justify-content: center;
  align-items: center;
  display: flex;
}

.text-span {
  font-size: 48px;
}

.image-3 {
  display: block;
  position: absolute;
  inset: -13% 0% auto 40%;
}

.image-3.right-left {
  top: -10%;
  left: 40%;
}

.columns {
  width: 100%;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}

.image-4 {
  width: 100%;
  padding-left: 20px;
  padding-right: 20px;
  display: block;
}

.image-4.pc {
  padding-top: 60px;
}

.image-4.sp {
  display: none;
}

.image-5 {
  position: absolute;
  inset: 15% 0% auto 3.3%;
}

.image-5.none {
  display: none;
}

.imagebox {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  height: 150px;
  display: flex;
}

.columns-2 {
  width: 100%;
  max-width: 1100px;
  padding-top: 40px;
}

.column-5 {
  padding-left: 20px;
  padding-right: 20px;
}

.flex-block-3 {
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 40px;
}

.container-5 {
  max-width: 1100px;
}

.columns-3 {
  margin-top: 0;
}

.flex-block-4 {
  justify-content: center;
  align-items: center;
  padding-top: 40px;
  padding-bottom: 40px;
}

.comment {
  z-index: 2;
  margin-bottom: -15px;
  padding-bottom: 0;
  display: block;
  position: relative;
}

.comment.sp {
  display: none;
}

.image-6, .image-7 {
  display: block;
}

.column-6 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.column-12, .column-13.none {
  display: block;
}

.column-14.top, .column-15.top {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.columns-4.top {
  width: 100%;
  max-width: 1100px;
}

.flex-block-5 {
  justify-content: center;
  align-items: center;
  padding-bottom: 30px;
}

.flex-block-5.last {
  padding-bottom: 0;
}

.div-block-8 {
  border: 1px #000;
}

.div-block-9 {
  padding-top: 0;
}

.section-2 {
  border-top: 2px solid #e4ebf3;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 80px;
  padding-bottom: 80px;
}

.flex-block-6 {
  flex-flow: row;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  max-width: 30%;
}

.link-block {
  border: 2px solid #0376c9;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-width: 104px;
  max-width: 104px;
  height: 38px;
  margin-left: 10px;
  padding: 10px;
  text-decoration: none;
  display: flex;
}

.link-block.ec {
  color: #fff;
  background-color: #0376c9;
  border-style: none;
  min-width: 138px;
  max-width: 138px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
}

.link-block.shop {
  color: #fff;
  background-color: #fc524c;
  border-style: none;
}

.image-9 {
  width: 100%;
  max-width: 14px;
  margin-right: 5%;
}

.paragraph-4 {
  color: #0376c9;
  -webkit-text-stroke-color: #0376c9;
  margin-top: 0;
  margin-bottom: 0;
  margin-right: 5%;
  font-family: Noto Sans JP, sans-serif;
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
  text-decoration: none;
}

.paragraph-5 {
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
}

.paragraph-6 {
  font-family: Noto Sans JP, sans-serif;
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
}

.logoblock {
  width: auto;
  max-width: none;
  margin-right: 3%;
}

.div-block-10 {
  justify-content: flex-end;
  width: 100%;
  max-width: 30%;
  display: flex;
}

.div-block-11 {
  width: auto;
  max-width: none;
  display: block;
}

.image-10 {
  width: 100%;
  max-width: 224px;
  margin-right: 3%;
  display: block;
}

.div-block-12 {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 224px;
  display: flex;
}

.list {
  margin-bottom: 0;
  padding-left: 0;
  display: flex;
  overflow: visible;
}

.div-block-13 {
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.ec.sp, .shop.sp {
  display: none;
}

.text-block {
  font-family: Noto Sans JP, sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 21px;
}

.dropdown-toggle, .dropdown-toggle-2 {
  padding: 10px 15px 8px;
}

.dropdown-toggle-3 {
  z-index: 1;
  justify-content: space-between;
  padding: 10px 15px 8px;
  display: flex;
}

.dropdown-link {
  margin-bottom: 5px;
  margin-left: 0;
  padding: 5px 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 21px;
  display: block;
}

.dropdown-list {
  z-index: -1;
  width: 100%;
  max-width: 100%;
  position: absolute;
  inset: 56px auto 0% -100px;
}

.image-11 {
  width: 100%;
  max-width: 8px;
}

.flex-block-8 {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 100%;
  margin-right: 5%;
}

.icon-2.sp, .image-12.sp, .flex-block-9.sp, .sp {
  display: none;
}

.pcnav {
  background-color: #fff;
  width: 100vw;
  margin-top: 15px;
}

.div-block-14 {
  width: 100%;
  max-width: 140px;
  margin-left: 2vw;
  margin-right: 2vw;
}

.div-block-14.service {
  max-width: 220px;
}

.link-block-5 {
  color: #000;
  width: 100%;
  max-width: 140px;
  margin-left: 2.5vw;
  margin-right: 2.5vw;
  text-decoration: none;
}

.flex-block-10 {
  justify-content: space-between;
  align-items: center;
}

.image-14 {
  max-width: 8px;
}

.paragraph-9 {
  font-family: Noto Sans JP, sans-serif;
  font-weight: 700;
  line-height: 21px;
}

.flex-block-11 {
  background-color: #fff;
  justify-content: center;
  align-items: flex-start;
  width: 137vw;
  min-width: auto;
  max-width: none;
  margin-left: -50%;
  margin-right: 0%;
  padding: 40px 0 40px 0;
  position: absolute;
  box-shadow: inset 0 3px 3px #0003;
}

.flex-block-11.contact {
  margin-left: -45vw;
  padding-left: 0;
}

.flex-block-11.service {
  width: 137vw;
  margin-left: -57%;
  padding-left: 0;
}

.flex-block-11.glasses {
  margin-left: -42%;
}

.image-15 {
  width: 100%;
}

.dropdown-list-2 {
  background-color: #fff;
}

.link-block-6 {
  color: #000;
  font-family: Noto Sans JP, sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 21px;
  text-decoration: none;
  display: block;
}

.paragraph-10 {
  color: #000;
  margin-top: 0;
  margin-bottom: 0;
  padding-bottom: 80px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 36px;
}

.image-16 {
  width: 100%;
  height: auto;
}

.heading-2 {
  z-index: -999;
  color: #6a859c00;
  position: absolute;
}

.utility-page-form {
  flex-direction: column;
  align-items: stretch;
  display: flex;
}

.image-17 {
  width: 100%;
}

.section-3 {
  padding-top: 80px;
}

.section-registration {
  border: 1px #000;
  width: 100%;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
  padding-top: 80px;
  transition: opacity .2s;
  transform: rotate(0);
}

.div-block-15 {
  flex-flow: column;
  width: auto;
  max-width: none;
  height: auto;
  padding-bottom: 100px;
  display: flex;
}

.div-block-16 {
  background-color: #199c5b;
  background-image: url('../images/houseline.svg');
  background-position: 50% 100%;
  background-repeat: no-repeat;
  background-size: auto;
  height: auto;
  padding-top: 0;
  padding-bottom: 0;
}

.div-block-16.none {
  display: none;
}

.heading-3 {
  color: #fff;
  text-align: center;
  margin-bottom: 0;
  padding-top: 10px;
  padding-bottom: 100px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 700;
}

.mypagetext {
  color: #000;
  text-align: center;
  margin-top: 0;
  margin-bottom: 60px;
  padding-top: 60px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 400;
  line-height: 40px;
}

.div-block-17 {
  border: 3px solid #199c5b;
  border-radius: 3px;
}

.link-block-7 {
  border: 3px solid #199c5b;
  border-radius: 8px;
  justify-content: space-between;
  align-items: stretch;
  width: 100%;
  max-width: 760px;
  margin-bottom: 20px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.flex-block-12 {
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 100%;
  display: flex;
}

.link-block-8 {
  background-color: #fff;
  border: 3px solid #199c5b;
  border-radius: 8px;
  justify-content: space-between;
  width: 100%;
  max-width: 50%;
  margin-left: 10px;
  margin-right: 10px;
  display: flex;
}

.image-18 {
  width: 100%;
  max-width: 90%;
  padding: 20px;
}

.div-block-18 {
  flex-flow: column;
  width: 100%;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 100px;
  display: flex;
}

.image-19 {
  width: 100%;
  max-width: 90%;
  margin-left: 0;
  margin-right: 0;
  padding: 20px 100px;
}

.div-block-19 {
  background-color: #199c5b;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 30px;
  display: flex;
}

.image-20 {
  width: 100%;
  max-width: 70%;
  transition: opacity .2s;
  transform: rotate(90deg);
}

.heading-4 {
  color: #000;
  text-align: center;
  margin-bottom: 0;
  padding-bottom: 60px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 30px;
  line-height: 36px;
}

.image-21 {
  width: 200%;
  max-width: 150%;
  overflow: hidden;
}

.link-block-9 {
  width: 100%;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 60px;
  padding-left: 40px;
  padding-right: 40px;
  display: block;
}

.link-block-9:hover {
  cursor: pointer;
}

.link-block-9.mypage {
  cursor: default;
}

.paragraph-11 {
  color: #fff;
  text-align: center;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  margin-top: 60px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 18px;
  font-weight: 700;
  text-decoration: underline;
  display: flex;
}

.image-22 {
  width: 100%;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 80px;
  display: block;
}

.tabs-menu {
  z-index: 999;
  justify-content: center;
  align-items: center;
  margin: -80px auto -3px;
  display: flex;
}

.section-4 {
  background-color: #5c4e4e;
}

.text-block-2 {
  color: #000;
  text-align: center;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 600;
  line-height: 24px;
}

.text-block-2:active {
  color: #000;
}

.tabteikibin {
  z-index: auto;
  -webkit-text-stroke-color: #92a0ad;
  background-color: #ddd;
  border: 3px solid #000;
  border-bottom-width: 0;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  justify-content: center;
  align-items: center;
  height: 80px;
  margin-left: 1px;
  margin-right: 1px;
  display: flex;
}

.tabteikibin.w--current {
  color: #000;
  background-color: #fff;
  border-top: 3px solid #000;
  border-left: 3px solid #000;
  border-right: 3px solid #000;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  justify-content: center;
  align-items: center;
  height: 80px;
  margin-left: 2px;
  margin-right: 2px;
  display: flex;
}

.text-block-3 {
  text-align: center;
}

.image-23 {
  width: 100%;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 100px;
  padding-bottom: 0;
  display: block;
}

.whitebg {
  border-top: 3px solid #000;
  padding-top: 100px;
  padding-left: 0;
  padding-right: 0;
}

.image-24 {
  width: 100%;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 60px;
  display: block;
}

.image-24.title2 {
  padding-top: 40px;
}

.lightbluebg {
  background-color: #e0f1f9;
  border: 3px #000;
  border-radius: 60px;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 0 60px 60px;
}

.div-block-22 {
  justify-content: space-around;
  align-items: center;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 40px 10px;
  display: flex;
}

.div-block-22.check {
  flex-flow: column;
  justify-content: space-around;
  align-items: center;
  max-width: 80%;
}

.div-block-22.delivery {
  flex-flow: column;
  max-width: 70%;
}

.courseteikibin {
  width: 100%;
  max-width: 90%;
  padding-left: 30px;
  padding-right: 30px;
}

.image-26 {
  width: 100%;
  max-width: 50%;
}

.courseteikibinblock {
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 50%;
}

.courseteikibinblock.blue {
  padding-right: 60px;
}

.courseteikibinblock.yellow {
  padding-left: 60px;
}

.attentionteikibin {
  color: #000;
  text-align: right;
  margin-top: 0;
  margin-bottom: 0;
  padding-bottom: 10px;
  padding-right: 10px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 12px;
  font-weight: 400;
  line-height: 20px;
}

.attentionteikibin.flow {
  text-align: left;
  align-items: flex-end;
  padding-top: 10px;
  padding-bottom: 0;
  padding-right: 0;
  display: flex;
}

.attentionteikibin.campaign {
  text-align: left;
  padding-top: 20px;
  padding-left: 0;
  padding-right: 0;
  display: none;
}

.attentionteikibin.case {
  text-align: left;
  padding-top: 20px;
  padding-bottom: 0;
  padding-right: 0;
}

.attentionteikibin.top {
  padding-top: 10px;
  padding-bottom: 0;
  padding-right: 0;
}

.coursetitle1 {
  color: #000;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 40px;
  padding-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 40px;
}

.coursetitle1.example {
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.pointblock {
  background-color: #fff;
  border: 3px #000;
  border-radius: 3px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 100%;
  padding-top: 0;
  padding-bottom: 0;
  display: flex;
}

.pointblock.mini {
  background-color: #fff;
  border: 3px solid #000;
  border-radius: 8px;
  max-width: 48%;
  margin-left: 0;
  margin-right: 0;
}

.pointblock.mini.case {
  background-color: #fff;
  justify-content: center;
  align-items: center;
  max-width: 100%;
  margin-bottom: 20px;
  margin-left: 0;
  margin-right: 0;
  position: relative;
}

.pointblock.sec02 {
  background-color: #0376c9;
  border-radius: 3px 3px 0 0;
  justify-content: center;
  align-items: center;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.value {
  width: 100%;
  max-width: 80%;
  padding-top: 30px;
  padding-bottom: 30px;
}

.value.line {
  max-width: 60%;
}

.pointteikibin {
  z-index: 3;
  color: #fff;
  text-align: center;
  background-color: #0376c9;
  border-top-left-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 20%;
  height: 80px;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 20px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 18px;
  font-weight: 600;
  display: flex;
  position: relative;
}

.pointteikibin.sec02 {
  background-color: #0376c900;
  max-width: 100%;
  height: auto;
  padding-left: 0;
}

.valueblock {
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 90%;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
}

.pointtitle {
  z-index: 999;
  background-color: #fff;
  border: 3px solid #000;
  border-radius: 8px;
  margin-bottom: 0;
  padding-bottom: 0;
  position: static;
}

.pointtitle.case {
  flex-flow: column;
  width: 100%;
  max-width: 600px;
  margin-bottom: 20px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.pointtitle.flow {
  margin-bottom: 20px;
}

.pointtitle.course {
  padding-bottom: 40px;
}

.cube {
  background-color: #0376c9;
  margin-left: -30px;
  padding: 29px;
  position: static;
  transform: rotate(45deg);
}

.flex-block-13 {
  padding-top: 40px;
  padding-bottom: 40px;
}

.image-27 {
  width: 100%;
  max-width: 3.3%;
}

.div-block-23 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  padding-top: 40px;
  padding-bottom: 40px;
  display: flex;
}

.teikibincoursetext {
  color: #000;
  margin-top: 5px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 700;
}

.teikibintext {
  color: #000;
  margin-top: 0;
  margin-bottom: 40px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 18px;
  font-weight: 400;
}

.paragraph-13 {
  text-align: center;
}

.div-block-24 {
  width: 100%;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}

.coursetitle2 {
  color: #000;
  text-align: center;
  margin: 0 auto 40px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 30px;
  font-weight: 600;
  line-height: 48px;
}

.coursetitle2.example {
  position: absolute;
  inset: -2% 0% auto;
}

.coursedescription {
  color: #000;
  text-align: center;
  background-color: #91d2e5;
  border-radius: 8px;
  margin-top: 40px;
  margin-bottom: 0;
  padding: 20px 40px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 400;
  line-height: 30px;
}

.coursedescription.yellow {
  background-color: #ffe450;
  border-radius: 8px;
  padding: 20px 40px;
}

.casecloud {
  max-width: 25%;
  position: absolute;
  inset: -13% auto auto -5%;
}

.image-29 {
  width: 100%;
  max-width: 70%;
  margin-left: auto;
  margin-right: auto;
  padding-top: 20px;
  padding-bottom: 20px;
}

.image-30 {
  position: absolute;
}

.flex-block-14 {
  justify-content: space-between;
}

.flex-block-14.merit {
  padding-bottom: 40px;
}

.teikibinsection {
  width: 100%;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

.teikibinsection.merit, .teikibinsection.flow {
  max-width: 960px;
  padding-top: 100px;
}

.teikibinsection.solution {
  max-width: 1100px;
}

.teikibinsection.info {
  cursor: auto;
  padding-top: 100px;
  padding-bottom: 100px;
}

.tekibinhukidashi {
  color: #000;
  text-align: center;
  margin-top: 0;
  padding-top: 100px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 20px;
}

.tekibinhukidashi.img {
  width: 100%;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 50px;
  padding-bottom: 0;
  display: block;
}

.casetext {
  color: #000;
  text-align: center;
  margin-bottom: 60px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 32px;
}

.casetext._2 {
  text-align: left;
  margin-bottom: 0;
}

.paragraph-15 {
  color: #000;
  text-align: center;
  margin-top: 0;
  margin-bottom: 10px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 40px;
}

.heading-5 {
  opacity: 0;
}

.div-block-25 {
  width: 100%;
  max-width: 48%;
}

.pointhukidashi {
  color: #0376c9;
  text-align: center;
  margin-top: 0;
  margin-bottom: 10px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 600;
  line-height: 14px;
}

.pointlabel {
  color: #000;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 600;
}

.div-block-26 {
  flex-flow: column;
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.paragraph-16 {
  font-weight: 600;
}

.div-block-27 {
  justify-content: space-around;
  display: flex;
}

.div-block-27.flow {
  padding: 40px 100px;
}

.paragraph-17 {
  color: #0376c9;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 40px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
  text-decoration: none;
}

.flex-block-15 {
  width: 100%;
  max-width: 25%;
}

.div-block-28 {
  border: 3px solid #0376c9;
  border-radius: 8px;
  width: 100%;
  max-width: 100%;
  height: auto;
  margin-left: 10px;
  margin-right: 10px;
  padding: 10px;
}

.div-block-28.height {
  height: 350px;
}

.paragraph-18 {
  color: #fff;
  text-align: center;
  background-color: #0376c9;
  border-radius: 50px;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 10px;
  padding-bottom: 10px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 600;
}

.paragraph-19 {
  color: #000;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 16px;
  font-weight: 600;
}

.paragraph-19.course {
  margin-top: 20px;
  margin-bottom: 10px;
}

.paragraph-20 {
  color: #000;
  text-align: center;
  background-color: #91d2e5;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
}

.paragraph-20.blue {
  background-color: #ffe450;
  border-radius: 8px;
  padding: 10px;
}

.paragraph-20.yellow {
  background-color: #91d2e5;
  border-radius: 8px;
  margin-bottom: 0;
}

.paragraph-21 {
  text-align: center;
  background-color: #0376c9;
  border-radius: 30px;
  width: 100%;
  max-width: 80%;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 10px;
  padding-bottom: 10px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 600;
}

.paragraph-22 {
  color: #000;
  width: 100%;
  max-width: 75%;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 32px;
}

.flex-block-16 {
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 100%;
}

.flex-block-16.first {
  padding-bottom: 40px;
}

.div-block-29 {
  color: #fff;
  background-color: #fff;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 25%;
  display: flex;
}

.div-block-30 {
  justify-content: center;
  align-items: center;
  padding-bottom: 40px;
  display: flex;
}

.flex-block-17 {
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 10px;
}

.image-31 {
  width: 100%;
  max-width: 50%;
}

.image-31.ec {
  max-width: 100%;
}

.image-31.shop {
  max-width: 80%;
}

.link-block-10 {
  width: 100%;
  max-width: 50%;
}

.link {
  color: #000;
  cursor: pointer;
  padding-bottom: 20px;
  font-family: Noto Sans JP, sans-serif;
  font-weight: 400;
  line-height: 32px;
  text-decoration: underline;
  display: inline;
}

.link.last {
  padding-bottom: 0;
}

.link.date {
  font-size: 16px;
  text-decoration: none;
}

.infoblock {
  cursor: pointer;
  padding-bottom: 20px;
  padding-left: 20px;
  padding-right: 20px;
}

.infoblock:hover {
  opacity: .7;
  cursor: pointer;
}

.infoblock.last {
  padding-bottom: 0;
}

.tab-pane-tab-2 {
  border-top: 3px solid #000;
}

.image-32 {
  z-index: 1;
  background-color: #0376c9;
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
  width: 100%;
  max-width: 20%;
  padding: 40px 20px;
  position: relative;
}

.image-32.last {
  max-width: 10%;
  padding-top: 100px;
  padding-bottom: 100px;
}

.link-block-11 {
  color: #0376c9;
  cursor: pointer;
}

.div-block-31 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  height: 230px;
  display: flex;
}

.image-34 {
  width: 50px;
  margin-bottom: 20px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.image-35 {
  width: 100%;
  max-width: 10%;
  position: absolute;
  inset: -28% auto auto -2%;
}

.link-block-12 {
  width: 100%;
  max-width: 50%;
}

.link-block-14 {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 50%;
  display: flex;
}

.div-block-32 {
  width: 100%;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

.div-block-33 {
  background-color: #ffe450;
  border-radius: 8px;
  width: 100%;
  max-width: 70%;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  position: absolute;
  inset: -13% 0% auto;
}

.div-block-33.blue {
  background-color: #8bd1e5;
}

.paragraph-23 {
  color: #000;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 16px;
}

.paragraph-24 {
  color: #000;
  text-align: center;
  margin-top: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 20px;
}

.div-block-34 {
  background-color: #e0f1f9;
  border-radius: 8px;
  width: 100%;
  max-width: 90%;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 40px;
  position: relative;
}

.div-block-35 {
  background-color: #fff;
  border-radius: 8px;
  width: 100%;
  max-width: 90%;
  margin-bottom: 100px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 40px;
  padding-bottom: 40px;
  position: relative;
}

.div-block-35.last {
  margin-bottom: 0;
  padding-top: 40px;
}

.lensbox {
  width: 100%;
  max-width: 50%;
  margin-left: auto;
  margin-right: auto;
  padding-top: 20px;
  padding-bottom: 20px;
  display: block;
}

.flex-block-18 {
  justify-content: center;
  align-items: flex-end;
  padding-top: 0;
}

.paragraph-25 {
  color: #000;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Noto Sans JP, sans-serif;
  font-size: 30px;
  font-weight: 600;
  line-height: 30px;
}

.paragraph-26 {
  color: #000;
  margin-top: 0;
  margin-bottom: 0;
  padding-left: 5px;
  font-family: Noto Sans JP, sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 18px;
}

.price {
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.div-block-36 {
  padding-top: 60px;
  padding-bottom: 90px;
}

.image-36 {
  width: 100%;
  max-width: 90%;
  margin-left: auto;
  margin-right: auto;
  padding-top: 0%;
  display: block;
}

.image-37 {
  display: none;
}

.image-38 {
  display: block;
}

.image-39 {
  width: 100%;
  max-width: 270px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 25px;
  padding-bottom: 25px;
  display: block;
}

.image-41 {
  width: 100%;
}

.image-42 {
  width: 100%;
  max-width: 70%;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.paragraph-27 {
  margin-bottom: 0;
}

.image-43 {
  display: none;
}

@media screen and (min-width: 1920px) {
  .flex-block-11.service {
    margin-left: -54%;
  }
}

@media screen and (max-width: 991px) {
  .navigation-link {
    color: #ffffff85;
  }

  .navigation-link.w--current {
    color: #000;
    -webkit-text-stroke-color: black;
    border: 1px #000;
    width: 100%;
    max-width: 100%;
    padding: 15px 0;
    font-size: 16px;
    line-height: 24px;
  }

  .navigation-link.contact {
    color: #000;
    width: 100%;
    max-width: 100%;
    padding: 15px 0;
    font-size: 16px;
    line-height: 24px;
  }

  .navigation-link.ear {
    color: #000;
    width: 100%;
    max-width: 100%;
    padding: 15px 0;
    font-size: 14px;
    line-height: 24px;
  }

  .navigation-link.saarvice {
    color: #000;
    width: 100%;
    max-width: 100%;
    padding: 15px 0;
    font-size: 16px;
    line-height: 24px;
  }

  .navigation-link.contents {
    color: #000;
    width: 100%;
    max-width: 100%;
    padding: 15px 0;
    font-size: 14px;
    line-height: 24px;
    display: block;
  }

  .navigation-bar, .hamburger-button {
    padding: 0;
  }

  .hamburger-button:active {
    background-color: #fff;
  }

  .hamburger-button.w--open {
    background-color: #3b99d9;
  }

  .navigation-menu {
    z-index: auto;
    background-color: #ecf2f6;
    flex-flow: column;
    height: 100vh;
    padding-left: 15px;
    padding-right: 15px;
    display: flex;
    overflow: auto;
    box-shadow: inset 0 4px 4px #0003;
  }

  .section {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }

  .section.pickup {
    padding-top: 8vw;
    padding-bottom: 0;
  }

  .section.blue {
    margin-right: auto;
    padding-top: 8vw;
    padding-bottom: 8vw;
  }

  .section.teikibin {
    z-index: -3;
    background-size: cover;
    padding-top: 10px;
    padding-bottom: 60px;
  }

  .white-box {
    padding: 2vw 1vw;
  }

  .hero-section.centered {
    padding-top: 144px;
    padding-bottom: 144px;
  }

  .section-heading.centered {
    font-size: 24px;
    line-height: 48px;
  }

  .section-heading.centered.blue {
    line-height: 40px;
  }

  .section-heading.centered.flow {
    padding-bottom: 4vw;
  }

  .section-title-group {
    margin-bottom: 3vw;
  }

  .grid-image {
    width: 50%;
    padding: 15px;
  }

  .tab-menu {
    justify-content: center;
    align-items: flex-end;
    display: flex;
  }

  .fullwidth-image {
    padding-left: 2vw;
  }

  .fullwidth-image.heart {
    padding-top: 3.5vw;
    padding-left: 5vw;
    padding-right: 40px;
  }

  .fullwidth-image.buy.syuccyou {
    max-width: 30vw;
  }

  .fullwidth-image.box {
    padding: 0;
  }

  .container {
    padding-left: 0;
    padding-right: 0;
  }

  .slider {
    height: auto;
  }

  .flex-block {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }

  .div-block-2 {
    margin-left: 1vw;
    margin-right: 1vw;
    padding: 3vw 1vw;
  }

  .logos-without-title {
    padding: 20px 0;
  }

  .container-3 {
    max-width: 728px;
  }

  .clients-wrapper-three {
    justify-content: center;
    margin-bottom: 0;
  }

  .clients-image-three {
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .container-4 {
    justify-content: space-between;
    align-items: center;
    padding: 15px;
  }

  .container-4.pc {
    display: block;
  }

  .container-4.spnav {
    display: inline-flex;
  }

  .paragraph {
    font-size: 13px;
  }

  .heading {
    font-size: 14px;
    line-height: 28px;
  }

  .flowtitle {
    margin-top: 0;
    margin-bottom: 1vw;
    font-size: 16px;
  }

  .bluebutton {
    margin-left: 10px;
    margin-right: 10px;
  }

  .minibutton {
    padding-left: 20px;
    padding-right: 20px;
    display: block;
  }

  .flowtext.under {
    margin-top: 3vw;
    margin-bottom: 2vw;
    padding-bottom: 0;
  }

  .flowtext.top {
    padding-bottom: 2vw;
  }

  .text-span {
    font-size: 40px;
  }

  .image-3, .image-3.right-left {
    width: 100%;
    max-width: 23%;
    inset: -5vw 0% auto 40%;
  }

  .image-3.right-left.right {
    margin-top: 0;
    padding-top: 0;
    position: absolute;
    inset: -5vw 0% auto 40%;
  }

  .image-4 {
    max-width: 50%;
    padding-left: 10px;
    padding-right: 10px;
  }

  .image-4.pc {
    max-width: 100%;
    padding-top: 8vw;
  }

  .image-5 {
    width: 100%;
    max-width: 14%;
    padding-left: 0;
    display: block;
    top: 2vw;
    left: 0;
    right: 10%;
  }

  .imagebox {
    padding-top: 0;
  }

  .column-5 {
    padding-left: 1vw;
    padding-right: 1vw;
  }

  .flex-block-3 {
    padding-bottom: 8vw;
    padding-left: 1.5vw;
    padding-right: 1.5vw;
  }

  .container-5 {
    padding-left: 1.5vw;
    padding-right: 1.5vw;
  }

  .comment {
    margin-bottom: -1.5vw;
  }

  .column-6, .column-7, .column-8, .column-9, .column-10, .column-11 {
    padding-left: 1vw;
    padding-right: 1vw;
  }

  .column-12, .column-13 {
    padding-left: 1.5vw;
    padding-right: 1.5vw;
  }

  .image-8 {
    width: 100%;
    max-width: 30vw;
  }

  .column-14 {
    padding-left: 1vw;
    padding-right: 0;
  }

  .column-15 {
    padding-left: 0;
    padding-right: 1vw;
  }

  .columns-4 {
    padding-left: 1.5vw;
    padding-right: 1.5vw;
  }

  .flex-block-5 {
    padding-bottom: 2vw;
  }

  .div-block-8 {
    border-bottom: 2px solid #e4ebf3;
  }

  .div-block-9 {
    padding-top: 8vw;
  }

  .section-2 {
    border-top-width: 1px;
    padding-top: 5vw;
    padding-bottom: 5vw;
  }

  .link-block.ec.pc, .link-block.pc, .div-block-10.pc {
    display: none;
  }

  .image-10 {
    max-width: 105px;
    margin-right: 5%;
  }

  .image-10.ec, .image-10.shop {
    max-width: 16px;
    margin-right: 5px;
  }

  .list {
    background-color: #0000;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    padding-bottom: 40px;
    overflow: auto;
  }

  .div-block-13 {
    width: 100%;
    max-width: 100%;
  }

  .icon {
    -webkit-text-fill-color: #0376c9;
    background-color: #fff;
  }

  .ec {
    justify-content: center;
    align-items: center;
    margin-right: 15px;
    text-decoration: none;
    display: flex;
  }

  .ec.sp {
    margin-right: 10px;
    display: flex;
  }

  .shop {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .shop.sp {
    text-decoration: none;
    display: flex;
  }

  .paragraph-7, .paragraph-8 {
    color: #000;
    margin-top: 0;
    margin-bottom: 0;
    font-family: Noto Sans JP, sans-serif;
    font-size: 12px;
    font-weight: 700;
    line-height: 18px;
  }

  .list-item {
    border-bottom: 1px solid #000;
    width: 100%;
    max-width: 100%;
  }

  .list-item.sp {
    display: block;
  }

  .text-block {
    width: 100%;
    max-width: 100%;
    margin-right: auto;
    font-family: Noto Sans JP, sans-serif;
    font-weight: 700;
    line-height: 24px;
    display: inline;
  }

  .dropdown {
    display: block;
  }

  .dropdown-toggle, .dropdown-toggle-2, .dropdown-toggle-3 {
    padding: 15px 0;
  }

  .dropdown-link {
    background-color: #ecf2f6;
    justify-content: flex-start;
    align-items: center;
    margin-left: 0;
    margin-right: auto;
    padding-top: 8px;
    padding-bottom: 8px;
    padding-right: 0;
    font-family: Noto Sans JP, sans-serif;
    font-size: 14px;
    font-weight: 700;
    line-height: 28px;
    display: flex;
  }

  .dropdown-link.last {
    padding-bottom: 0;
  }

  .dropdown-list {
    z-index: 0;
    margin-bottom: 0;
    padding-bottom: 30px;
    inset: auto;
  }

  .flex-block-7 {
    justify-content: space-between;
  }

  .image-11 {
    width: Infinity% ;
    vertical-align: baseline;
    display: inline;
  }

  .flex-block-8 {
    background-color: #ecf2f6;
    justify-content: flex-start;
    align-items: center;
    padding-left: 20px;
  }

  .flex-block-8.last {
    margin-bottom: 30px;
  }

  .icon-2 {
    margin-right: 0;
    display: block;
  }

  .icon-2.sp {
    display: block;
  }

  .image-12 {
    width: 100%;
    max-width: 290px;
    margin-top: 30px;
    margin-left: auto;
    margin-right: auto;
  }

  .image-12.sp {
    margin-top: 0;
    display: block;
  }

  .flex-block-9 {
    justify-content: center;
    align-items: center;
    margin-top: 20px;
    padding-top: 20px;
  }

  .flex-block-9.sp {
    margin-top: 0;
    padding-bottom: 20px;
    display: block;
    overflow: auto;
  }

  .link-block-2 {
    width: 100%;
    max-width: 35px;
    margin-left: 13px;
    margin-right: 13px;
  }

  .link-block-3 {
    width: 100%;
    max-width: 50px;
    margin-left: 13px;
    margin-right: 13px;
  }

  .link-block-4 {
    width: 100%;
    max-width: 35px;
    margin-left: 13px;
    margin-right: 13px;
  }

  .image-13 {
    width: 100%;
    max-width: 8px;
    margin-left: auto;
  }

  .sp {
    display: block;
  }

  .sp.registration, .pcnav {
    display: none;
  }

  .dropdown-link-2 {
    margin-left: 0;
    padding: 8px 0;
    font-family: Noto Sans JP, sans-serif;
    font-size: 14px;
    font-weight: 700;
    line-height: 28px;
    text-decoration: none;
  }

  .dropdown-link-2.last {
    margin-bottom: 0;
  }

  .dropdown-list-2 {
    background-color: #ecf2f6;
    padding-bottom: 0;
  }

  .dropdown-list-2.last {
    padding-bottom: 0;
  }

  .link-block-6 {
    color: #000;
    text-decoration: none;
  }

  .paragraph-10 {
    padding-left: 10px;
    padding-right: 0;
  }

  .paragraph-10.pc {
    font-size: 16px;
    line-height: 32px;
  }

  .paragraph-10.sp {
    display: none;
  }

  .section-registration {
    padding-top: 60px;
    padding-left: 10px;
    padding-right: 10px;
  }

  .div-block-15 {
    padding-bottom: 8vw;
  }

  .heading-3 {
    padding-top: 1vw;
    padding-bottom: 8vw;
    font-size: 36px;
  }

  .mypagetext {
    margin-bottom: 6vw;
    padding-top: 6vw;
  }

  .div-block-18 {
    text-transform: none;
    padding-bottom: 8vw;
  }

  .link-block-9 {
    padding-top: 6vw;
    padding-left: 20px;
    padding-right: 20px;
  }

  .image-22 {
    max-width: 65vw;
    padding-top: 8vw;
  }

  .tabs-menu {
    margin-top: -60px;
  }

  .text-block-2 {
    font-size: 14px;
    line-height: 21px;
  }

  .tabteikibin, .tabteikibin.w--current {
    height: 60px;
  }

  .image-23 {
    max-width: 60%;
  }

  .whitebg {
    padding-top: 60px;
  }

  .image-24 {
    padding-bottom: 40px;
    padding-left: 10vw;
    padding-right: 10vw;
  }

  .lightbluebg {
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .div-block-22 {
    display: block;
  }

  .div-block-22.check {
    max-width: 90%;
    display: flex;
  }

  .div-block-22.delivery, .courseteikibin {
    max-width: 100%;
  }

  .courseteikibinblock.blue {
    padding-left: 10px;
    padding-right: 5vw;
  }

  .courseteikibinblock.yellow {
    padding-left: 5vw;
    padding-right: 10px;
  }

  .attentionteikibin.flow {
    text-align: left;
    justify-content: center;
    align-items: flex-end;
  }

  .coursetitle1 {
    font-size: 18px;
    line-height: 30px;
  }

  .pointtitle {
    padding-bottom: 0;
  }

  .pointtitle.course {
    padding-bottom: 40px;
  }

  .coursetitle2 {
    font-size: 24px;
    line-height: 35px;
  }

  .coursetitle2.example {
    top: -2%;
  }

  .coursedescription, .coursedescription.yellow {
    font-size: 16px;
  }

  .flex-block-14.merit {
    padding-bottom: 30px;
  }

  .teikibinsection.merit, .teikibinsection.flow {
    padding-top: 80px;
  }

  .tekibinhukidashi {
    margin-bottom: 20px;
    padding-top: 80px;
  }

  .tekibinhukidashi.img {
    margin-bottom: 0;
  }

  .casetext {
    font-size: 14px;
    line-height: 28px;
  }

  .casetext.sp {
    display: none;
  }

  .paragraph-15 {
    font-size: 18px;
    line-height: 36px;
  }

  .pointhukidashi.sp {
    display: none;
  }

  .pointlabel {
    font-size: 18px;
  }

  .paragraph-17.sp {
    display: none;
  }

  .flex-block-15 {
    max-width: 100%;
    margin-bottom: 40px;
  }

  .div-block-28 {
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
    padding: 20px;
  }

  .div-block-28.height {
    height: auto;
    padding-top: 20px;
  }

  .paragraph-19.course {
    margin-top: 40px;
  }

  .flex-block-17 {
    padding-left: 0;
    padding-right: 0;
  }

  .div-block-31 {
    height: auto;
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .image-35 {
    max-width: 10%;
    top: -23%;
    left: -5%;
  }

  .div-block-32 {
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .div-block-35 {
    margin-bottom: 90px;
    padding-top: 43px;
  }

  .paragraph-25 {
    font-size: 24px;
    line-height: 24px;
  }

  .price {
    width: 100%;
    max-width: 250px;
  }

  .div-block-36 {
    padding-bottom: 80px;
  }

  .image-39 {
    max-width: 230px;
    padding-top: 30px;
    padding-bottom: 30px;
  }

  .image-40.sp {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .button.full-width {
    margin-left: auto;
    margin-right: auto;
  }

  .button.tab {
    padding: 10px 20px;
    font-size: 12px;
    display: inline-block;
  }

  .section {
    padding: 10vw 0;
  }

  .section.pickup {
    padding-top: 10vw;
    padding-bottom: 0;
  }

  .section.flow {
    padding-left: 0;
    padding-right: 0;
  }

  .section.blue {
    background-image: url('../images/back_sp.svg');
    background-position: 50%;
    background-size: cover;
    margin-right: auto;
    padding: 10vw 6%;
  }

  .section.blue.support {
    margin-right: auto;
  }

  .section.buy {
    padding: 10vw 6%;
  }

  .section.teikibin {
    background-size: cover;
    padding-bottom: 0;
  }

  .white-box {
    margin-bottom: 30px;
  }

  .white-box.flow {
    margin-bottom: 15vw;
    margin-left: 6%;
    margin-right: 6%;
    padding: 10vw 10vw 3vw;
  }

  .white-box.flow.last {
    margin-bottom: 10vw;
  }

  .hero-section.centered {
    padding-top: 119px;
    padding-bottom: 119px;
  }

  .hero-heading {
    margin-bottom: 15px;
    font-size: 50px;
  }

  .hero-subheading {
    font-size: 18px;
  }

  .section-heading.centered {
    line-height: 36px;
  }

  .section-heading.centered.flow {
    padding-bottom: 10vw;
  }

  .section-title-group {
    margin-bottom: 5vw;
  }

  .form-field.text-area {
    display: block;
  }

  .footer-text {
    font-size: 10px;
    line-height: 15px;
  }

  .grid-image {
    width: 20%;
    padding: 20px;
  }

  .fullwidth-image {
    min-width: auto;
    max-width: 100%;
    padding-left: 0;
  }

  .fullwidth-image.heart {
    min-width: 300px;
    max-width: 180px;
    padding-right: 5vw;
  }

  .fullwidth-image.flow {
    min-width: auto;
    max-width: 400px;
    padding-left: 0;
    padding-right: 0;
  }

  .fullwidth-image.support, .fullwidth-image.buy {
    max-width: 70vw;
    margin-left: auto;
    margin-right: auto;
  }

  .fullwidth-image.buy.syuccyou {
    max-width: 70vw;
  }

  .fullwidth-image.box {
    min-width: auto;
    padding-left: 15vw;
    padding-right: 15vw;
  }

  .fullwidth-image.none {
    display: none;
  }

  .spc {
    margin-bottom: 30px;
  }

  .container._4-5 {
    padding-left: 0;
  }

  .flex-block {
    flex-flow: column;
  }

  .flex-block.pickup {
    padding-top: 5vw;
    padding-bottom: 5vw;
    display: block;
  }

  .div-block-2 {
    margin-bottom: 5vw;
    margin-left: 6%;
    margin-right: 6%;
    padding-left: 0;
    padding-right: 0;
  }

  .div-block-2.last {
    margin-bottom: 0;
  }

  .logos-without-title {
    padding: 0 0 60px;
  }

  .clients-wrapper-three {
    margin-bottom: -30px;
    padding-top: 20px;
  }

  .clients-image-three {
    max-width: 120px;
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .paragraph {
    margin-top: 0;
  }

  .paragraph.title {
    padding-bottom: 1vw;
  }

  .heading {
    margin-bottom: 0;
  }

  .flowtitle {
    margin-top: 2vw;
    margin-bottom: 2vw;
  }

  .bluebutton {
    justify-content: center;
    align-items: center;
    min-width: 150px;
    margin-left: 5px;
    margin-right: 0;
    padding: 15px 0;
    font-size: 14px;
    line-height: 28px;
    display: flex;
  }

  .flowtext {
    margin-top: 0;
    margin-bottom: 2vw;
    font-size: 14px;
    font-weight: 400;
    line-height: 28px;
  }

  .flowtext.under {
    margin-top: 3vw;
  }

  .image-3, .image-3.right-left {
    max-width: 12vw;
    top: -10vw;
    left: 43%;
  }

  .image-3.right-left.right {
    min-width: 50px;
    max-width: 12vw;
    top: -10vw;
    left: 43%;
  }

  .image-4 {
    padding-left: 1vw;
    padding-right: 1vw;
  }

  .image-4.pc {
    display: none;
  }

  .image-4.sp {
    max-width: 100%;
    display: block;
  }

  .image-5 {
    max-width: 14vw;
    margin-left: 0;
    inset: 0% auto auto 10vw;
  }

  .image-5.none {
    display: none;
  }

  .imagebox {
    height: auto;
  }

  .columns-2 {
    padding-top: 0;
  }

  .column-5 {
    padding-left: 0;
    padding-right: 0;
  }

  .flex-block-3 {
    padding-top: 10vw;
    padding-left: 0;
    padding-right: 0;
  }

  .flex-block-4 {
    padding-top: 3vw;
    padding-bottom: 0;
  }

  .comment {
    margin-bottom: -1.5vw;
  }

  .comment.buy {
    max-width: 70vw;
    margin-bottom: -2.5vw;
    margin-left: auto;
    margin-right: auto;
  }

  .comment.pc {
    display: none;
  }

  .comment.sp {
    display: block;
  }

  .image-7 {
    max-width: 70vw;
    margin-left: auto;
    margin-right: auto;
  }

  .column-7 {
    padding-left: 0;
    padding-right: 0;
  }

  .column-10 {
    padding-bottom: 3vw;
    padding-left: 0;
    padding-right: 0;
  }

  .column-11 {
    padding-bottom: 3vw;
  }

  .image-8 {
    z-index: 3;
    max-width: 57vw;
    margin-bottom: -2.5vw;
    padding-bottom: 0;
    position: relative;
  }

  .column-15 {
    display: block;
  }

  .flex-block-5 {
    justify-content: center;
    align-items: center;
    padding-bottom: 2vw;
  }

  .flex-block-5.last {
    padding-bottom: 0;
  }

  .column-16 {
    padding-bottom: 5vw;
    padding-left: 0;
    padding-right: 0;
  }

  .column-17 {
    padding-left: 0;
    padding-right: 0;
  }

  .image-10 {
    margin-right: 5%;
  }

  .paragraph-10 {
    font-size: 16px;
    line-height: 32px;
  }

  .paragraph-10.pc {
    display: none;
  }

  .paragraph-10.sp {
    padding-bottom: 10vw;
    padding-left: 0;
    font-size: 14px;
    line-height: 28px;
    display: block;
  }

  .image-17.pc {
    display: none;
  }

  .section-registration {
    padding-top: 60px;
    padding-left: 1vw;
    padding-right: 1vw;
  }

  .heading-3 {
    font-size: 24px;
    line-height: 48px;
  }

  .mypagetext {
    margin-bottom: 4vw;
    padding-top: 4vw;
    font-size: 16px;
    line-height: 32px;
  }

  .link-block-8 {
    margin-left: 1vw;
    margin-right: 1vw;
  }

  .div-block-18 {
    padding-bottom: 6vw;
  }

  .link-block-9 {
    padding-left: 1.5vw;
    padding-right: 1.5vw;
  }

  .paragraph-11 {
    margin-top: 6vw;
    margin-bottom: 1vw;
    font-size: 14px;
    line-height: 28px;
  }

  .image-22 {
    padding-top: 6vw;
  }

  .tabs-menu {
    margin-top: -53px;
  }

  .text-block-2 {
    font-size: 12px;
    line-height: 18px;
  }

  .tabteikibin, .tabteikibin.w--current {
    height: 55px;
    padding-left: 15px;
    padding-right: 15px;
  }

  .image-23 {
    padding-bottom: 100px;
  }

  .whitebg {
    padding-top: 30px;
  }

  .lightbluebg {
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
  }

  .div-block-22 {
    padding: 20px 20px 0;
  }

  .div-block-22.check {
    max-width: 100%;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .div-block-22.delivery {
    padding-bottom: 20px;
  }

  .courseteikibin {
    padding-left: 0;
    padding-right: 0;
  }

  .courseteikibinblock {
    max-width: 45%;
  }

  .courseteikibinblock.blue {
    padding-right: 0;
  }

  .courseteikibinblock.yellow {
    padding-left: 0;
  }

  .attentionteikibin.campaign {
    padding-top: 10px;
  }

  .attentionteikibin.case {
    margin-bottom: 0;
  }

  .attentionteikibin.top.pc {
    display: none;
  }

  .attentionteikibin.top.sp {
    text-align: center;
  }

  .pointblock.mini {
    max-width: 100%;
    margin-bottom: 20px;
  }

  .pointblock.mini.case {
    max-width: 600px;
  }

  .pointblock.sec02 {
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .valueblock {
    max-width: 80%;
  }

  .pointtitle {
    padding-bottom: 0;
  }

  .pointtitle.course {
    padding-bottom: 20px;
  }

  .coursetitle2.example {
    top: -3%;
  }

  .coursedescription, .coursedescription.yellow {
    padding-left: 20px;
    padding-right: 20px;
  }

  .flex-block-14 {
    display: block;
  }

  .flex-block-14.merit {
    padding-bottom: 0;
  }

  .teikibinsection.merit, .teikibinsection.flow, .tekibinhukidashi, .tekibinhukidashi.img {
    padding-top: 40px;
  }

  .tekibinhukidashi.img.none {
    display: none;
  }

  .casetext {
    text-align: left;
    margin-bottom: 40px;
  }

  .casetext._2 {
    margin-bottom: 40px;
  }

  .casetext._2.last {
    margin-bottom: 0;
  }

  .casetext.sp {
    display: block;
  }

  .casetext.pc {
    display: none;
  }

  .heading-5 {
    position: absolute;
  }

  .div-block-25 {
    max-width: 100%;
  }

  .div-block-27.flow {
    justify-content: space-around;
    padding: 20px;
  }

  .paragraph-17 {
    padding-top: 20px;
  }

  .flex-block-15 {
    margin-bottom: 20px;
  }

  .paragraph-19.course {
    margin-top: 20px;
  }

  .paragraph-20.yellow {
    padding: 10px;
  }

  .paragraph-21 {
    max-width: 100%;
    padding: 10px;
  }

  .paragraph-22 {
    max-width: 70%;
    padding-left: 20px;
  }

  .flex-block-16.first {
    padding-bottom: 20px;
  }

  .div-block-29 {
    max-width: 30%;
  }

  .flex-block-17 {
    flex-flow: column-reverse wrap;
    justify-content: center;
    align-items: center;
    padding: 0 0 20px;
    display: flex;
  }

  .image-31 {
    max-width: 70%;
  }

  .image-31.ec {
    margin-right: 0;
  }

  .image-31.shop {
    max-width: 90%;
    margin-right: 0;
    padding-right: 0;
  }

  .link-block-10 {
    max-width: 70%;
  }

  .link {
    font-size: 14px;
    line-height: 28px;
  }

  .link.date {
    font-size: 14px;
  }

  .image-32.last {
    max-width: 20%;
  }

  .image-35 {
    max-width: 15%;
    top: -46%;
    left: -4%;
  }

  .link-block-14 {
    max-width: 70%;
  }

  .div-block-33 {
    max-width: 90%;
    padding: 10px;
    top: -14%;
  }

  .paragraph-23 {
    font-size: 14px;
    line-height: 14px;
  }

  .div-block-34 {
    max-width: 95%;
    padding-bottom: 20px;
  }

  .div-block-35 {
    max-width: 95%;
    margin-bottom: 60px;
    padding-top: 30px;
    padding-bottom: 6%;
  }

  .lensbox {
    max-width: 70%;
  }

  .price {
    max-width: 200px;
  }

  .div-block-36 {
    padding-top: 50px;
    padding-bottom: 70px;
  }

  .image-36 {
    max-width: 95%;
  }

  .image-39 {
    max-width: 210px;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .image-43 {
    display: block;
  }
}

@media screen and (max-width: 479px) {
  .button {
    margin-bottom: 25px;
  }

  .button.tab {
    margin-bottom: 0;
    padding: 8px;
  }

  .section {
    padding-left: 0;
    padding-right: 0;
  }

  .section.blue {
    background-image: url('../images/Group-103.svg');
    background-position: 50%;
    background-size: cover;
    margin-right: auto;
    padding-top: 20vw;
    padding-left: 3%;
    padding-right: 3%;
  }

  .section.blue.support {
    background-repeat: repeat;
    background-size: cover;
    margin-right: auto;
    padding-bottom: 7vw;
    padding-right: 3%;
  }

  .section.blue.sp_buy {
    background-image: url('../images/back_sp.svg');
    background-position: 50%;
    background-repeat: repeat;
    background-size: cover;
  }

  .section.buy {
    padding-left: 0%;
    padding-right: 0%;
  }

  .section.teikibin {
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: scroll;
  }

  .white-box.transparent.value {
    margin-bottom: 0;
  }

  .white-box.flow {
    border-width: 2.5px;
    margin-left: 6%;
    margin-right: 6%;
    padding-bottom: 10vw;
  }

  .white-box.flow.last {
    border-width: 2.5px;
  }

  .hero-section.centered {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .section-heading.centered {
    font-size: 18px;
    line-height: 29px;
  }

  .section-heading.centered.blue {
    line-height: 20px;
  }

  .section-subheading.center {
    line-height: 30px;
  }

  .grid-image {
    width: 35%;
  }

  .tab-menu {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .fullwidth-image {
    min-width: auto;
    max-width: 100%;
  }

  .fullwidth-image.heart, .fullwidth-image.flow {
    min-width: auto;
  }

  .fullwidth-image.support {
    padding-bottom: 1vw;
  }

  .fullwidth-image.buy.syuccyou {
    max-width: 70vw;
  }

  .fullwidth-image.box {
    min-width: auto;
  }

  .flex-block {
    flex-flow: column;
  }

  .logos-without-title {
    padding-bottom: 5vw;
  }

  .container-3 {
    max-width: none;
  }

  .clients-wrapper-three {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    grid-template: "."
                   "."
                   / 1fr 1fr 1fr;
    grid-auto-rows: auto;
    grid-auto-columns: 1fr;
    justify-items: center;
    margin-bottom: 0;
    padding-top: 5vw;
    padding-left: 6%;
    padding-right: 6%;
    display: grid;
  }

  .clients-image-three {
    max-width: 100px;
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .paragraph {
    font-size: 14px;
  }

  .paragraph.title {
    font-size: 12px;
    line-height: 24px;
  }

  .bluebutton {
    min-width: 115px;
    margin-left: 2.5px;
    margin-right: 2.5px;
    padding-top: 10px;
    padding-bottom: 10px;
    font-size: 12px;
    line-height: 24px;
  }

  .bluebutton.red.top {
    flex-flow: row;
    margin-top: 20px;
  }

  .bluebutton.syuccyou {
    border-width: 2.5px;
    max-width: 115px;
  }

  .flowtext {
    margin-bottom: 20px;
  }

  .flowtext.under {
    margin-top: 10vw;
    margin-bottom: 5vw;
  }

  .flowtext.top {
    margin-bottom: 5vw;
    padding-bottom: 0;
  }

  .text-span {
    font-size: 24px;
    line-height: 30px;
  }

  .image-3 {
    min-width: 55px;
  }

  .image-3.right-left {
    left: 42%;
  }

  .image-3.right-left.right {
    min-width: 55px;
    left: 42%;
  }

  .image-4.pc {
    display: none;
  }

  .image-4.sp {
    padding-left: .5vw;
    padding-right: .5vw;
  }

  .flex-block-3 {
    padding-top: 5vw;
  }

  .columns-3 {
    padding-left: 1.5vw;
    padding-right: 1.5vw;
  }

  .comment {
    margin-bottom: -3vw;
  }

  .comment.buy {
    margin-bottom: -3.5vw;
  }

  .comment.pc {
    display: block;
  }

  .comment.sp {
    display: none;
  }

  .image-8 {
    z-index: 3;
    max-width: 70vw;
    position: relative;
  }

  .column-14 {
    padding-left: 0;
  }

  .column-15 {
    padding-bottom: 5vw;
    padding-right: 0;
  }

  .column-16, .column-17 {
    padding-left: 1vw;
    padding-right: 1vw;
  }

  .section-2 {
    padding-top: 10vw;
    padding-bottom: 10vw;
  }

  .flex-block-8 {
    background-color: #0000;
  }

  .sp.registration {
    padding: 5vw 15vw;
    display: block;
  }

  .dropdown-list-2 {
    background-color: #0000;
  }

  .paragraph-10.sp {
    padding-left: 0;
  }

  .icon-3 {
    font-size: 25px;
    line-height: 25px;
    inset: 0% auto 0% 0%;
  }

  .icon-4 {
    font-size: 25px;
    line-height: 25px;
    inset: 0% 0% 0% auto;
  }

  .slide-nav {
    font-size: 5px;
    line-height: 30px;
  }

  .section-registration {
    padding-top: 20vw;
    padding-left: 10vw;
    padding-right: 10vw;
  }

  .div-block-16 {
    background-size: auto;
  }

  .heading-3 {
    font-size: 20px;
    line-height: 40px;
  }

  .mypagetext {
    margin-bottom: 10vw;
    padding-top: 10vw;
    font-size: 14px;
    line-height: 28px;
  }

  .flex-block-12 {
    display: block;
  }

  .link-block-8, .link-block-8.w--current {
    max-width: 100%;
    margin-bottom: 5vw;
    margin-left: 0;
    margin-right: 0;
  }

  .div-block-18 {
    padding-bottom: 10vw;
  }

  .link-block-9.mypage.pc, .link-block-9.pc {
    display: none;
  }

  .image-22 {
    max-width: 90vw;
  }

  .card-registration {
    padding-top: 5vw;
    padding-bottom: 5vw;
    display: block;
  }

  .card-registration.last {
    padding-bottom: 0;
  }

  .tabs-menu {
    margin-top: -45px;
  }

  .text-block-2 {
    font-size: 10px;
    line-height: 15px;
  }

  .tabteikibin {
    border-width: 2px 2px 0;
    height: 45px;
    padding-left: 7px;
    padding-right: 7px;
  }

  .tabteikibin.w--current {
    border: 2px solid #000;
    border-bottom-style: none;
    height: 45px;
    margin-left: 1px;
    margin-right: 1px;
    padding-left: 7px;
    padding-right: 7px;
  }

  .image-23 {
    max-width: 70%;
    padding-bottom: 100px;
  }

  .whitebg {
    border-top-width: 2px;
  }

  .image-24 {
    padding-bottom: 40px;
    padding-left: 0;
    padding-right: 0;
  }

  .lightbluebg {
    padding-bottom: 40px;
    padding-left: 3vw;
    padding-right: 3vw;
  }

  .div-block-22.delivery {
    padding: 10px;
  }

  .courseteikibinblock {
    max-width: 100%;
  }

  .courseteikibinblock.blue {
    max-width: 47%;
    padding-left: 5px;
  }

  .courseteikibinblock.yellow {
    max-width: 47%;
    padding-right: 5px;
  }

  .attentionteikibin {
    font-size: 10px;
  }

  .attentionteikibin.campaign {
    padding-top: 0;
    font-size: 10px;
    line-height: 15px;
  }

  .attentionteikibin.case {
    margin-bottom: 0;
    padding-top: 10px;
  }

  .attentionteikibin.top.sp {
    display: none;
  }

  .coursetitle1 {
    padding-top: 20px;
  }

  .pointblock.mini.case {
    margin-bottom: 10px;
  }

  .pointtitle {
    padding-bottom: 0;
  }

  .pointtitle.case {
    margin-bottom: 10px;
  }

  .pointtitle.flow {
    margin-bottom: 20px;
  }

  .pointtitle.course {
    padding-bottom: 20px;
  }

  .coursetitle2 {
    margin-bottom: 20px;
    font-size: 20px;
    line-height: 30px;
  }

  .coursetitle2.example {
    top: -1%;
  }

  .coursedescription {
    margin-top: 20px;
  }

  .casecloud {
    left: -3%;
  }

  .teikibinsection.info {
    padding-top: 10vw;
    padding-bottom: 10vw;
  }

  .tekibinhukidashi {
    margin-bottom: 10px;
    font-size: 14px;
  }

  .tekibinhukidashi.img {
    max-width: 95%;
  }

  .casetext {
    text-align: left;
  }

  .casetext._2 {
    margin-bottom: 40px;
  }

  .casetext._2.last {
    margin-bottom: 0;
  }

  .casetext.sp {
    display: block;
  }

  .casetext.pc {
    display: none;
  }

  .heading-5 {
    margin-bottom: 0;
    font-size: 14px;
  }

  .pointhukidashi {
    font-size: 12px;
  }

  .pointhukidashi.pc {
    display: none;
  }

  .pointhukidashi.sp {
    display: block;
  }

  .pointlabel {
    font-size: 16px;
  }

  .div-block-27 {
    display: block;
  }

  .paragraph-17 {
    padding-top: 10px;
    font-size: 12px;
    line-height: 24px;
  }

  .paragraph-17.sp {
    text-align: center;
    display: block;
  }

  .paragraph-17.pc {
    display: none;
  }

  .paragraph-22 {
    font-size: 14px;
    line-height: 28px;
  }

  .div-block-30 {
    padding-bottom: 20px;
  }

  .image-31.shop {
    flex-flow: column;
    justify-content: center;
    align-items: center;
    max-width: 85%;
    padding-right: 0;
  }

  .link-block-10 {
    max-width: 100%;
  }

  .tab-pane-tab-2 {
    border-top-width: 2px;
  }

  .image-32 {
    padding-top: 42px;
    padding-bottom: 42px;
  }

  .tabs {
    padding-top: 0;
  }

  .tabs-content-2 {
    margin-top: 1px;
  }

  .image-33 {
    max-width: 100%;
    padding-bottom: 10px;
  }

  .image-34 {
    width: 40px;
  }

  .image-35 {
    max-width: 20%;
    top: -32%;
    left: -3%;
  }

  .link-block-13 {
    width: 100%;
    max-width: 50%;
  }

  .link-block-14 {
    max-width: 100%;
  }

  .div-block-32 {
    padding-left: 3vw;
    padding-right: 3vw;
  }

  .div-block-33 {
    max-width: 100%;
    top: -5%;
  }

  .div-block-34 {
    max-width: 95%;
  }

  .div-block-35 {
    max-width: 90%;
    padding-top: 35px;
  }

  .lensbox {
    max-width: 80%;
  }

  .paragraph-25 {
    font-size: 20px;
    line-height: 20px;
  }

  .paragraph-26 {
    font-size: 14px;
    line-height: 14px;
  }

  .div-block-36 {
    padding-top: 40px;
    padding-bottom: 60px;
  }

  .image-36.pc {
    display: none;
  }

  .image-39 {
    max-width: 80%;
    padding-top: 30px;
    padding-bottom: 30px;
  }

  .image-40 {
    width: 100%;
    max-width: 70%;
    margin-left: auto;
    margin-right: auto;
    display: block;
  }

  .image-40.sp {
    display: block;
  }

  .image-43 {
    padding-top: 40px;
    padding-left: 10px;
    padding-right: 10px;
    display: block;
  }

  #w-node-_0fed6b20-171e-4114-9234-7e367f34aac5-26e6407e {
    grid-area: span 1 / span 1 / span 1 / span 1;
  }
}


