@charset "UTF-8";
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

th {
  text-align: left;
  vertical-align: top;
  font-weight: normal;
}

td {
  text-align: left;
  vertical-align: top;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input, select, textarea, img {
  vertical-align: middle;
}

ul, dl, ol {
  list-style: none;
}

em {
  font-style: normal;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

/* ========================================
    ■ 必須設定
======================================== */
/* 文字色 */
.font_blue {
  color: #0065b4;
}
.font_orange {
  color: #ffcb16;
}

/* 関数
----------------------------- */
.kenten, .kenten_half {
  /* 圏点 */
  padding: 0.35em 0;
  background-repeat: repeat-x;
  background-size: 1em 0.5em;
  background-position: top left;
  background-image: radial-gradient(0.4rem 0.4rem at center center, #222 50%, transparent 50%);
  font-feature-settings: normal;
}

.kenten_half {
  background-size: 0.65em 0.5em;
}

.is_sp {
  display: block;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .is_sp {
    display: none;
  }
}

.is_pc {
  display: none;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .is_pc {
    display: block;
  }
}

img.is_sp,
br.is_sp {
  display: inline-block;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  img.is_sp,
  br.is_sp {
    display: none;
  }
}

img.is_pc,
br.is_pc {
  display: none;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  img.is_pc,
  br.is_pc {
    display: inline-block;
  }
}

/* ========================================
    ■ General
======================================== */
html {
  font-size: 3.6458333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  html {
    font-size: 1.6276041667vw;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #222;
  line-height: 1.8;
  background: #fff;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

a {
  color: #0033cc;
  text-decoration: underline;
  transition: 0.2s ease;
}
a::before, a::after {
  transition: 0.2s ease;
}
a:hover {
  text-decoration: none;
  transition: 0.2s ease;
}
a:hover::before, a:hover::after {
  transition: 0.2s ease;
}

img,
video,
object {
  width: 100%;
  height: auto;
  vertical-align: bottom;
  border: none;
}

section {
  position: relative;
}

mark {
  background: none;
  color: inherit;
  font-weight: normal;
  font-style: normal;
}

/* utility class
----------------------------- */
.wrap {
  position: relative;
  width: 100%;
  margin: 0 auto;
}

.clearfix {
  overflow: hidden;
  zoom: 1;
}
.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

.hover:hover {
  transition: 0.2s ease;
}
.hover:hover:hover {
  transform: scale(0.98, 0.98);
  transition: 0.2s ease;
}

.scrollbar::-webkit-scrollbar {
  background: #ccc;
  width: 10px;
}
.scrollbar::-webkit-scrollbar-thumb {
  background: #aaa;
}

table.tbl_block {
  display: block;
  text-align: left;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  table.tbl_block {
    display: table;
  }
}
table.tbl_block tbody {
  display: block;
  text-align: left;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  table.tbl_block tbody {
    display: table-row-group;
  }
}
table.tbl_block tr {
  display: block;
  text-align: left;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  table.tbl_block tr {
    display: table-row;
  }
}
table.tbl_block th,
table.tbl_block td {
  display: block;
  text-align: left;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  table.tbl_block th,
  table.tbl_block td {
    display: table-cell;
  }
}

/* マーカー */
/* ・リスト */
.list_dot > li {
  position: relative;
  padding-left: 1em;
}
.list_dot > li::before {
  content: '・';
  display: inline-block;
  position: absolute;
  left: 0;
  top: 0;
}

/* 背景 */
.bg_orange {
  background: linear-gradient(to right, #ffcb16, #ffdb17);
}

/* ========================================
    ■ ページトップボタン
======================================== */
#page_top {
  position: fixed;
  right: 20px;
}
#page_top a {
  display: block;
  width: 12vw;
  height: 12vw;
  color: #fff;
  text-align: center;
  background: rgba(0, 0, 0, 0.25);
  border-radius: 50%;
  /* メディアクエリ用 */
}
#page_top a:hover {
  background: rgba(0, 0, 0, 0.5);
}
@media screen and (min-width: 769px) {
  #page_top a {
    width: 44px;
    height: 44px;
  }
}
#page_top .material-icons {
  line-height: 12vw;
  font-size: 9vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #page_top .material-icons {
    line-height: 44px;
    font-size: 20px;
  }
}

/* ========================================
    ■ header
======================================== */
header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  box-shadow: 0 1.0416666667vw 1.6927083333vw rgba(0, 0, 0, 0.33);
  padding: 2.34375vw 3.2552083333vw 2.34375vw 3.90625vw;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
  position: relative;
  z-index: 2;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  header {
    box-shadow: 0 0 0.8463541667vw rgba(0, 0, 0, 0.33);
    padding: 0.6510416667vw 5% 0.5208333333vw 4.5%;
  }
}

.header_logo {
  width: 33.8541666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .header_logo {
    width: 15.2994791667vw;
    padding-bottom: 0.9765625vw;
  }
}
.header_logo > img {
  vertical-align: middle;
}

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

.header_sub_point {
  width: 11.9791666667vw;
  margin-right: 1.3020833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .header_sub_point {
    width: 7.8125vw;
    margin-right: 1.953125vw;
  }
}

.header_sub_tel {
  width: 43.6197916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .header_sub_tel {
    width: 24.9348958333vw;
  }
}

/* ========================================
    ■ keyv
======================================== */
#keyv {
  position: relative;
  z-index: 1;
}

.keyv_inner {
  background: url(../images/keyv_bg01.png) no-repeat center top;
  background-size: cover;
  height: 96.3541666667vw;
  box-shadow: 0 0 2.6041666667vw rgba(0, 0, 0, 0.33);
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv_inner {
    background: url(../images/keyv_bg01_pc.png) no-repeat center top;
    background-size: cover;
    height: 45.0520833333vw;
    padding: 1.8229166667vw 0 0;
    overflow-x: hidden;
    box-shadow: 0 0 0.8463541667vw rgba(0, 0, 0, 0.33);
  }
}

.keyv_tit {
  position: relative;
  z-index: 9;
  padding: 5.859375vw 0 0 3.3854166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv_tit {
    padding: 0 0 0 5.2083333333vw;
  }
}
.keyv_tit img {
  width: 71.09375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv_tit img {
    width: 45.2473958333vw;
  }
}

.keyv_img {
  position: absolute;
  width: 33.8541666667vw;
  top: -2.6041666667vw;
  right: 0;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv_img {
    width: 25.9114583333vw;
    top: -0.3255208333vw;
  }
}

.keyv_txt {
  position: absolute;
  left: 0;
  bottom: -10.6770833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .keyv_txt {
    width: 100%;
    left: -0.5208333333vw;
    bottom: 0.9765625vw;
  }
}

/* ========================================
    ■ cta_fixed
======================================== */
.cta_fixed {
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 999;
  width: 100%;
  box-shadow: 0 0 1.6927083333vw rgba(0, 0, 0, 0.33);
}

.cta_fixed_btn {
  display: block;
}

/* ========================================
    ■ sec01
======================================== */
#sec01 {
  background: url(../images/sec01_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 12.5vw 0 3.2552083333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec01 {
    background: url(../images/sec01_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding: 3.515625vw 0 1.953125vw;
  }
}

.sec01_area {
  width: 97.1354166667vw;
  margin: -0.6510416667vw auto 0;
  background: url(../images/sec01_area_bg.png) no-repeat center center/100% 100%;
  padding: 6.7708333333vw 5.2083333333vw 7.421875vw;
  /* メディアクエリ用 */
  text-align: center;
}
@media screen and (min-width: 769px) {
  .sec01_area {
    width: 72.9166666667vw;
    margin: -1.1067708333vw auto 0;
    background: url(../images/sec01_area_bg_pc.png) no-repeat center center/100% 100%;
    padding: 3.2552083333vw 4.8828125vw 3.5807291667vw;
  }
}
.sec01_area dt {
  width: 76.0416666667vw;
  margin: 0 auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec01_area dt {
    width: 38.0208333333vw;
  }
}
.sec01_area dd {
  padding: 2.6041666667vw 5% 0;
  text-align: center;
  color: #004069;
  font-weight: 500;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec01_area dd {
    letter-spacing: 0.07em;
    padding: 1.3020833333vw 0 0;
  }
}

/* ========================================
    ■ sec02
======================================== */
#sec02 {
  background: url(../images/sec02_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 3.90625vw 0 5.859375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec02 {
    background: url(../images/sec02_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding: 1.8229166667vw 0 2.2135416667vw;
  }
}

.sec02_tit {
  margin: 0 auto;
  width: 83.3333333333vw;
  margin: 0 auto 1.3020833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec02_tit {
    margin: 0 auto 0.6510416667vw;
    width: 67.7083333333vw;
  }
}

.sec02_item01 {
  margin: 0 auto 3.3854166667vw;
  width: 90.234375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec02_item01 {
    margin-bottom: 2.6041666667vw;
    width: 65.1692708333vw;
  }
}

.sec02_price {
  margin: 0 auto;
  width: 90.1041666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec02_price {
    width: 69.8567708333vw;
  }
}

.sec02_price_note {
  color: #7d7d7d;
  margin: 0 auto;
  font-size: 2.2135416667vw;
  line-height: 1.411;
  font-weight: 300;
  padding-left: 8.7239583333vw;
  padding-top: 1.3020833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec02_price_note {
    font-size: 1.1067708333vw;
    width: 70.5078125vw;
    padding-top: 0.6510416667vw;
    padding-left: 3.2552083333vw;
  }
}

/* ========================================
    ■ sec03
======================================== */
#sec03 .bg_orange {
  padding: 5.3385416667vw 0 6.3802083333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec03 .bg_orange {
    padding: 4.296875vw 0 4.1015625vw;
  }
}

.sec03_tit {
  width: 75.390625vw;
  margin: 0 auto 1.8229166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec03_tit {
    margin-bottom: 2.4088541667vw;
    width: 72.265625vw;
  }
}

.sec03_txt {
  width: 89.9739583333vw;
  margin: 0 auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec03_txt {
    width: 59.6354166667vw;
  }
}

/* ========================================
    ■ sec04
======================================== */
#sec04 {
  background: url(../images/sec04_bg01.png) center top;
  background-size: 100% auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec04 {
    background: url(../images/sec04_bg01_pc.png) center top;
    background-size: 100% auto;
  }
}

.sec04_anchor {
  margin: 0 auto;
  text-align: center;
  padding: 3.90625vw 0 4.1666666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_anchor {
    padding: 4.3619791667vw 0 2.6041666667vw;
  }
}
.sec04_anchor li {
  display: inline-block;
  font-size: 0;
  margin: 0 -1.3020833333vw;
  /* メディアクエリ用 */
}
.sec04_anchor li img {
  width: 32.5520833333vw;
}
@media screen and (min-width: 769px) {
  .sec04_anchor li {
    padding-left: 0.6510416667vw;
    margin: 0 -0.5208333333vw;
  }
  .sec04_anchor li img {
    width: 24.0885416667vw;
  }
}

.sec04_item {
  margin: 0 auto 7.1614583333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_item {
    width: 79.1015625vw;
    margin-bottom: 0.6510416667vw;
  }
}
.sec04_item:after {
  content: "";
  display: block;
  clear: both;
}
.sec04_item_child {
  margin: 0 auto;
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec04_item_child {
    width: 82.2916666667vw;
  }
}
.sec04_item_child#sec04_anchor01 {
  margin-bottom: 6.5104166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_item_child#sec04_anchor01 {
    margin-bottom: 5.6640625vw;
  }
}
.sec04_item_child#sec04_anchor02 {
  margin-bottom: 6.5104166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_item_child#sec04_anchor02 {
    float: left;
  }
  .sec04_item_child#sec04_anchor02 img {
    width: 40.3645833333vw;
  }
}
.sec04_item_child#sec04_anchor03 {
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_item_child#sec04_anchor03 {
    float: right;
    margin-left: -2.2786458333vw;
    margin-right: -0.6510416667vw;
  }
  .sec04_item_child#sec04_anchor03 img {
    width: 40.5598958333vw;
  }
}

.sec04_txt01 {
  width: 81.5104166667vw;
  margin: 0 auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_txt01 {
    width: 58.0078125vw;
  }
}

.sec04_trouble {
  background: url(../images/sec04_bg02_pc.png) center top no-repeat;
  background-size: 100% auto;
  color: #fff;
  margin-top: -6.25vw;
  padding: 12.7604166667vw 0 5.2083333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_trouble {
    padding: 11.3932291667vw 0 3.2552083333vw;
    margin-top: -7.03125vw;
  }
}
.sec04_trouble_balloon {
  margin: 0 auto 1.953125vw;
  width: 83.3333333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_trouble_balloon {
    width: 61.1979166667vw;
    margin-bottom: 1.3020833333vw;
  }
}
.sec04_trouble_txt01 {
  text-align: center;
  font-weight: 700;
  font-size: 4.9479166667vw;
  line-height: 1.63;
  letter-spacing: 0.05em;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_trouble_txt01 {
    font-size: 3.125vw;
    line-height: 1.44;
  }
}

.sec04_solution {
  background: url(../images/sec04_bg03.png) center top;
  background-size: cover;
  padding: 6.1197916667vw 0 7.8125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_solution {
    background: url(../images/sec04_bg03_pc.png) center top;
    background-size: cover;
    padding: 5.078125vw 0 3.90625vw;
  }
}
.sec04_solution_hl01 {
  margin: 0 auto 4.9479166667vw;
  width: 90.234375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_solution_hl01 {
    width: 65.625vw;
    margin-bottom: 2.2786458333vw;
  }
}
.sec04_solution_maker {
  margin: 0 auto 6.640625vw;
  width: 90.1041666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec04_solution_maker {
    width: 65.625vw;
    margin-bottom: 4.1015625vw;
  }
}
.sec04_solution_txt01 {
  text-align: center;
  font-weight: 700;
  color: #00416a;
  letter-spacing: 0.05em;
  line-height: 1.479;
  font-size: 5.078125vw;
  /* メディアクエリ用 */
}
.sec04_solution_txt01 .marker {
  background: linear-gradient(0deg, #ffda13 20%, transparent 20%);
}
@media screen and (min-width: 769px) {
  .sec04_solution_txt01 {
    font-size: 2.7994791667vw;
  }
}

/* ========================================
■ cta01
======================================== */
.cta01 {
  background: #0065b4;
  padding: 3.6458333333vw 0 3.90625vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta01 {
    padding: 6.5104166667vw 0 4.9479166667vw;
  }
  .cta01 .cta01_block {
    justify-content: center;
    align-items: center;
  }
}

.cta01_block {
  margin: 0 auto;
  /* メディアクエリ用 */
}
.cta01_block:after {
  content: "";
  display: block;
  clear: both;
}
@media screen and (min-width: 769px) {
  .cta01_block {
    width: 89.453125vw;
  }
}

.cta01_tit {
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta01_tit {
    width: 36.2630208333vw;
    float: left;
    padding-top: 1.6927083333vw;
  }
}
@media screen and (max-width: 768px) {
  .cta01_tit {
    padding: 0 0 7.8125vw;
  }
}

.cta01_box {
  position: relative;
  background: #ffffff;
  padding: 35.546875vw 0 3.2552083333vw;
  margin: 0 5vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta01_box {
    width: 47.3307291667vw;
    float: right;
    margin: 0;
    padding: 19.7265625vw 0 1.3020833333vw;
  }
}

.cta01_box_tit {
  position: absolute;
  left: calc(50% - 40vw);
  top: -5.859375vw;
  width: 79.5572916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta01_box_tit {
    left: 2.4739583333vw;
    top: -2.9296875vw;
    width: 42.9036458333vw;
  }
}

.cta01_box_btn {
  display: block;
  width: 86.1979166667vw;
  margin: 0 auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta01_box_btn {
    width: 42.9036458333vw;
  }
}

/* ========================================
■ cta02
======================================== */
.cta02 {
  background: url(../images/cta02_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 1.953125vw 0 4.8177083333vw;
  border-bottom: 1.4322916667vw solid #00416a;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta02 {
    background: url(../images/cta02_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding: 1.953125vw 0 3.0598958333vw;
    border-bottom-width: 0.7161458333vw;
  }
}

.cta02_block {
  margin: 0 auto;
  width: 90.4947916667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta02_block {
    width: 77.7994791667vw;
  }
}

.cta02_tit {
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .cta02_tit {
    margin-right: -3.6458333333vw;
  }
}

.cta02_note {
  color: #7d7d7d;
  font-size: 2.2135416667vw;
  margin-top: 0.6510416667vw;
  font-weight: 500;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .cta02_note {
    font-size: 1.1067708333vw;
    margin-top: 0.3255208333vw;
    padding-left: 4.5572916667vw;
  }
}

/* ========================================
    ■ sec05
======================================== */
#sec05 {
  background: url(../images/sec05_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 5.2083333333vw 0;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec05 {
    background: url(../images/sec05_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding: 3.7109375vw 0 2.1484375vw;
  }
}

.sec05_tit {
  margin: 0 auto;
  width: 79.6875vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec05_tit {
    width: 50.9114583333vw;
  }
}

.sec05_relief {
  margin: 0 auto;
  padding-top: 3.2552083333vw;
  width: 86.1979166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec05_relief {
    padding-top: 0.9765625vw;
    width: 77.9947916667vw;
  }
}
.sec05_relief_list {
  /* メディアクエリ用 */
}
.sec05_relief_list:after {
  content: "";
  display: block;
  clear: both;
}
@media screen and (min-width: 769px) {
  .sec05_relief_list li {
    margin-left: -1.3020833333vw;
    margin-right: -1.3020833333vw;
    margin-bottom: 1.3020833333vw;
  }
  .sec05_relief_list li img {
    width: 41.015625vw;
  }
  .sec05_relief_list li:nth-child(odd) {
    clear: both;
    float: left;
  }
  .sec05_relief_list li:nth-child(even) {
    float: right;
  }
}
.sec05_relief_note {
  position: relative;
  font-weight: 500;
  color: #7d7d7d;
  font-size: 2.2135416667vw;
  padding-left: 2.6041666667vw;
  top: -1.3020833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec05_relief_note {
    top: -1.6276041667vw;
    margin-left: -1.953125vw;
    font-size: 1.1067708333vw;
  }
}

/* ========================================
■ sec06
======================================== */
#sec06 {
  background: url(../images/sec06_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 5.2083333333vw 0 6.5104166667vw;
  border-bottom: 1.3020833333vw solid #00416a;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec06 {
    background: url(../images/sec06_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding: 3.2552083333vw 0 2.34375vw;
    border-bottom-width: 0.6510416667vw;
  }
}

.sec06_tit {
  margin: 0 auto;
  width: 91.1458333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec06_tit {
    width: 56.640625vw;
  }
}

.sec06_flow {
  margin: -3.90625vw auto 0;
  width: 90.234375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec06_flow {
    width: 77.4739583333vw;
    margin-top: -2.5390625vw;
  }
}
.sec06_flow li + li {
  margin-top: 0.9114583333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec06_flow li + li {
    margin-top: 0.5859375vw;
  }
}
.sec06_flow_note {
  font-weight: 500;
  color: #4a4a4a;
  padding-top: 0.6510416667vw;
  font-size: 2.2135416667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec06_flow_note {
    padding-top: 0.3255208333vw;
    font-size: 1.1067708333vw;
    color: #0b0b0b;
  }
}

/* ========================================
    ■ sec07
======================================== */
#sec07 {
  background: url(../images/sec07_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 1.5625vw 0 9.375vw;
  border-bottom: 1.3020833333vw solid #00416a;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec07 {
    background: url(../images/sec07_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding: 2.34375vw 0 6.5104166667vw;
    border-bottom-width: 0.6510416667vw;
  }
}

.sec07_tit {
  margin: 0 auto 1.3020833333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec07_tit {
    margin-bottom: 0.3255208333vw;
    width: 77.0182291667vw;
  }
}

#sec07_slide {
  position: relative;
}
#sec07_slide .flickity-prev-next-button {
  width: 8.203125vw;
  height: 8.203125vw;
  border-radius: 0;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  #sec07_slide .flickity-prev-next-button {
    top: 62.109375vw !important;
  }
}
@media screen and (min-width: 769px) {
  #sec07_slide .flickity-prev-next-button {
    width: 4.1015625vw;
    height: 4.1015625vw;
  }
}
#sec07_slide .flickity-prev-next-button.previous {
  background: url(../images/sec07_slide_arrow01.png) no-repeat center top;
  background-size: 100% 100%;
  left: 7.1614583333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec07_slide .flickity-prev-next-button.previous {
    left: 8.4635416667vw;
  }
}
#sec07_slide .flickity-prev-next-button.next {
  background: url(../images/sec07_slide_arrow02.png) no-repeat center top;
  background-size: 100% 100%;
  right: 7.1614583333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec07_slide .flickity-prev-next-button.next {
    right: 8.4635416667vw;
  }
}
#sec07_slide .flickity-prev-next-button .flickity-button-icon {
  opacity: 0;
}

.sec07_slide_item {
  width: 78.125vw;
  margin: 12.109375vw 2.8645833333vw 1.3020833333vw;
  border: 0.6510416667vw solid #00416a;
  background: #fff;
  /* メディアクエリ用 */
}
.sec07_slide_item.is-selected {
  border-width: 1.6927083333vw;
  margin-top: 11.71875vw;
}
@media screen and (min-width: 769px) {
  .sec07_slide_item {
    width: 77.2786458333vw;
    margin: 6.5104166667vw 2.734375vw 0.6510416667vw;
    border-width: 0.3255208333vw;
  }
  .sec07_slide_item.is-selected {
    border-width: 0.78125vw;
    margin-top: 6.0546875vw;
  }
}

.sec07_slide_item_box {
  padding: 9.1145833333vw 6.5104166667vw 18.2291666667vw;
  position: relative;
  height: 148.4375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec07_slide_item_box {
    display: flex;
    padding: 5.2083333333vw 2.9947916667vw 6.9661458333vw;
    height: 45.8984375vw;
  }
}

.sec07_slide_tit {
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  font-weight: 700;
  color: #fff;
  background: #00a8f7;
  border-radius: 100px;
  top: -13.0208333333vw;
  padding: 3.2552083333vw 6.25vw;
  font-size: 4.4270833333vw;
  letter-spacing: -0.05em;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec07_slide_tit {
    width: 63.28125vw;
    line-height: 1.2857;
  }
}
@media screen and (min-width: 769px) {
  .sec07_slide_tit {
    padding: 1.953125vw 1.7578125vw;
    width: 52.0833333333vw;
    text-align: center;
    font-size: 2.0833333333vw;
    top: -6.1848958333vw;
  }
  .sec07_slide_tit._tit1 {
    width: 47.0703125vw;
  }
}
.sec07_slide_tit:before, .sec07_slide_tit:after {
  content: "";
  display: block;
  position: absolute;
}
.sec07_slide_tit:before {
  background: url(../images/sec07_slide_arrow.png) center center no-repeat;
  background-size: 100%;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 4.0364583333vw;
  height: 2.0833333333vw;
  bottom: -1.953125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec07_slide_tit:before {
    width: 2.4088541667vw;
    height: 1.2369791667vw;
    bottom: -1.171875vw;
  }
}
.sec07_slide_tit:after {
  background: url(../images/sec07_slide_ico.png) center center no-repeat;
  background-size: 100%;
  width: 15.625vw;
  height: 9.8958333333vw;
  right: 1.6927083333vw;
  bottom: 0;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec07_slide_tit:after {
    width: 7.8125vw;
    height: 4.9479166667vw;
    right: 0.8463541667vw;
  }
}

.sec07_slide_img {
  position: relative;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec07_slide_img:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -3.515625vw;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 13.671875vw;
    height: 0.390625vw;
    background: linear-gradient(#00b4fa, #0075e9);
  }
}
@media screen and (min-width: 769px) {
  .sec07_slide_img {
    flex-shrink: 0;
    width: 33.8541666667vw;
    margin-right: 2.734375vw;
    margin-top: 1.953125vw;
  }
}

.sec07_slide_txt {
  margin: 5.2083333333vw 0 0;
  line-height: 1.6;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec07_slide_txt {
    letter-spacing: 0.05em;
  }
}
@media screen and (min-width: 769px) {
  .sec07_slide_txt {
    margin: 0;
    line-height: 1.8;
  }
}
.sec07_slide_txt .marker {
  background: linear-gradient(0deg, #ffda13 20%, transparent 20%);
}
.sec07_slide_txt strong {
  font-weight: 700;
  color: #fff;
  background: #0065b4;
  border-radius: 20px;
  display: block;
  padding: 2px 15px;
  text-align: center;
}

.sec07_slide_name {
  color: #fff;
  background: #00416a;
  border-radius: 100px 0 0 100px;
  text-align: center;
  bottom: 7.03125vw;
  right: 0;
  position: absolute;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec07_slide_name {
    display: inline-block;
    padding: 0.6510416667vw 6.5104166667vw 0.6510416667vw 4.9479166667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec07_slide_name {
    margin-top: 2.34375vw;
    padding: 0.1953125vw 0.6510416667vw;
    width: 34.3098958333vw;
    right: 1.8880208333vw;
    bottom: 3.4505208333vw;
    border-radius: 100px;
    letter-spacing: 0.05em;
    font-size: 1.8229166667vw;
  }
}

/* ========================================
■ sec08
======================================== */
#sec08 {
  background: url(../images/sec08_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 4.5572916667vw 0 7.2916666667vw;
  border-bottom: 1.3020833333vw solid #00416a;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec08 {
    background: url(../images/sec08_bg01_pc.png) repeat-y center top;
    background-size: 100% auto;
    padding: 3.2552083333vw 0 4.5572916667vw;
    border-bottom-width: 0.6510416667vw;
  }
}

.sec08_tit {
  margin: 0 auto 5.859375vw;
  width: 89.5833333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_tit {
    margin-bottom: 2.4739583333vw;
    width: 50.5859375vw;
  }
}

.sec08_qa {
  margin: 0 auto;
  width: 89.84375vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_qa {
    width: 76.8229166667vw;
  }
}
.sec08_qa dl > div + div {
  margin-top: 5.2083333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_qa dl > div + div {
    margin-top: 1.953125vw;
  }
}
.sec08_qa_mark {
  position: absolute;
  font-family: 'Roboto', sans-serif;
  font-weight: 900;
  font-size: 5.2083333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_qa_mark {
    font-size: 2.6041666667vw;
  }
}
.sec08_qa dt {
  background: #00416a;
  position: relative;
  color: #fff;
  font-weight: 700;
  padding: 1.0416666667vw 3.2552083333vw 1.0416666667vw 7.1614583333vw;
  font-size: 4.1666666667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_qa dt {
    font-size: 2.0833333333vw;
    padding: 0.3255208333vw 3.515625vw 0.5208333333vw 6.25vw;
  }
}
.sec08_qa dt .sec08_qa_mark {
  top: 0;
  left: 2.0833333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_qa dt .sec08_qa_mark {
    top: 0vw;
    left: 3.2552083333vw;
  }
}
.sec08_qa dd {
  background: #fff;
  position: relative;
  border-left: 2px dashed #00416a;
  border-right: 2px dashed #00416a;
  border-bottom: 2px dashed #00416a;
  font-weight: 700;
  line-height: 1.6;
  font-size: 3.6458333333vw;
  padding: 2.6041666667vw 3.2552083333vw 3.90625vw 7.8125vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_qa dd {
    font-size: 1.8229166667vw;
    padding: 1.171875vw 3.515625vw 1.3020833333vw 6.9010416667vw;
  }
}
.sec08_qa dd .sec08_qa_mark {
  color: #00416a;
}
.sec08_qa dd .marker {
  background: linear-gradient(0deg, #ffda13 20%, transparent 20%);
}
.sec08_qa dd .sec08_qa_mark {
  top: 1.3020833333vw;
  left: 2.0833333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec08_qa dd .sec08_qa_mark {
    top: 0.6510416667vw;
    left: 3.2552083333vw;
  }
}
.sec08_qa_note {
  font-weight: 500;
  /* メディアクエリ用 */
  /* メディアクエリ用 */
}
@media screen and (max-width: 768px) {
  .sec08_qa_note {
    font-size: 2.2135416667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec08_qa_note {
    font-size: 1.1067708333vw;
  }
}

/* ========================================
■ sec09
======================================== */
#sec09 {
  background: url(../images/sec09_bg01.png) no-repeat center top;
  background-size: cover;
  padding-top: 7.5520833333vw;
  padding-bottom: 3.6458333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec09 {
    background: url(../images/sec09_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding-top: 5.4036458333vw;
    padding-bottom: 4.5572916667vw;
  }
}

.sec09 {
  margin: 0 auto;
  /* メディアクエリ用 */
}

/* ========================================
■ sec10
======================================== */
#sec10 {
  background: url(../images/sec10_bg01.png) no-repeat center top;
  background-size: cover;
  padding: 5.2083333333vw 0 5.2083333333vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  #sec10 {
    background: url(../images/sec10_bg01_pc.png) no-repeat center top;
    background-size: cover;
    padding: 2.6041666667vw 0 1.953125vw;
  }
}

.sec10_btn {
  display: block;
  width: 100vw;
  margin: 0 auto;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  .sec10_btn {
    width: 50vw;
  }
}

/* ========================================
    ■ footer
======================================== */
footer {
  background: #0065b4;
  padding: 1.3020833333vw 0;
  color: #fff;
  font-size: 1.5625vw;
  text-align: center;
  letter-spacing: 0.1em;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  footer {
    padding: 0.3255208333vw 0;
    font-size: 1.1067708333vw;
  }
}
footer.main {
  padding-bottom: 37.7604166667vw;
  /* メディアクエリ用 */
}
@media screen and (min-width: 769px) {
  footer.main {
    padding-bottom: 0.6510416667vw;
  }
}
