@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Noto+Serif+JP:wght@400;500;700&family=Playfair+Display:wght@400;500;700&family=Roboto+Condensed:wght@400;700&display=swap');

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, main {
	display: block;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* -------------------------------- 

Primary style

-------------------------------- */

html * {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

*, *:after, *:before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 100%;
    color: #000;
    background-color: #fff;
    line-height: 1.6;
    -webkit-text-size-adjust: none;
}

body, html {
  /* important */
    height: 100%;
}

a {
    color: #fff;
    text-decoration: none;
}

a:hover {
    color: #ccc;
    transition: color 0.2s ease-out;
}

a:hover img {
	opacity: 0.6;
    transition: opacity 0.2s ease-out;
}

/* -------------------------------- 

Modules

-------------------------------- */

.container {
    width: 100%;
    max-width: 1366px;
    margin: 0 auto;
    clear: both;
    position: relative;
    z-index: 100;
}

.container_1050 {
    width: 100%;
    max-width: 1050px;
    margin: 0 auto;
    clear: both;
    position: relative;
    z-index: 100;
}

.container_1180 {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    clear: both;
    position: relative;
    z-index: 100;
}

/* -------------------------------- 

main

-------------------------------- */

main {
    overflow: hidden;
}

#main {}

h1#logo {
    width: 100%;
    height: 100vh;
    left: 0;
    top: 0;
    display: -webkit-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    position: absolute;
    z-index: 50;
    backdrop-filter: brightness(0.5);
}

h1#logo img {
    max-width: 700px;
    width: 100%;
    height: auto;
}

.mainimg {
    width: 100%;
    height: 100vh;
    left: 0;
    top: 0;
    background: url(../images/mainimg.jpg) no-repeat 50%;
    background-size: cover;
    position: relative;
    z-index: 50;
}

.whatis {
    padding: 115px 0 30px;
}

.whatis h1 {
    font-family: 'Noto Serif JP', serif;
    font-size: 60px;
    font-weight: 400;
    text-align: center;
    padding: 0 0 42px 30px;
}

.whatis p {
    font-size: 24px;
    text-align: center;
    line-height: 200%;
}

.what-is-planaria {
    text-align: left;
    margin: 110px 0 0;
}

.what-is-planaria img {
    max-width: 980px;
    width: 100%;
    height: auto;
}

.about {
    background-color: #dad9d5;
    padding: 80px 0 0;
}

.about_cont {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
    max-width: 1183px;
    margin: 0 auto;
}

.box_about {
    max-width: 560px;
    margin: 0 auto 50px;
}

.box_about_img {
    margin: 0 0 37px;
}

.box_about_img img {
    max-width: 560px;
    width: 100%;
    height: auto;
}

.box_about_txt {
    min-height: 280px;
}

.box_about_txt img {}

.box_about_txt p {
    font-size: 15px;
    line-height: 180%;
}

.craftsman_img {
    text-align: center;
}

.craftsman_img img {
    max-width: 1366px;
    width: 100%;
    height: auto;
    display: block;
}

.craftsman_designer {
    background: #ece8e4 url(../images/bg_craftsman.png);
}

.craftsman_base {
    background-color: #f2f1ed;
    padding: 110px 0 30px;
}

.craftsman {
    margin: 0 0 84px;
}

.craftsman h2 {
    font-family: 'Playfair Display', serif;
    font-size: 60px;
    font-weight: 500;
    text-align: center;
    margin: 0 0 80px;
}

.craftsman_cont {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 908px;
    margin: 0 auto;
}

.box_craftsman {
    max-width: 372px;
    margin: 0 0 50px;
}

.box_craftsman img {
    margin: 0 0 11px;
    max-width: 371px;
    width: 100%;
    height: auto;
}

.box_craftsman p {
    font-size: 19px;
    line-height: 170%;
}

.designer {
    margin: 0 0 50px;
}

.designer h2 {
    font-family: 'Playfair Display', serif;
    font-size: 60px;
    font-weight: 500;
    text-align: center;
    margin: 0 0 50px;
}

.product {
    background-color: #dcdee0;
    padding: 92px 0 155px;
}

.product h2 {
    font-family: 'Playfair Display', serif;
    font-size: 55px;
    font-weight: 500;
    text-align: center;
    margin: 0 0 66px;
}

.product h2::before {
    content: '';
    position: absolute;
    width: 435px;
    height: 2px;
    background: #000;
    top: 53px;
    left: 30px;
}

.product h2::after {
    content: '';
    position: absolute;
    width: 435px;
    height: 2px;
    background: #000;
    top: 53px;
    right: 30px;
}

.product ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.product ul li {
    max-width: 370px;
    width: 100%;
    text-align: center;
    margin: 0 11px 15px;
}

.product ul li img {
    max-width: 370px;
    width: 100%;
    height: auto;
}

/* -------------------------------- 

footer

-------------------------------- */

footer {
    background-color: #b58f62;
    padding: 92px 0 80px;
    text-align: center;
}

.logo_footer {
    margin: 0 0 25px;
}

.logo_footer img {
    width: 260px;
    height: auto;
}

.sns_in {}

.sns_in img  {
    width: 50px;
    height: auto;
}

footer p {
    font-size: 24px;
    color: #fff;
    line-height: 180%;
    padding: 23px 0 0;
}

/* -------------------------------- 

-------------------------------- */

@media only screen and (max-width:1180px) {

h1#logo img {
    width: 80%;
}

.whatis {
    padding: 50px 20px 30px;
}

.whatis h1 {
    font-size: 45px;
    line-height: 125%;
    padding: 0 0 40px;
}

.whatis p {
    font-size: 14px;
    text-align: center;
    line-height: 3em;
}

.about {
    padding: 50px 20px 0;
}

.craftsman_base {
    padding: 66px 0 30px;
}

.craftsman_designer {
    padding: 0 20px;
}

.craftsman {
    margin: 0 0 50px;
}

.craftsman h2 {
    font-size: 42px;
    margin: 0 0 60px;
}

.designer h2 {
    font-size: 42px;
}

.craftsman_cont {
    padding: 0 20px;
}

.box_craftsman p {
    font-size: 14px;
    line-height: 160%;
}

.product {
    padding: 92px 20px 60px;
}

.product h2 {
    font-size: 42px;
}

.product h2::before {
    width: 18%;
    top: 38px;
    left: 5%;
}

.product h2::after {
    width: 18%;
    top: 38px;
    right: 5%;
}

footer p {
    font-size: 11px;
}

}

