@charset "UTF-8";
.sp {
  display: none;
}

#container {
  width: 100%;
  color: #333333;
  font-family: 'Roboto', 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-feature-settings: "palt";
}

div#wrap-container {
  padding: 0;
  width: 100%;
}

#main-contents {
  width: 100%;
  margin: 0 0 100px;
}

h1 {
  border-bottom: 1px solid #cccccc;
  font-size: 1.8em;
  margin: 0 auto 12px;
  padding-bottom: 4px;
  font-weight: 700;
  line-height: 1;
  width: 980px;
}

h2.read {
  display: block;
  border-bottom: 3px solid #EF5E4B;
  font-size: 2em;
  margin: 0 auto;
  padding: 0.5% 1%;
  text-align: center;
  width: 69%;
}

/* バナー */
div#banner-outer {
  background-color: #254860;
}

div#banner-area {
  width: 980px;
  margin: 0 auto;
}

/* 動画 */
div#movie {
  width: 760px;
  margin: 0 auto;
  padding: 65px 100px 0;
}

/* リード文 */
div#read-outer {
  background-color: #F2F2F2;
  padding: 0 0 75px;
}

div #read {
  width: 980px;
  font-size: 0.95em;
  margin: 0 auto 20px;
  padding: 60px 0 0;
  line-height: 1.7;
}

#read p {
  margin: 3.5% auto 3%;
  font-size: 1.13em;
  line-height: 1.8em;
  font-weight: 400;
  letter-spacing: 0.3px;
  width: 65%;
}

#read p span {
  font-weight: 700;
}

#read p:nth-of-type(2) {
  margin-top: 3%;
}

.read-ul {
  background-color: #f5f5f5;
  margin: 20px auto 25px 3.5%;
  width: 775px;
  text-align: center;
}

#read .read-ul + p {
  margin: 3% auto 0;
}

#read ul {
  padding: 21px 0 20px;
  font-size: 1.1em;
  display: inline-block;
  text-align: left;
}

#read li {
  margin: 0 0 5px 0;
  font-weight: 700;
  text-align: left;
}

/* メニュー */
ul#menu {
  text-align: left;
  width: 752px;
  margin: 0 auto;
}

ul#menu li {
  display: inline-block;
  width: 370px;
  text-align: left;
  line-height: 1.6;
  font-size: 1.3em;
}

ul#menu li:nth-of-type(1) {
  margin: 0 6px 0 0;
}

ul#menu li a {
  display: block;
  position: relative;
  color: #333333;
}

ul#menu li a:hover {
  opacity: 0.6;
}

ul#menu li a:hover img {
  opacity: 1 !important;
}

ul#menu li a img {
  width: 100%;
}

ul#menu li a span {
  display: block;
  position: absolute;
  top: 17%;
  left: 7%;
  font-weight: bold;
}

ul#menu li a span object {
  color: #EF5E4B;
}

/* ポイント */
div#point {
  border: 1px solid #A2A2A2;
  padding: 6% 10%;
  margin: 2% auto 0;
  width: 58%;
}

div#point p {
  margin: 0 0 6%;
  text-align: center;
  font-size: 1.25em;
  font-weight: 700;
}

div#point li {
  margin: 0 0 6%;
}

div#point li:nth-last-of-type(1) {
  margin: 0;
}

div#point li img {
  width: 13px;
  vertical-align: -2px;
  margin: 0 5px 0 0;
}

div#point li a {
  font-size: 1.25em;
  font-weight: 700;
  color: #F55076;
}

div#point li a:hover {
  text-decoration: none;
  color: #FAADBF;
}

/* ポイント一覧 */
div#point-list {
  width: 100%;
  padding: 100px 0;
  background-color: #254860;
}

div#point-list-inner {
  width: 980px;
  margin: 0 auto 90px;
}

div#point-list-inner:nth-last-of-type(1) {
  width: 980px;
  margin: 0 auto;
}

div#point-list h2 {
  border-bottom: 3px solid #EF5E4B;
  font-size: 1.7em;
  line-height: 1.4;
  text-align: center;
  margin: 0 auto 5%;
  padding: 0.5% 0;
  color: #333333;
  width: 46%;
}

div#point-list h2 img {
  width: 25px;
  margin: 0 auto 3.5%;
  display: block;
}

div#point-list h2 object {
  display: block;
  font-size: 1.15em;
  text-align-last: justify;
  text-justify: inter-ideograph;
}

div#point-list h2 span {
  color: #EF5E4B;
}

div#point-list div.point-detail {
  background-color: #FFFFFF;
  padding: 10% 0;
}

div#point-list img.point-detail-image {
  margin: 0 0 4%;
}

div#point-list div.content {
  width: 670px;
  margin: 0 auto;
}

p.list-read {
  font-size: 1.1em;
  line-height: 1.8;
  margin: 0 0 7%;
}

p.cate-title {
  background-color: #254860;
  font-size: 1.6em;
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
  color: #FFFFFF;
  margin: 16% 0 4%;
  padding: 1.85% 0 1.6%;
}

p.cate-title.top {
  margin: 0 0 4%;
}

div.detail-list.ire {
  margin: 12% 0 0;
}

div.detail-list:nth-last-of-type(1) {
  margin: 0;
}

div.detail-c {
  margin: 0 0 5%;
}

div.detail-c object.tab {
  display: inline-block;
  padding: 1.6% 3%;
  background-color: #FA7392;
  font-size: 1.2em;
  font-weight: 700;
  color: #FFFFFF;
}

div.detail-c div.detail-outer {
  border: 1px solid #CCCCCC;
  padding: 3.5% 3%;
  position: relative;
}

div.detail-c div.detail-outer.sec {
  margin: 3% 0 0;
}

div.detail-c img.detail-image {
  width: 130px;
  float: left;
}

div.detail-c div.detail-left {
  width: 76%;
  float: right;
}

div.detail-c div.detail-left p.detail-caption {
  font-size: 1.03em;
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 4%;
}

div.detail-c div.detail-left a {
  color: #004DA2;
  display: block;
  position: absolute;
  bottom: 21px;
}

div.detail-c div.detail-left a:hover {
  color: #FF0000;
}

div.detail-c div.detail-left dt {
  margin: 0 0 0.8em;
}

div.detail-c div.detail-left dd img {
  margin: 0 5px 0 0;
  vertical-align: -2.5px;
}

div.detail-c div.detail-left2 {
  width: 76%;
  float: right;
}

div.detail-c div.detail-left2 p.detail-caption {
  font-size: 1.03em;
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 4%;
}

div.detail-c div.detail-left2 a {
  color: #004DA2;
  display: block;
  position: absolute;
  bottom: 50px;
}

div.detail-c div.detail-left2 a:hover {
  color: #FF0000;
}

div.detail-c div.detail-left2 dt {
  margin: 1.5em 0 0.8em;
}

div.detail-c div.detail-left2 dd {
  margin: 0 0 2em;
}

div.detail-c div.detail-left2 dd img {
  margin: 0 5px 0 0;
  vertical-align: -2.5px;
}

div.other-link {
  text-align: center;
  margin: 7% 0 0;
}

div.other-link a img {
  width: 3%;
  vertical-align: -3px;
  margin: 0 0 0 2%;
}

div.other-link.sepa {
  text-align: center;
  margin: 5% 0 8%;
}

div.other-link.sepa:nth-last-of-type(1) {
  text-align: center;
  margin: 5% 0 0;
}

div.other-link a {
  display: inline-block;
  padding: 1.3%;
  margin: 0 0 5%;
  background-color: #EF5E4B;
  border-radius: 2em;
  font-size: 1.15em;
  color: #FFFFFF;
  width: 60%;
  text-align: center;
}

div.other-link a:nth-last-of-type(1) {
  margin: 0;
}

div.other-link a:hover {
  text-decoration: none;
  opacity: 0.6;
}

span.triangle {
  display: inline-block;
  width: 15px;
  height: 17px;
  transform: matrix(0, 1, -1, 0, 0, 0);
  background: #FFFFFF 0% 0% no-repeat padding-box;
  opacity: 1;
}

p.attention {
  border: 1px solid #0099FF;
  color: #0099FF;
  text-align: center;
  padding: 1.8% 0;
}

p.attention a {
  color: #0099FF;
}

p.attention a:hover {
  color: #FF0000;
}

div #relation-outer {
  width: 100%;
}

div .relation {
  width: 980px;
  margin: 100px auto 0;
}

.relation h3 {
  font-size: 1.6em;
  text-align: center;
  padding: 13px 0;
  color: #fff;
  background-color: #004DA2;
}

.relation img {
  width: 230px;
  height: 153px;
  margin: 20px 15px 0 0;
}

.link-img li {
  display: inline;
}

.link-img li:nth-child(4n) img {
  margin-right: 0;
}

div.message-temp {
  background-color: #F5F5F5;
  padding: 5% 3%;
  margin: 7% 0 0;
}

div.temp-t {
  display: flex;
  margin: 0 0 5%;
}

div.temp-t img {
  margin: 0 4% 0 0;
}

div.temp-t object strong {
  display: block;
  font-size: 1.45em;
  line-height: 1.3;
  margin: 0 0 2.5%;
}

div.temp-t object span {
  display: block;
  font-size: 1.05em;
  line-height: 1.4;
}

div.temp-t object span a {
  text-decoration: underline;
}

div.temp-b {
  display: flex;
}

div.temp-b div.temp-b-inner {
  display: flex;
  width: 48%;
  margin: 0 4% 0 0;
}

div.temp-b div.temp-b-inner:nth-of-type(2) {
  margin: 0;
}

div.temp-b div.temp-b-inner img.template {
  height: 6.5em;
  margin: 0 4% 0 0;
  border: 1px solid #CECECE;
}

div.temp-b object {
  line-height: 1.3;
  font-size: 0.9em;
}

div.temp-b object strong {
  display: block;
  font-size: 1.2em;
  margin: 0 0 1%;
  color: #245BB5;
}

div.temp-b object span {
  display: block;
  margin: 0 0 5%;
}

/* clfx */
.clfx:after {
  content: "";
  clear: both;
  height: 0;
  display: block;
  visibility: hidden;
}
