@charset "UTF-8";
/*ーーーーーーーーーー
共通
ーーーーーーーーーーー*/
body {
  color: #444;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 1.8; }
  @media (max-width: 800px) {
    body {
      font-size: 14px; } }

.wrap {
  width: 100%;
  max-width: 1600px;
  margin: 0 auto; }

img {
  max-width: 100%; }

.container {
  width: 92%;
  margin: 0 auto 80px;
  max-width: 1000px;
  padding: 0; }
  @media (max-width: 800px) {
    .container {
      margin: 0 auto 60px; } }

h2.category-title {
  width: 52%;
  max-width: 250px;
  padding: 0;
  margin: 0 0 20px; }
  @media (max-width: 800px) {
    h2.category-title {
      margin: 0 0 15px; } }

.head-img {
  margin: 0 0 5px;
  padding: 107px 0 0;
  position: relative; }
  .head-img p {
    display: inline;
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 0 0.8em;
    margin: 0;
    background: white;
    font-size: 12px;
    border-radius: 5px 0 0 0; }
    @media (max-width: 940px) {
      .head-img p {
        font-size: 11px; } }
  @media (max-width: 940px) {
    .head-img {
      padding: 76px 0 0; } }
  .head-img h2 {
    text-align: center;
    font-size: 30px;
    line-height: 1.2;
    padding: 100px 0;
    background: #d8dfe1; }
    @media (max-width: 940px) {
      .head-img h2 {
        font-size: 20px;
        padding: 60px 0; } }

.p-list {
  font-size: 13px;
  color: #666;
  margin-bottom: 60px; }
  @media (max-width: 800px) {
    .p-list {
      font-size: 12px;
      margin-bottom: 40px; } }
  .p-list a {
    color: #666;
    text-decoration: underline;
    display: inline; }
    .p-list a:hover {
      text-decoration: none; }
  .p-list span:after {
    content: "　＞　"; }

.btn-pink {
  background: #ea5550;
  font-size: 18px;
  font-weight: 500;
  color: #fff;
  width: 18em;
  text-align: center;
  margin: 0 0;
  padding: 0.5em;
  border-radius: 32px;
  position: relative;
  transition: .3s; }
.btn-pink.gray {
  background: #ddd;
  color: #444;
}
  .btn-pink.dl {
    margin: 0 auto;
    background: #1c50a1; }
@media (max-width: 800px) {
	.btn-pink {
		font-size: 15px;
		width: 15em;
		margin: 0 auto;
	}
}
.btn-pink:hover {
	opacity: .7;
}
.btn-pink:hover a:after {
	right: 0.7em;
}
.btn-pink a:hover {
	text-decoration: none;
}
.btn-pink a::after {
	content: '';
	width: 18px;
	height: 7px;
	border-bottom: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: skew(45deg);
	position: absolute;
	right: 1.2em;
	top: 40%;
	transition: .3s;
}
.btn-pink.gray a::after {
	display: none;
}

/*ーーーーーーーーーー
TOP スライダー
ーーーーーーーーーーー*/
.slick-main {
  padding: 107px 0 0; }
  @media (max-width: 940px) {
    .slick-main {
      padding: 76px 0 0; } }
  .slick-main .main-slider {
    position: relative;
    width: 100%; }
    .slick-main .main-slider p {
      display: inline;
      position: absolute;
      bottom: 0;
      right: 0;
      padding: 0 0.8em;
      margin: 0;
      background: white;
      font-size: 12px;
      border-radius: 5px 0 0 0; }
      @media (max-width: 940px) {
        .slick-main .main-slider p {
          font-size: 11px; } }

.slick-dots li button:before {
  font-size: 16px !important;
  color: #aaa; }

.slick-dots {
  bottom: -35px !important; }

.slick-dots li.slick-active button:before {
  color: #ea5550; }

/*ーーーーーーーーーー
TOP お知らせ
ーーーーーーーーーーー*/
#information {
  margin: 80px 0 0; }
  @media (max-width: 800px) {
    #information {
      margin: 60px 0 0; } }

.cont-info {
  display: flex;
  padding: 1.2em 0;
  border-bottom: 1px solid #ddd;
  flex-wrap: nowrap;
  line-height: 1.6; }
  .cont-info .date {
    margin-right: 3em; }
    @media (max-width: 800px) {
      .cont-info .date {
        margin-right: 1.5em; } }
  .cont-info .cont {
    display: block;
    width: 100%; }
  .cont-info a {
    display: block;
    width: 100%;
    position: relative;
    color: #444;
    padding-right: 3.5em; }
    @media (max-width: 800px) {
      .cont-info a {
        padding-right: 3em; } }
    .cont-info a::after {
      content: '';
      width: 1.5em;
      height: 0.7em;
      border-bottom: solid 2px #1c50a1;
      border-right: solid 2px #1c50a1;
      transform: skew(45deg);
      position: absolute;
      right: 1em;
      top: 0.5em; }

/*ーーーーーーーーーー
TOP おすすめ
ーーーーーーーーーーー*/
.arch-top {
  z-index: 100; }

.arch-bottom {
  margin-top: -5px;
  z-index: 100; }

#pickup {
  background: #e2f2f5;
  margin-top: -5px;
  z-index: 101;
  padding: 10px 0; }
  @media (max-width: 800px) {
    #pickup {
      padding: 20px 0; } }
  #pickup .container {
    margin: 0 auto 0px; }

.list-pickup {
  display: flex;
  gap: 3%;
  flex-wrap: wrap;
  padding: 15px 0 0 0; }
  @media (max-width: 800px) {
    .list-pickup {
      display: flex;
      gap: 35px 0;
      flex-wrap: wrap;
      justify-content: center; } }
  .list-pickup li {
    width: 22.75%;
    text-align: center;
    transition: .3s; }
    @media (max-width: 800px) {
      .list-pickup li {
        width: 60%; } }
    .list-pickup li h3 {
      text-align: center;
      font-size: 18px;
      display: inline;
      margin: 0 auto;
      padding: 5px 0.5em 2px;
      background: linear-gradient(transparent 70%, #a0d7e2 70%); }
      @media (max-width: 800px) {
        .list-pickup li h3 {
          font-size: 16px; } }
    .list-pickup li a:hover {
      text-decoration: none; }
    .list-pickup li img {
      border-radius: 20px;
      border: 1px solid #fff;
      box-shadow: 8px 8px 5px #a0d7e2;
      margin: 0 0 18px; }
    .list-pickup li:hover {
      margin-top: -12px;
      padding-bottom: 12px; }
      @media (max-width: 800px) {
        .list-pickup li:hover {
          margin-top: 0px;
          padding-bottom: 0px; } }

/*ーーーーーーーーーー
TOP シリーズ
ーーーーーーーーーーー*/
#series h2.category-title {
  padding-top: 40px; }

.list-series {
  display: flex;
  gap: 27px 3%;
  flex-wrap: wrap;
  padding: 15px 0 0 0; }
  @media (max-width: 800px) {
    .list-series {
      gap: 15px 4%;
      flex-wrap: wrap;
      padding: 10px 0 0 0; } }
  .list-series li {
    width: 22.75%;
    text-align: center;
    transition: all .3s;
    position: relative; }
    @media (max-width: 800px) {
      .list-series li {
        width: 48%; } }
    .list-series li img {
      border-radius: 20px;
      border: 1px solid #ddd; }
    .list-series li h3 {
      position: absolute;
      text-align: center;
      bottom: 0;
      width: 100%;
      background: rgba(255, 255, 255, 0.95);
      padding: 0.7em 0;
      margin: auto auto;
      font-size: 15px;
      font-weight: 500;
      transition: .3s;
      border-bottom: 1px solid #ddd;
      border-left: 1px solid #ddd;
      border-right: 1px solid #ddd;
      border-radius: 0 0 20px 20px; }
      @media (max-width: 800px) {
        .list-series li h3 {
          font-size: 14px; } }
    .list-series li:hover {
      margin-top: -12px;
      padding-bottom: 12px; }
      @media (max-width: 800px) {
        .list-series li:hover {
          margin-top: 0px;
          padding-bottom: 0px; } }
      .list-series li:hover h3 {
        bottom: 12px; }
        @media (max-width: 800px) {
          .list-series li:hover h3 {
            bottom: 0; } }

/*ーーーーーーーーーー
シリーズ　ページ
ーーーーーーーーーーー*/
.box-prd {
  width: 95%;
  max-width: 850px;
  margin: 0 auto 40px;
  border: 1px solid #ddd;
  background: #fff;
  box-shadow: 8px 8px 5px #a0d7e2;
  display: flex;
  gap: 0;
  border-radius: 20px; }
  @media (max-width: 800px) {
    .box-prd {
      width: 80%;
      max-width: 500px;
      margin: 0 auto 30px;
      flex-wrap: wrap; } }
  .box-prd .ph {
    width: 38%; }
    .box-prd .ph img {
      border-radius: 20px 0 0 20px; }
    @media (max-width: 800px) {
      .box-prd .ph {
        width: 100%; }
        .box-prd .ph img {
          border-radius: 20px 20px 0 0; } }
  .box-prd .cont-prd {
    width: 62%;
    align-self: center;
    padding: 1em 2em; }
    @media (max-width: 800px) {
      .box-prd .cont-prd {
        width: 100%;
        padding: 1em 1em; } }
  .box-prd h2 {
    font-size: 21px;
    margin: 0;
    padding: 0 0 0.7em;
    line-height: 1.6; }
    @media (max-width: 800px) {
      .box-prd h2 {
        font-size: 18px; } }
  .box-prd p.two-line {
    margin: 0 0 0.5em; }
  .box-prd p span {
    background: #ddd;
    width: 6em;
    text-align: center;
    display: inline-block;
    padding: 0.1em 0.5em 0.2em;
    margin: 0 0.5em 0 0; }


/*店舗限定アイコン_2022.10.11追加
-----------------------------------*/
ul.shop_icon {
  display: flex;
  justify-content: start;
  flex-direction: row;
  gap: 10px;
}

ul.shop_icon li {
  position: relative;
}

ul.shop_icon li img {
  width: auto;
  height: 50px;
}
ul.shop_icon.small_icon li img {
  width: auto;
  height: 30px;
}

ul.shop_icon span {
  width:max-content;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  font-weight: 600;
}
@media (max-width: 800px) {
  .box-prd {
    width: 80%;
    max-width: 500px;
    margin: 0 auto 30px;
    flex-wrap: wrap;
  }

  .box-prd .ph {
    width: 100%;
  }

  .box-prd .ph img {
    border-radius: 20px 20px 0 0;
  }

  .box-prd .cont-prd {
    width: 100%;
    padding: 1.8em 1em;
  }

  .box-prd h2 {
    font-size: 18px;
  }

  .box-prd p.two-line {
    margin: 0 0 1em; 
  }

  /*店舗限定アイコン_2022.10.11追加
-----------------------------------*/

  ul.shop_icon li img {
    height: 30px;
  }

  ul.shop_icon span {
    font-size: 16px;
  }
}



/*ーーーーーーーーーー
ダウンロードページ
ーーーーーーーーーーー*/
.box-prd.pop {
  width: 95%;
  max-width: 850px;
  margin: 0 auto 40px;
  border: 1px solid #ddd;
  background: #fff;
  box-shadow: 8px 8px 5px #a0d7e2;
  display: flex;
  gap: 0;
  border-radius: 20px; }
  .box-prd.pop .btn-pink {
    background: #1c50a1; }
  @media (max-width: 800px) {
    .box-prd.pop {
      width: 80%;
      max-width: 500px;
      margin: 0 auto 30px;
      flex-wrap: wrap; } }
  .box-prd.pop .ph {
    width: 35%;
    padding: 1em; }
    .box-prd.pop .ph img {
      border-radius: 0; }
    @media (max-width: 800px) {
      .box-prd.pop .ph {
        width: 100%; }
        .box-prd.pop .ph img {
          border-radius: 0; } }
  .box-prd.pop .cont-prd {
    width: 65%;
    align-self: center;
    padding: 1em 2em; }
    @media (max-width: 800px) {
      .box-prd.pop .cont-prd {
        width: 100%;
        padding: 1em 1em; } }

.pop-menu {
  margin: 10px auto 50px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
	max-width: 750px;
}
  @media (max-width: 800px) {
    .pop-menu {
      margin: 10px auto 30px;
      gap: 8px 0.4%; } }
  .pop-menu li {
    text-align: center;
    min-width: 14em; }
    @media (max-width: 800px) {
      .pop-menu li {
        min-width: 49.8%;
        width: 49.8%; } }
    .pop-menu li a {
      background: #1c50a1;
      border: 2px solid #1c50a1;
      color: #fff;
      padding: 0.4em 0.1em;
      border-radius: 20px;
      font-size: 14px;
      min-width: 15em;
      display: inline-block; }
      @media (max-width: 800px) {
        .pop-menu li a {
          font-size: 12px; } }
      .pop-menu li a.active {
        background: #fff;
        color: #1c50a1; }


  /*ダウンロードボタン_2024.09.27追加
-----------------------------------*/
.W_btn {
	position: relative;
}
.W_btn:hover {
	opacity: 1;
}
.W_btn p.download_btn::after {
    content: '';
    width: 18px;
    height: 7px;
    border-bottom: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: skew(45deg);
    position: absolute;
    right: 1.2em;
    top: 40%;
    transition: .3s;
}

.W_btn:hover p.download_btn::after {
	right: 0.7em;
}
.W_btn p.download_btn {
	display: inline-block;
	font-size: 18px;
	font-weight: 500;
	color: #fff;
	text-align: center;
	margin: 0 0;
	transition: .3s;
}
.W_btn_list a::after {
	display: none;
}
.W_btn ul.W_btn_list {
	position: absolute;
	top: 50px;
	left: 50%;
	transform: translateX(-50%);
	width: 88%;
	background: #2d4f9f82;
	padding: 10px 0;
	opacity: 0;
	z-index: -1;
	transition: .3s;
}
.W_btn ul.W_btn_list.active {
	opacity: 1;
	z-index: 1;
}
.W_btn ul.W_btn_list li a {
	display: block;
	padding: 0.5em;
	text-decoration: underline;
}
.W_btn ul.W_btn_list li a:hover {
	opacity: 0.2;
}
@media (max-width: 800px) {
	.W_btn p.download_btn {
		font-size: 15px;
		margin: 0 auto;
	}
	.W_btn ul.W_btn_list {
		top: 40px;
	}
}



















