@charset "utf-8";
/* CSS Document */

/*------------------------
 common
------------------------*/

* {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 2.0em;
  letter-spacing: 0.1em;
  color: #000;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
}

@media only screen and (max-width : 768px) {
  * {
    font-size: 3.5vw;
  }
}

/* wrap header footer size -------------*/
#wrap {
  width: 100%;
  min-width: 1200px;
  position: relative;
}

header,
footer {
  width: 100%;
  min-width: 1200px;
}

header {
  padding: 0 30px 12px;
}

footer {
  padding: 22px 30px;
}

@media only screen and (max-width : 768px) {
  #wrap {
    width: 100vw;
    min-width: auto;
  }

  header,
  footer {
    width: 100vw;
    min-width: auto;
  }

  header {
    padding: 0 3vw;
  }

  footer {
    padding: 5vw 5vw;
  }
}

/* -------------*/
a {
  text-decoration: none;
}

a:hover {
  opacity: 0.5;
}

a[href^="tel:"]:hover {
  opacity: 1.0;
  cursor: default;
}

.container {
  width: 1200px;
  margin: 0 auto;
}

.container-s {
  width: 1000px;
  margin: 0 auto;
}

.flexbox {
  display: flex;
  align-items: center;
}

.flex-spcbt {
  justify-content: space-between;
}

section {
  margin-bottom: 80px;
}

@media only screen and (min-width : 769px) {
  .sp {
    display: none;
    visibility: hidden;
  }
}

@media only screen and (max-width : 768px) {
  .container {
    width: 90vw
  }

  .container-s {
    width: 90vw;
    margin: 0 auto;
  }

  section {
    margin-bottom: 15vw;
  }

  .pc {
    display: none;
    visibility: hidden;
  }
}


/* nav -------------*/
nav a {
  color: inherit;
  letter-spacing: 0.1em;
  line-height: 1.0em;
}

header nav a {
  font-size: 1.20rem;
}

header nav ul {
  text-align: center;
}

footer nav a {
  font-size: 0.80rem;
  letter-spacing: 0;
}

header nav li + li {
  margin-left: 2.0em;
}

footer nav li + li {
  margin-left: 1.0em;
}

@media only screen and (min-width : 769px) {
  header nav ul {
    display: flex;
    justify-content: center;
  }

  header nav li {
    display: block;
  }
}

@media only screen and (max-width : 768px) {
  header nav {
    display: none;
  }

  header nav.openNav {
    display: block;
    position: absolute;
    left: 0;
    z-index: 100;
    width: 100vw;
    margin-top: 1px;
    padding: 10vw 0;
    background: rgba(243, 246, 251, 0.95);
    animation: navOpen 0.3s linear;
  }

  @keyframes navOpen {
    0% {
      opacity: 0
    }

    100% {
      opacity: 10
    }
  }

  header nav.openNav a {
    font-size: 1.2rem;
  }

  header nav.openNav ul {
    display: flex;
    flex-direction: column;
  }

  header nav.openNav ul li {
    margin: 0 auto 1.5rem;
  }
}

/**/
.nvUpp {
  position: relative;
}

@media only screen and (min-width : 769px) {

  .nvChild {
    width: 10em;
    padding: 0.5em 0.8em;
    position: absolute;
    left: 0%;
    z-index: 10;
    /*background:rgba(0,58,152,0.9);*/
    background: rgba(255, 255, 255, 1.0);
    /* border-top:2px solid #003a98; */
  }

  .nvChild ul {
    display: block;
    text-align: left;
  }

  .nvChild li {
    display: block;
  }

  .nvChild li + li {
    margin: 0.2em auto 0;
    padding-top: 0.2em;
    border-top: 1px solid #eee;
  }

  .nvChild li a {
    font-size: 1.0rem;
  }

  .nvChild {
    display: none;
  }
}

@media only screen and (max-width : 768px) {

  .nvUpp,
  .nvChild {
    position: static;
  }

  .nvChild {
    display: block !important;
  }

  .nvChild ul {
    margin-top: 0.2em;
  }

  .nvChild li {
    margin: 0 auto !important;
  }

  .nvChild li a {
    font-size: 1.05rem !important;
  }

}

/* menu-trigger -------------*/
@media only screen and (min-width : 769px) {
  #menu-trigger {
    display: none !important;
  }
}

#menu-trigger,
#menu-trigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}

#menu-trigger {
  position: absolute;
  width: 12vw;
  height: 12vw;
  right: 2.5vw;
  top: -0.5vw;
  background-color: #004fa2;
  z-index: 200;
}

a#menu-trigger:hover {
  opacity: 1.0;
}

#menu-trigger span {
  position: absolute;
  width: 60%;
  height: 0.7vw;
  left: 20%;
  background-color: #fff;
}

#menu-trigger span:nth-of-type(1) {
  top: 3vw;
}

#menu-trigger span:nth-of-type(2) {
  top: 5.5vw;
}

#menu-trigger span:nth-of-type(3) {
  bottom: 3vw;
}

/**/
#menu-trigger.active span:nth-of-type(1) {
  left: 21%;
  -webkit-transform: translateY(2.6vw) rotate(-45deg);
  transform: translateY(2.6vw) rotate(-45deg);
}

#menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}

#menu-trigger.active span:nth-of-type(3) {
  left: 21%;
  -webkit-transform: translateY(-2.8vw) rotate(45deg);
  transform: translateY(-2.8vw) rotate(45deg);
}

/* header -------------*/
header {
  border-bottom: 1px solid #d9d9d9;
}

header .flexbox {
  margin: 30px auto;
}

@media only screen and (max-width : 768px) {
  header .flexbox {
    margin: 3vw auto 4vw;
  }
}

/* rogo */
header h1 {
  margin: 0;
}

header h1 a {
  display: block;
  width: 306px;
  height: 60px;
  margin: 0;
  background-image: url(assets/images/rogo.jpg);
}

header h1 span {
  display: none;
}

@media only screen and (max-width : 768px) {
  header h1 a {
    width: 50vw;
    height: 10vw;
  }
}

/* TELs */
.TELs a {
  display: block;
}

.TELs span {
  display: none;
}

.TELs,
.tel01,
tel02 {
  width: 405px;
}

.TELs {
  height: 54px;
}

.TELs .tel01 {
  height: 25px;
  background-image: url(assets/images/tel01.png);
}

.TELs .tel02 {
  height: 20px;
  margin-top: 10px;
  background-image: url(assets/images/tel02.png);
}

@media only screen and (max-width : 768px) {
  .TELs {
    display: none;
  }
}

/* TELs-SP */
@media only screen and (min-width : 769px) {
  header nav .TELs-SP {
    display: none;
  }
}

.TELs-SP {
  width: 90vw;
  margin: 5vw auto;
  padding-top: 5vw;
  border-top: 1px solid #d9d9d9;
}

.TELs-SP a {
  display: block;
  font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  width: 80vw;
  margin: 8vw auto;
  line-height: 1.3em;
  text-align: center;
}

.TELs-SP a::before {
  content: "";
  display: block;
  width: 100%;
  margin-bottom: 0.5em;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
}

.TELs-SP span {
  display: none;
}

.TELs-SP a.tel01 {
  font-size: 1.3rem;
}

.TELs-SP a.tel01::before {
  height: 7vw;
  background-image: url(assets/images/tel01-sp.png);
}

.TELs-SP a.tel02::before {
  height: 7vw;
  margin-top: 10px;
  background-image: url(assets/images/tel02-sp.png);
  background-size: 120%;
}


/* main -------------*/
.mainImg {
  position: relative;
  width: 100%;
  height: 200px;
  margin-bottom: 15px;
  background-size: cover;
}

.mainImg#home {
  height: 600px;
  margin-bottom: 0;
/* 更新時に0にする */
  margin-bottom: 80px;
}

.mainImg h1 {
  display: block;
  width: 500px;
  height: 100px;
  position: absolute;
  top: 50px;
  left: calc(50% - 250px);
}

.mainImg h1 span {
  display: none;
}

@media only screen and (max-width : 768px) {
  .mainImg {
    height: 35vw;
    margin-bottom: 0;
  }

  .mainImg h1 {
    width: 100%;
    height: 50%;
    top: 25%;
    left: 0;
  }

  .mainImg#home {
    height: 80vw;
    margin-bottom: 15vw;
  }
}

/* pankuzu */
.pankuzu {
  width: 1200px;
  margin: 0 auto 50px;
  text-align: right;
}

.pankuzu li,
.pankuzu li a {
  font-size: 0.8rem;
  color: #000;
}

.pankuzu li + li::before {
  content: "";
  display: inline-block;
  width: 0.4em;
  height: 0.4em;
  margin: 0 0.6em 0.13em;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  transform: rotate(45deg)
}

@media only screen and (max-width : 768px) {
  .pankuzu {
    width: 95vw;
    margin: 0 auto 8vw;
  }
}

/* listBox */
.listBox li {
  position: relative;
  padding-left: 1.8em;
}

.listBox li::before {
  content: "";
  position: absolute;
  top: 0.5em;
  left: 0;
  display: inline-block;
  width: 1.2em;
  height: 1.0em;
  background-image: url(assets/images/list-icon.png);
  background-size: contain;
  background-repeat: no-repeat;
}

@media all and (-ms-high-contrast:none) {
  .listBox li::before {
    top: 0.3em;
  }
}

/* note */
.note {
  width: 860px;
  padding: 50px 40px 30px;
  margin: auto;
  background-color: #f1eef4;
  border: 2px solid #003a98;
  border-radius: 6px
}

.note h3 {
  font-size: 1.4rem;
  font-weight: bold;
  text-align: center
}

@media only screen and (max-width : 768px) {
  .note {
    width: 90vw;
    padding: 2.0em 1.0em 1.0em;
    margin: 10vw auto 15vw;
  }
}

.note-special {
  padding: 20px 0;
  background: #fff;
  border-radius: 6px;
  margin-bottom: 2.5em;
}

@media all and (-ms-high-contrast:none) {
  .note-special {
    padding: 22px 0 18px;
  }
}

.note-special h4 {
  width: 300px;
  font-size: 1.27rem;
  color: #000;
  text-align: center;
}

.note-special ul {
  width: calc(100% - 300px)
}

.note-special li {
  display: block;
}

.note-special li + li {
  margin-top: -0.3em;
}

@media only screen and (max-width : 768px) {
  .note-special {
    flex-direction: column;
    padding: 1.8em 1.8em;
  }

  .note-special h4 {
    width: 100%;
  }

  .note-special h4 {
    margin-bottom: 0.8em;
  }

  .note-special li {
    line-height: 1.6em
  }

  .note-special li + li {
    margin-top: 0.5em;
  }

  .note-special li + li::before {
    top: 0.3em;
  }
}

/**/

h1,
h2,
h3,
h4 {
  color: #003a98;
}

h2 {
  padding-bottom: 1.5rem;
  margin-bottom: 50px;
  font-size: 1.87rem;
  line-height: 1.0em;
  text-align: center;
  position: relative;
}

h2 span {
  display: block;
  margin-top: 0.3em;
  color: inherit;
  letter-spacing: 0.2em;
  font-family: 'Source Serif Pro', serif;
}

h2::after {
  content: "";
  display: block;
  width: 300px;
  height: 2px;
  background: #c4c7c7;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -150px;
}

@media only screen and (max-width : 768px) {
  h2 {
    margin-bottom: 10vw;
  }

  h2 span {
    margin-top: 0em;
  }

  h2::after {
    width: 50vw;
    margin-left: -25vw;
  }
}

/* h2-sl */
h2.h2-sl,
h3.h2-sl {
  font-size: 1.6rem;
  text-align: left;
  padding: 0;
  position: relative;
  margin-bottom: 0.8em;
}

h2.h2-sl::before,
h3.h2-sl::before {
  content: "";
  display: block;
  width: 1.4em;
  height: 1.4em;
  position: absolute;
  top: -0.7em;
  z-index: -1;
  border-top: 1px solid #003a98;
  background-color: #fff;
  transform: rotate(135deg);
}

h2.h2-sl::after,
h3.h2-sl::after {
  content: "";
  display: block;
  height: 1px;
  background-color: #003a98;
  position: absolute;
  right: 0;
  top: 0.5em;
  left: inherit;
  bottom: inherit;
}


ruby{
  color: inherit;
  font-size: 100%;
}
ruby rt{
  color: inherit;
  font-size: 50%;
  line-height: 1;
}


/* h2-sl の修正版 */

.l-title {
  overflow: hidden;
  font-size: 1.6rem;
  text-align: left;
  padding: 0;
  margin-bottom: 0.8em;
  color: #004fa2;
}
.l-title::before,
.l-title::after {
  display: none;
}
.l-title-text {
  display: inline-block;
  position: relative;
  font-size: 100%;
  color: #004fa2;
}
.l-title-text::before {
  content: "";
  display: block;
  width: 1.4em;
  height: 1.4em;
  position: absolute;
  top: 20%;
  left: 100%;
  z-index: -1;
  border-top: 1px solid #003a98;
  background-color: #fff;
  translate: 0 -50%;
  rotate: 135deg;
}
.l-title-text::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #003a98;
  position: absolute;
  left: calc(100% + 1.2em);
  top: 45%;
}


@media all and (-ms-high-contrast:none) {
  h2.h2-sl::before {
    top: -0.9em;
  }

  h2.h2-sl::after {
    top: 0.3em
  }

  h3.h2-sl::before {
    top: -0.9em;
  }

  h3.h2-sl::after {
    top: 0.3em
  }
}

/**/
.read {
  color: #003a98;
  font-size: 1.07rem;
  line-height: 2.5em;
  text-align: center;
}

.pattern {
  background-image: url(assets/images/pattern.png);
  background-size: auto;
  background-position: top;
  background-repeat: repeat-x;
}

/* access-box */
.access-box {
  background: #003a98;
  margin-bottom: 0;
}

.access-box iframe {
  flex-basis: 57%;
  height: 500px;
  border: 0;
}

.access-box div > div {
  flex-basis: 43%;
  padding-left: 100px;
}

.access-box div > div h2 {
  margin-bottom: 30px;
}

.access-box div > div h3 {
  font-size: 1.40rem;
}

.access-box div > div h2,
.access-box div > div h3 {
  text-align: left;
  color: #fff;
}

.access-box div > div p,
.access-box div > div a {
  color: #fff;
}

.access-box div > div h2::after {
  background: #fff;
  opacity: 0.3;
  margin-left: 0;
  left: 0;
}

.access-box div > div a {
  display: inline-block;
  position: relative;
  margin-top: 25px;
  margin-left: 1.3em;
}

.access-box div > div a::before {
  content: "";
  position: absolute;
  top: 0.4em;
  left: -1.3em;
  display: block;
  width: 12px;
  height: 17px;
  background-image: url(assets/images/map-icon.png);
  background-size: contain;
  background-repeat: no-repeat;
}

@media only screen and (max-width : 768px) {
  .access-box {
    padding: 15vw 0;
  }

  .access-box div.flexbox {
    flex-direction: column-reverse
  }

  .access-box iframe {
    display: block;
    width: 90vw;
    flex-basis: 80vw;
  }

  .access-box div > div {
    width: 80vw;
    flex-basis: 100%;
    padding-left: 0;
    margin-bottom: 5vw;
    text-align: center;
  }

  .access-box div > div h2 {
    text-align: center;
    margin-bottom: 5vw;
  }

  .access-box div > div h2::after {
    margin-left: 15vw;
  }

  .access-box div > div h3 {
    text-align: center;
  }

  .access-box div > div a {
    margin-top: 2vw;
  }

  .access-box div > div a::before {
    width: 3.5vw;
    height: 4.5vw;
    top: 0.35em;
    left: -1.5em;
  }
}

/* ft-box */
.ft-box {
  height: 500px;
  margin-bottom: 0;
  background-image: url(assets/images/ft-bg.jpg);
  background-size: cover;
}

.ft-box div {
  color: #fff;
  text-align: center;
  font-size: 1.4rem;
}

.ft-box div a {
  margin-top: 0.6em;
  border-top: 1px solid #fff;
  border-left: 1px solid #fff;
  border-bottom: 1px solid #fff;
}

.ft-box div a span {
  display: none
}

.ft-box div a,
.ft-box div a p {
  display: block;
  width: 500px;
  height: 110px;
  background-size: cover;
}

@media only screen and (max-width : 768px) {
  .ft-box {
    height: auto;
    padding: 10vw 0 15vw;
  }

  .ft-box div.flexbox {
    flex-wrap: wrap;
  }

  .ft-box div.flexbox div + div {
    margin-top: 5vw;
  }

  .ft-box div a {
    border-right: 1px solid #fff;
  }

  .ft-box div a,
  .ft-box div a p {
    width: 90vw;
    height: 25vw;
    background-size: cover;
  }
}

.ft-box div.ft-tel a {
  background-image: url(assets/images/ft-tel-bg.jpg);
}

.ft-box div.ft-tel a p {
  background-image: url(assets/images/ft-tel.png);
}

.ft-box div.ft-contact a {
  background-image: url(assets/images/ft-contact-bg.jpg);
  border-right: 1px solid #fff;
}

.ft-box div.ft-contact a p {
  background-image: url(assets/images/ft-tel-contact.png);
}

.ft-box div.ft-contact a:hover {
  opacity: 1.0
}

.ft-box div.ft-contact a:hover p {
  opacity: 0.5
}

/* footer -------------*/
footer small {
  color: #858585;
  font-size: 0.67rem;
  font-family: 'Source Serif Pro', serif;
}

@media only screen and (max-width : 768px) {
  footer.flexbox {
    flex-wrap: wrap;
  }

  footer ul li:nth-child(6) {
    margin-left: 0;
  }

  footer small {
    width: 100%;
    text-align: right;
    margin-top: 3vw;
  }
}

/*----------------------------------

 home

----------------------------------*/
.mainImg#home {
  position: relative;
}

.mainImg#home p {
  position: absolute;
  top: 140px;
  left: calc(50% - 353px);
  z-index: 1;
  width: 706px;
  height: 64px;
  margin: auto;
  background-image: url(assets/images/top-catch.png);
}

.mainImg#home p span {
  display: none;
}

@media only screen and (max-width : 768px) {
  .mainImg#home p {
    top: 22vw;
    left: calc(50% - 35vw);
    width: 70vw;
    height: 30vw;
    background-image: url(assets/images/top-catch-sp.png);
  }
}

/* slider */
#home .mainImg-img,
#home .mainImg-img div {
  width: 100%;
  height: 100%;
}

#home .mainImg-img {
  position: absolute;
  z-index: 0;
  left: 0;
}

#home .slider div {
  background-size: cover;
}

#home .slider div:nth-child(1) {
  background-image: url(assets/images/top-main05.jpg);
}

#home .slider div:nth-child(2) {
  background-image: url(assets/images/top-main02.jpg);
}

#home .slider div:nth-child(3) {
  background-image: url(assets/images/top-main04.jpg);
}

#home .slider div:nth-child(4) {
  background-image: url(assets/images/top-main02.jpg);
}

@media only screen and (max-width : 768px) {

  #home .mainImg-img,
  #home .mainImg-img div {
    height: 80vw;
  }
}

.bx-controls {
  position: absolute;
  z-index: 50;
  top: 0;
}

.bx-controls-direction a {
  position: absolute;
  top: 0;
  display: block;
  height: 100%;
  width: 80px;
}

.bx-controls-direction a::before {
  content: "";
  position: absolute;
  top: calc(50% - 15px);
  display: block;
  width: 40px;
  height: 40px;
  border-right: 2px solid #000;
  border-top: 2px solid #000;
}

.bx-controls-direction a.bx-prev {
  left: 0;
}

.bx-controls-direction a.bx-prev::before {
  transform: rotate(-135deg);
  left: 35%;
}

.bx-controls-direction a.bx-next {
  right: 0;
}

.bx-controls-direction a.bx-next::before {
  transform: rotate(45deg);
  left: 10%;
}

@media only screen and (max-width : 768px) {
  .bx-controls-direction a {
    width: 5vw;
  }

  .bx-controls-direction a::before {
    width: 1.5vw;
    height: 1.5vw;
  }

}

/* intro-box - plan-box */
.intro-box .flexbox {
  margin-top: 80px;
  align-items: flex-start;
}

.plan-box {
  background-color: #f4f1f7;
  padding: 120px 0;
  margin-bottom: 0;
}

.plan-box h2 {
  margin-bottom: 70px;
}

@media only screen and (max-width : 768px) {
  .intro-box h2 {
    line-height: 1.3em;
    margin-bottom: 5vw;
  }

  .intro-box .flexbox {
    margin-top: 10vw;
  }

  .intro-box .flexbox,
  .plan-box .flexbox {
    flex-wrap: wrap;
  }

  .plan-box {
    padding: 15vw 0;
  }

  .plan-box h2 {
    margin-bottom: 15vw;
  }
}

.intro-box section,
.plan-box section {
  margin-bottom: 0;
  flex-basis: 33.333%;
  text-align: center;
}

@media only screen and (max-width : 768px) {

  .intro-box section,
  .plan-box section {
    flex-basis: 100%;
  }

  .intro-box section + section,
  .plan-box section + section {
    margin-top: 8vw;
  }
}

.intro-box section a,
.plan-box section a {
  display: block;
}

.intro-box section a h3,
.plan-box section a h3 {
  font-size: 1.20rem;
  line-height: 1.0em;
  margin: 1.5em 0 0.8em;
}

@media only screen and (max-width : 768px) {

  .intro-box section a h3,
  .plan-box section a h3 {
    font-size: 1.4rem;
    margin: 1.0em 0 0.5em;
  }
}

.intro-box section a p,
.plan-box section a p {
  line-height: 1.3em;
}

.plan-box section a p span {
  font-size: 1.2rem;
  line-height: 1.5em
}

.intro-box section a::before,
.plan-box section a::before {
  content: "";
  display: block;
  width: 400px;
  background-size: cover;
}

.intro-box section a::before {
  height: 200px;
}

.plan-box section a::before {
  height: 280px;
}

@media only screen and (max-width : 768px) {

  .intro-box section a::before,
  .plan-box section a::before {
    width: 100%;
    margin: auto;
  }

  .intro-box section a::before {
    height: 45vw;
  }

  .plan-box section a::before {
    height: 65vw;
  }
}

.intro-box section:nth-child(1) a::before {
  background-image: url(assets/images/top-img01.jpg);
}
.intro-box section:nth-child(2) a::before {
  background-image: url(assets/images/top-img02.jpg);
}
.intro-box section:nth-child(3) a::before {
  background-image: url(assets/images/top-img03.jpg);
}

.plan-box section:nth-child(1) a::before {
  background-image: url(assets/images/plan_ippan.jpg);
}

.plan-box section:nth-child(2) a::before {
  background-image: url(assets/images/plan_kazoku.jpg);
}

.plan-box section:nth-child(3) a::before {
  background-image: url(assets/images/plan_kasou.jpg);
}

/*----------------------------------

 plan

----------------------------------*/
.mainImg#plan {
  background-image: url(assets/images/main-plan.jpg);
}

.mainImg#plan h1 {
  background-image: url(assets/images/main-plan-txt.png);
}

.planList-box section {
  margin-bottom: 50px !important;
}

.planList-box section:nth-last-child(1) {
  margin-bottom: 100px !important;
}

.planList-box .flexbox {
  justify-content: space-between;
  flex-direction: row-reverse;
}

.planList-box .flexbox > div {
  width: 540px;
  font-size: 1.27rem;
}

.planList-box .flexbox > img {
  width: 600px;
}

@media only screen and (max-width : 768px) {
  .planList-box section {
    margin-bottom: 15vw !important;
  }

  .planList-box .flexbox {
    flex-direction: column;
  }

  .planList-box .flexbox > div {
    margin-bottom: 5vw;
  }

  .planList-box .flexbox > div,
  .planList-box .flexbox > img {
    width: 100%;
  }
}

.planList-box h2.h2-sl::before {
  left: 3.0em;
}

.planList-box h2.h2-sl::after {
  width: calc(100% - 4.2em);
}

.planList-box ul {
  margin: 0.3em 0;
}

.planList-box ul li {
  display: block;
  margin: 0;
}

.planList-box ul li + li {
  margin-top: -0.3em;
}

.planList-box .price span {
  font-size: 1.87rem;
}

.planList-box a {
  display: block;
  text-align: center;
  width: 400px;
  padding: 1.2em 0;
  margin-top: 1.0em;
  font-size: 1.2rem;
  line-height: 1.0em;
  border: 1px solid #003a98;
  color: #003a98;
}

@media all and (-ms-high-contrast:none) {
  .planList-box a {
    padding: 1.4em 0 1.0em;
  }
}

@media only screen and (max-width : 768px) {
  .planList-box a {
    width: 100%;
    margin: auto;
  }

  .planList-box section:nth-last-child(1) {
    margin-bottom: 4rem !important;
  }
}

/* plan ---------------------------------- */

.planDetail-box .detail {
  flex-direction: row-reverse;
  justify-content: space-between;
  align-items: start;
  margin-bottom: 55px;
}

.planDetail-box .detail img {
  width: 600px;
}

.setDetail {
  width: 550px;
  margin-top: 1.3em;
}

.setDetail h3 {
  line-height: 1.0em;
  margin-bottom: 0;
}

.setDetail h3 span {
  color: inherit;
  font-size: inherit;
  line-height: inherit;
}

.setDetail .setPrice span {
  font-size: 1.87rem;
  letter-spacing: 0.06em;
  padding-right: 0.05em;
}

.planDetail-box > p {
  padding-bottom: 1.5em;
}

.plan-cremation .setPrice {
  margin: auto 0 2.1em;
}

.plan-cremation .setDetail p {
  line-height: 1.0em;
  margin-top: 1.0em;
}

@media only screen and (max-width : 768px) {
  .planDetail-box {
    padding-bottom: 5vw;
  }

  .planDetail-box .detail {
    flex-direction: column;
    margin-bottom: 15vw;
  }

  .planDetail-box .detail img {
    width: 100%;
    margin-top: 3vw;
  }

  .planDetail-box > p {
    margin-top: -10vw;
  }

  .setDetail {
    width: 100%;
    margin-top: 0em;
  }

  .setDetail h3 {
    line-height: 1.3em
  }

  .setDetail h3 span {
    display: block;
    font-size: 1.5rem;
  }

  .plan-general .setDetail h3::before,
  .plan-family .setDetail h3::before {
    width: 2.8em;
    height: 2.8em;
    top: -1.15em;
  }

  .plan-general .setDetail h3::after,
  .plan-family .setDetail h3::after {
    top: 1.25em;
  }

  .setDetail .setPrice {
    margin: 0.8em 0;
  }

  .setDetail .setPrice span {
    line-height: 1.2em
  }

  .plan-cremation .setDetail p {
    line-height: 1.3em;
    margin: 0.5em 0;
  }
}

/* */
.setList {
  margin: 0.4em 0 0.8em;
}

.setList li {
  display: inline-block;
  font-size: 0.87rem;
  text-align: center;
}

.setList li + li {
  margin-left: 0.8em;
}

.setList li::before {
  content: "";
  display: block;
  width: 70px;
  height: 70px;
  margin: 0 auto 0.2em;
  background-size: contain;
}

@media only screen and (max-width : 768px) {
  .setList li + li {
    margin-left: 0.4em;
  }

  .setList li::before {
    width: 17vw;
    height: 17vw;
  }
}

.setList li.setList-shiraki::before {
  background-image: url(assets/images/plan-icon01.png);
}

.setList li.setList-seika::before {
  background-image: url(assets/images/plan-icon02.png);
}

.setList li.setList-photo::before {
  background-image: url(assets/images/plan-icon03.png);
}

.setList li.setList-shikai::before {
  background-image: url(assets/images/plan-icon04.png);
}

.setList li.setList-shinkou::before {
  background-image: url(assets/images/plan-icon05.png);
}

/* */
.planDetail-box .setDetail .listBox {
  display: flex;
  flex-wrap: wrap;
}

.planDetail-box .setDetail .listBox li {
  display: block;
  margin-top: -0.3em;
}

.plan-general .setDetail .listBox div:nth-child(1) {
  width: 220px;
}

.plan-general .setDetail .listBox div:nth-child(2) {
  width: 315px;
}

.plan-family .setDetail .listBox div:nth-child(1) {
  width: 270px;
}

.plan-family .setDetail .listBox div:nth-child(2) {
  width: 270px;
}

.plan-cremation .setDetail .listBox div:nth-child(1) {
  width: 270px;
}

.plan-cremation .setDetail .listBox div:nth-child(2) {
  width: 270px;
}

@media only screen and (max-width : 768px) {
  .planDetail-box .setDetail .listBox li {
    font-size: 1.2em;
  }

  .planDetail-box .setDetail .listBox div:nth-child(1) {
    width: 100%;
  }

  .planDetail-box .setDetail .listBox div:nth-child(2) {
    width: 100%;
  }
}

/* plan-set general */

.plan-general .pln00 h3::before {
  left: 16.0em;
}
.plan-general .pln00 h3::after {
  width: calc(100% - 17.2em)
}

.plan-general .pln01 h3::before {
  left: 12.0em;
}

.plan-general .pln01 h3::after {
  width: calc(100% - 13.3em)
}

.plan-general .pln02 h3::before {
  left: 15.0em;
}
.plan-general .pln02 h3::after {
  width: calc(100% - 16.2em)
}

.plan-general .pln03 h3::before {
  left: 16.2em;
}

.plan-general .pln03 h3::after {
  width: calc(100% - 17.3em)
}

.plan-general .pln04 h3::before {
  left: 16.2em;
}

.plan-general .pln04 h3::after {
  width: calc(100% - 17.3em)
}

.plan-general .pln05 h3::before {
  left: 18.5em;
}

.plan-general .pln05 h3::after {
  width: calc(100% - 19.7em)
}

.plan-general .pln06 h3::before {
  left: 14.2em;
}

.plan-general .pln06 h3::after {
  width: calc(100% - 15.3em)
}

.plan-general .pln07 h3::before {
  left: 18.4em;
}

.plan-general .pln07 h3::after {
  width: calc(100% - 19.5em)
}

@media only screen and (max-width : 768px) {

  .plan-general .pln00 h3::before {
    left: 7.3em;
  }
  .plan-general .pln00 h3::after {
    width: calc(100% - 9.7em)
  }

  .plan-general .pln01 h3::before {
    left: 4.5em;
  }

  .plan-general .pln01 h3::after {
    width: calc(100% - 7.0em)
  }

  .plan-general .pln02 h3::before {
    left: 7.3em;
  }
  .plan-general .pln02 h3::after {
    width: calc(100% - 9.7em)
  }

  .plan-general .pln03 h3::before {
    left: 8.2em;
  }

  .plan-general .pln03 h3::after {
    width: calc(100% - 10.6em)
  }

  .plan-general .pln04 h3::before {
    left: 8.3em;
  }

  .plan-general .pln04 h3::after {
    width: calc(100% - 10.6em)
  }

  .plan-general .pln05 h3::before {
    left: 10.5em;
  }

  .plan-general .pln05 h3::after {
    width: calc(100% - 12.9em)
  }

  .plan-general .pln06 h3::before {
    left: 6.2em;
  }

  .plan-general .pln06 h3::after {
    width: calc(100% - 8.5em)
  }

  .plan-general .pln07 h3::before {
    left: 10.4em;
  }

  .plan-general .pln07 h3::after {
    width: calc(100% - 12.8em)
  }
}

/* plan-set family */
.plan-family .pln01 h3::before {
  left: 13.8em;
}

.plan-family .pln01 h3::after {
  width: calc(100% - 15.0em)
}

.plan-family .pln02 h3::before {
  left: 12.8em;
}

.plan-family .pln02 h3::after {
  width: calc(100% - 14.0em)
}

.plan-family .pln03 h3::before {
  left: 12.8em;
}

.plan-family .pln03 h3::after {
  width: calc(100% - 14.0em)
}

.plan-family .pln04 h3::before {
  left: 12.8em;
}

.plan-family .pln04 h3::after {
  width: calc(100% - 14.0em)
}

.plan-family .pln05 h3::before {
  left: 12.8em;
}

.plan-family .pln05 h3::after {
  width: calc(100% - 14.0em)
}

@media only screen and (max-width : 768px) {
  .plan-family .pln01 h3::before {
    left: 6.5em;
  }

  .plan-family .pln01 h3::after {
    width: calc(100% - 8.9em)
  }

  .plan-family .pln02 h3::before {
    left: 6.5em;
  }

  .plan-family .pln02 h3::after {
    width: calc(100% - 8.9em)
  }

  .plan-family .pln03 h3::before {
    left: 6.5em;
  }

  .plan-family .pln03 h3::after {
    width: calc(100% - 8.9em)
  }

  .plan-family .pln04 h3::before {
    left: 6.5em;
  }

  .plan-family .pln04 h3::after {
    width: calc(100% - 8.9em)
  }

  .plan-family .pln05 h3::before {
    left: 6.5em;
  }

  .plan-family .pln05 h3::after {
    width: calc(100% - 8.9em)
  }
}

/* plan-set cremation */
.plan-cremation .pln01 h3::before {
  left: 5.0em;
}

.plan-cremation .pln01 h3::after {
  width: calc(100% - 6.2em)
}

/* plan-flow -------------*/
.planFlow-box {
  background-color: #f4f1f7;
  padding: 120px 0 100px;
  margin-bottom: 0;
}

.planFlow-box .step-box:nth-last-child(1) {
  margin-bottom: 0;
}

.planFlow-box .step-box {
  width: 860px;
  margin: auto;
  align-items: start;
  margin-bottom: 10px;
}

.planFlow-box .step-box h3 {
  width: 240px;
  height: 130px;
  background-color: #5f83be;
  position: relative;
  margin-bottom: 30px;
}

.planFlow-box .step-box h3 span {
  display: none;
}

.planFlow-box .step-box h3::after {
  content: "";
  display: block;
  width: 240px;
  height: 30px;
  position: absolute;
  top: 130px;
  background-image: url(assets/images/plan-flow-arrow.png);
  background-size: contain;
}

.planFlow-box .step-box:nth-last-child(1) h3 {
  margin-bottom: 0;
}

.planFlow-box .step-box:nth-last-child(1) h3::after {
  display: none;
}

.planFlow-box .step-box h3::before {
  content: "";
  display: block;
  width: 80px;
  height: 25px;
  z-index: 1;
  position: absolute;
  left: 30px;
  top: 45%;
  background-size: contain;
  background-repeat: no-repeat;
}

.planFlow-box .step-box:nth-last-child(1) h3::before {
  top: 42%;
}

.planFlow-box .step-box h3 div {
  width: 85px;
  height: 85px;
  position: absolute;
  z-index: 1;
  right: 25px;
  top: 28px;
}

.planFlow-box .step-box:nth-last-child(1) h3 div {
  top: 22px;
}

.planFlow-box .step-box dl {
  width: 620px;
  height: 130px;
  border-bottom: 1px solid #c4c7c7;
  padding: 0 0 0 40px;
}

.planFlow-box .step-box dl dt {
  font-size: 1.67rem;
  color: #003a98;
}

.planFlow-box .step-box dl dd {
  color: #003a98;
  line-height: 1.66em
}

@media all and (-ms-high-contrast:none) {
  .planFlow-box .step-box dl {
    margin-top: -1.8em;
    height: 125px;
  }
}

@media only screen and (max-width : 768px) {
  .planFlow-box {
    padding: 15vw 0 10vw;
  }

  .planFlow-box .step-box {
    width: 90vw;
    align-items: stretch;
    position: relative;
    margin-bottom: 8vw;
  }

  .planFlow-box .step-box::after {
    content: "";
    display: block;
    width: 25vw;
    height: 5vw;
    position: absolute;
    bottom: -5vw;
    background-image: url(assets/images/plan-flow-arrow.png);
    background-size: 100% 100%;
  }

  .planFlow-box .step-box:nth-last-child(1)::after {
    display: none;
  }

  .planFlow-box .step-box h3 {
    width: 25vw;
    height: auto;
    margin-bottom: 0;
  }

  .planFlow-box .step-box h3::after {
    display: none;
  }

  .planFlow-box .step-box h3::before {
    width: 18vw;
    height: 7vw;
    left: 4.0vw;
    top: 25%;
  }

  .planFlow-box .step-box:nth-last-child(1) h3::before {
    top: 28%;
  }

  .planFlow-box .step-box h3 div {
    width: 20vw;
    height: 20vw;
    left: 2.5vw;
    right: auto;
    top: 37%;
    background-size: 90%;
  }

  .planFlow-box .step-box.stp-nokotsu h3::before {
    top: 27%;
  }

  .planFlow-box .step-box.stp-nokotsu h3 div {
    height: 16vw;
    background-size: 120%;
  }

  .planFlow-box .step-box.stp-ido h3 div {
    height: 15vw;
  }

  .planFlow-box .step-box.stp-tsuya h3::before {
    top: 22%;
  }

  .planFlow-box .step-box.stp-tsuya h3 div {
    height: 18vw;
    background-size: 85%
  }

  .planFlow-box .step-box.stp-kasou h3::before {
    top: 32%;
  }

  .planFlow-box .step-box.stp-kasou h3 div {
    height: 15vw;
    background-size: 120%;
    top: 42%;
  }

  .planFlow-box .step-box:nth-last-child(1) h3 div {
    top: 35%;
  }

  .planFlow-box .step-box dl {
    width: 65vw;
    height: auto;
    padding: 0 0 1.5em 1.5em;
  }
}

/* step01-10 */
.planFlow-box .stp01 h3::before {
  background-image: url(assets/images/plan-flow-step01.png);
}

.planFlow-box .stp02 h3::before {
  background-image: url(assets/images/plan-flow-step02.png);
}

.planFlow-box .stp03 h3::before {
  background-image: url(assets/images/plan-flow-step03.png);
}

.planFlow-box .stp04 h3::before {
  background-image: url(assets/images/plan-flow-step04.png);
}

.planFlow-box .stp05 h3::before {
  background-image: url(assets/images/plan-flow-step05.png);
}

.planFlow-box .stp06 h3::before {
  background-image: url(assets/images/plan-flow-step06.png);
}

.planFlow-box .stp07 h3::before {
  background-image: url(assets/images/plan-flow-step07.png);
}

.planFlow-box .stp08 h3::before {
  background-image: url(assets/images/plan-flow-step08.png);
}

.planFlow-box .stp09 h3::before {
  background-image: url(assets/images/plan-flow-step09.png);
}

.planFlow-box .stp10 h3::before {
  background-image: url(assets/images/plan-flow-step10.png);
}

/* plan-flow general family */
.plan-general .stp01 h3 div {
  background-image: url(assets/images/plan-flow-icon01.png);
}

.plan-general .stp02 h3 div {
  background-image: url(assets/images/plan-flow-icon02.png);
}

.plan-general .stp03 h3 div {
  background-image: url(assets/images/plan-flow-icon03.png);
}

.plan-general .stp04 h3 div {
  background-image: url(assets/images/plan-flow-icon04.png);
}

.plan-general .stp05 h3 div {
  background-image: url(assets/images/plan-flow-icon06.png);
}

.plan-general .stp06 h3 div {
  background-image: url(assets/images/plan-flow-icon07.png);
}

.plan-general .stp07 h3 div {
  background-image: url(assets/images/plan-flow-icon08.png);
}

.plan-general .stp08 h3 div {
  background-image: url(assets/images/plan-flow-icon09.png);
}

.plan-general .stp09 h3 div {
  background-image: url(assets/images/plan-flow-icon010.png);
}

.plan-general .stp10 h3 div {
  background-image: url(assets/images/plan-flow-icon010.png);
}

/* plan-flow cremation */
.plan-cremation .stp01 h3 div {
  background-image: url(assets/images/plan-flow-icon01.png);
}

.plan-cremation .stp02 h3 div {
  background-image: url(assets/images/plan-flow-icon02.png);
}

.plan-cremation .stp03 h3 div {
  background-image: url(assets/images/plan-flow-icon03.png);
}

.plan-cremation .stp04 h3 div {
  background-image: url(assets/images/plan-flow-icon04.png);
}

.plan-cremation .stp05 h3 div {
  background-image: url(assets/images/plan-flow-icon09.png);
}

.plan-cremation .stp06 h3 div {
  background-image: url(assets/images/plan-flow-icon010.png);
}

/*----------------------------------

 member

----------------------------------*/
.mainImg#member {
  background-image: url(assets/images/main-premium.jpg);
}

.mainImg#member h1 {
  background-image: url(assets/images/main-premium-txt.png);
}

.member-box div.flexbox div {
  display: block;
  width: 33.333%;
  height: 200px;
  margin: 3.0em 0;
}

@media only screen and (max-width : 768px) {
  .member-box div.flexbox div {
    height: 20vw;
    background-size: cover;
    margin: 1.0em 0;
  }
}

.member-box div.flexbox div:nth-child(1) {
  background-image: url(assets/images/premium-img01.jpg);
}

.member-box div.flexbox div:nth-child(2) {
  background-image: url(assets/images/premium-img02.jpg);
}

.member-box div.flexbox div:nth-child(3) {
  background-image: url(assets/images/premium-img03.jpg);
}

.member-note {
  margin: 80px auto 100px;
}

.member-note-read,
.member-note-matome h4 {
  font-size: 1.4rem;
  color: #000;
  font-weight: bold;
}

.member-note-read {
  text-align: center;
  margin: 0 0 0.5em
}

.member-note-read span {
  display: block;
  margin-top: -0.5em;
}

.member-note-matome {
  margin-bottom: 0 !important;
  justify-content: space-between;
}

.member-note-matome h4 {
  margin-bottom: 0.5em;
}

.member-note-matome img {
  width: 210px;
}

@media only screen and (max-width : 768px) {
  .member-note {
    margin: 10vw auto 15vw;
  }

  .member-note ul {
    width: 100%;
  }

  .member-note-matome {
    flex-direction: column;
    text-align: center;
  }

  .member-note-matome h4 {
    line-height: 1.6em;
  }

  .member-note-matome img {
    width: 100%;
    margin-top: 0.8em;
  }
}

/*----------------------------------

 goods

----------------------------------*/
.mainImg#goods {
  background-image: url(assets/images/main-goods.jpg);
}

.mainImg#goods h1 {
  background-image: url(assets/images/main-goods-txt.png);
}

.goods-box .note {
  text-align: center;
}

.goods-box .note p {
  line-height: 1.2em;
  margin: 0.5em 0 1.8em;
}

.goods-box .note section.note-special {
  margin-bottom: 1.2em;
}

.goods-note {
  margin-bottom: 80px;
}

.goods-note .note-special > div {
  width: calc(100% - 300px);
}

.goods-note .note-special span {
  display: none;
}

.goods-note .note-special .tel01 div {
  width: 405px;
  height: 30px;
  background-image: url(assets/images/tel01.png);
}

.goods-note .note-special .tel02 div {
  width: 405px;
  height: 20px;
  margin-top: 5px;
  background-image: url(assets/images/tel02.png);
}

.goods-note .note-special .fax div {
  width: 405px;
  height: 35px;
  background-image: url(assets/images/fax.png);
}

.goods-note .note-special .fax a {
  display: block;
  text-align: left;
  color: #003a98;
  position: relative;
  margin-top: 0.2em;
  ;
  padding-left: 20px;
  font-size: 0.87rem;
  font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}

.goods-note .note-special .fax a::before {
  content: "";
  position: absolute;
  top: 0.4em;
  left: 0;
  display: block;
  width: 1.2em;
  height: 1.2em;
  background-image: url(assets/images/icon-pdf.png);
  background-size: contain;
  background-repeat: none;
}

@media all and (-ms-high-contrast:none) {
  .goods-note .note-special .fax a::before {
    top: 0.2em;
  }
}

@media only screen and (max-width : 768px) {
  .goods-note h3 {
    line-height: 1.2em;
  }

  .goods-box .note p {
    font-size: 0.9rem;
    margin: 1.5em 0 2.0em;
  }

  .goods-note {
    margin-bottom: 15vw;
  }

  .goods-note .note-special > div {
    width: 100%
  }

  .goods-note .note-special span {
    display: block;
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  }

  .goods-note .note-special .tel01 div,
  .goods-note .note-special .tel02 div,
  .goods-note .note-special .fax div {
    width: 100%;
  }

  .goods-note .note-special .tel01 div {
    height: 7.5vw;
    margin-bottom: 0.5em;
    background-image: url(assets/images/tel01-sp.png);
  }

  .goods-note .note-special .tel02 div {
    height: 7vw;
    margin-top: 3vw;
    margin-bottom: 0;
    background-image: url(assets/images/tel02-sp.png);
  }

  .goods-note .note-special .fax div {
    height: 9.5vw;
    margin-bottom: 0.3em;
    background-image: url(assets/images/fax-sp.png);
  }

  .goods-note .note-special .fax a {
    margin-top: 3vw;
    display: inline-block;
  }
}

/**/
.goods-list {
  margin-bottom: 65px;
}

.goods-list h2::before {
  left: 6.3em;
}

.goods-list h2::after {
  width: calc(100% - 7.5em)
}

.goods-list > p {
  margin: 30px 0;
}

.goods-list div.flexbox {
  flex-wrap: wrap;
  align-items: start;
}

.goods-list div.flexbox figure {
  width: 280px;
  margin: 0 26px 35px 0;
  text-align: center;
}

.goods-list div.flexbox figure:nth-child(4n) {
  margin-right: 0;
}

.goods-list div.flexbox figcaption h3 {
  color: #000;
  font-size: 1.07rem;
}

.goods-list div.flexbox figcaption div {
  line-height: 1.2rem !important;
}

.goods-list div.flexbox figcaption p {
  display: inline
}

.goods-list div.flexbox figcaption span {
  font-size: 1.2em;
  line-height: 1.2em
}
}

.goods-list div.flexbox figcaption div span {
  font-size: 1.2em;
}

@media only screen and (max-width : 768px) {
  .goods-list {
    margin-bottom: 8vw;
  }

  .goods-list > p {
    margin: 3vw 0 5vw;
  }

  .goods-list div.flexbox figure {
    width: 48%;
    margin: 0 4% 6vw 0;
    text-align: center;
  }

  .goods-list div.flexbox figure:nth-child(2n) {
    margin-right: 0;
  }

  .goods-list div.flexbox figcaption p {
    display: block;
  }
}

/*----------------------------------

 conference

----------------------------------*/
.mainImg#conference {
  background-image: url(assets/images/main-conference.jpg);
}

.mainImg#conference h1 {
  background-image: url(assets/images/main-conference-txt.png);
}

.conference-box {
  margin-bottom: 60px;
  padding-top: 240px;
  background-image: url(assets/images/conference-img.jpg);
  background-position: top;
}

.conference-box > p {
  width: 660px;
  text-align: left;
  margin-bottom: 1.5em;
  line-height: 2.0em
}

@media only screen and (max-width : 768px) {
  .conference-box {
    margin-bottom: 10vw;
    padding-top: 36vw;
    background-size: 200%;
  }

  .conference-box > p {
    width: 95%;
  }
}

.conference-note {
  margin-bottom: 100px;
}

.conference-note h3 + p {
  font-size: 1.2rem;
  margin: 10px 0 15px;
}

.conference-note h3 + p + .note-special {
  margin-bottom: 1.5em;
}

.conference-note p {
  text-align: center;
  line-height: 1.5em
}

.conference-note .note-special {
  padding: 10px 0;
}

.conference-note .note-special.conference-Trademark {
  padding: 15px 0;
}

.conference-note .note-special h4 {
  line-height: 0.8em;
}

@media only screen and (max-width : 768px) {
  .conference-note {
    margin-bottom: 15vw;
  }

  .conference-note h3 + p {
    margin: 0.8em 0 1.2em;
  }

  .conference-note .note-special ul {
    width: 100%;
  }

  .conference-note .note-special {
    padding: 1.8em;
  }

  .conference-note .note-special.conference-Trademark {
    padding: 1.8em;
  }
}

.conference-Trademark {
  width: 390px;
  margin: 20px auto;
}

.conference-Trademark dl {
  width: 87%;
  margin: auto;
  flex-wrap: wrap;
}

.conference-Trademark dt,
.conference-Trademark dd {
  width: 50%;
  font-size: ;
  color: #003a98;
  font-size: 0.93em;
  line-height: 1.5em;
}

.conference-Trademark dd {
  text-align: right;
}

@media only screen and (max-width : 768px) {
  .conference-Trademark {
    width: 100%;
    margin: 5vw auto;
  }

  .conference-Trademark dl {
    width: 100%;
  }
}

/*----------------------------------

 access

----------------------------------*/
.mainImg#access {
  background-image: url(assets/images/main-access.jpg);
}

.mainImg#access h1 {
  background-image: url(assets/images/main-access-txt.png);
}

.accesspage-box {
  margin-bottom: 60px;
}

.accesspage-box iframe {
  width: 100%;
  height: 400px;
  margin-top: 0.8em;
}

.accesspage-box .flexbox,
.accesspage-box .flexbox a {
  color: #003a98;
  font-size: 1.07rem;
}

.accesspage-box .flexbox a {
  position: relative;
  display: inline-block;
  margin-left: 1.3em;
}

.accesspage-box .flexbox a::before {
  content: "";
  position: absolute;
  top: 0.4em;
  left: -1.3em;
  display: block;
  width: 12px;
  height: 17px;
  background-image: url(assets/images/map-icon-blue.png);
  background-size: contain;
}

@media only screen and (max-width : 768px) {
  .accesspage-box {
    margin-bottom: 8vw;
  }

  .accesspage-box iframe {
    width: 100%;
    height: 80vw;
    flex-basis: 80vw;
  }

  .accesspage-box .flexbox {
    display: block;
  }

  .accesspage-box .flexbox a {
    margin-top: 0.5em;
  }
}

.access-photo {
  text-align: center;
  line-height: 1.0em;
}

.access-photo div {
  width: 33.333%
}

.access-photo div h3 {
  font-size: 1.2rem;
  line-height: 1.0em;
  margin: 1.0em auto 0.8em;
}

.access-photo div p {
  line-height: 1.6em;
}

@media only screen and (max-width : 768px) {
  .access-photo.flexbox {
    display: block;
  }

  .access-photo div + div {
    margin-top: 5vw;
  }

  .access-photo div {
    width: 100%
  }

  .access-photo div h3 {
    margin: 0.8em auto 0.5em;
  }
}

.access-public {
  justify-content: space-between;
  align-items: start
}

.access-public h2 {
  width: 525px;
  margin: 0.3em 0;
}

.access-public h2::before {
  left: 13.9em;
}

.access-public h2::after {
  width: calc(100% - 15.1em)
}

.access-public ul {
  width: calc(100% - 560px);
}

@media only screen and (max-width : 768px) {
  .access-public.flexbox {
    display: block
  }

  .access-public h2,
  .access-public ul {
    width: 100%;
  }

  .access-public ul {
    margin: 1.5em 0 0;
  }
}

.company-box {
  background-color: #f4f1f7;
  padding: 120px 0 100px;
  margin-bottom: 0;
}

.company-box h2 {
  margin-bottom: 70px;
}

.company-box dl {
  width: 860px;
  margin: auto;
  display: flex;
  flex-wrap: wrap;
}

.company-box dl dt,
.company-box dl dd {
  color: #003a98;
  line-height: 1.6em;
  border-bottom: 1px solid #c4c7c7;
  padding-top: 0.8em;
  padding-bottom: 0.8em;
}

.company-box dl dt {
  width: 200px;
  padding-left: 2em;
}

.company-box dl dd {
  width: calc(100% - 200px);
}

@media only screen and (max-width : 768px) {
  .company-box {
    padding: 15vw 0;
  }

  .company-box h2 {
    margin-bottom: 15vw;
  }

  .company-box dl {
    width: 90vw;
  }

  .company-box dl dt {
    width: 25vw;
    padding-left: 0.5em;
  }

  .company-box dl dd {
    width: calc(100% - 25vw);
  }
}


/*----------------------------------

 privacy

----------------------------------*/
.mainImg#privacy {
  background-image: url(assets/images/main-pp.jpg);
}

.mainImg#privacy h1 {
  background-image: url(assets/images/main-pp-txt.png);
}

.pp-box h2::before {
  left: 11.5em;
}

.pp-box h2::after {
  width: calc(100% - 12.7em)
}

.pp-box dl {
  width: 1000px;
  margin: 1.8rem auto 100px;
}

.pp-box dl dt {
  font-size: 1.2rem;
  color: #003a98;
  margin: 3.0em 0 0.3em;
  padding-left: 1.2em;
}

.pp-box dl dt::before {
  display: inline-block;
  width: 1.2em;
  margin-left: -1.2em;
}

.pp-box dl dt.pp01::before {
  content: "1.";
}

.pp-box dl dt.pp02::before {
  content: "2.";
}

.pp-box dl dt.pp03::before {
  content: "3.";
}

.pp-box dl dd {
  line-height: 1.66em
}

.pp-box dl dd:nth-child(1) {
  font-size: 1.07rem;
}

@media only screen and (max-width : 768px) {
  .pp-box dl {
    width: 100%;
    margin: 1.8rem auto 4rem;
  }

  .pp-box dl dt {
    line-height: 1.6em;
    margin: 2.0em 0 0.5em;
  }
}

/*----------------------------------

 contact

----------------------------------*/
.mainImg#contact {
  background-image: url(assets/images/main-contact.jpg);
}

.mainImg#contact h1 {
  background-image: url(assets/images/main-contact-txt.png);
}


.contact-box01,
.contact-box02,
.form-box {
  width: 860px;
  margin-bottom: 100px;
}

.contact-box01 h2,
.contact-box02 h2,
.form-box h2 {
  margin-bottom: 1.5em;
}

.contact-box01 p,
.contact-box02 p {
  line-height: 1.66em
}

@media only screen and (max-width : 768px) {

  .contact-box01,
  .contact-box02,
  .form-box {
    width: 90vw;
    margin-bottom: 10vw;
  }

  .contact-box01 h2,
  .contact-box02 h2,
  .form-box h2 {
    margin-bottom: 0.5em;
  }
}

/* contact-box01 */
.contact-box01 h2::before {
  left: 15em;
}

.contact-box01 h2::after {
  width: calc(100% - 16.2em);
}

/* contact-box02 */
.contact-box02 h2::before {
  left: 8.5em;
}

.contact-box02 h2::after {
  width: calc(100% - 9.7em);
}

.contact-box02 div {
  padding-top: 1.5em;
}

.contact-box02 h3 {
  margin-top: 1.3em;
  font-size: 1.2rem;
}

.contact-box02 ul {
  padding: 0.8em 0;
  margin: 0.8em 0;
  border-top: 1px dashed #c4c7c7;
  border-bottom: 1px dashed #c4c7c7;
}

.contact-box02 ul li {
  display: block;
  line-height: 1.66em
}

@media only screen and (max-width : 768px) {
  .contact-box02 div {
    padding-top: 0.5em;
  }

  .contact-box02 h3 {
    margin-top: 0.8em;
  }
}

/* form-box */
.form-box {
  margin-top: 1.0em !important;
  padding-top: 1.0em;
}

.form-box h2::before {
  left: 10.5em;
}

.form-box h2::after {
  width: calc(100% - 11.7em);
}

/* form-nav */
.form-nav {
  display: flex;
  margin: 2.0em 0 3.0em;
}

.form-nav.step3 {
  display: flex;
  margin: 2.0em 0 1.0em;
}

.form-nav li {
  background-color: #cbccd9;
  text-align: center;
  line-height: 1.0em;
  padding: 0.4em 0;
}

.form-nav li:nth-child(1) {
  width: 36%;
  text-indent: -2.0em;
}

.form-nav li:nth-child(2) {
  width: 35%;
  text-indent: -3.3em;
}

.form-nav li:nth-child(3) {
  width: 29%;
  text-indent: -1.0em;
  background-image: none;
}

@media all and (-ms-high-contrast:none) {
  .form-nav li {
    padding: 0.6em 0 0.2em;
  }
}

.form-nav li {
  background-image: url(assets/images/contact-nv.png);
  background-size: contain;
  background-position: right
}

.form-nav li span + span {
  margin-left: 2.0em;
}

.form-nav.step1 li:nth-child(1) {
  background-color: #003a98;
  color: #fff;
  background-image: url(assets/images/contact-nv1.png);
}

.form-nav.step2 li:nth-child(2) {
  background-color: #003a98;
  color: #fff;
  background-image: url(assets/images/contact-nv1.png);
}

.form-nav.step2 li:nth-child(1) {
  background-image: url(assets/images/contact-nv2.png);
}

.form-nav.step3 li:nth-child(3) {
  background-color: #003a98;
  color: #fff;
}

.form-nav.step3 li:nth-child(2) {
  background-image: url(assets/images/contact-nv2.png);
}

.form-nav.step1 li:nth-child(1) span,
.form-nav.step2 li:nth-child(2) span,
.form-nav.step3 li:nth-child(3) span {
  color: #fff;
}

@media only screen and (max-width : 768px) {
  .form-nav {
    display: flex;
    margin: 1.0em 0 1.5em;
  }

  .form-nav li:nth-child(1) {
    width: 43%;
    text-indent: -2.3em;
  }

  .form-nav li:nth-child(2) {
    width: 33.5%;
    text-indent: -3.8em;
  }

  .form-nav li:nth-child(3) {
    width: 23.5%;
    text-indent: -1.0em;
    background-image: none;
  }

  .form-nav li span {
    display: block;
    line-height: 1.2em;
  }

  .form-nav li span + span {
    margin-left: -0.25em;
  }
}

/* form-box dl */
.form-box dl {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #c4c7c7;
}

.form-box dt,
.form-box dd {
  border-bottom: 1px solid #c4c7c7;
}

.form-box dt {
  width: 30%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 0.8em 1.5em 0.8em 1.0em;
  color: #003a98;
}

.form-box dt span {
  background: #003a98;
  color: #fff;
  font-size: 0.85em;
  line-height: 1.0em;
  padding: 0.5em;
  margin-top: 0.3em;
  border-radius: 0.3em;
}

.form-box dd {
  width: 70%;
  padding: 0.8em 1.5em 0.8em 0;
}

@media all and (-ms-high-contrast:none) {
  .form-box dt {
    padding: 1.0em 1.5em 0.6em 1.0em;
  }

  .form-box dt span {
    padding: 0.7em 0.5em 0.3em;
    margin-top: 0.1em;
  }
}

.form-bts {
  display: flex;
  justify-content: center;
  margin-top: 1.5em;
}

@media only screen and (max-width : 768px) {

  .form-box dl dt,
  .form-box dl dd {
    width: 100%
  }

  .form-box dl dt {
    justify-content: start;
    border-bottom: 0 none;
    padding: 1.0em 0.5em 0 0.5em;
  }

  .form-box dl dt span {
    margin-left: 1.0em;
    margin-top: 0.1em;
  }

  .form-box dl dd {
    padding: 0.5em 0.5em 1.5em 0.5em;
  }
}

/* form parts */
input[type="text"],
input[type="mail"],
textarea {
  border: 1px solid #003a98;
  background-color: #f4f1f7;
  padding: 0.25em 0.5em;
  width: 100%;
  font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  line-height: 1.5em;
}

dd.mailcheck input + input {
  margin-top: 0.5em;
}

textarea {
  height: 165px;
}

input[type="radio"] {
  display: none
}

label + label {
  margin-left: 1.0em;
}

label span {
  position: relative;
  padding-left: 1.7em;
}

label span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  display: inline-block;
  width: 1.1em;
  height: 1.1em;
  border: 1px solid #003a98;
  background-color: #f4f1f7;
  border-radius: 50%
}

input[type="radio"]:checked + span::after {
  content: "";
  position: absolute;
  left: 0.3em;
  top: 0.3em;
  z-index: 2;
  display: inline-block;
  width: 0.65em;
  height: 0.65em;
  background-color: #003a98;
  border-radius: 50%
}

@media all and (-ms-high-contrast:none) {
  label {
    display: inline-block;
    padding-top: 0.2em;
  }

  input[type="text"],
  input[type="mail"],
  textarea {
    padding: 0.43em 0.5em 0.05em;
  }
}

.form-bts input + input {
  margin-left: 1.0em;
}

input[type="submit"],
input[type="button"] {
  width: 400px;
  padding: 1.3em 0;
  background: #003a98;
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.0em;
  text-align: center;
}

input[type="button"] {
  background: #cbccd9;
  color: #555;
}

@media all and (-ms-high-contrast:none) {

  input[type="submit"],
  input[type="button"] {
    padding: 1.5em 0 1.1em;
  }
}

@media only screen and (max-width : 768px) {
  textarea {
    height: 40vw;
  }

  input[type="submit"],
  input[type="button"] {
    width: 45%;
  }
}

/**/
.error_messe {
  font-weight: bold;
}

.formTable dd {
  font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  line-height: 1.5em;
  padding-top: 1.0em;
}






.fee{
  border: 2px solid #003a98;
  background: url(./assets/images/bg01.jpg) no-repeat center right / cover;
  padding: 40px 5%;
  text-align: center;
}

.fee-heading{
  padding-bottom: 10px;
}
.fee-heading span{
  display: inline-block;
  font-size: 2rem;
  position: relative;
  color: #004fa2;
}
.fee-heading span::before,
.fee-heading span::after{
  content: "";
  display: block;
  width: 100px;
  height: 1px;
  background-color: #004fa2;
  position: absolute;
  top: 50%;
}
.fee-heading span::before{
  right: 100%;
  margin-right: 15px;
}
.fee-heading span::after{
  left: 100%;
  margin-left: 15px;
}


.fee-inner{
  max-width: 900px;
  margin: 0 auto 30px;
}
.fee-list {
  display: flex;
  justify-content: space-between;
  margin-left: -40px;
  margin-top: 40px;
}
.fee-list-item {
  width: 25%;
  padding-left: 40px;
  position: relative;
}
.fee-list-item:not(:last-child)::before,
.fee-list-item:not(:last-child)::after{
  content: "";
  display: block;
  width: 20px;
  height: 2px;
  margin-top: -8px;
  margin-left: 10px;
  background-color: #004fa2;
  position: absolute;
  left: 100%;
  top: 50%;
}
.fee-list-item:not(:last-child)::after{
  transform: rotate(90deg);
}


.fee-block {
  display: flex;
  justify-content: space-between;
  padding-top: 4em;
}
.fee-item {
  width: 200px;
  padding-bottom: 20px;
}
.fee-title {
  font-size: clamp(1.2rem,5vw, 1.4rem);
  padding-bottom: 0.3em;
}
.fee-icon {
  width: 100%;
  border-radius: 5px;
  border: 3px solid #5f83be;
  background-color: #fff;
  margin: 0;
  padding: 0;
  position: relative;
}
.fee-icon img {
  vertical-align: bottom;
}
.fee-item:not(:last-child) .fee-icon::before,
.fee-item:not(:last-child) .fee-icon::after{
  content: "";
  display: block;
  width: 30px;
  height: 3px;
  margin-top: -8px;
  margin-left: 10px;
  background-color: #5f83be;
  position: absolute;
  left: calc(100% + 26%);
  top: 50%;
  border-radius: 3px;
}
.fee-item:not(:last-child) .fee-icon::after{
  transform: rotate(90deg);
}


.fee-summary {
  font-size: clamp(1rem,3.6vw, 1.2rem);
  margin: 0;
  padding: 1em 0 0 0.5em;
  text-align: left;
}
.fee-summary li {
  display: block;
  padding-left: 1em;
  padding-bottom: 0.5em;
  line-height: 1.5;
  position: relative;
}
.fee-summary li::before {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  position: absolute;
  left: 0.2em;
  top: 0.55em;
  background-color: #000;
  border-radius: 50%;
  opacity: 0.5;
}




.fee-lead {
  margin-top: 10px;
  background: url(./assets/images/fee_balloon.png) no-repeat center top / 100% auto;
  padding-top: 30px;
  font-size: clamp(18px,4.6vw, 26px);
  color: #003a98
}


.fee-set {
  padding-bottom: 2em;
}
.fee-set-section {
  width: clamp(0px,100%, 860px);
  background-color: rgba(255, 255, 255, 0.8);
  padding: 2.5em 5%;
  margin: 0 auto;
}
.fee-set-section + .fee-set-section  {
  margin-top: 2em;
}
.fee-set-heading {
  display: flex;
  align-items: center;
  justify-content: center;
}
.fee-set-title {
  font-size: 1.5rem;
  min-width: 11em;
  margin-right: 3em;
  color: #004fa2;
  position: relative;
}
.fee-set-title::after {
  content: "";
  display: block;
  width: 1px;
  height: 1.5em;
  background-color: #004fa2;
  position: absolute;
  left: calc(100% + 1em);
  top: 50%;
  translate: 0 -50%;
  rotate: 30deg;
}
.fee-set-price {
  font-size: 1.1rem;
  letter-spacing: 0;
}
.fee-set-price em {
  font-style: normal;
  font-size: 180%;
  font-weight: normal;
  letter-spacing: 0;
  line-height: 1.5;
}
.fee-set-tags {
  padding-top: 0.8em;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.4em;
}
.fee-set-tags span {
  border: 1px solid #004fa2;
  padding: 0.1em 1em;
  color: #004fa2;
}


@media screen and (max-width:768px) {

  .fee{
    border: 2px solid #003a98;
    background: url(./assets/images/pattern01.png);
    padding: 20px 5%;
    overflow: hidden;
  }

  .fee-heading{
    padding-bottom: 10px;
  }
  .fee-heading span{
    font-size: 1.4rem;
  }
  .fee-heading span::before,
  .fee-heading span::after{
    width: 2rem;
  }
  .fee-heading span::before{
    margin-right: 5px;
  }
  .fee-heading span::after{
    margin-left: 5px;
  }
  .fee-text {
    font-size: 0.8rem;
  }
  .fee-text br {
    display: none;
  }

  .fee-inner{
    margin: 0 auto 20px;
  }
  .fee-list {
    display: flex;
    flex-wrap: wrap;
    justify-content:center;
    margin-left: -20px;
    margin-top: 20px;
  }
  .fee-list-item {
    width: 33.3%;
    padding-left: 20px;
    position: relative;
  }
  .fee-list-item:not(:last-child)::before,
  .fee-list-item:not(:last-child)::after{
    width: 13px;
    height: 2px;
    margin-top: -4px;
    margin-left: 3px;
  }
  .fee-lead {
    margin-top: 5px;
    background: url(./assets/images/fee_balloon.png) no-repeat center top / 100% 3vmin;
    padding-top: 10px;
    font-size: 1.1rem;
  }




  .fee-block {
    display: block;
    padding-top: 2em;
  }
  .fee-item {
    width: auto;
    padding-bottom: 50px;
    position: relative;
  }
  .fee-item:not(:last-child) .fee-icon::before,
  .fee-item:not(:last-child) .fee-icon::after{
    display: none;
  }
  .fee-title {
  }
  .fee-icon {
    width: 100%;
    max-width: 400px;
    border-width: 2px;
    margin: 0 auto;
    padding: 10px 0 0;
  }
  .fee-icon img {
    width: 45%;
    max-width: 200px;
  }
  .fee-item:not(:last-child)::before,
  .fee-item:not(:last-child)::after{
    content: "";
    display: block;
    width: 30px;
    height: 3px;
    background-color: #5f83be;
    position: absolute;
    left: 50%;
    top: auto;
    bottom: 30px;
    translate: -50% 0;
    border-radius: 3px;
  }
  .fee-item:not(:last-child)::after{
    transform: rotate(90deg);
  }

  .fee-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0 1em;
  }
  .fee-summary li {
    display: block;
    padding-left: 1em;
    padding-bottom: 0.5em;
    line-height: 1.5;
    position: relative;
  }
  .fee-summary li::before {
    content: "";
    display: block;
    width: 4px;
    height: 4px;
    position: absolute;
    left: 0.2em;
    top: 0.55em;
    background-color: #000;
    border-radius: 50%;
    opacity: 0.5;
  }


  .fee-set {
    padding-bottom: 1em;
  }
  .fee-set-section {
    padding: 2em 4%;
  }
  .fee-set-section + .fee-set-section  {
    margin-top: 1em;
  }
  .fee-set-heading {
    display: block;
  }
  .fee-set-title {
    font-size: 1.5rem;
    min-width: initial;
    margin-right: 0;
  }
  .fee-set-title::after {
    display: none;
  }
  .fee-set-price {
    font-size: 1rem;
  }
  .fee-set-price em {
    font-size: 160%;
  }
  .fee-set-tags {
    padding-top: 0.8em;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.2em;
  }
  .fee-set-tags span {
    padding: 0em 0.5em;
    font-size: 0.9rem;
    font-feature-settings: "palt";
    font-family: sans-serif;
    font-weight: normal;
  }



}





/*
homeNews
*/

.homeNews{
  background-color: #f4f1f7;
  padding: 80px 0 10px;
}

.homeNews-container {
  max-width: 1024px;
  padding: 0 12px;
  margin: 0 auto;
}
.homeNews-section {
  background-color: #fff;
  padding: 30px 8%;
  border: 3px solid #5f83be;
}
.homeNews-section:not(:last-child) {
  margin-bottom: 30px;
}


.homeNews-heading {
  font-size: 131%;
  border-bottom: 1px solid rgba(0, 58, 152, 0.5);
  padding-bottom: 0.2em;
  margin-bottom: 1em;
}

.homeNews-text {
  line-height: 1.7;
}

.homeNews-event{
  margin-top: 20px;
}
.homeNews-event-date {
  display: flex;
  margin-bottom: 10px;
}
.homeNews-event-date dt {
  padding: 5px 0;
  width: 10em;
  text-align: center;
  background-color: #5f83be;
  color: #fff;
  border-radius: 5px;
}
.homeNews-event-date dd {
  flex: 1;
  font-feature-settings: "palt";
  padding-left: 1.5em;
  padding: 5px 0 5px 1.5em;
}

.homeNews-event {
  display: flex;
  justify-content: space-between;
}
.homeNews-event-inner {
  flex: 1;
  padding-right: 50px;
}
.homeNews-event-calendar {
  width: 300px;
}

.homeNews-calendar {
}

/*
flatpickr
*/

.flatpickr-calendar *{
  font-family: '游ゴシック体', YuGothic, '游ゴシック', 'Yu Gothic', sans-serif !important;
}
.flatpickr-days {
  pointer-events: none;
}

.flatpickr-disabled{
  color: #888 !important;
}

.flatpickr-day{
  background-color: #5f83be;
  color: #fff;
}


.flatpickr-day.nextMonthDay:not(.flatpickr-disabled) {
  background-color: rgba(95, 131, 190, 0.1);
}

.flatpickr-day.nextMonthDay.flatpickr-disabled,
.flatpickr-day.prevMonthDay.flatpickr-disabled{
  color: #ddd !important;
}

.flatpickr-day.today {
  border: 1px solid #ccc;
  background-color: rgba(255, 255, 0, 0.2);
}


@media screen and (max-width:768px) {

  .homeNews{
    padding: 50px 0 10px;
  }

  .homeNews-container {
    padding: 0 12px;
  }
  .homeNews-section {
    padding: 20px 4%;
    border-width: 2px;
  }
  .homeNews-section:not(:last-child) {
    margin-bottom: 15px;
  }


  .homeNews-event {
    display: block;
  }
  .homeNews-event-inner {
    padding-right: 0;
  }
  .homeNews-event-calendar {
    width: 300px;
    padding-top: 20px;
    margin: 0 auto;
  }

  .homeNews-heading {
    font-size: 124%;
    line-height: 1.4;
    padding-bottom: 0.8em;
  }

  .homeNews-text {
    line-height: 1.6;
  }

}



@media screen and (max-width:320px) {

  .homeNews-calendar {
    transform: scale(0.88);
    transform-origin: left top;
  }
}

/*
plan
*/

.planBlock {
}
.planBlock + .planBlock {
  margin-top: 5em;
}
.planBlock-container {
  display: flex;
  gap: 0 5%;
}
.planBlock-img {
  width: 50%;
}
.planBlock-img img{
  vertical-align: bottom;
}
.planBlock-img-caption {
  display: block;
  text-align: right;
  font-size: 0.8rem;
  font-weight: 400;
  font-family: sans-serif;
  line-height: 1;
  letter-spacing: 0;
  padding: 0.8em 0 0;
}

.planBlock-inner {
  flex: 1;
}

.l-title.planBlock-title {
  padding-bottom: 0;
  margin-bottom: 0;
}
.planBlock-price {
  font-size: 1.1rem;
  letter-spacing: 0;
}
.planBlock-price em {
  font-style: normal;
  font-size: 180%;
  font-weight: normal;
  letter-spacing: 0;
  line-height: 1.5;
}

.planBlock-icons {
  padding-top: 1em;
  display: flex;
  flex-wrap: wrap;
  gap: 0.6em;
}
.planBlock-icons-item {
}
.planBlock-icons-item img{
  width: 70px;
  vertical-align: bottom;
}
.planBlock-icons-item span {
  display: block;
  font-family: sans-serif;
  font-feature-settings: "palt";
  font-size: 0.9rem;
  font-weight: normal;
  letter-spacing: 0;
  text-align: center;
  padding-top: 0.2em;
}

.planBlock-tips {
  font-size: 0.9rem;
  font-family: sans-serif;
  line-height: 1.6;
  padding-top: 1.2em;
}


.planBlock-tags {
  padding-top: 0.8em;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4em;
}
.planBlock-tags span {
  border: 1px solid #004fa2;
  padding: 0.1em 1em 0.1em 1.8em;
  background: url(./assets/images/list-icon.png) no-repeat 0.5em center / 0.9em auto;
  color: #004fa2;
  font-family: sans-serif;
  font-weight: normal;
  font-feature-settings: "palt";
  min-width: 8em;
  letter-spacing: 0;
}

@media screen and (max-width:768px) {

  .planBlock {
  }
  .planBlock + .planBlock {
    margin-top: 6em;
  }
  .planBlock-container {
    display: block;
  }
  .planBlock-img {
    width: auto;
  }
  .planBlock-inner {
    flex: 1;
    padding-top: 0.5em;
  }

  .planBlock-price {
    font-size: 1.1rem;
    letter-spacing: 0;
    line-height: 1;
  }
  .planBlock-price em {
    font-size: 180%;
    line-height: 1.2;
  }

  .planBlock-icons {
    padding-top: 1.2em;
  }
  .planBlock-icons-item img{
    width: clamp(50px,5rem, 120em);
  }
  .planBlock-icons-item span {
    font-size: 0.95rem;
  }



  .planBlock-tags {
    padding-top: 0.8em;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4em;
  }
  .planBlock-tags span {
    border: 1px solid #004fa2;
    padding: 0em 1em 0em 1.8em;
    font-family: sans-serif;
    font-feature-settings: "palt";
    letter-spacing: 0;
  }


}
