@charset "UTF-8";
html, body, div, span, p, a, del, em, img, ol, ul, li, fieldset, form, label,1h,2h,3h,4h,5h, p,span {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
}
html {
    scroll-behavior: smooth;
}
body {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 400;
	letter-spacing: 0.1em;
	background: #EFF5FC;
	color: #000;
	font-size: 16px;
	text-align: center;
	line-height:2;
	
}
a {
	text-decoration: none;
	color: #000;
	transition: 0.3s;
}
a:hover {
    opacity: 0.7;
}
.t_80 {
font-size: 80%;}

.clearfix:after{
    content: ".";
    display: block;
    height: 0;
    font-size:0;
    clear: both;
	visibility:hidden;
}
.clearfix{
	display: inline-block;
}
 .clear {
	clear:both;
}
.pagetop {
    display: none;    /* 最初は隠しておく（jQueryのfadeInで表示される） */
    position: fixed;  /* 画面の決まった位置に固定 */
    bottom: 20px;     /* 下から20px */
    right: 20px;      /* 右から20px */
    z-index: 100;     /* 他の要素より上に表示 */
}

.pagetop a {
    display: block;
    width: 50px;
    height: 50px;
    background: #FFF; /* ボタンの色（オレンジ） */
    color: #666;
    text-align: center;
    line-height: 48px; /* アイコンを上下中央に */
    text-decoration: none;
    font-size: 20px;
    transition: 0.3s;
}

.pagetop a:hover {
    opacity: 0.7;
}

.footer {
margin: 5% 0;
}

#bg1, #bg2 {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; /* 100%で固定 */
    z-index: -10;
    pointer-events: none;
}

#bg1 {
    background-image: url(../img/back.png);
    background-size: 100%;
    background-repeat: repeat; /* 繰り返し表示 */
}

#bg2 {
    background-image: url(../img/back0.png);
    background-size: 100%;
    background-repeat: repeat; /* 繰り返し表示 */
}
@media screen and (min-width: 768px) {
#bg1 {
    background-size: 600px;
}

#bg2 {
    background-size: 600px;
}
}

/*	 header
/* ------------------------------------- */

.t1 {
width: 100%;
	padding: 3% 10% 0 10%;
	box-sizing: border-box;
	margin: auto;
}
.t1 h1 {
	font-weight: 400;
}	
.t1 p {
}

@media screen and (min-width: 1000px) {
	.t1 {
	padding: 30px 50px 50px 50px;
}
}
/*	 portfolio
/* ------------------------------------- */
.list {
width: 100%;
	padding: 3% 10%;
	box-sizing: border-box;
	margin: auto;
}
.list ul {
	list-style: none;
	display: flex;
    flex-wrap: wrap;
	padding: 0;
	margin: 0;
}
.list ul li {
	width: 30%;
	margin-right: 5%;
    margin-bottom: 20px;
    display: flex;
	flex-direction: column;
	aspect-ratio: 1 / 1; /* ★コンテナを正方形にする★ */
    overflow: hidden; /* 画像がコンテナからはみ出した部分を非表示にする */
}
.list ul li:nth-child(3n) {
	margin-right: 0;
}

.list ul li img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 50% 50% 0% 0%;
}
.list ul li p {
	margin: 10px 0 0 0;
}
@media screen and (min-width: 1024px) {
  .list {
    max-width: 1024px; 
    padding: 0;
  }
}




.po {
width: 100%;
	padding: 10%;
	box-sizing: border-box;
	margin: auto;
	text-align: center;
}
.po p {
	font-size: 120%;
}
.p {
	margin: 5% 0 0 0;
}
.p img {
	width: 100%;
}
@media screen and (min-width: 768px) {
.po {
	padding: 5%;
}
.p {
	margin: 2% 0 0 0;
}
.p img {
	width: 70%;
}
}
@media screen and (min-width: 1024px) {
.po {
	padding: 50px;
}
.p {
	margin: 30px 0 0 0;
}
.p img {
	width: 800px;
}
}