@charset "UTF-8";
/* =====================
  リセット
 ======================= */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Work+Sans:wght@600;700&family=Quicksand:wght@700&display=swap");

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%;
  font-weight: normal;
  vertical-align: baseline;
  background: transparent;
}

html {
  font-size: 62.5%;
}

p {
  font-size: 1.4rem;
}

:root {
  --rblack: #484848;
  --rb0: #d8f5f9;
  --rb1: #36CCDA;
  --rb2: #0097AC;
  --rb3: #003589;
  --b0: #0097ac66;
  --rlgray1: #FAFAFA;
  --rlgray2: #F4F4F4;
  --rlgray3: #efefef;
  --rgray1: #e1e1e1;
  --rgray2: #d8d8d8;
  --rgray3: #cbcbcb;
  --rgray4: #adadad;
  --rorange: #f78c15;
  --ryellow: #fff2cf;
  --rred: #dc241f;
  --ryellow-green: #87d322;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

ul,
ol {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
}

.sp_only {
  display: contents;
}

@media screen and (max-width: 767px) {
  .sp_only {
    display: block;
  }
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
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;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

i,
address,
em {
  font-style: normal;
}

/* =====================
  common
 ======================= */
.ttl_blue {
  color: #0C76BE;
  letter-spacing: 0.05em;
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 60px;
  text-align: center;
  line-height: 1.6;
}

.ttl_blue .s {
  font-size: 24px;
  font-weight: inherit;
  display: block;
}

@media screen and (max-width: 767px) {
  .ttl_blue {
    font-size: 20px;
    margin-bottom: 40px;
  }

  .ttl_blue .s {
    font-size: 16px;
  }
}

.block_btn__order {
  margin-top: 50px;
}

.block_btn__order_catch {
  font-size: 22px;
  margin: 0 0 20px;
}

.block_btn__order_link {
  width: 505px;
  border-radius: 100px;
  background: #F78C15;
  color: #fff;
  font-size: 32px;
  line-height: 1;
  text-align: center;
  padding: 13px 30px;
  margin: 0 auto;
  display: flex;
  align-items: center;
}

.block_btn__order_link_free {
  color: #000;
  font-size: 10px;
  margin: 0 30px 0 0;
  display: flex;
  align-items: flex-end;
}

.block_btn__order_link_free_txt {
  width: 74px;
  height: 74px;
  border-radius: 8px;
  background: #fff;
  font-size: 25px;
  font-weight: bold;
  line-height: 1.1;
  padding: 12px 12px 7px 12px;
  margin: 0 3px 0 0;
  display: inline-block;
}

.block_btn__order_link_label {
  letter-spacing: 0.08em;
}

.block_btn__order_note {
  font-size: 16px;
  margin: 25px 0 0;
  text-align: center;
}

.example {
  font-size: 0.7em;
  vertical-align: top;
}

@media screen and (max-width: 767px) {
  .block_btn__order {
    margin-top: 4rem;
  }

  .block_btn__order_catch {
    font-size: 16px;
    line-height: 1.6;
    margin: 0 0 15px;
  }

  .block_btn__order_link {
    width: auto;
    font-size: 22px;
    padding: 13px 20px;
  }

  .block_btn__order_link_free {
    margin: 0 20px 0 0;
  }

  .block_btn__order_link_free_txt {
    width: 52px;
    height: 52px;
    font-size: 18px;
    padding: 8px 5px 5px 5px;
  }

  .block_btn__order_note {
    font-size: 12px;
    margin: 10px 0 0;
  }
}

/* =====================
  テントコースLP
 ======================= */
body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0;
  color: var(--rblack);
}

body * {
  box-sizing: border-box;
}

img {
  max-width: 100%;
  display: block;
}

li {
  list-style: none;
}

h1,
h2,
h3,
p {
  margin: 0;
}

.clearfix {
  clear: both;
}

a {
  color: #292929;
  transition: all 0.2s ease;
  text-decoration: none;
}

a:hover {
  opacity: 0.7;
}

.t-center {
  text-align: center;
}

.t-right {
  text-align: right;
}

.t-left {
  text-align: left;
}

.t-bold {
  font-weight: 700;
}

.underline {
  background: linear-gradient(transparent 70%, rgba(251, 248, 119, 0.69) 70%);
}

.inner {
  width: 100%;
  max-width: 1032px;
  padding: 0 16px;
  margin: 0 auto;
}

.inner.wide {
  max-width: 1232px;
}

/* .section {
  padding: 80px 0;
} */

.btn {
  background: #D52D2D;
  border-radius: 5px;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  margin: auto;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 316px;
  height: 70px;
  letter-spacing: 0.05em;
}

.btn span {
  position: relative;
}

.btn span:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent currentColor;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -20px;
  margin: auto;
}

.ttl1 {
  padding-left: 150px;
  position: relative;
  margin-bottom: 100px;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.3611111111;
}

.ttl1:before {
  content: "";
  width: 100px;
  height: 11px;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  background: linear-gradient(to bottom, rgb(0, 107, 175) 0%, rgb(0, 145, 198) 100%);
}

.ttl1.red:before {
  background: #AD4449;
}

.ttl2 {
  letter-spacing: 0.05em;
  position: relative;
  font-size: 32px;
  font-weight: 700;
  /* padding: 23px 50px; */
  margin: 0 auto 60px;
  text-align: center;
  line-height: 1.4;
}

.ttl2::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -2rem;
  display: inline-block;
  width: 2rem;
  height: .2rem;
  transform: translate(-50%);
  background-color: var(--rb2);
}

span.s {
  /* word-break: keep-all; */
  font-size: 1.6rem;
  font-weight: 500;
  margin-top: 1rem;
  display: block;
  line-height: 1.4;
  word-break: keep-all;
}

.tax,
.sub {
  font-size: 0.7em;
  padding-left: .4em;
}

.kome {
  font-size: 1.2rem;
  vertical-align: top;
  padding-left: .4rem;
}

/* section {
  margin-bottom: 8rem;
} */

#tent,
#price,
#reason,
#media,
#no1,
.order {
  margin-bottom: 0;
}

#price,
#media,
.order {
  padding: 8rem 0;
}

#tent {
  padding: 10rem 0;
}

.red {
  color: var(--rred);
}

.note {
  font-size: 1.2rem;
  text-indent: -1em;
  padding-left: 1em;
  text-align: left;
  line-height: 1.4;
}

/* =====================
 ヘッダー
 ======================= */

.header {
  width: 100%;
}

.header .h_inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px;
  height: 80px;
}

.header .logo {
  max-width: 16rem;
  position: fixed;
  top: 14px;
  left: 6rem;
  z-index: 1000;
  background: #ffffffe0;
  border-radius: .5rem;
  padding: .8rem 2rem;
}

.header .btn-small {
  width: 180px;
  height: 50px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  margin-right: 15px;
  position: fixed;
  top: 15px;
  right: 30px;
  z-index: 1000;
}

/* =====================
キービジュアル
 ======================= */
.sp {
  display: none;
}

.kv {
  margin-bottom: 10rem;
}

.kv_inner {
  position: relative;
}

.kv_img {
  width: 100%;
  margin-left: auto;
  height: 72rem;
  object-fit: cover;
}

.kv_circle {
  position: absolute;
  bottom: -6%;
  left: 14%;
  display: inline-block;
  width: 24rem;
  height: 24rem;
  border-radius: 50%;
  /* background: #F8CD15; */
  background: rgb(0, 151, 172, 72%);
  text-align: center;
  line-height: 80px;
  color: #fff;
}

.kv_circle div {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -46%);
}

.kv_circle p {
  font-weight: 700;
  line-height: 1.2857142857;
  font-size: 2.4rem;
}

.kv_circle p span {
  font-size: 4rem;
  font-weight: 700;
}

.kv_circle p.tax {
  font-size: 1em;
}

.kv_box {
  position: absolute;
  top: 7%;
  left: 9%;
  z-index: 3;
}

.kv_box h1 {
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 1.3;
  color: #451500;
}

.kv_box h2 {
  font-size: 2.05vw;
  font-weight: 700;
  color: #0C76BE;
  margin-top: 16px;
}

.kv_box h3 {
  font-size: 24px;
  line-height: 1.375;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 8px;
}

.kv_box .no1_box {
  margin-top: 23px;
  display: flex;
  align-items: center;
}

.kv_box .no1_box .no1_img {
  width: 135px;
  margin-right: 17px;
}

.kv_box .no1_box dl {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}

.kv_box .no1_box dl:last-child {
  margin-bottom: 0;
}

.kv_box .no1_box dl dt {
  width: 187px;
  color: #CA9841;
  font-size: 14px;
  font-weight: 700;
}

.kv_box .no1_box dl dd {
  color: #CA9841;
  font-size: 20px;
  font-weight: 700;
  display: flex;
  align-items: center;
  flex-grow: 1;
}

.kv_box .no1_box dl dd:before {
  content: "";
  width: 31px;
  height: 21px;
  background: url(https://rinavis.com/s/img/quick/ico_crown.png) no-repeat center/contain;
  margin-right: 7px;
}

.kv_box ul {
  display: flex;
  margin-top: 32px;
}

.kv_box ul li {
  width: 115px;
  margin-right: 12px;
}

.kv_box ul li img {
  filter: drop-shadow(0px 13px 16px rgba(0, 0, 0, 0.09));
}

.kv_box .notice {
  text-align: right;
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  font-size: 10px;
  margin-top: 18px;
}

.kv_box .kv-subttl {
  font-size: 3.2rem;
  line-height: 1.3;
  font-weight: 500;
  color: #451500;
}

#message .msg_area {
  color: var(--rblack);
  text-align: center;
  /* margin-top: 8rem; */
}

#message .msg_area p {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.4;
}

#message .msg_area .msg_txt1 {
  font-size: 3.2rem;
  padding: 0 2rem;
  word-break: keep-all;
}

#message .msg_area .msg_txt2 {
  margin-top: 2rem;
  font-size: 1.8rem;
  font-weight: 500;
  padding: 0 2rem;
  word-break: keep-all;
}

@media (max-width: 820px) {
  .kv {
    margin-bottom: 4rem;
  }

  .kv_circle {
    width: 18rem;
    height: 18rem;
    left: 4%;
    bottom: -6%;
  }

  .kv_circle p {
    font-size: 1.8rem;
  }

  .kv_circle p span {
    font-size: 3.2rem;
  }

  #tent,
  #price,
  #media,
  .order {
    padding: 4rem 0;
  }


  .kv_box .kv-subttl {
    font-size: 4vw;
    line-height: 1.5;
  }

  #message .msg_area .msg_txt1 {
    font-size: 2rem;
    margin-bottom: 2rem;
  }

  #message .msg_area .msg_txt2 {
    font-size: 1.4rem;
    margin-bottom: 4rem;
  }

  .ttl2 {
    font-size: 1.8rem;

  }

  .tent ul.merit li h3 {
    font-size: 1.8rem;
  }

  .reason_box .txt_box h3 {
    font-size: 2.4rem;
    line-height: 1.4;
  }
}

@media (max-width:460px) {
  .kv_circle {
    width: 14rem;
    height: 14rem;
  }

  .kv_circle p {
    font-size: 1.4rem;
  }

  .kv_circle p span {
    font-size: 2.4rem;
  }

}

/* =====================
料金表
 ======================= */

#price {
  /* padding: 85px 0; */
  /* background: var(--rb2); */
  background: var(--b0);
}

#price .price_bg {
  background: #fff;
  border-radius: 3rem;
  padding: 2rem;
}

#price .price_bg_border {
  border-radius: 2rem;
  padding: 6rem 4rem;
  border: .2rem dotted #ccc;
}

#price .plus_icon {
  position: relative;
  width: 3rem;
  height: .8rem;
  background: var(--rb1);
  margin: 4rem auto;
}

#price .plus_icon::after {
  position: absolute;
  display: block;
  content: "";
  width: .8rem;
  height: 3rem;
  margin-left: -.4rem;
  bottom: -1.1rem;
  left: 50%;
  background: var(--rb1);
}

#price .price_light h3 {
  background-color: #0c76be;
  padding: 15px;
  border-radius: 10px;
  margin-bottom: 20px;
  color: #fff;
}

#price .price_standard h3 {
  background-color: #45b14e;
  padding: 15px;
  border-radius: 10px;
  margin-bottom: 20px;
  color: #fff;
}

#price .price_premium h3 {
  background-color: #f78c15;
  padding: 15px;
  border-radius: 10px;
  margin-bottom: 20px;
  color: #fff;
}

#price .price_course h3 span {
  font-size: 18px;
  font-weight: 500;
}

#price .price_course_txt {
  margin-bottom: 20px;
  text-align: left;
  font-weight: 500;
  line-height: 1.5;
}

/* #price .price_course_lst {
  display: flex;
  align-items: flex-start;
  padding-bottom: 50px;
} */

/* #price .price_course {
  border: 3px dotted #b5b5b6;
  border-radius: 20px;
  padding: 20px;
  margin: 0 5px;
} */

#price .price_course h3 {
  font-size: 23px;
  text-align: center;
  font-weight: 500;
  line-height: 1.2;
}

#price .price_course h4 {
  font-size: 20px;
  text-align: center;
  font-weight: 500;
  line-height: 1.2;
  border-top: 2px solid #0C76BE;
  padding-top: 10px;
  margin-bottom: 10px;
}

#price .price_option_item_lst_default {
  margin-bottom: 20px;
}

#price .price_option_item_default {
  position: relative;
  line-height: 2;
  font-size: 20px;
}

#price .price_option_item_default::after {
  content: '';
  display: block;
  position: absolute;
  top: 10px;
  right: 0;
  width: 18px;
  height: 10px;
  border-left: 4px solid #f78c15;
  border-bottom: 4px solid #f78c15;
  transform: rotate(-45deg);
}

#price .price_option_item_lst_option {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  line-height: 2;
  font-size: 18px;
  margin-bottom: 10px;
}

#price .price_option_item_lst_option dt {
  width: 50%;
  line-height: 1.1;
}

#price .price_option_item_lst_option dd {
  width: 50%;
  text-align: right;
}

#price .block-btn {
  text-align: center;
  margin: 4rem 0 1rem;
}

#price .block-btn-a {
  width: 50%;
  /* border-radius: 10px; */
  border-radius: 4rem;
  font-size: 23px;
  color: #fff;
  text-decoration: none;
  line-height: 1;
  padding: 2.4rem;
  display: inline-block;
  background: var(--rorange);
}

#price .block-btn-a span {
  font-weight: 500;

}

#price .price_light .block-btn-a {
  background: #0c76be;
}

#price .price_standard .block-btn-a {
  background: #45b14e;
}

#price .price_premium .block-btn-a {
  background: #f78c15;
}

#price .price_menu dl.price_menu_course {
  font-size: 2.4rem;
  padding: 2.4rem;
  border-radius: 1rem;
  margin-bottom: 2rem;
  background: var(--rb2);
  color: #fff;
  display: flex;
  justify-content: space-between;
  margin-top: 4rem;
}

#price .price_menu dl.price_menu_course dt,
#price .price_menu dl.price_menu_course dd {
  font-weight: 700;
}

#price .price_menu p {
  margin-bottom: 1.6rem;
  padding: 0 4rem;
}

.price_menu_option {
  margin-bottom: 1rem;
}

#price .price_menu .price_menu_option h3 {
  font-size: 2.4rem;
  padding: 2.4rem;
  border-radius: 1rem;
  margin-bottom: 2rem;
  background: var(--rb1);
  font-weight: 700;
  text-align: center;
  color: #fff;
}

.price_menu_option dl {
  padding: 2rem 0;
}

.price_menu_option dl+dl {
  border-left: .1rem solid #ccc;
}

#price .price_menu .price_menu_option .opitem {
  font-size: 1.8rem;
  padding: 1rem 4rem;
  font-weight: 700;
  display: flex;
  justify-content: space-between;
  /* margin-bottom: .8rem; */
}

#price .price_menu .price_menu_option .opitem dt,
#price .price_menu .price_menu_option .opitem dd {
  font-weight: 700;
}

.price_menu_option>div {
  display: flex;
  justify-content: space-between;
  margin-top: 2rem;
}

.price_menu_option>div dl {
  padding: 2rem 0;
  width: 50%;
}

@media (max-width:1000px) {
  #price .price_menu .price_menu_option .opitem {
    padding: 1rem 2rem;
  }

  #price .price_bg_border {
    padding: 6rem 2rem;
  }
}

@media (max-width:820px) {
  span.s {
    font-size: 1.3rem;
  }

  #price .price_bg {
    border-radius: 1rem;
    padding: .4rem;
  }

  #price .price_bg_border {
    border-radius: .8rem;
    padding: 4rem 1rem;
  }

  #price .price_menu dl.price_menu_course {
    font-size: 1.6rem;
    padding: 1rem 1.6rem;
    border-radius: .4rem;
    margin-bottom: 1rem;
    margin-top: 2rem;
  }

  #price .price_menu p {
    margin-bottom: 1rem;
    padding: 0 2rem;
  }

  #price .plus_icon {
    margin: 2.4rem auto;
  }

  .price_menu_option>div {
    flex-direction: column;
    margin-top: 0;
  }

  .price_menu_option>div dl {
    width: 100%;
  }

  .price_menu_option dl {
    padding: 1rem 0;
  }

  .price_menu_option dl+dl {
    border-top: .1rem solid #ccc;
  }

  .price_menu_option dl+dl {
    border-left: none;
  }

  #price .price_menu .price_menu_option .opitem {
    font-size: 1.4rem;
    padding: .8rem;

  }

  #price .price_menu .price_menu_option h3 {
    font-size: 1.6rem;
    padding: 1rem;
    border-radius: .4rem;
    margin-bottom: 1rem;
  }

  #price .block-btn-a {
    width: 100%;
    padding: 18px 15px 14px;
  }

}

/* =====================
メリット
 ======================= */

.tent {
  background: #FAF3E4;
  padding: 244px 0 104px;
  text-align: center;
  margin-top: 8rem;
}

.title_img {
  width: 10rem;
  margin: 0 auto 1rem;
}

/* .ttl2::after {
  position: absolute;
  content: "";
  background: url(../img/tent_item1_2.png) no-repeat center/contain;
  width: 173px;
  width: 100%;
  height: 37px;
  height: 2.4rem;
  top: -38px;
  left: 50%;
  transform: translateX(-50%);
} */

.tent ul.merit {
  display: flex;
  flex-wrap: wrap;
  /* justify-content: center; */
  align-content: space-between;
  padding-bottom: 4rem;
  gap: 4rem;
  width: 100%;
}

.tent ul.merit li {
  width: calc((100% - 12rem) / 4);
  /* width: 33%; */
  /* min-width: 240px; */
  /* margin-bottom: 56px; */
  /* padding: 0 5px; */
}

.tent ul.merit li img {
  width: 80%;
  max-width: 160px;
  margin: 0 auto 24px;
}

.tent ul.merit li h3 {
  font-weight: 700;
  font-size: 2rem;
  margin-bottom: 16px;
  line-height: 1.6;
}

.tent ul.merit li p {
  line-height: 1.4;
}

.tent_attention {
  font-size: 12px;
  line-height: 2;
  text-align: center;
}

/* =====================
No1訴求
 ======================= */

#no1 {
  padding: 14rem 0;
}

.no1 {
  background: var(--rlgray3);
}

.no1 h2 {
  display: flex;
  align-items: center;
  margin-bottom: 57px;
  text-align: center;
  justify-content: center;
}

.no1 h2 span {
  font-size: 4rem;
  font-weight: 700;
  line-height: 40px;
  margin-right: 40px;
}

.no1 h2 span em {
  font-size: 30px;
  font-weight: 700;
}

.no1 h2 strong {
  margin-right: 60px;
}

.no1 dl {
  display: flex;
  align-items: center;
  margin-bottom: 30px;
  justify-content: space-between;
}

.no1 dl:last-of-type {
  margin-bottom: 0;
}

.no1 dl dt {
  /* width: 56.7%; */
  flex-shrink: 0;
  font-size: 20px;
  font-weight: 500;
  display: flex;
  align-items: center;
}

.no1 dl dt strong {
  font-family: "YuMincho", "游明朝", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: 3.6rem;
  font-weight: 400;
  vertical-align: middle;
}

.no1 dl dd {
  display: flex;
  align-items: center;
  font-size: 2rem;
  font-weight: 700;
}

.no1 dl dd i {
  width: 35px;
  height: 23px;
  background: url(https://rinavis.com/s/img/quick/ico_crown.png) no-repeat center/contain;
  margin: 0 8px 0 17px;
}

.no1 dl dd em {
  font-family: "Work Sans", sans-serif;
  font-size: 24px;
  font-weight: 600;
}

.no1 .notice {
  margin-top: 57px;
  font-size: 10px;
  font-weight: 500;
  line-height: 1.4;
}

.no1_text {
  display: table;
  margin: 0 auto;
  width: 100%;
  padding: 0 12rem 0 4rem;
}

@media (max-width:1200px) {
  .no1 h2 span {
    font-size: 3vw;
  }

  .no1 dl dt strong {
    font-size: 3vw;

  }

  .no1 dl dd {
    font-size: 2vw;
  }
}

@media (max-width:820px) {
  #no1 {
    padding: 4rem 0;

  }

  .no1 h2 {
    flex-wrap: wrap;
    margin-bottom: 37px;
  }

  .no1 h2 span {
    font-size: 1.8rem;
    line-height: 30px;
    margin-right: 0;
    margin-bottom: 18px;
    width: 100%;
  }

  .no1 h2 span em {
    font-size: 22px;
  }

  .no1 h2 strong {
    margin-right: 17px;
  }

  .no1 h2 strong img {
    width: 116px;
  }

  .no1 h2>img {
    width: 103px;
  }

  .no1 dl {
    /* display: block; */
    margin-bottom: 27px;
  }

  .no1 dl dt {
    /* width: auto; */
    /* display: inline-block; */
    font-size: 12px;
    margin-right: 0;
    /* margin-bottom: 7px; */
  }

  .no1 dl dt strong {
    font-size: 23px;
    vertical-align: baseline;
  }

  .no1 dl dd {
    justify-content: flex-end;
    padding-right: 12px;
  }

  .no1 dl dd i {
    width: 35px;
    height: 23px;
    /* margin: 0 10px 0 44px; */
  }

  .no1 .notice {
    margin-top: 40px;
  }

  .no1_text {
    padding: 0;
  }
}

@media (max-width:600px) {
  .no1 h2 span {
    word-break: keep-all;
  }

  .no1 dl {
    flex-wrap: wrap;
    justify-content: center;
  }

  .no1 dl dt strong {
    font-size: 1.8rem;

  }

  .no1 dl dd {
    font-size: 1.4rem;
  }

}


/* =====================
背景画像＋訴求
 ======================= */
.reason_box {
  padding: 68px 0;
  word-break: keep-all;
}

.reason_box .txt_box {
  background: #fff;
  width: 500px;
  min-height: 402px;
  padding: 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  box-shadow: 0px 10px 10px 0px rgba(0, 0, 0, 0.16);
}

.reason_box .txt_box.transparent {
  background: #fff;
}

.reason_box .txt_box.transparent span {
  display: inline-block;
  font-size: 12px;
  line-height: 1.5;
}

.reason_box .txt_box h3 {
  color: var(--rblack);
  font-size: 32px;
  line-height: 52px;
  font-weight: 700;
}

.reason_box .txt_box h3 em {
  font-size: 60px;
  font-weight: 700;
}

.reason_box .txt_box h3 span {
  font-weight: 700;
  line-height: 40px;
}

.reason_box .txt_box h3 .fs_s {
  font-size: 20px;
}

.reason_box .txt_box h3 .fs_xs {
  font-size: 12px;
  margin-left: 1em;
}

.reason_box .txt_box h3+h3 {
  margin-top: 32px;
}

.reason_box .txt_box p {
  margin-top: 32px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
}

.reason_box .txt_box p em {
  font-weight: 700;
}

.reason_box .txt_box p em span {
  font-weight: 700;
}

.reason_box .txt_box p .fs_xs {
  font-size: 10px;
}

.reason_box .txt_box p+p {
  margin-top: 16px;
}

.reason_box .txt_box a.tel {
  pointer-events: none;
  font-family: "Work Sans", sans-serif;
  font-size: 28px;
  color: #292929;
}

.reason_box .txt_box a.tel:after {
  display: none;
}

.reason_box:nth-child(2n) .txt_box {
  margin-left: auto;
}

.reason1 {
  background: url(../../img/tent/reason1_bg.jpg) no-repeat center/cover;
}

.reason2 {
  background: url(../../img/tent/reason2_bg.jpg) no-repeat center/cover;
}

.reason3 {
  background: url(../../img/tent/reason3_bg.jpg) no-repeat center/cover;
}

@media (max-width:820px) {
  #reason {
    /* margin-bottom: 4rem; */
  }
}

/* =====================
ポイントリスト
 ======================= */
.point_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.point_list li {
  width: 48%;
  position: relative;
  padding: 80px 30px 30px;
  border: 1px solid #E8E8E8;
  border-radius: 5px;
  box-shadow: 0px 10px 10px 0px rgba(149, 149, 149, 0.16);
}

.point_list li .ttl2 {
  position: absolute;
  top: -30px;
  left: -30px;
}

.point_list li figure {
  margin-bottom: 30px;
}

.point_list li p {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  font-size: 16px;
  line-height: 1.75;
}

.point_list li p+p {
  margin-top: 15px;
}

.cta2 {
  padding: 104px 0;
}

/* =====================
メディア掲載
 ======================= */

.media .lead_txt {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 40px;
  line-height: 1.4;
  word-break: keep-all;
  text-align: center;
}

.media_list {
  max-width: 718px;
  margin: 0 auto;
  text-align: left;
}

.media_list li {
  padding: 30px 0;
  border-bottom: 1px solid var(--rb1);
  display: flex;
  align-items: center;
  font-size: 18px;
}

.media_list li:before {
  content: "";
  width: 30px;
  height: 30px;
  /* background: url(https://rinavis.com/s/img/quick/ico_tv.png) no-repeat center/contain; */
  background: url(../img/tv_icon.png) no-repeat center/contain;
  margin-right: 2rem;
  flex-shrink: 0;
}

.media_list li .date {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  width: 34.8189415042%;
}

.media_list li .name {
  font-weight: 700;
  flex-grow: 1;
}

.media_list li .comp {
  /* width: 18.3844011142%; */
  width: 24%;
}

.media .notice {
  margin-top: 72px;
  text-align: right;
  font-size: 18px;
}

section.media {
  background: #FAF3E4;
}

.media ul.media_list {
  background: #fff;
  border-radius: 1rem;
  padding: 4rem;
}


@media (max-width:820px) {
  .media ul.media_list {
    border-radius: .4rem;
    padding: 1.2rem;
  }
}

/* =====================
お客様の声
 ======================= */
.voice {
  background: #F4FAFF;
}

.voice_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: -40px;
}

.voice_list li {
  width: 47.4%;
  background: #fff;
  box-shadow: 5px 5px 40px 0px rgba(0, 0, 0, 0.04);
  border-radius: 10px;
  margin-bottom: 40px;
  padding: 26px 24px;
  line-height: 1.375;
}

.voice_list li .header_cont {
  display: flex;
  align-items: center;
  margin-bottom: 24px;
}

.voice_list li .header_cont .thumb {
  margin-right: 15px;
  width: 71px;
  height: 71px;
  background: #F4FAFF;
  border-radius: 10px;
  display: block;
  overflow: hidden;
}

.voice_list li .header_cont h3 {
  font-weight: 700;
}

.voice_list li .body_cont p {
  font-weight: 500;
}

.voice_list li .body_cont .name {
  font-weight: 700;
  width: 56px;
  text-align: center;
  margin-bottom: 24px;
}

/* =====================
過去LP使用スタイル
 ======================= */

.price .bnr {
  margin-top: -20px;
  margin-bottom: 83px;
}

.price .bnr a {
  display: block;
}

.price .bnr img {
  height: auto;
  margin: 0 auto;
}

.price_list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: -40px;
}

.price_list li {
  width: 25%;
  margin-bottom: 40px;
  display: flex;
  align-items: center;
}

.price_list li img {
  width: 61px;
  margin-right: 1em;
}

.price_list li h4 {
  color: #0C76BE;
  font-weight: 700;
  line-height: 1.375;
}

.price_list li p {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.35;
}

.price_list li p span {
  font-size: 12px;
  font-weight: 700;
}

.course {
  background: #F7F7F7;
  padding: 80px 0 52px;
  text-align: center;
}

.course .rc-tab_item {
  text-align: left;
}

/* =====================
オーダーフォーム
 ======================= */

.order {
  /* background: var(--rb0); */
  background: var(--b0);
  padding: 0 0 76px;
  /** 送料・数量は変更させない **/
}

.order h3 {
  font-size: 36px;
  font-weight: 700;
  margin-bottom: 15px;
  padding-left: 5px;
  line-height: 1.5;
}

.order .price {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 30px;
  padding-left: 5px;
}

.order .price span {
  font-size: 16px;
  font-weight: normal;
}

.order_form {
  padding: 30px;
  background: #fff;
  border: 2px solid #E4E4E4;
  border-radius: 5px;
  margin-bottom: 30px;
}

.order_form .box {
  border-bottom: 1px solid #E4E4E4;
  padding: 30px;
  background: #F7F7F7;
}

.order_form .box h4 {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 16px;
  position: relative;
}

.order_form .box .fs-c-requiredMark {
  display: inline-block;
  position: absolute;
  overflow: hidden;
  text-indent: -999em;
  width: calc(2em + 14px);
  height: 2em;
  padding: 5px 5px 3px 5px;
  left: 204px;
  top: calc(50% - 1em);
  border: 1px solid #E50000;
  font-size: 12px;
}

.order_form .box .fs-c-requiredMark::before {
  display: block;
  content: "必須";
  font-size: 12px;
  font-weight: bold;
  color: #E50000;
}

.order_form .box select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  vertical-align: middle;
  background: #ffffff;
  color: #292929;
  width: 100%;
  padding: 15px 20px;
  border-radius: 6px;
  font-size: 16px;
  border: 2px solid #777777;
  cursor: pointer;
  line-height: 1.4;
  min-height: 1.8em;
  text-transform: none;
}

.order_form .box .select_wrap {
  position: relative;
}

.order_form .box .select_wrap:after {
  position: absolute;
  bottom: 1px;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
  color: #292929;
  display: flex;
  justify-content: center;
  align-items: center;
  content: "\e90f";
  font-family: "fs-icon" !important;
  font-size: 1.8rem;
  line-height: 1;
  pointer-events: none;
  padding: 8px 18px;
  height: calc(100% - 4px);
  box-sizing: border-box;
  width: auto;
  right: 2px;
  top: 2px;
  border-left: 1px solid #777777;
  background: #fff;
}

.order_form .box input[type=text]::after {
  content: none;
}

.order_form .box input[type=radio] {
  opacity: 0;
  position: absolute;
  left: 20px;
  top: 0;
  bottom: 0;
  margin: auto;
}

.order_form .box input[type=radio]+label {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  flex-grow: 1;
  position: relative;
  word-break: keep-all;
  font-size: 16px;
  line-height: 1.5;
}

.order_form .box input[type=radio]+label:before {
  display: block;
  margin: 0 10px 0 0;
  position: relative;
  min-width: 16px;
  background: #ffffff;
  border-radius: 50%;
  border: 1px solid #707070;
  cursor: pointer;
  content: "";
  width: 24px;
  height: 24px;
}

.order_form .box input[type=radio]+label:after {
  border-radius: 50%;
  content: "";
  display: block;
  opacity: 0;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 4px;
  margin: auto;
  width: 16px;
  height: 16px;
  background: #006CAF;
}

.order_form .box input[type=radio]:checked+label:after {
  opacity: 1;
}

.order_form .box .radio_wrap {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  flex-direction: column;
  background: #fff;
  padding: 20px;
  position: relative;
}

.order_form .box input[type=text] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  vertical-align: middle;
  background: #ffffff;
  color: #292929;
  width: 100%;
  padding: 15px 20px;
  border-radius: 6px;
  font-size: 16px;
  border: 2px solid #777777;
  cursor: pointer;
  line-height: 1.4;
  min-height: 1.8em;
  text-transform: none;
}

.order_form .box p {
  margin-top: 20px;
  font-size: 14px;
  line-height: 1.6;
}

.order_form .box p.agree {
  margin-bottom: 2em;
  display: flex;
  align-items: flex-start;
}

.order_form .box p.agree i {
  width: 1em;
  height: 1em;
  margin-top: 0.3em;
  margin-right: 5px;
  background: url(https://cleaners.itembox.design/item/ssl/img2/product/bikkurimark.png) no-repeat center/contain;
}

.order_form .box p strong {
  color: red;
  font-weight: 700;
}

.order_form button {
  font-size: 0;
  margin: 0 auto;
  width: 300px;
  height: 67px;
  background: url(https://cleaners.itembox.design/item/InCartButton.gif?t=20210607135939) no-repeat center/contain;
  border: 0;
}

.order_form .button_wrap {
  margin-top: 30px;
  text-align: center;
}

.order_form .notice {
  text-align: center;
  padding-top: 15px;
  font-size: 12px;
  line-height: 1.6;
}

.order .shippingfee_wrap,
.order .quantity_wrap {
  display: none;
}

.block-order--form {
  /*width: 890px;*/
  font-size: 12px;
  line-height: 1.8;
  margin: 0 auto 80px;
  padding-top: 8rem;
}

.block-order--form .form-tent-price {
  padding: 0 30px 30px;
  font-weight: 700;
}

.block-order--form .form-tent-price p {
  font-size: 3.2rem;
  font-weight: 700;
}

.block-order--form .form-tent-price span {
  font-size: 3.2rem;
  font-weight: 700;
}

.block-order--form .form-tent-price .tax {
  font-size: .7em;
  font-weight: normal;

}

.block-order--form .cp_ipselect {
  overflow: hidden;
  width: 100%;
  text-align: center;
  margin-bottom: 10px;
}

.block-order--form .cp_ipselect select {
  width: 100%;
  padding: 18px 80px 17px 20px;
  cursor: pointer;
  color: #000;
  font-size: 16px;
  text-indent: 0.01px;
  text-overflow: ellipsis;
  border: none;
  outline: none;
  background: transparent;
  background-image: none;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.block-order--form .cp_ipselect select::-ms-expand {
  display: none;
}

.block-order--form .cp_ipselect.cp_sl02 {
  position: relative;
  border: 1px solid #000;
  border-radius: 2px;
  background: #fff;
}

.block-order--form .cp_ipselect.cp_sl02:before,
.block-order--form .cp_ipselect.cp_sl02:after {
  content: "";
  position: absolute;
  display: block;
}

.block-order--form .cp_ipselect.cp_sl02:before {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12px 9px 0 9px;
  border-color: #737373 transparent transparent transparent;
  margin: -6px 0 0;
  top: 50%;
  right: 20px;
  pointer-events: none;
}

.block-order--form .cp_ipselect.cp_sl02:after {
  width: 1px;
  height: 100%;
  background: #000;
  top: 0;
  right: 60px;
  bottom: 0;
}

.block-order--form .addCart {
  text-align: center;
  margin: 30px 0 0 !important;
  padding-bottom: 40px;
}

.block-order--form .addCart [type=submit] {
  border-radius: 10px;
  border: 0;
  background: #D52D2D;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  padding: 26px 150px;
  margin: 0 0 8px;
  display: inline-block;
  cursor: pointer;
}

.block-order--form .addCart [type=submit]:hover,
.block-order--form .addCart [type=submit]:focus {
  box-shadow: none;
  margin: 8px 0 0;
}

.block-order--form-header {
  background: #003580;
  color: #fff;
  font-size: 24px;
  text-align: center;
  line-height: 1.2;
  padding: 26px 15px;
}

.block-order--form-body {
  padding: 4rem;
  background: #fff;
  text-align: left;
  border-radius: 2rem;
}

.block-order--form-body .al {
  background: #dc241f;
  color: #fff;
  font-size: 16px;
  font-weight: normal;
  line-height: 1;
  vertical-align: middle;
  padding: 5px 10px;
  margin: 0 0 0 20px;
  display: inline-block;
}

.block-order--form-body .couBtn,
.block-order--form-body .panel form>dl {
  padding: 20px 30px 30px;
}

.block-order--form-body .panel form>dl {
  border-top: 1px solid #d6d5ce;
}

.block-order--form-body .panel form>dl:last-child {
  border-bottom: 0;
}

.block-order--form-body .couBtn>dl>dt,
.block-order--form-body .panel form>dl>dt {
  font-size: 20px;
  font-weight: bold;
  margin: 0 0 15px;
}

.block-order--form-body .couBtn>dl ul {
  margin: 0 0 0 -10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.block-order--form-body .couBtn>dl ul>li {
  width: 100%;
  border-radius: 10px;
  border: 1px solid #000;
  background: #fff;
  color: #000;
  font-size: 16px;
  line-height: 1.4;
  text-align: center;
  padding: 11px 10px 9px;
  margin: 0 0 0 10px;
  cursor: pointer;
  transition: 0.2s;
}

.block-order--form-body .couBtn>dl ul>li.is_active,
.block-order--form-body .couBtn>dl ul>li:hover {
  border-color: #0C76BE;
  background: #0C76BE;
  color: #fff;
}

.block-order--form-body .panel {
  /* display: none; */
}

.block-order--form-body .panel.is_show {
  display: block;
}

.block-order--form-body .panel form>dl>dd {
  margin: 0 0 20px;
}

.block-order--form-body .panel form>dl>dd:last-child {
  margin-bottom: 0;
}

.rc-tab_item_numcol_item {
  width: calc(50% - 10px);
  display: flex;
  justify-content: space-between;
  margin-bottom: 2rem;
  align-items: center;
  gap: 2rem;
}

.rc-tab_item_numcol_body h4 {
  font-weight: 500;
}

.rc-tab_item_numcol_img {
  width: 32%;
  position: relative;
}

.rc-tab_item_numcol_item .rc-tab_item_numcol_img::before {
  content: "";
  width: 4rem;
  height: 4rem;
  background: var(--rb1);
  display: block;
  color: #fff;
  font-weight: 500;
  border-radius: 50%;
  padding: 1rem;
  position: absolute;
  text-align: center;
}

.rc-tab_item_numcol_item:first-child .rc-tab_item_numcol_img::before {
  content: "1";
}

.rc-tab_item_numcol_item:nth-child(2) .rc-tab_item_numcol_img::before {
  content: "2";
}

.rc-tab_item_numcol_item:nth-child(3) .rc-tab_item_numcol_img::before {
  content: "3";
}

.rc-tab_item_numcol_item:nth-child(4) .rc-tab_item_numcol_img::before {
  content: "4";
}

.rc-tab_item_numcol_body {
  width: 68%;
}

@media only screen and (max-width: 950px) {
  .block-order--form {
    width: auto;
    margin: 0 auto 4rem;
    padding-top: 4rem;
  }
}

@media (max-width:820px) {
  .block-order--form-body {
    padding: 2rem;
    border-radius: .8rem;
  }

  .block-order--form .form-tent-price p {
    font-size: 2.4rem;
  }

  .block-order--form .form-tent-price span {
    font-size: 2rem;
  }

  .rc-tab_item_numcol_item .rc-tab_item_numcol_img::before {
    width: 3rem;
    height: 3rem;
    padding: .8rem;
  }
}

@media only screen and (max-width: 750px) {
  .block-order {
    font-size: 10px;
    margin: 0 0 60px;
  }

  .block-order--form .cp_ipselect select {
    padding: 10px 50px 10px 10px;
  }

  .block-order--form .cp_ipselect.cp_sl02:before {
    border-width: 9px 7px 0 7px;
    margin: -5px 0 0;
    right: 13px;
  }

  .block-order--form .cp_ipselect.cp_sl02:after {
    right: 40px;
  }

  .block-order--form .addCart {
    margin: 20px 0 0 !important;
  }

  .block-order--form .addCart [type=submit] {
    width: 100%;
    border-radius: 5px;
    font-size: 20px;
    padding: 20px;
    margin: 0 0 5px;
  }

  .block-order--form .addCart [type=submit]:hover,
  .block-order--form .addCart [type=submit]:focus {
    box-shadow: none;
    margin: 5px 0 0;
  }

  .block-order--form-header {
    font-size: 20px;
    padding: 15px 15px;
  }

  .block-order--form-body .al {
    font-size: 10px;
    margin: 0 0 0 10px;
  }

  .block-order--form-body .couBtn,
  .block-order--form-body .panel form>dl {
    padding: 20px 0;
  }

  .block-order--form-body .couBtn>dl>dt,
  .block-order--form-body .panel form>dl>dt {
    font-size: 14px;
    margin: 0 0 10px;
  }

  .block-order--form-body .couBtn>dl ul {
    margin: -10px 0 0 -10px;
  }

  .block-order--form-body .couBtn>dl ul>li {
    width: calc(50% - 10px);
    border-radius: 5px;
    font-size: 12px;
    padding: 11px 5px 9px;
    margin: 10px 0 0 10px;
  }
}

.block-order--form .cp-info {
  display: flex;
}

.block-order--form .cp-img {
  width: 40%;
}

.block-order--form .cp-txt {
  width: 60%;
  padding-left: 20px;
  font-size: 14px;
}

@media only screen and (max-width: 750px) {
  .block-order--form .cp-info {
    flex-direction: column;
    padding: 0 10px;
  }

  .block-order--form .cp-img {
    width: 100%;
    padding: 0 50px;
  }

  .block-order--form .cp-txt {
    width: 100%;
    padding-left: 0px;
    padding-top: 10px;
    font-size: 14px;
  }
}

@media (max-width:600px) {
  .rc-tab_item_numcol_item {
    width: 100%;
  }
}


/* =====================
注意事項
 ======================= */

.flow {
  background: var(--rlgray3);
  padding: 8rem 0;
  /* padding: 0 0 104px; */
}

.flow .flow_tent_txt li {
  font-size: 14px;
  margin-bottom: 1rem;
  line-height: 1.7;
  text-indent: -1em;
  padding-left: 1em;
}

.flow .flow_tent_txt .note {
  font-size: 12px;
  text-indent: -1em;
  padding-left: 1em;
}

.flow .guide-btn {
  background: var(--rb2);
  border-radius: 4rem;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  margin: 40px auto 0;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 300px;
  height: 60px;
}

.about {
  background-color: #f5f5f5;
  padding: 1rem 1rem;
  margin: 1em 0em;
}

/* =====================
フッター
 ======================= */
.footer {
  /* padding: 40px 0; */
  text-align: center;
  background: #fff;
  margin-bottom: 8rem;
}

.footer .logo {
  width: 88px;
  margin: 0 auto 24px;
}

.footer .copy {
  margin-bottom: 6px;
  margin-bottom: 1rem;
}

.footer .copy small {
  font-size: 1.2rem;
  line-height: 1.35714;
  color: #292929;
}

.footer .link a {
  font-size: 1.2rem;
  line-height: 1.35714;
  color: #292929;
}

.footer .footer__menu_course {
  padding: 90px 0;
}

.footer .footer__menu_course h2 {
  margin-bottom: 60px;
  font-size: 3rem;
}

.footer .footer__menu_course_item_wrap {
  display: flex;
  justify-content: center;
  text-align: left;
}

.footer .footer__menu_course_item {
  width: 40rem;
}

.footer .footer__menu_course_item+* {
  margin-left: 5%;
}

.footer .footer__menu_course_item h3 {
  margin-bottom: 10px;
  font-weight: 500;
  font-size: 20px;
}

.footer .footer__menu_course_item .txt_head {
  position: relative;
  cursor: pointer;
  padding-right: 25px;
}

.footer .footer__menu_course_item .txt_head::before,
.footer .footer__menu_course_item .txt_head::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 2px;
  background-color: #333;
}

.footer .footer__menu_course_item .txt_head::before {
  top: 48%;
  right: 0;
  transform: rotate(0deg);
}

.footer .footer__menu_course_item .txt_head::after {
  top: 48%;
  right: 0;
  transform: rotate(90deg);
}

.footer .footer__menu_course_item .txt_head.is_open::after {
  display: none;
}

.footer .footer__menu_course_item ul {
  font-size: 14px;
  line-height: 1.8;
}

.footer .footer__menu_course_item ul li {
  padding: 5px 0;
}

.footer .footer__menu_course_item ul li a {
  display: block;
}

.footer .footer__menu_course_item ul li ul {
  display: none;
  margin-left: 20px;
}

/* PCのみ
  ------------------------ */
@media (min-width: 767px) {
  /* .sp {
    display: none !important;
  } */

  .price_kihon_wrap .note {
    text-align: right;
  }
}



/* タブレットのみ
  ------------------------ */
@media (max-width: 980px) and (min-width: 767px) {
  .ttl1 {
    padding-left: 110px;
  }

  .ttl1:before {
    width: 70px;
  }

  .header .gnav {
    display: none;
  }

  .no1 h2 span {
    margin-right: 20px;
  }

  .no1 h2 strong {
    margin-right: 30px;
  }

  .no1 dl {
    /* flex-wrap: wrap; */
  }

  .no1 dl dt {
    /* width: 100%; */
    justify-content: center;
  }

  .no1 dl dd {
    justify-content: center;
    /* width: 100%; */
  }

  .price_list li {
    width: 33%;
  }

  .item_list li {
    width: 33%;
  }


}


/* スマホ
  ------------------------ */
@media (max-width: 820px) {
  body {
    font-size: 14px;
  }

  .sp {
    display: block;
  }

  .pc {
    display: none !important;
  }

  /* .section {
    padding: 40px 0;
  } */

  .btn {
    font-size: 18px;
    font-weight: 700;
    width: calc(100% - 30px);
    height: 60px;
  }

  .ttl1 {
    font-size: 18px;
    padding-left: 35px;
    margin-bottom: 37px;
  }

  .ttl1:before {
    width: 25px;
    height: 5px;
  }

  .ttl2 {
    font-size: 1.8rem;
    /* padding: 15px; */
    border-radius: 0;
    margin: 0 0 5rem;
    text-align: center;
  }

  .header .h_inner {
    padding: 16px;
    height: 70px;
  }

  .header .logo {
    max-width: 12rem;
    left: 1.2rem;
    padding: .4rem 1rem;
  }

  .header .btn-small {
    width: 150px;
    height: 40px;
    font-size: 15px;
    margin-right: 0;
    right: 15px;
  }

  .kv {
    /* margin-top: 22px; */
  }

  .kv_box {
    width: 90%;
    position: absolute;
    top: 4.5%;
    left: 46%;
    z-index: 3;
    transform: translateX(-40.5%);
  }

  .kv_box h1 {
    font-size: 6.48vw;
  }

  .kv_box h2 {
    font-size: 5.4vw;
    text-shadow: 0px 0px 2px rgba(255, 255, 255, 0.47);
    margin-top: 11px;
  }

  .kv_img {
    width: 100%;
    height: 40rem;
  }



  #price {
    /* padding: 60px 0; */
    /* padding: 10rem 1.6rem; */
  }

  /* #price .price_course {
    width: 100%;
    margin: 0 0 20px;
  } */

  /* #price .price_course_lst {
    flex-direction: column;
    padding-bottom: 0;
  } */

  /* #price .price_course h3 {
    font-size: 20px;
  }

  #price .price_course h4 {
    font-size: 18px;
  }

  #price .price_course_sp .rc-tab_item_ttl {
    position: relative;
    padding: 12px 24px 12px 5px;
  }

  #price .price_course_sp .rc-tab_item_ttl::before,
  #price .price_course_sp .rc-tab_item_ttl::after {
    position: absolute;
    content: "";
    width: 15px;
    height: 2px;
    background-color: #0C76BE;
  }

  #price .price_course_sp .rc-tab_item_ttl::before {
    top: 48%;
    right: 0;
    transform: rotate(0deg);
  }

  #price .price_course_sp .rc-tab_item_ttl::after {
    top: 48%;
    right: 0;
    transform: rotate(90deg);
  }

  #price .price_course_sp .rc-tab_item_ttl.is-active::after {
    top: 48%;
    right: 0;
    transform: rotate(0deg);
  }

  #price .price_option_item_lst_default {
    margin-bottom: 10px;
  }

  #price .price_option_item_default {
    line-height: 2;
    font-size: 17px;
  }

  #price .price_option_item_default::after {
    top: 5px;
    border-left: 3px solid #f78c15;
    border-bottom: 3px solid #f78c15;
  }

  #price .price_option_item_lst_option {
    line-height: 1.5;
    font-size: 15px;
    margin-bottom: 15px;
  }

  #price .price_option_item_lst_option dd {
    line-height: 2;
  }

  #price .block-btn-a {
    font-size: 20px;
  } */

  .tent {
    margin-top: 0;
    padding: 120px 0 50px;
    margin-top: 2rem;
  }

  .tent ul.merit {
    gap: 2rem;
  }

  .tent ul.merit li {
    width: calc((100% - 2rem) / 2);
    min-width: auto;
    /* margin-bottom: 40px; */
  }

  .tent ul.merit li img {
    width: 56%;
    margin-bottom: 14px;
  }

  .tent ul.merit li h3 {
    font-size: 1.6rem;
    margin-bottom: .8rem;
  }

  .tent_attention {
    font-size: 12px;
    padding: 0 20px;
  }



  .reason_box {
    padding: 170px 0 20px;
  }

  .reason_box .txt_box {
    width: 100%;
    min-height: auto;
    padding: 2rem;
    display: block;
    box-shadow: none;
  }

  .reason_box .txt_box h3 {
    /* font-size: 21px; */
    /* line-height: 34px; */
    font-size: 1.8rem;
    line-height: 1.4;
  }

  .reason_box .txt_box h3 em {
    font-size: 35px;
  }

  .reason_box .txt_box h3 span {
    line-height: 24px;
  }

  .reason_box .txt_box h3 .fs_s {
    font-size: 14px;
  }

  .reason_box .txt_box h3 .fs_xs {
    font-size: 8px;
  }

  .reason_box .txt_box h3+h3 {
    margin-top: 22px;
  }

  .reason_box .txt_box p {
    margin-top: 9px;
    font-size: 14px;
  }

  .reason_box .txt_box p .fs_xs {
    font-weight: 500;
  }

  .reason_box .txt_box a.tel {
    pointer-events: auto;
    font-size: 24px;
  }

  .reason1 {
    background: url(../../img/tent/reason1_bg_sp.jpg) no-repeat top center/100% auto;
  }

  .reason1 .txt_box,
  .reason2 .txt_box,
  .reason3 .txt_box {
    box-shadow: none;
  }

  .reason2 {
    background: url(../../img/tent/reason2_bg_sp.jpg) no-repeat top center/100% auto;
  }

  .reason3 {
    background: url(../../img/tent/reason3_bg_sp.jpg) no-repeat top center/100% auto;
  }

  .point_list li {
    width: 100%;
    margin-bottom: 65px;
    padding: 50px 22px 25px;
  }

  .point_list li:last-child {
    margin-bottom: 0;
  }

  .point_list li .ttl2 {
    width: calc(100% - 68px);
    top: -25px;
    left: 0;
    right: 0;
    margin: auto;
    border-radius: 5px;
  }

  .point_list li p {
    font-size: 14px;
  }

  .point_list li p+p {
    margin-top: 0;
  }

  .media .lead_txt {
    font-size: 14px;
    margin-bottom: 25px;
  }

  .media_list li {
    padding: 20px 10px 15px 40px;
    flex-wrap: wrap;
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", YuGothic, "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
    font-size: 12px;
    position: relative;
  }

  .media_list li:last-child {
    border-bottom: 0;
  }

  .media_list li:before {
    width: 2rem;
    height: 2rem;
    position: absolute;
    top: 1.6rem;
    left: 1rem;
  }

  .media_list li .date {
    width: 100%;
    margin-bottom: 10px;
  }

  .media_list li .name {
    width: 50%;
    font-size: 14px;
  }

  .media_list li .comp {
    width: 50%;
  }

  .media .notice {
    margin-top: 25px;
    font-size: 14px;
  }

  .voice {
    padding-top: 0;
  }

  .voice_list {
    margin-bottom: 0;
  }

  .voice_list li {
    width: 100%;
    margin-bottom: 24px;
    padding: 16px;
  }

  .voice_list li .header_cont {
    margin-bottom: 10px;
  }

  .voice_list li .body_cont p {
    font-weight: 500;
  }

  .voice_list li .body_cont .name {
    width: auto;
    padding-left: 17px;
    text-align: left;
    margin-bottom: 20px;
  }

  .price .bnr {
    margin-top: 0;
    margin-bottom: 24px;
  }

  .price_list {
    margin-bottom: -20px;
  }

  .price_list li {
    width: 50%;
    margin-bottom: 20px;
    padding-left: 8px;
    flex-grow: 1;
  }

  .price_list li img {
    width: 48px;
    margin-right: 10px;
  }

  .price_list li h4 {
    font-size: 12px;
  }

  .price_list li p {
    font-size: 15px;
  }

  .price_list li p span {
    font-size: 11px;
  }

  .course {
    padding: 40px 0;
    background: #fff;
  }

  .course .inner {
    padding: 0;
  }

  .order {
    padding-bottom: 20px;
    background: var(--rb0);
  }

  .block-order--form .form-tent-price {
    padding: 0 0 15px;
    font-size: 23px;
  }

  .block-order--form .addCart {
    padding-bottom: 0;
  }


  .flow {
    background: #fff;
    padding: 0;
    /* padding-bottom: 60px; */
  }

  .flow .inner {
    padding: 0;
  }

  .flow_list {
    margin-bottom: 0;
  }

  .flow_list li {
    width: 100%;
    min-height: auto;
    margin-bottom: 20px;
    padding: 20px 10px;
  }

  .flow_list li:last-child {
    margin-bottom: 0;
  }

  .flow_list li h3 {
    font-size: 16px;
  }

  .flow_list li h3 i {
    font-size: 51px;
    margin-right: 7px;
  }

  .flow_list li img {
    margin-bottom: 10px;
  }

  .footer .footer__menu_course h2 {
    font-size: 2.4rem;
  }

  .footer .footer__menu_course {
    padding: 60px 20px;
  }

  .footer .footer__menu_course_item_wrap {
    flex-direction: column;
  }

  .footer .footer__menu_course_item {
    width: 100%;
  }

  .footer .footer__menu_course_item+* {
    margin-left: 0;
    margin-top: 20px;
  }

  .footer .footer .block_footer__hdg_lv2 {
    font-size: 22px;
  }

  .rc-tab_item_ttl h3::after {
    top: calc(50% - 11px);
  }

  /* section {
    margin-bottom: 4rem;
  } */
}

/*# sourceMappingURL=index.css.map */