@charset "UTF-8";

body {
  margin: 0 auto;
  font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color:#231815;
  font-size: 15px;
  -webkit-print-color-adjust: exact;
  overflow-x: hidden;
}
body img {
  width: 100%;
	max-width: 100%;
  height: auto;
	user-select: none;
}
a, a div {
	transition: opacity .3s;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
}
a{
	text-decoration: underline;
  color: #0077cc;
}
a:hover, a div:hover { opacity: 0.7; }
.link_txt:hover { opacity: 1; text-decoration: none; }

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}
.pc_size{display: block;}
.sp_size{display: none;}
.fs-s{font-size: .75em;}
.lh-l{line-height: 2.2em;}
.fc-g{color: #555;}

.note-txt{
  color: #666666;
}
.emp_txt{
  font-weight: bold;
}
.emp_txt_bg{
  background-color: #FFEB71;
  font-weight: bold;
}
.list_disc{
  margin-left: 1.5em;
}
.list_disc li{
  list-style-type: disc;
  margin-bottom: 5px;
}
.list_free{
  display: flex;
  margin-bottom: 3px;
}
.list_free_mark{
  margin-right: .1em;
}

/* header */
header{
	width:100%;
}
.header-bar { 
	max-width: 1200px;
  width: 100%;
  line-height: 1;
}
.header-bar a {
  display: inline-block;
}
.header-bar img {
  width: 310px;
	padding: 15px;
  display: block;
  box-sizing: border-box;
}

/* container */
.container{
  width:100%;
  margin:0 auto;
}
.wrapper{
  width: 92%;
  max-width: 1000px;
  margin-right: auto;
  margin-left: auto;
}
.wrapper2{
  width: 90%;
  max-width: 843px;
  margin-right: auto;
  margin-left: auto;
}
.content-item_S{ margin-top: 20px; }
.content-item_SS{ margin-top: 10px; }

/* MV */
.mv {
  width: 100%;
  margin: 0 auto;
}
.mv h1{
  position: relative;
  background: url("../images/mv_bg_pc.png");
  background-size: cover;
}
.mv h1::before, .mv h1::after{
  content: "";
  z-index: 0;
  width: 50%;
  max-width: 260px;
  height: 100%;
  position: absolute;
  top: 0;
}
.mv h1::before {
  background: url("../images/mv_ornament01_pc.png") top left no-repeat;
  background-size: contain;
  left: 0;
}
.mv h1::after{
  background: url("../images/mv_ornament02_pc.png") top right no-repeat;
  background-size: contain;
  right: 0;
}
.mv_wrapper{
  position: relative;
  z-index: 1;
}
.mv_inner{
  position: relative;
	padding-top: 76%;
	margin:0 auto;
	background: url(../images/mv_pc.png) center no-repeat ;
	background-size:100%;
  max-width: 1000px;
}
.mv_link{
  color: #333333;
  position: absolute;
  top: 34.5%;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  width: 100%;
}
.mv_btn{
  display: inline-block;
  /*width: 33vw;*/
  width: 51%;
  max-width: 500px;
}
@media screen and (min-width:1000px){
  .mv_inner{
    padding-top: 768px;
  }
}

/* クリッカブルエリア */
.maparea{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.maparea_inner{
  position: relative;
  width: 100%;
  height: 100%;
}
.maparea a{
  text-indent: -9999em;
  line-height: 0;
  display: block;
  position: absolute;
}
.maparea a:hover{
  background-color: rgba(255,255,255,.2);
}
.maparea a:nth-of-type(1){
  bottom: 9%;
  left: 37%;
  max-width: 206px;
  width: 19.3%;
  height: 30.6%;
}
.maparea a:nth-of-type(2){
  bottom: 9%;
  right: 22.5%;
  max-width: 206px;
  width: 19.3%;
  height: 30.6%;
}
.maparea a:nth-of-type(3){
  bottom: 9%;
  right: 1.5%;
  max-width: 206px;
  width: 19.3%;
  height: 30.6%;
}

/* モーダル */
.blocker{
  z-index: 100;
}
.modal{
  border-radius: 0;
  box-shadow: none;
  max-width: 350px;
  width: 80%;
  background: none;
  padding: 0;
}
.modal .modal_inner{
  padding: 0;
  border-radius: 10px;
  box-shadow: 3px 3px 17px -2px rgba(0,0,0,.6);
  background-color: #FFF;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal .modal_main{
  margin: auto;
}
.modal a.close-modal{
  width: 45px;
  height: 45px;
  background: url("../images/modal_close.png") center center / contain no-repeat;
  top: -8px;
  right: -22px;
  transition: .2s;
}
.modal .modal_title{
  background-color: #ffdc02;
  line-height: 1;
}
.modal .caution{
  margin: 8px auto 17px;
  padding-top: 10px;
  width: 93%;
  border-top: 1px dotted #333;
}
.modal .caution li{
  font-size: 10px;
  transform: scale(.9);
  transform-origin: top left;
  width: 111%;
  margin-bottom: 0;
}

/* 対象商品 */
.shipping{
  padding: 65px 0;
}
.shipping_ttl{
	width: 40%;
	max-width: 277px;
  margin: 0 auto;
	padding-bottom: 20px;
}
.hoken_banner{
  width: 96%;
  max-width: 868px;
  margin-right: auto;
  margin-left: auto;
}
.hoken_banner li{
  max-width: 400px;
  margin-right: auto;
  margin-left: auto;
}
.shipping .hoken_banner{
  display: -webkit-flex;
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: inherit;
}
.shipping .hoken_banner li{
  width: 46%;
  max-width: inherit;
  padding: 30px 0 0;
  margin: 0 auto;
}
.shipping .hoken_banner li a{
  display: block;
}
@media screen and (min-width:769px){
  .hoken_banner{
    display: -webkit-flex;
    display: flex;
  }
  .hoken_banner li{
    width: 50%;
    padding: 30px 16px 0;
  }
}

/* awards */
.awards{
  background: #ffdbdb;
  padding: 45px 0 75px;
}
.awards_image{
  width: 95%;
  max-width: 1317px;
  margin: 0 auto;
}

.Present {
  background: url("../images/Present_bg_pc.png");
  background-size: cover;
}

/* 全員プレゼント */
.allPresent{
  padding: 110px 0 0;
  position: relative;
}
.allPresent::before, .allPresent::after{
  content: "";
  z-index: 0;
  width: 50%;
  max-width: 270px;
  height: 100%;
  position: absolute;
  top: 0;
}
.allPresent::before {
  background: url("../images/allPresent_ornament01_pc.png") top left no-repeat;
  background-size: contain;
  left: 0;
}
.allPresent::after{
  background: url("../images/allPresent_ornament02_pc.png") top right no-repeat;
  background-size: contain;
  right: 0;
}
.allPresent_ttl{
  max-width: 800px;
  margin: 0 auto 45px;
  position: relative;
  z-index: 0;
}
.allPresent_box{
  position: relative;
}
.allPresent_box_inner{
  background:#ffffff;
  padding: 50px 60px ;
}
.allPresent_gift_img{
  max-width: 247px;
  width: 33%;
  padding: 10px 20px;
}
.allPresent_gift_txt{
  padding: 10px 25px 10px;
}
.allPresent_gift_txt img{
	margin: 0 auto 25px;
}
.allPresent_moreTxt{
  background: #e1e1e1;
  padding: 20px;
}
.moreTxt{
	text-align: center;
  margin-top: 20px;
}
.moreTxt > *{
  text-align: left;
}
.moreTxt_btn{
	padding: 5px 0 3px 33px;
	display: inline-block;
  position: relative;
}
.moreTxt_btn::before, .moreTxt_btn::after{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.moreTxt_btn::before{
  content: "";
  width: 23px;
  height: 23px;
  border: 2px solid #dbdbdb;
  border-radius: 100px;
  left: 0;
}
.moreTxt_btn::after{
  content: "";
  background: url("../images/plus-solid.svg") center center / contain no-repeat;
  left: 6px;
  width: 16px;
  height: 16px;
}
.moreTxt_btn:hover{
	cursor: pointer;
}
.moreTxt_btn.switch_btn_open{
  margin-bottom: 10px;
}
.moreTxt_btn.switch_btn_open::after{
  background: url("../images/minus-solid.svg") center center / contain no-repeat;
}
.close{
	display: none;
}
@media screen and (min-width:769px){
  .allPresent_gift{
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    margin: 0 -20px;
  }
  .allPresent_gift_txt{
    width: 67%;
    max-width: 560px;
  }
}

/* さらにプレゼント */
.morePresent{
  padding: 110px 0 115px;
}
.morePresent_ttl{
  margin: 0 auto 40px;
  max-width: 785px;
  position: relative;
  z-index: 0;
}
.morePresent_img{
  position: relative;
}
.morePresent ul{
  margin: 10px auto 0;
}

/* 愛犬／愛猫のためにできること */
.dekirukoto {
  background-color: #FF9F52;
  padding: 90px 0 100px;
}
.dekirukoto_ttl {
  max-width: 765px;
  margin: 0 auto;
}
.dekirukoto_lead {
  text-align: center; 
  margin: 35px 0;
  padding-bottom: 30px;
}
.dekirukoto_point {
  position: relative;
  margin-bottom: 60px;
  margin-left: 2%;
}
.dekirukoto_point01 .dekirukoto_point_img {
  position: absolute;
    top: -25px;
    left: -18px;
    max-width: 480px;
}
.dekirukoto_point02 .dekirukoto_point_img {
  position: absolute;
    top: -25px;
    left: -18px;
    max-width: 480px;
}
.dekirukoto_point03 .dekirukoto_point_img {
  position: absolute;
    top: -25px;
    left: -18px;
    max-width: 480px;
}
.dekirukoto_point04 .dekirukoto_point_img {
  position: absolute;
    top: -25px;
    left: -18px;
    max-width: 480px;
}
.dekirukoto_point05 .dekirukoto_point_img {
  position: absolute;
    top: -25px;
    left: -18px;
    max-width: 480px;
}
.dekirukoto_point_txt {
  background-color: #ffffff;
  padding: 50px 30px 35px;
}
.dekirukoto_point_txt03 img {
  max-width: 85px;
    position: relative;
    top: 0.45em;
    margin-right: 0.8em;
}
.dekirukoto_foot {
  max-width: 980px;
  margin: 0 auto;
}
.dekirukoto_foot h3 {
  max-width: 510px;
  margin: 80px 0 20px;
}
.dekirukoto_flex {
  display: flex;
}
.dekirukoto_flex_txt {
  font-size: 1.2em;
  line-height: 1.75;
}
.dekirukoto_flex_txt span {
  background-color: #ffffff;
  font-weight: bold;
}
.dekirukoto_flex_txt .link {
  margin-top: 20px;
  font-size: 0.75em;
}
.dekirukoto_flex_txt .link a {
  color: #231815;
}
.dekirukoto_flex_txt .link a:hover {
  text-decoration: none;
}
.dekirukoto_flex_img {
  max-width: 270px;
  margin-left: 50px;
}

/* rule */
.rule{
	width:100%;
	background:#ffffff;
  padding: 110px 0 20px;
}
.rule_ttl{
	width: 40%;
	max-width: 277px;
  margin: 0 auto 30px;
}
.rule .text_box{
  background: #e8e8e8;
	padding:30px ;
	box-sizing: border-box;
  margin-bottom: 90px;
}

.hoken-area .wrapper{
	max-width: 1000px;
}

/* hoken */
.hoken{
	width:100%;
	background: #fff2dd;
  padding: 85px 0 60px;
}
.hoken_point{
  margin-top: 54px;
}
.hoken .tit2{
	display: block;
  max-width: 540px;
  width: 85%;
	margin:0 auto;
}
.hoken .tit3{
  max-width: 776px;
	margin: 135px auto 20px;
}
.hoken p{
	text-align: center;
	font-size:20px;
	color:#000;
	margin: 60px 0 0 ;
}
.hoken .sub-p{
  margin-top: 10px;
}

/* footer */
footer div{
	width:100%;
	background:#FFF;
  margin-bottom: 124px;
}
footer div.copy{
	text-align: center;
  box-sizing: border-box;
  padding: 30px 0 50px;
  font-size: 13px;
  color: #333;
}

.footer_nav_ttl {
  margin: 12px auto 7px;
  text-align: center;
}

.boban{
  background: #fff4de;
	text-align: right;
	font-size:12px;
	padding: 10px;
}

/* ページトップ */
.btn-pagetop { cursor: pointer; position: fixed; z-index: 1000; right: 15px; bottom: 3%; display: none; }
.btn-pagetop img { width: 60px; }

/* 固定ボタン */
.footer_nav{
	position: fixed;
	bottom: 0;
  width: 100%;
  z-index: 100;
  background: #63d100;
  line-height: 1;
  box-shadow: 0px -5px 17px 0px rgb(0 0 0 / 25%);
}
.footer_nav_ttl{
  margin: 10px auto 0;
  text-align: center;
}
.footer_nav_ttl img{
  width: 72%;
  max-width: 410px;
}
.footer_nav nav{
  justify-content: center;
  position: static;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  z-index: 100;
}
.footer_nav nav a{
  padding: 0 4px;
}
.footer_nav nav img{
	max-width: 420px;
}
@media screen and (min-width:769px){
  .footer_nav{
		display: block;
	}
}