@charset "utf-8";
/* CSS Document */
/* =======================================
 共通
======================================= */
p {
  line-height: 160%;
  font-size: 16px;
}
@media (max-width: 768px) {
  p {
    font-size: 13px;
  }
}
img {
  max-width: 100%;
}
.sec {
  max-width: 1040px;
  margin: 0 auto;
  padding: 30px 10px;
}
h1 {
  text-align: center;
}
h2 {
  font-size: 28px;
  margin: 0px auto 30px;
  text-align: center;
}
@media (max-width: 768px) {
  h2 {
    font-size: 20px;
  }
}
a:hover {
  text-decoration: underline !important;
}
a img {
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
a img:hover {
  opacity: .7;
}
.center {
  text-align: center;
}
.mar_top10 {
  margin-top: 10px;
}
.mar_top30 {
  margin-top: 30px;
}
@media (max-width: 767px) {
  .pc_img_change {
    display: none;
  }
  .sp_img_change {
    display: block;
  }
}
@media (min-width: 768px) {
  .pc_img_change {
    display: block;
  }
  .sp_img_change {
    display: none;
  }
}
/* =======================================
 背景
======================================= */
.bg_01 {
  background-color: #e7a1c3;
}
.bg_02 {
  background-image: url("../images/school.webp");
}
.bg_03 {
  background-color: #ffe99e;
}
.bg_05 {
  background-color: #f5c9c8;
}
.bg_06 {
  background-image: linear-gradient(90deg, rgba(115, 248, 224, 1), rgba(150, 167, 241, 1));
}
.bg_07 {
  background-color: #fffee8;
}
/* =======================================
 レイアウト
======================================= */
.c2_con {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.c2_sec {
  width: 48%;
}
@media (max-width: 768px) {
  .c2_sec {
    width: 100%;
    margin-bottom: 20px;
  }
}
@media (min-width: 769px) {
  .c2_sec {
    padding-bottom: 20px;
  }
}
#asfor_con {
  position: relative;
}
@media (min-width: 769px) {
  #asfor_con {
    margin: 0 auto;
    padding: 30px 0px 80px;
  }
}
@media (max-width: 768px) {
  #asfor_con {
    margin: 0 auto;
    padding: 30px 0px 40px;
  }
}
.asfor_il_01, .asfor_il_02 {
  position: absolute;
}
.asfor_il_01 {
  bottom: 0;
  left: 0;
}
.asfor_il_02 {
  bottom: 0;
  right: 0;
}
@media (max-width: 768px) {
  .asfor_il_01, .asfor_il_02 {
    display: none;
  }
}
.asfor {
  max-width: 400px;
  margin: auto;
  padding: 0 1em;
}
@media (min-width: 960px) {
  .asfor {
    max-width: 500px;
  }
}
@media (min-width: 769px) {
  .recommend_con {
    background: url("../images/recommend.png") no-repeat;
    background-position: 50%;
    background-size: 615px auto;
  }
  .recommend_con .recommend_sec {
    display: flex;
    justify-content: space-between;
    width: 100%;
  }
  .recommend_con .recommend_sec_row1 {
    padding-bottom: 135px;
  }
  .recommend_con .recommend_sec_row1 .od_illustrator {
    width: 327px;
    height: auto;
  }
  .recommend_con .recommend_sec_row2 {
    align-items: flex-end;
  }
  .recommend_con section {
    width: 400px;
  }
}
.recm_hd03 {
  font-size: 28px;
  color: #ff6779;
  display: inline-block;
  line-height: 128%;
  background-color: rgba(255, 255, 255, 0.8);
  padding: 10px 10px 5px;
  border-bottom: 5px solid;
}
@media (max-width: 768px) {
  .recommend_sec section {
    margin-bottom: 25px;
  }
  .recm_hd03 h3 {
    font-size: 20px;
  }
}
.item img {
  text-align: center;
}
.item h3 {
  text-align: center;
  font-size: 22px;
}
@media (max-width: 768px) {
  .item h3 {
    font-size: 20px;
  }
}
.reference_con {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.reference_con li {
  width: 33%;
}
@media (max-width: 768px) {
  .reference_con li {
    width: 50%;
    margin-bottom: 20px;
  }
}
.btn {
  margin: 30px auto 20px;
}
.btn_01 {
  margin: 5px 0;
  position: relative;
  padding: 1.2rem 6rem 1.2rem 5rem;
  background-color: #ffe99e;
  color: #444444;
  display: inline-block;
  text-align: center;
  border: 1px solid #ffe99e;
  text-decoration: none;
  transition: all 0.3s;
  border-radius: 14px;
  font-weight: bold;
}
.btn_01:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 2rem;
  font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.btn_01:hover {
  background: #fff;
  color: #ffe99e;
}
.btn_01:hover:after {
  right: 1.4rem;
}
.btn_01_white {
  background-color: #fff;
  color: #ffe99e;
}
footer small {
  padding-bottom: 20px;
}
.recommend_idx_con {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0px auto 50px;
}
.recommend_idx_box {
  width: 300px;
  padding-bottom: 30px;
  margin-right: 40px;
  margin-top: 40px;
  padding: 10px 20px;
  box-sizing: border-box;
  background-color: #fff;
  box-shadow: 6px 6px #4a556d;
}
.recommend_idx_box:nth-child(3n), .recommend_idx_box:nth-child(5n) {}
.recommend_idx_img {
  margin: 5px 0px;
  text-align: center;
}
.recommend_idx_txt {
  padding: 10px 0 15px;
}
@media (max-width: 768px) {
  .recommend_idx_box {
    display: block;
    width: 100%;
    padding: 20px;
    margin: 0px;
    width: 100%;
    max-width: 400px;
    border-bottom: 1px dotted #444;
  }
  .recommend_idx_box h3 {
    font-size: 16px;
  }
}
.tbl01 {
  border-collapse: collapse;
  margin: 0 auto;
  padding: 0;
  width: 850px;
  table-layout: fixed;
}
.tbl01 tr {
  background-color: #fff;
  padding: .35em;
  border: 2px solid #eee;
}
.tbl01 tr:last-child {
  border: none;
}
.tbl01 th {
  padding: 1.5em;
  border-right: 2px solid #fff;
}
.tbl01 td {
  padding: 2em .5em;
  border-right: 2px solid #eee;
  text-align: center;
}
.tbl01 th {
  font-size: .85em;
}
.tbl01 .attention {
  font-size: 120%;
  background-color: #ffeac2;
  color: #f8a200;
  font-weight: bold;
}
.tbl01 thead tr {
  background-color: #9a9a9a;
  color: #fff;
}
.tbl01 tbody th {
  border-right: 2px solid #eee;
}
.tbl01 th.non {
  border-right: none;
}
.tbl01 .txt {
  text-align: left;
  font-size: .85em;
}
.tbl01 .price {
  color: #000;
  font-weight: bold;
  font-size: 1.3em
}
.tbl01 .price span {
  font-size: .6em;
}
.tbl01 .orange_bk {
  background: #F8A200;
  color: #fff;
  position: relative;
}
.orange_bk:before {
  content: '';
  width: 100%;
  height: 10px;
  position: absolute;
  background-color: #F8A200;
  left: 0;
  bottom: 100%;
}
.orange_bk:after {
  width: max-content;
  color: #f88400;
  font-size: .8rem;
  padding: 0.3em 1em;
  background: #fff;
  border: 2px solid #f88400;
  border-radius: 100vh;
  position: absolute;
  top: -25px;
  left: 50%;
  transform: translateX(-50%);
}
.tbl01 .red-txt {
  color: #e81010
}
@media screen and (max-width: 600px) {
  .wrap {
    overflow-x: scroll;
  }
  .tbl01 {
    width: 600px;
  }
  .tbl01 tr {
    font-size: 90%;
  }
}
.bubble_con {
  margin: 0 auto;
  max-width: 960px;
}
.bubble {
  display: inline-block;
  position: relative;
  border-radius: 5px;
  background: #fff;
  width: 100%;
  max-width: 960px;
}
.bubble:after {
  position: absolute;
  content: " ";
  height: 0;
  width: 0;
}
/* 下中央 */
.bubble-bottom:after {
  top: 100%;
  left: 50%;
  border: 30px solid transparent;
  border-top: 30px solid #fff;
  margin-left: -30px;
}
.bubble_txt {
  margin: 30px 10px;
}
.bubble_imga img {
  width: 100%;
  height: auto;
  max-width: 300px;
  margin: 5px 0 5px;
}
.bubble_txt h3 {
  margin-bottom: 15px;
}
.bubble_icon {
  position: absolute;
  right: -16px;
  top: 10px;
}
@media (min-width: 769px) {
  .bubble .right_con4 {
    width: 63%;
    margin-right: 5%;
  }
}
@media (max-width: 768px) {
  .bubble_icon {
    right: -18px;
    top: 150px;
  }
}
@media (min-width: 769px) {
  .left_con {
    float: left;
  }
  .right_con {
    float: right;
  }
  .left_con {
    width: 28%;
  }
  .right_con {
    width: 68%;
  }
}
.k_hd03 {
  width: fit-content;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
.k_hd03 span {
  padding: 7px 19px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border: solid 1px #2e2e38;
  background: #3ecfd8;
  margin-top: 10px;
  color: #fff;
  font-size: 20px;
}
#hd03 {
  background-color: #e2f47b;
}
.btn_area {
  margin: 20px auto;
  width: 100%;
  text-align: center;
}
.btn_02 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50%;
  height: 50px;
  box-sizing: border-box;
  background: repeating-linear-gradient(45deg, #ffffff, #ffffff 3px, #e7e7e7 3px, #e7e7e7 30px);
  color: #333;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-decoration: none;
  position: relative;
  margin: auto;
}
.btn_02 span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 50px;
  color: #fff;
  box-sizing: border-box;
  position: absolute;
  top: -6px;
  left: -6px;
  transition-duration: 0.2s;
  background: -moz-linear-gradient(65deg, #F13F79, #FFC778);
  background: -webkit-linear-gradient(65deg, #F13F79, #FFC778);
  background: linear-gradient(25deg, #F13F79, #FFC778);
}
.btn_02:hover span {
  left: -1px;
  top: -1px;
}
.grd_hd02 {
  position: relative;
  padding: .5rem;
  outline: 1px solid #FF5ACD;
  outline-offset: -1px;
  color: #353535 !important;
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  background-color: #fff;
  max-width: 450px;
}
.grd_hd02::before, .grd_hd02::after {
  position: absolute;
  content: '';
}
.grd_hd02::before {
  top: 5px;
  right: -10px;
  width: 10px;
  height: 100%;
  background-image: linear-gradient(45deg, #FBDA61 0%, #FF5ACD 100%);
  transform: skewY(45deg);
}
.grd_hd02::after {
  bottom: -10px;
  left: 5px;
  width: 100%;
  height: 10px;
  background-image: linear-gradient(45deg, #FF5ACD 0%, #FBDA61 100%);
  transform: skewX(45deg);
}
@media only screen and (max-width: 480px) {
  .grd_hd02 {
    padding: .1rem;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    background-color: #fff;
  }
}
.feat_hd03 {
  padding: 0.5rem 1rem 0.5rem 1.5rem;
  margin-bottom: 0.2rem;
  background-image: linear-gradient(to top, #b2d5de 10%, #66c5dd 100%);
  background-repeat: no-repeat;
  background-size: 0.5rem 100%;
  font-weight: bold;
  font-size: 18px;
}
.overview_con {
  width: 100%;
  max-width: 1080px;
  margin: auto;
  padding-top: 20px;
}
/*＝＝＝並び替えボタンのCSS*/
.sort-btn {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding: 50px 20px;
}
.sort-btn li {
  background: #eee;
  list-style: none;
  border-radius: 10px;
  cursor: pointer;
  padding: 10px;
  margin: 0 10px;
}
.sort-btn li.active { /*ボタンに現在地＝activeというクラス名がついたら背景色を変更*/
  background: #ccc;
}
/*横幅が480px以下になった際の指定*/
@media only screen and (max-width: 480px) {
  .sort-btn {
    justify-content: space-between;
  }
  .sort-btn li {
    width: 42%;
    margin: 0 0 10px 0;
    text-align: center;
    font-size: 90%;
  }
}
/*＝＝＝Muuriのレイアウトのための調整 */
.grid {
  position: relative; /*並び替えの基準点を指定*/
}
/*各画像の横幅などの設定*/
.item_box {
  display: block;
  position: absolute;
  width: 33%; /*横並びで3つ表示*/
  z-index: 1;
  list-style: none;
}
/*内側のボックスの高さが崩れないように維持*/
.item-content {
  position: relative;
  width: 100%;
  height: 100%;
}
/*画像の横幅を100%にしてレスポンシブ化*/
.grid img {
  width: 100%;
  height: auto;
  vertical-align: bottom; /*画像の下にできる余白を削除*/
}
/*横幅が768px以下になった際の指定*/
@media only screen and (max-width: 768px) {
  .item_box {
    width: 49.5%; /*横並びで2つ表示*/
  }
}
.item_box p {
  text-align: center;
}
.tbl02 {
  width: 100%;
  text-align: center;
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 120%;
}
.tbl02 tr:nth-child(2n+1) {
  background: #f0f0f0;
}
.tbl02 th {
  padding: 10px;
  background: #444;
  border-right: solid 1px #778ca3;
  color: #ffffff;
}
.tbl02 th:last-child {
  border-right: none;
}
.tbl02 td {
  padding: 10px;
  border-right: solid 1px #778ca3;
}
.tbl02 td:last-child {
  border-right: none;
}
.list_worries {
  list-style-type: disc;
  list-style-position: inside;
  padding: 1em;
  border: 2px solid #2589d0;
  margin: auto;
  max-width: 600px;
  background-color: #fff;
	font-size: 130%;
}
.list_worries li {
  padding: .5em;
}
.list_worries li:not(:last-child) {
  border-bottom: 1px dashed #2589d0;
}
.list_worries li::marker {
  color: #2589d0;
  font-size: 1.1em;
}
@media (max-width: 768px) {
.list_worries {
font-size: 110%;
}
}
.age_hd02 {
  position: relative;
  margin-bottom: 30px;
  font-size: 24px;
  text-align: center;
  padding-top: 20px;
}
.age_hd02:before {
  content: '';
  position: absolute;
  bottom: -7px;
  display: inline-block;
  width: 60px;
  height: 3px;
  left: 50%;
  -moz-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: black;
  border-radius: 2px;
}
.parallax_bg {
  background: url("../images/print_agency/bg_plala.jpg");
  background-size: cover;
  height: 450px;
  position: relative;
	background-position: center right;
}
@media (min-width: 769px) {
  .parallax_bg {
    background-attachment: fixed;
  }
}
@media (max-width: 768px) {
  .parallax_bg {
    height: 320px;
  }
}
#catch_txt{
position: absolute;
  top: 25%;
  left: 0;
  right: 0;
  margin: auto;
}
#pri_01, #pri_02{
	position: absolute;
	bottom:20%;
}
#pri_01{
	left: 10%;
}
#pri_02{
	right: 10%;
}



.parallax_bg02 {
  background: url("../images/print_agency/bg_plala02.jpg");
  background-size: cover;
  height: 350px;
  position: relative;
}
@media (min-width: 769px) {
  .parallax_bg02 {
    background-attachment: fixed;
  }
}
@media (max-width: 768px) {
  .parallax_bg02 {
    height: 320px;
  }
}
#catchcopy {
  position: absolute;
  left: 50%;
  top: 50%;
  bottom: 50%;
  transform: translateX(-50%);
}
.bg_08 {
  background-color: #D1D1D1;
}
.bg_09 {
  background-image: url("../images/print_agency/stripes-light.webp");
}
.bg_10 {
  background-color: #014099;
}
.bg_10 .age_hd02 {
  color: #fff;
}
.bg_10 .age_hd02:before {
  background-color: #fff;
}
.age_hd03 {
  padding: 0.25em 0.5em;
  color: #0c5295;
  background: transparent;
  border-left: solid 5px #0c5295;
  font-weight: bold;
  font-size: 120%;
}
.recommend_con2 {
  margin-bottom: 30px;
}
.recommend_box2 {
  background: rgba(255, 255, 255, 0.8);
  padding: 1em;
  line-height: 200%;
}
.recommend_box2 h3 span {
  display: inline-block;
  vertical-align: middle;
}
.recommend_box2 p {
  margin-top: 10px;
}
.mar_left10 {
  margin-left: 10px;
}
@media (min-width: 769px) {
  .recommend_box2 {
    padding: 2em;
    margin-top: 4%;
    height: 170px;
  }
  .neg_mar_left50 {
    margin-left: -50px;
  }
  .neg_mar_right50 {
    margin-right: -50px;
  }
}
.service_txt {
  font-size: 20px;
  color: #0c5295;
  text-align: center;
  margin-top: 5px;
}
@media (max-width: 768px) {
  .service_txt {
    font-size: 15px;
  }
}
.about-book {
  background-color: #ebebeb;
  border: none;
}
@media (min-width: 769px) {
  .left_con1 {
    float: left;
    width: 59%;
  }
  .right_con1 {
    float: right;
    width: 39%;
  }
  .left_con2 {
    float: left;
    width: 39%;
  }
  .right_con2 {
    float: right;
    width: 59%;
  }
}
.precautions h3 {
  font-size: 130%;
  font-weight: bold;
}
.reco_hd3 {
  position: relative;
  padding: .5em .5em .5em calc(60px + .8em);
  background-color: #0c5295;
  color: #fff;
  overflow: hidden;
  font-size: 20px;
}
.reco_hd3 span {
  position: absolute;
  top: 0;
  left: 0;
  width: 65px;
  height: 100%;
  clip-path: polygon(0 0, 100% 0, 75% 100%, 0 100%);
  background-color: #000; /*左側の背景色*/
  color: #fff; /*数字の文字色*/
  opacity: .5; /*不透明度*/
  font-size: 1.5em;
  padding: 10px 0 0 .3em;
}
.sona {
  background-color: #014099;
  width: 100%;
  text-align: center;
  font-weight: bold;
  font-size: 3em;
  color: white;
  padding: 1.7em 0 1em 0;
  position: relative;
}
.sona::after {
  position: absolute;
  content: "";
  width: 0;
  height: 0;
  border: 100px solid transparent;
  border-top: 30px solid #fff;
  left: calc(50% - 100px);
  top: -2px;
}
.sona p {
  font-size: 20px;
}
@media (max-width: 960px) {
  .spnone {
    display: none;
  }
}
#pri_01 img, #pri_02 img{
	width: 280px;
	height: auto;
}
.marker_blue{
	background: linear-gradient(transparent 50%, #bde4f7 50%);
  padding: 0 0.1em;
	font-weight: bold;
}

.btn_contact summary {
  cursor: pointer;
}
.btn_contact details {
  padding: 10px 20px;
  position: fixed;
  right: 0;
  bottom: 0;
background: -moz-linear-gradient(65deg, #F13F79, #FFC778);
    background: -webkit-linear-gradient(65deg, #F13F79, #FFC778);
    background: linear-gradient(25deg, #F13F79, #FFC778);
  color: #fff;
  z-index: 999;
}

@media (max-width: 768px) {
.btn_contact details {
	display: none;
}
}
.btn_contact summary {
  list-style: none;
  position: relative;
  cursor: pointer;
  padding-right: 2em;
  font-size: 140%;
  font-weight: bold;
}

.btn_contact summary::-webkit-details-marker {
  display: none;
}

.btn_contact summary::after {
  content: '+';
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  transition: transform 0.5s;
  font-size: 30px;
}

.btn_contact details[open] summary::after {
  transform: translateY(-50%) rotate(45deg);
}

.btn_contact_box {
  text-align: center;
}

.btn_contact_link a {
  display: block;
  color: #E26B5D;
  background: #fff;
  padding: 0.5em;
  font-size: 110%;
  font-weight: bold;
  text-decoration: none;
  border-radius: 100vh;
  border: 4px double #E26B5D;
  transition: 0.5s;
}


.btn_contact_link a:hover {
    opacity: 0.8;
}