@charset "utf-8";

/*  
Theme Name: Kishiharu
Theme URI: https://kishiharu.com/
Description: A theme by Kishiharu.
Version: 1.0
Author: Kishiharu
Author URI: https://kishiharu.com/
*/

/******************

 Reset

******************/

html {font-size: 62.5%; color: #000; background: #fff;}
body { font-size: 15px; font-size: 1.5rem;}
body,div,figure,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,button,textarea,
p,blockquote,th,td {margin: 0;padding: 0;}
fieldset,img {border: 0;}
address,caption,cite,code,dfn,em,th,var,optgroup {font-style: inherit;font-weight:inherit;}
li {list-style: none;}
caption,th {text-align: left;}
h1,h2,h3,h4,h5,h6 {font-size: 100%;	font-weight: normal;}
q:before,q:after {content: '';}
abbr,acronym {border: 0;font-variant: normal;}
hr {margin:0;}
img {vertical-align: bottom;}
a { outline: none; }

img[src$=".svg"] {
    width: 100%;
}

/*because legend doesn't inherit in IE */
legend {color: #000;}
input,button,textarea,select,optgroup,option {font-family: inherit;font-size:inherit;font-style:inherit;font-weight: inherit;}

/*@purpose To enable resizing for IE */
/*@branch For IE6-Win, IE7-Win */
input,button,textarea,select {font-size: 100%;}

/******************************/
/* Clearfix */
.clearfix:after,.clearfix:after {content: " "; display: block; height: 0; clear: both; visibility: hidden;}
.clearfix {display: inline-block;min-height: 1%;}
/* Hides from IE-mac \*/
.clearfix {display: block;}
/* End hide from IE-Mac */
/**tag**************************/
.clearfix {overflow:hidden;}

/* ----------------------------------------------
 * Generated by Animista on 2019-6-7 17:35:15
 * w: http://animista.net, t: @cssanimista
 * ---------------------------------------------- */

/**
 * ----------------------------------------
 * animation kenburns-top
 * ----------------------------------------
 */
@-webkit-keyframes kenburns-top {
  0% {
    -webkit-transform: scale(1) translateY(0);
            transform: scale(1) translateY(0);
    -webkit-transform-origin: 50% 16%;
            transform-origin: 50% 16%;
  }
  100% {
    -webkit-transform: scale(1.25) translateY(-15px);
            transform: scale(1.25) translateY(-15px);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
}
@keyframes kenburns-top {
  0% {
    -webkit-transform: scale(1) translateY(0);
            transform: scale(1) translateY(0);
    -webkit-transform-origin: 50% 16%;
            transform-origin: 50% 16%;
  }
  100% {
    -webkit-transform: scale(1.25) translateY(-15px);
            transform: scale(1.25) translateY(-15px);
    -webkit-transform-origin: top;
            transform-origin: top;
  }
}

/**
 * ----------------------------------------
 * animation text-focus-in
 * ----------------------------------------
 */
@-webkit-keyframes text-focus-in {
  0% {
    -webkit-filter: blur(12px);
            filter: blur(12px);
    opacity: 0;
  }
  100% {
    -webkit-filter: blur(0px);
            filter: blur(0px);
    opacity: 1;
  }
}
@keyframes text-focus-in {
  0% {
    -webkit-filter: blur(12px);
            filter: blur(12px);
    opacity: 0;
  }
  100% {
    -webkit-filter: blur(0px);
            filter: blur(0px);
    opacity: 1;
  }
}

* {
	box-sizing: border-box;
}

:root {
	--black: #2f2725;
	--orenge: #f4a000;
}

a {
	text-decoration: none;
}
a[href^="tel:"] {
	pointer-events: none;
	cursor: text;
}

@media screen and (max-width: 767px) {
	a[href^="tel:"] {
		pointer-events: auto;
		cursor: pointer;
	}
}

img {
	vertical-align: bottom;
	line-height: 0;
	max-width: 100%;
	height: auto;
}

html{
	width: 100%;
	height: 100%;
	background: #fff;
}

body{
	width: 100%;
	height: 100%;
	font-family: 'Noto Sans JP', sans-serif;
	color: #2f2725;
	text-align: left;
	line-height: 1.5;
	font-weight: 400;
	padding: 0;
	margin: 0;
	background: #fff;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
}

.obl{
	font-style: oblique;
	padding: 0 0 0 .15em;
}

.sp {
	display: none !important;
}

 
 @media screen and (max-width: 767px) {
	.pc {
	   display: none !important;
	}
	.sp {
	   display: block !important;
	}
}
 
/******************************


 Header


******************************/

#header{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	min-height: 80px;
	background: inherit;
	opacity: 0;
    visibility: hidden;
	z-index: 980;
	transition: all 0.3s;
}
#header::before{
	content: '';
	position: absolute;
	inset: 0;
	background: #fff;
	filter: drop-shadow(0 3px 3px rgba(0, 0, 0, 0.08));
	z-index: -1;
}
#header.show {
    opacity: 1;
    visibility: visible;
}
.header-inner{
	width: 100%;
	min-height: 80px;
	padding: 0;
	display: grid;
	grid-template-columns: 210px 1fr;
	grid-gap: 56px;
}
.header-logo{
	width: 100%;
	padding-inline: 30px 0;
	display: flex;
	align-items: center;
}
.header-logo a{
	display: block;
	width: 100%;
}
.header-gnav{
	display: flex;
	justify-content: flex-end;
	align-items: center; 
	padding: 0 56px 0 0;
}
.header-gnav-menu{
	max-width: 580px;
	width: 100%;
}
.header-gnav-menu-list{
	display: flex;
	justify-content: space-between;
}
.header-gnav-menu-list li{
	font-weight: 700;
	font-size: 1.5rem;
	line-height: 1;
	letter-spacing: .05em;
	color: var(--black);
}
.header-gnav-menu-list li a{
	color: var(--main-color-1);
	transition-duration: .3s;
}
.header-gnav-menu-list li a:hover{
	opacity: .7;
}

.menu-btn{
	display: none;
}

.menu-logo{
	max-width: 233px;
	width: 100%;
	margin: 41px 0 0 43px;
}
.menu-navi-container{
	width: 100%;
	padding: 0 80px;
	margin: 54px auto;
	color: #fff;
}
.menu-navi-content{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}
.menu-navi-content a{
	display: inline-flex;
	flex-direction: column;
	font-family: 'Marcellus', serif;
	font-size: 4.0rem;
	line-height: 1.25;
	letter-spacing: .1em;
	color: #fff;
	transition: .15s;
}
.menu-navi-content a:hover{
	opacity: .7;
}
.menu-navi-content .menu-txt-sub{
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.25;
	letter-spacing: .1em;
}
.menu-navi-list > li + li{
	margin: 32px 0 0;
}
.menu-navi-contact-read{
	margin: 23px 0 0;
}
.menu-navi-contact-read p{
	font-weight: 300;
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: .1em;
}
.menu-navi-contact-other{
	max-width: 441px;
	width: 100%;
	margin: 45px 0 0;
}
.menu-navi-contact-other-list > li + li{
	margin: 28px 0 0;
}
.menu-wrap{
	display: none;
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
	.header-gnav{
		padding: 0 30px 0 0;
	}
	.header-gnav-menu{
		max-width: 560px;
		width: 100%;
	}
}

@media screen and (max-width: 767px) {
	#header{
		position: fixed;
		min-height: 76px;
		opacity: 1;
		visibility: visible;
		z-index: 980;
	}
	.hfixed #header{
		opacity: 1;
		visibility: visible;
	}
	.header-inner{
		min-height: 76px;
		padding: 0 76px 0 0;
		display: flex;
		align-items: center;
	}
	.header-logo{
		position: relative;
		width: 170px;
		padding: 0 0 0 20px;
		z-index: 980;
	}
	.header-logo a{
		display: block;
	}
	.header-gnav{
		display: none;
	}
	.menu-btn{
		position: absolute;
		top: 0;
		right: 0;
		width: 76px;
		height: 76px;
		display: flex;
		justify-content: center;
		align-items: center;
		transition-duration: .3s;
		z-index: 980;
	}
	.menu-btn::before{
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		background: #e3d392;
	}
	.hamburger,
	.hamburger-fil{
		right: 0;
	}
	.hamburger{
		position: relative;
		display: block;
		box-sizing: content-box;
		width: 25px;
		height: 21px;
		padding: 0;
		-webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
		transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		border: 0;
		outline: 0;
		background-color: transparent;
		margin: 0 auto;
		cursor: pointer;
	}
	.hamburger-icon {
		position: relative;
		display: block;
	}
	.hamburger-icon,
	.hamburger-icon:before,
	.hamburger-icon:after{
		width: 100%;
		height: 3px;
		-webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
		transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
		background-color: var(--black);
	}
	.hamburger-icon:before,
	.hamburger-icon:after{
		position: absolute;
		top: -9px;
		left: 0;
		content: '';
	}
	.hamburger-icon:after{
		top: 9px;
		width: 16px;
	}
	.hfixed .hamburger-icon {
		background-color: transparent;
	}
	.hfixed .hamburger-icon:before,
	.hfixed .hamburger-icon:after {
		top: 0;
		width: 25px;
		background-color: var(--black);
	}
	.hfixed .hamburger-icon:before {
		-webkit-transform: rotate(135deg);
		transform: rotate(135deg);
	}
	.hfixed .hamburger-icon:after {
		-webkit-transform: rotate(-135deg);
		transform: rotate(-135deg);
	}
	.hfixed .hamburger:after{
		color: #fff;
	}
	.menu-wrap{
		position: fixed;
		top: -100vh;
		left: 0;
		display: block;
		opacity: 0;
		visibility: hidden;
		width: 100%;
		height: 100vh;
		overflow-y: hidden;
		background: #f5f0e9;
		padding: 0;
		margin: 0;
		z-index: 890;
		transition: all 0.5s;
	}
	.hfixed .menu-wrap{
		top: 0;
		opacity: 1;
		visibility: visible;
		overflow-y: scroll;
	}
	.menu-wrap-inner{
		padding: 96px 20px 32px;
	}
	.menu-gnav{
		padding: 0 13px;
	}
	.menu-gnav-list > li{
		font-weight: 500;
		font-size: 1.6rem;
		line-height: 1;
		color: var(--black);
		letter-spacing: .1em;
		padding: 0;
		border-bottom: 1px #e3d392 solid;
	}
	.menu-gnav-list > li a{
		width: 100%;
		min-height: 72px;
		display: flex;
		justify-content: center;
		align-items: center;
		color: var(--black);
	}
	.menu-contact{
		background: #fff;
		margin: 50px 0 0;
	}
	.menu-contact-inner{
		max-width: 315px;
		width: 100%;
		margin: 0 auto;
		padding: 25px 0 16px;
	}
	.menu-contact-ttl-h2{
		font-family: "Zen Old Mincho", serif;
  		font-weight: 600;
		text-align: center;
		font-size: 1.8rem;
		line-height: 1;
		letter-spacing: .08em;
		color: #22201E;
	}
	.menu-contact-ttl-en{
		display: block;
		font-family: "Manrope", serif;
  		font-weight: 200;
		text-align: center;
		font-size: 4.5rem;
		line-height: 1;
		letter-spacing: .04em;
		color: #22201E;
		padding: 8px 0 0;
	}
	.menu-contact-btn{
		margin: 20px 0 0;
	}
	.menu-contact-btn-list > li + li{
		margin: 4px 0 0;
	}
	.menu-contact-btn-list > li a{
		display: block;
	}
}

footer{
	position: relative;
	width: 100%;
	min-height: 160px;
	margin: 0;
	background: #e3d392;
	z-index: 6;
}
.footer-inner{
	padding: 64px 30px 40px;
}
.f-logo{
	width: 100%;
}
.f-logo-mark{
	max-width: 240px;
	width: 100%;
	margin: 0 auto;
	z-index: 6;
}
.f-menu{
	padding-block: 40px 56px;
}
.f-menu-block{
	max-width: 680px;
	width: 100%;
	margin-inline: auto;
}
.f-menu-block + .f-menu-block{
	margin-block: 12px 0;
}
.f-menu-list{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 32px;
}
.f-menu-list li a{
	position: relative;
	font-weight: 500;
	font-size: 1.2rem;
	line-height: 1;
	letter-spacing: .078em;
	color: var(--black);
	padding-inline: 14px 0;
	transition: all 0.3s;
	z-index: 6;
}
.f-menu-list li a:hover{
	opacity: .6;
}
.f-menu-list li a::before{
	content: '';
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%) rotate(45deg);
	width: 4px;
	height: 4px;
	border-right: 1px solid var(--orenge);
	border-top: 1px solid var(--orenge);
	z-index: 1;
}

footer .copy{
	width: 100%;
	margin: 0;
	padding:0;
	text-align: center;
}

footer .copy small{
	font-weight: 500;
	font-size: 1.1rem;
	line-height: 1;
	letter-spacing: .078em;
}

@media screen and (max-width: 767px) {
	footer{
		position: relative;
		width: 100%;
		min-height: 160px;
		margin: 0;
		background: #e3d392;
		z-index: 6;
	}
	.footer-inner{
		padding: 64px 30px 40px;
	}
	.f-logo{
		width: 100%;
	}
	.f-logo-mark{
		max-width: 180px;
		width: 100%;
		margin: 0 auto;
		z-index: 6;
	}
	.f-menu{
		padding-block: 42px 56px;
	}
	.f-menu-block{
		max-width: 680px;
		width: 100%;
		margin-inline: auto;
	}
	.f-menu-block + .f-menu-block{
		margin-block: 24px 0;
	}
	.f-menu-list{
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-gap: 24px 24px;
	}
	.f-menu-list li a{
		position: relative;
		font-weight: 500;
		font-size: 1.2rem;
		line-height: 1;
		letter-spacing: .078em;
		color: var(--black);
		padding-inline: 16px 0;
		transition: all 0.3s;
		z-index: 6;
	}
	.f-menu-list li a:hover{
		opacity: 1;
	}
	.f-menu-list li a::before{
		content: '';
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%) rotate(45deg);
		width: 6px;
		height: 6px;
		border-right: 1px solid var(--orenge);
		border-top: 1px solid var(--orenge);
		z-index: 1;
	}
	
	footer .copy{
		width: 100%;
		margin: 0;
		padding:0;
		text-align: center;
	}
	
	footer .copy small{
		font-weight: 500;
		font-size: 1.1rem;
		line-height: 1.5;
		letter-spacing: .078em;
	}
}


