@charset "UTF-8";

/*共通部分
---------------------------*/

html {
    font-size:100%;
}
body {
    background-color: #ccc3ba;
    font-family:"Klee One","Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    line-height:1.7;
    color: #2b2725;
}
a {
    text-decoration:none;
}
img {
    max-width: 100%;
}

/* レイアウト */
.wrapper {
    max-width: auto;
    margin: auto;
    padding: 0 1.5rem;
}
.align-left {
    text-align: left;
}

/* ヘッダー 
----------------------------*/
.page-header {
    justify-content: space-between;
    padding-top: 1rem;
    background-color: #ccc3ba;
 }

.logo {
    width: 210px;
}

.main-nav {
    display: flex;
    padding-right: 1rem;
    justify-content: right;
    gap: 0.5rem;
    font-size: medium;
    font-style: bold;
    list-style: none;
}

.main-nav a {
    color: #2b2725;
}

.main-nav a:hover {
     color: #f0e8e3;
}

.cover {
    background-size: cover;
    background-position: center bottom;
    height: 400px;
}
.cover-home {
    background-image: url(../images/cover-home-l.jpg);
}

/*　見出し */
.font-japanese {
    font-family: "Klee One", serif;
    font-weight: 500;
    color: #fffdfb;
}

.page-title {
    font-size: 2rem;
    text-align: center;
    margin-top: 9rem;
    line-height: 2;
    text-shadow: 3px 3px 5px #181716;
}

.heading-large {
    font-size: 3rem;
    text-align: center;
    margin-bottom: 1rem;
}

/* about */
.about {
    max-width: 800px;
    padding: 0 1.5rem;
    margin: 3rem auto 4rem;
    text-align: center;
    justify-content: center;
}
.heading-large {
    font-size: large;
    font-style: bold;
    color: #181716;
}
.about p {
    font-size: medium;
    font-style: normal;
    margin-bottom: 3rem;
}

/* ボタン */
.container {
    display: block;
    font-family: "Klee One", serif;
    color: #fffdfb;
    font-weight: 500;
    font-style: normal;
    text-align: left;
}
a{
    display: flex;
    justify-content:space-between;
    align-items: center;
    margin-left: 20px;
    color: #fffdfb;
}
.category {
    font-size: medium;
    width: 150px;
}
.contents {
    width: fit-content;
    width: 40%;
    font-size: small;
    text-align: left;
    align-items: left;
}

.item {
    background-color: #2b2725;
    margin: 10px;
    padding: 10px;
}
.item:hover {
    background-color: #7c7670;
}

/*　SNS　*/
.sns {
    display: flex;
    align-items: flex-start;
    gap: 5rem;
    background-color: #2b2725;
    margin: 10px;
    padding: 20px;
    margin-bottom: 2rem;
}
.instagram-media {
    height: 300px;
}
.sns-item:hover {
    background-color: #7c7670;
}
.sns-item .heading-medium {
    margin-bottom: .5rem;
}
.add{
    color: #ccc3ba;
}
/* フッター 
----------------------------*/
.page-footer {
    max-width: auto;
    margin-top: 30px;
    background-color: #5c524d;
    color: #f0e8e3;
}
.footer-name {
    display: flex;
    font-style: bold;
    color: #f0e8e3;
    margin-left: 30px;
    padding-top: 10px;
    position: left;
}
.footer-name {
    display:flex;
    align-items: baseline;
}
.name1 {
    font-size: medium;  
    padding-left: 10px;  
}
.name2 {
    font-size: larger;
    padding-left: 10px;
}
.info {
    display: flex;
    margin-left: 30px;
    padding-top: 10px;
    text-align: left;
    font-size: small;
    flex-wrap: wrap;
}
.adress {
    padding-left: 10px;
}
.tel {
    padding-left: 10px;
}
.fax {
    padding-left: 10px;
}
.copyright {
    text-align: right;
    font-size: xx-small;
    margin-right: 20px;
    padding: 10px;
}

/* aboutus
--------------------------*/
.cover-aboutus {
    background-size: cover;
    background-position: center;
    height: 220px;
}
.cover-aboutus {
    background-image: url(../images/cover-sub-l.jpg);
}
.page-title-aboutus {
    font-size: 1.5rem;
    text-align: center;
    margin-top: 3rem;
    line-height: 2;
    text-shadow: 5px 5px 5px #181716;
}
.grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap:1rem 1.5rem;
}
.item-a {
    background-color: #ccc3ba;
}
.item-a img {
    aspect-ratio: 1/1;
    object-fit: cover;
}
.item-a p {
    font-size: .875rem;
}

/* product
--------------------------*/
.cover-product {
    background-size: cover;
    background-position: center;
    height: 220px;
}
.cover-product {
    background-image: url(../images/cover-sub-l.jpg);
}
.page-title-product {
    font-size: 1.5rem;
    text-align: center;
    margin-top: 3rem;
    line-height: 2;
    text-shadow: 5px 5px 5px #181716;
}
.grid-p {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap:1rem 1.5rem;
}
.item-p {
    background-color: #ccc3ba;
}
.item-p img {
    aspect-ratio: 1/1;
    object-fit: cover;
}
.item-p p {
    font-size: .875rem;
}

/* contact
--------------------------*/
.cover-contact {
    background-size: cover;
    background-position: center;
    height: 220px;
}
.cover-contact {
    background-image: url(../images/cover-sub-l.jpg);
}
.page-title-contact {
    font-size: 1.5rem;
    text-align: center;
    margin-top: 3rem;
    line-height: 2;
    text-shadow: 5px 5px 5px #181716;
}
.contact {
    max-width: 800px;
    padding: 0 1.5rem;
    margin: 3rem auto 4rem;
    text-align: center;
    justify-content: center;
}

/*mailform-------*/
#formWrap {
	width:700px;
	margin:30px auto;
	color:#555;
	line-height:120%;
	font-size:90%;
}
table.formTable{
	width:80%;
	margin: 20px auto;
	border-collapse:collapse;
}
table.formTable td,table.formTable th{
	border:1px solid #555;
	padding:10px;
}
table.formTable th{
	width:30%;
    border:1px solid #555;
	font-weight:normal;
	background:#efefef;
	text-align:left;
}
form input[type="text"], form textarea {
	border:1px solid #555;
}
form input[type="submit"], form input[type="reset"], form input[type="button"] {
    background-color: #5c524d;
    padding: 5px 10px 10px 10px;
    margin-bottom: 20px;
    color: #ccc3ba;
}

/*　簡易版レスポンシブ用CSS（必要最低限のみとしています。ブレークポイントも含め自由に設定下さい）　*/
@media screen and (max-width:572px) {
#formWrap {
	width:95%;
	margin:0 auto;
}
table.formTable th, table.formTable td {
	width:auto;
	display:block;
}
table.formTable th {
	margin-top:5px;
	border-bottom:0;
}
form input[type="text"], form textarea {
	width:80%;
	padding:5px;
	font-size:110%;
	display:block;
}
form input[type="submit"], form input[type="reset"], form input[type="button"] {
	display:block;
	width:100%;
	height:40px;
}
}

/*　スマホ版　　　
-----*/
@media(max-width:440px) {
/* 共通部分 ヘッダー　------------------*/
.page-header {
    padding-top: 1rem;
 }
.logo {
    width: 180px;
    justify-content: center;
}
.main-nav {
    display: flex;
    padding-top: 1rem;
    justify-content:center;
    gap: 2rem;
    font-size: 15px;
    font-style: bold;
    list-style: none;
}
.cover {
    background-size: cover;
    background-position: center bottom;
    height: 270px;
}
.cover-home {
    background-image: url(../images/cover-home-ss.jpg);
}
.page-title {
    font-size: 1.5rem;
    text-align: center;
    margin: 3rem;
    line-height: 2;
    text-shadow: 3px 3px 5px #181716;
}
/*　見出し */
.font-japanese {
    font-family: "Klee One", serif;
    font-weight: 500;
    color: #fffdfb;
}

.heading-large {
    font-size: 3rem;
    text-align: center;
    margin-bottom: 1rem;
}

/* TOPページ
-------------------*/
.about {
    max-width: 380px;
    padding: 0 0.5rem;
    margin: 1rem;
    text-align: center;
    justify-content: center;
}
.heading-large {
    font-size: 16px;
    font-style: bold;
    color: #181716;
}
.about p {
    font-size: 12px;
    font-style: normal;
    margin-bottom: 1rem;
}
/* ボタン */
.container {
    display: block;
}
a{
    margin: 0;
    justify-content: center;
}
.category {
    font-size: 20px;
    text-align: center;
}
.contents { 
    display: none;
    margin: 0;
}
.photo1 {
    display: none;
}
/*　SNS　*/
.sns {
    display: block;    
    padding: 0;
}
  
.sns-item {
    justify-content: center;
}

.heading-medium {
    display: block;  
    justify-content: center;
    font-size: 15px;
}

 /* フッター */
.name1 {
    font-size: small;  
    text-align: center;
    padding-left: 2px;  
}
.name2 {
    font-size: large;
    text-align: left;
    margin-left: 5px;
}
.copyright {
    text-align: right;
    font-size: xx-small;
    margin-right: 10px;
}

 /* aboutus
----------------------------*/
.cover-aboutus {
    background-size: cover;
    background-position: center;
    height: 220px;
    background-image: url(../images/cover-sub-s.jpg);
}
.page-title-aboutus {
    font-size: 1.5rem;
    text-align: center;
    margin-top: 3rem;
    line-height: 2;
    text-shadow: 5px 5px 5px #181716;
}
.grid {
    display: grid;
    grid-template-columns: 1fr;
    gap:1rem 1.5rem;
}    
.item-a {
    background-color: #ccc3ba;
}
.item-a img {
    aspect-ratio: 1fr;
    object-fit: cover;
}
.item-a p {
    font-size: .75rem;
}

/* product
----------------------------*/
.cover-product {
    background-size: cover;
    background-position: center;
    height: 220px;
    background-image: url(../images/cover-sub-s.jpg);
}
.page-title-product {
    font-size: 1.5rem;
    text-align: center;
    margin-top: 3rem;
    line-height: 2;
    text-shadow: 5px 5px 5px #181716;
}
.grid-p{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap:1rem 1.5rem;
}    
.item-p {
    background-color: #ccc3ba;
}
.item-p img {
    aspect-ratio: 1fr;
    object-fit: cover;
}
.item-p {
    font-size: .75rem;
}

/* contact
----------------------------*/
.cover-contact {
    background-size: cover;
    background-position: center;
    height: 220px;
    background-image: url(../images/cover-sub-s.jpg);
}
.page-title-contact {
    font-size: 1.5rem;
    text-align: center;
    margin-top: 3rem;
    line-height: 2;
    text-shadow: 5px 5px 5px #181716;
}
}
