@charset "utf-8";

/* テンプレ乗るまでの仮CSSここから */
html {
  font-size: 62.5%;
}

body {
  font-size: 1.4rem;
}

#index p,
#category p,
#page p {
  margin-top: 1rem;
}

#index p>span,
#category p>span,
#page p>span {
  color: red;
}

#index .caption,
#category .caption,
#page .caption {
  font-size: 1rem;
}

#index .caption,
#category .caption,
#page .caption a {
  color: #999;
}

#index p.btn-internal,
#category p.btn-internal,
#page p.btn-internal,
#index p.btn-web,
#category p.btn-web,
#page p.btn-web {
  display: block;
  width: 50%;
  box-sizing: border-box;
  padding: 0.5rem;
  border: 1px solid #000;
  text-align: center;
  margin: 2rem auto;
}

/* テンプレ乗るまでの仮CSSここまで */

.category_links{
	margin: 5rem 0 3.5rem;
	padding: 1.7rem 3rem;
	font-size: 3rem;
	font-weight: 900;
	color: #453c18;
	border-bottom: 3px solid #95ce57;
	line-height: 1.4;
	position: relative;
	z-index: 5;
	background: url(img/bg_shooting_small01.png) no-repeat left 30px center;
	background-color: #b2de83;
}


.google {
    display: flex;
    justify-content: center;
    width: 100%;
    border-top: #006894 solid 1px;
    border-bottom: #006894 solid 1px;
    padding: 16px 0;
}

.google dt {
    box-sizing: border-box;
    width: 176px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    background-image: -moz-linear-gradient(0deg, rgb(105, 190, 239) 0%, rgb(179, 233, 226) 100%);
	background-image: -webkit-linear-gradient(0deg, rgb(160 211 104) 0%, rgb(179, 233, 226) 100%);
    background-image: -ms-linear-gradient(0deg, rgb(105, 190, 239) 0%, rgb(179, 233, 226) 100%);
    padding: 1rem 1.7rem;
    font-size: 1.8rem;
    line-height: 1.2;
}

.google dd {
    display: flex;
    align-items: baseline;
    justify-content: center;
    text-align: center;
    padding: 6px 55px;
    font-size: 2rem;
    line-height: 1.2;
    font-weight: bold;
}

.selectionBoxGoogle {
 display: table;
 width: 100%;
 border-top: #006894 solid 1px;
 border-bottom: #006894 solid 1px;
 padding: 15px 0;
 margin: 14px 0 0;
}

.selectionBoxGoogle dt {
 display: table-cell;
 background-image: -moz-linear-gradient( 0deg, rgb(105,190,239) 0%, rgb(179,233,226) 100%);
 background-image: -webkit-linear-gradient(0deg, rgb(160 211 104) 0%, rgb(179, 233, 226) 100%);
 background-image: -ms-linear-gradient( 0deg, rgb(105,190,239) 0%, rgb(179,233,226) 100%);
 vertical-align: middle;
 text-align: center;
 padding: 1rem 1.7rem;
 font-size: 1.4rem;
 line-height: 1.2;
}

.selectionBoxGoogle dd {
 display: table-cell;
 vertical-align: middle;
 text-align: center;
 padding: 6px 10px;
 font-size: 1.4rem;
 line-height: 1.2;
 font-weight: bold;
}

.selectionBoxGoogle dd span {
 color: #dc405d;
 font-size: 3.2rem;
}




details.js-details {
  margin-bottom: 10px;
}
details.js-details summary {
  display: block;
  list-style: none;
}
details.js-details summary::-webkit-details-marker {
  display: none;
}
details.js-details .summary_inner{
  border: 1px solid #ccc;
  border-radius: 6px;
  color: #002255;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 18px;
  font-weight: bold;
  padding: 10px;
}
details.js-details .a-icon {
  display: block;
  position: relative;
  width: 24px;
  margin-left: 6px;
  flex-shrink: 0;
  transform-origin: center 43%;
  transition: transform 0.4s;
}
details.details-opened .a-icon {
  transform: rotate(180deg);
}
details.js-details .a-icon:before,
details.js-details .a-icon:after {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 3px;
  background-color: #666;
}
details.js-details .a-icon:before {
  left: 0;
  transform: rotate(45deg);
}
details.js-details .a-icon:after {
  right: 0;
  transform: rotate(-45deg);
}
details.js-details .js-content-in {
  background-color: #f7f7f7;
  padding: 10px;
  word-break: break-all;
}

.l-parts03-column3__box {
    width: calc(((100% - 4rem) / 3) - 1px);
    margin: 0 2rem 2rem 0;
    background: #fff;
    border-radius: 20px 20px 0 0;
    position: relative;
    padding-bottom: 50px;
    height: 100%;
}


.l-parts03-column3__title::after {
    top: unset;
    bottom: 1rem;
}

.l-parts03-column3__title {
    position: relative;
}
.selectionBoxGoogle {
    display: flex;
    justify-content: space-around;
}

.selectionBoxGoogle dd span {
    font-size: 2rem;
}
.l-parts03-column3__title {
    padding-top: 0;
}

.l-parts03-column3__heading {
    margin-top: 2rem;
}
.l-mv {min-height: 24vw;background-size: 100%;background-position-y: -10%;border-bottom: 3rem solid #b2df84;padding-top: 0rem;background-repeat: no-repeat;}
.l-parts03-column3__frame2 {
    font-weight: bold;
    line-height: 1.5;
}
ul.future li {margin-bottom: 15px;padding-left: 20px;position: relative;}

ul.future li span {
    color: #f25b18;
    font-weight: bold;
    font-size: 1.4rem;
}
ul.future {
    background: #fbf7ef;
    padding: 10px;
    margin: 0;
}

ul.future li:before {
    content: "●";
    position: absolute;
    left: 0;
    color: #f25b18;
}
p.future-ttl {
    text-align: center;
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 0;
    padding: 0;
}

/*----------------------------------------------------
    PCサイトcss
----------------------------------------------------*/

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

  /*/////////////PC用のCSSをここに作成してください。/////////////*/
  /*/////////////必ず中括弧の中に作成してください。/////////////*/
  #page div.wr_two-box {
    position: relative;
    width: 100%;
    margin: 1rem auto;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: row;
  }

  #page div.wr_two-box * {
    box-sizing: border-box;
  }

  #page div.wr_two-box .wr_box {
    width: 47.5%;
    padding: 1rem;
    /* text-align: center; */
  }

  #page div.wr_two-box .wr_box img {
    width: 100%;
    max-width: 100%;
    height: auto;
    vertical-align: top;
    border: none;
  }

  #page div.wr_two-box .wr_caption {
    font-size: 1rem;
    color: #999;
    display: inline-block;
    margin: 0.5rem auto;
  }

  #page div.wr_two-box .wr_caption a {
    color: #999;
  }
}



/*----------------------------------------------------
    SPサイトcss
----------------------------------------------------*/

@media screen and (max-width: 599px) {
  /*/////////////SP用のCSSをここに作成してください。/////////////*/
  /*/////////////必ず中括弧の中に作成してください。/////////////*/

  #page div.wr_two-box {
    position: relative;
    width: 100%;
    margin: 1rem auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
  }

  #page div.wr_two-box .wr_box {
    width: 100%;
    padding: 2rem;
    /* text-align: center; */
  }
.category_links{
    font-size: 2rem;
    background-size: 56px;
    padding: 1.4rem 1rem 1.2rem;
    margin: 5rem 0 2rem;
    background: url(img/bg_shooting_small01.png) no-repeat left 7px center #b2de83;
}
}

/*----------------------------------------------------
    PCサイトcss
----------------------------------------------------*/

@media screen and (min-width: 600px) {
/*/////////////PC用のCSSをここに作成してください。/////////////*/
/*/////////////必ず中括弧の中に作成してください。/////////////*/
.l-header-area,
.l-contents-area,
.l-footer-area {
	padding-left: 0;
}
.l-footer-disclaimer {
	margin: 0 auto 20px;
}
.l-parts03-column3__frame2 {
    padding-inline: 10px;
}

}



/*----------------------------------------------------
    SPサイトcss
----------------------------------------------------*/

@media screen and (max-width: 599px) {
/*/////////////SP用のCSSをここに作成してください。/////////////*/
/*/////////////必ず中括弧の中に作成してください。/////////////*/
.l-footer-area {
    padding: 2rem 0 0;
}
.google dd {
    padding: 6px 0;
    margin: 0;
}
.google dl {
    width: 50%;
}

.google dl dt {
    width: auto;
}	
.l-parts03-column3 {
    display: block;
}
.l-parts03-column3__box {
    width: auto;
    margin: unset;
    margin-bottom: 3rem;
}	
.l-mv {
    margin:0;
}

.l-mv-box {
    min-height: 110px;
}

.l-parts03 {
    padding-top: 1rem;
}
.l-common-title {font-size: 2rem;padding-inline: 0.5rem;line-height: 1.5;}
.l-parts03-column3__catch {
    font-size: 2rem;
    padding-left: 7rem;
}
.l-parts03-column3__catch:before {
    background-size: 70px !important;
    left: 50px !important;
}

}