@charset 'UTF-8';



/* 基本設定
------------------------------------------------------------ */
html {
    font-size: 62.5%;
}

@media screen and (max-width: 543px) {
html {
    font-size: 56.25%;
  }
}

body {
  
    color: #4B4242;
     font-family: "Noto Sans JP"; 
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.7;
    letter-spacing: .08em;
    /*background: linear-gradient(to right, #ddd, #cbdad8, #b0b1a9, #42423b);*/
}




/* IE10以降游ゴシックオフ */
@media all and (-ms-high-contrast:none) {
  body {
		 font-family: "Noto Sans JP"; 
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 500;
}

img {
    vertical-align: top;
}

a {
    outline: 0;
    color: inherit;
    text-decoration: none;
    -webkit-transition: all .2s;
          transition: all .2s;
}




/* flexbox */
.flex {
    display: -webkit-box;
    display:-moz-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:flex;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;

}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}



/* 改行制御
------------------------------------------------------------------------------ */
.br {
  display: inline-block;
}

@media screen and (max-width: 543px) {
  .br_xs::before {
    white-space: pre;
    content: '\A';
  }
}

@media screen and (min-width: 544px) and (max-width: 767px) {
  .br_sm::before {
    white-space: pre;
    content: '\A';
  }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  .br_md::before {
    white-space: pre;
    content: '\A';
  }
}

@media screen and (min-width: 992px) {
  .br_lg::before {
    white-space: pre;
    content: '\A';
  }
}







.wrp{
     position:relative;
     font-family: "Noto Sans JP"; 

}

.content{
   padding: 0 10px 30px 10px;
   box-sizing: border-box;
}
@media screen and (max-width: 640px) {

.content{
    padding: 2rem;
    box-sizing: border-box;
}
}
.main_area{


}
.box_area{

}
  footer .closebutton a {
    color: #4A4747;
    font-weight: bold;
    text-decoration: none;
    padding: 1rem;  
    background: #fff; 
    width: 25rem;
    letter-spacing: .4rem;
    border-radius: 10px;
     }
  footer .closebutton a:hover {
     background: #ffadad;

  }

.title h1{
     text-align: center;
     margin: 0 auto 0 auto;
    font-size:34px; 
    color: #f10061;
   border-bottom: 1px solid #ddd;
   background: #333;
}
@media screen and (max-width: 640px) {
.title h1{
    font-size:18px; 
  }
}
/* ------------------------------

     ページトップ

  ------------------------------ */

#page-top {
	position: fixed;
	bottom: 1.5rem;
	right: .9rem;
	font-size: 1.2rem;
	-webkit-transition: all .25s;
	transition: all .25s;
	z-index: 103;
}
#page-top a {
	text-decoration: none;
	width: 6rem;
	height: 6rem;
	text-align: center;
	display: block;
	border-radius: 50%;
	position: relative;
	color: rgba(255, 255, 255, 0.9);
    background: #f10061;
}
#page-top a::after {
	position: absolute;
	content: "";
	top: 50%;
	left: 50%;
	width: 1.6rem;
	height: 1.6rem;
	margin-top: -.5rem;
	margin-left: -.77rem;
	border-left: 2px solid rgba(255, 255, 255, 0.9);
	border-top: 2px solid rgba(255, 255, 255, 0.9);
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
#page-top:hover {
	bottom: 2.5rem;
	right: .9rem;
	opacity: 0.8;
}

                                                             


.intro{
     text-align: center;
     padding: 2rem 1rem;
     box-sizing: border-box;
     font-size: 1.5rem;
     font-family: "Noto Sans JP"; 
}
@media screen and (max-width: 640px) {
.intro{
  text-align: left;
}
}


.box img{
    width: 100%;
    margin: 0 auto;
    position: relative;
}
.trimming {
  overflow: hidden;
  position: relative;
  padding-top: 100%; /*写真の高さ*/
  
  display: block;
}
.trimming .img {
  width: 100%;
  position: absolute;
  /*top: 50%;*/
  top: -20px;
  left: 50%;
/*  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);*/
  -webkit-transform: translate(-50%, -20px);
  transform: translate(-50%, -20px);
  height: auto;
}

.trimming img:hover{
  opacity: 0.5;
  transition: .3s;
}







/*下層ページサムネイルの微調整*/

/* Filter controls */
.filter-controls li, .multifilter li, .sortandshuffle li {
    color: white;
    cursor: pointer;
    display: inline-block;
    
    padding: 0.4rem 1rem;
    margin-bottom: 10px;
}
.filter-controls li {
    background-color: #585858;
    margin-bottom: 10px;
    font-size: 1.8rem;
}
.filter-controls li.active {
    background-color: #212121;
    color: #f10061;
}


.box_area{

}





.gitem img{
    width: 100%;
}
.mphoto{
   /* padding: 1rem;*/
    box-sizing:border-box;
    position: relative;

}
.details{
    padding-bottom: 10px;
}
.details .category{
    font-size: 1.3rem;
    text-align: center;
    letter-spacing: 0;
    color: #fff;
    line-height: 1.6;
    margin: 0 auto;
    z-index: 10;
    padding: 1.2rem .5rem;
    box-sizing: border-box;
    width: 100%;
    display:block;
}
.details .category2{
    font-size: 1.3rem;
    text-align: center;
    
    color: #fff;
    line-height: 2.5;
    position: relative;
}
.bg1{  background: #f10061}
.bg2{  background: #5363ea}


.category::before,
.category::after  {
  content: "";
  position: absolute;
  top: calc(50% - 2px);
  right: 10px;
  width: 15px;
  height: 4px;
  border-radius: 9999px;
  background-color: #fff;
  transform-origin: calc(100% - 2px) 50%;
}

.details .category::before {
  transform: rotate(45deg);
}

.details .category::after {
  transform: rotate(-45deg);
}


.category{
     position: relative;
        
}
.details .category a, .details .category2 a{
display:block;
}

.details .name{
    font-size: 2.5rem;
    padding: 0 1rem 0 1rem;
    box-sizing:border-box;
    text-align: center;
}
.details .name span{
    font-size: 1.6rem;

}
.details .size{
    font-size: 1.3rem;
    padding: 0 1rem 0 1rem;
    box-sizing:border-box;
    text-align: center;
    letter-spacing: 0;
}





/*btn*/
.model_info .btn{
    font-size: 1.6rem;
    cursor: pointer;
    margin: 2rem auto;
    background: #333;
    text-align: center; 
    width: 100%;
    position: relative;
    line-height: 2.5;
}
.btn::after {
  position: absolute;
  top: 50%;
  right: .2em;
  content: '';
  margin-top: -5px;
  border: 7px solid transparent;
  border-top-width: 5px;
  border-bottom-width: 5px;
  border-left-color: #fff;
  transition: all .3s;
}
.model_info .btn:hover{
    background: #35135d;

}
@media screen and (max-width: 640px) {
.model_info .btn{
    font-size: 1.6rem;
    line-height: 2;
}
}

.model_work{
    background: #fff;   
}
.tab01{
    
}

.work{
   text-align: center;
   background: #444;
   color: #fff;
   margin: 0 10px !important;
   
}
.work_wrp{
  height: auto !important;
    min-height: 30px !important;
    margin-top:5px;
}




















#footer {
    width: 100%;
    padding: 2rem 1rem;
    box-sizing:border-box;
    font-size: 1.2rem; 
    color: #fff;
    display: flex;
    background: #000;
    justify-content:center;
    position: relative;
  }
@media screen and (max-width: 780px) {
#footer {
    margin-top: 0;
}
}

.closebutton{
    text-align:center;
    margin:1rem auto;
    color:#111;
}


.foot_copy{
    text-align:center;
    background: #000;
    color: #fff;
}

.head_shop{
   text-align: center;
   padding-right: 2rem;
   box-sizing:border-box;
   display: flex;
   align-items: center;

}
.head_shop img{
    width: 100px;
    background: #fff;
}

ul.contact{
}
ul.contact li{
    display: block;
    text-align: left;
    line-height: 2;
}


@media screen and (max-width: 780px) {

ul.contact{
    margin-top: 0;
}

}








.box_area {
    max-width: 1200px; 
    margin-left: auto;  
    margin-right: auto;  
    padding-left: 15px; 
    padding-right: 15px; 
    box-sizing: border-box; 
}


.grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; 
}

.grid-item {
  width: calc(25% - 20px);
  box-sizing: border-box;
  border: 1px solid #ddd;
  margin: 6px;
}

@media screen and (max-width: 980px) {
     .grid-item{  width: calc(33.333% - 12px); /* 100% / 3列 - 左右マージン12px */}
     /*width:33.3%;*/
}
@media screen and (max-width: 750px) {
   .grid-item{ width: calc(50% - 12px); /* 100% / 2列 - 左右マージン12px */}
   /*width:50%;*/
}

@media screen and (max-width: 640px) {
    .grid-item{     
        width: calc(100% - 12px); /* 100% / 1列 - 左右マージン12px */
        margin-bottom: 20px;
        height: auto !important;

    }
}


.tab01 {
  padding-left: 35px;
  box-sizing: border-box;
}
.gallery-wrapper{
  padding-left: 30px;
  box-sizing: border-box; 
}
@media screen and (max-width: 950px) {
.tab01 {
  padding-left: 0;
}
.gallery-wrapper{
  padding-left: 0;
}
}

/*ノノカ*/
.id16361 .trimming .img {
    top:-32px;
}
/*ユカリ*/
.id18720 .trimming .img {
    top:-3px;
}
/*アユミ*/
.id15160 .trimming .img {
    top:-3px;
}
/*マリン*/
.id16931 .trimming .img {
    top:0;
}
/*スイ*/
.id18455 .trimming .img {
    top:0;
}
/*ツキ*/
.id18318 .trimming .img {
    top:0;
}
/*ミツキ*/
.id17285 .trimming .img {
    top:-1px;
}
/*エル*/
.id16368 .trimming .img {
    top:-2px;
}
/*ヒナ*/
.id18651 .trimming .img {
    top:-2px;
}





.no-zaiseki {
    background-color: #888888 !important; 
    color: #ffffff; 
    cursor: default;
}

.no-zaiseki::before,
.no-zaiseki::after {
    display: none;
}