@charset "UTF-8";

html {
	width: 100%;
	height: 100%;
	color: #000;
	margin: 0;
	padding: 0;
	font-feature-settings: "palt" 1;
}
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td,figure {
	margin: 0;
	padding: 0;
}

body{
	line-height: 1.5;
	font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	counter-reset:number;
	height: 100%;
	overflow-wrap: anywhere;
	word-break: normal;
	line-break: strict;
	-webkit-text-size-adjust: none;
}

table {
	font: 100%;
	font-size: inherit;
	border-collapse: collapse;
	border-spacing: 0;
}
caption,th { text-align:left; }

fieldset,img { border: 0;}

h1,h2,h3,h4,h5,h6 {
	font-size: 100%;
	font-weight: normal;
}
address,caption,cite,code,dfn,em,th,var {
	font-style: inherit;
	font-weight: inherit;
}
ol,ul { list-style: none;}

q:before,q:after { content:'';}
abbr,acronym {
	border: 0;
	font-variant: normal;
}
sup { vertical-align: text-top; }
sub { vertical-align: text-bottom;}
input,textarea,select {
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
	outline: 0;
}
legend{ color:#555;}

select,input,button,textarea{ font-family: inherit; }

pre,code,kbd,samp,tt{
	font-family: monospace;
	line-height: 100%;
}

main { display: block; }

a {
	color: inherit;
	outline: none;
	text-decoration: none;
}
a:hover,
a:focus,
a:active { text-decoration: none; }

a img { border: none; }

li img,
dt img,
dd img{ vertical-align: top; }

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

html, body {
	height: 100%;
	text-align: justify;
	text-justify: inter-ideograph;
}
body { -webkit-text-size-adjust: 100%; }

.serif { font-family: "Noto Serif JP", serif; }
@media screen and (min-width:769px), print{
	body {
		font-size: 15px;
  	letter-spacing: 0.12em;
	}
	.sp { display: none !important; }
	a[href^="tel:"] { pointer-events: none; }
	.inner {
		max-width: 1000px;
		margin-inline: auto;
		padding-inline: 50px;
	}
}
@media screen and (max-width:768px){
	body {
		font-size: 12px;
  	letter-spacing: 0.08em;
	}
	.pc { display: none !important; }
	.inner {
		padding-inline: 25px;
	}
}

#wrapper {
	display: flex;
	min-height: 100vh;
	flex-direction: column;
}
#wrapper #container {
	flex-grow: 1;
}
@media screen and (min-width:769px), print{
}
@media screen and (max-width:768px){
}

#footer {
	color: #fff;
	font-weight: 300;
	background-color: #0db7d6;
}
@media screen and (min-width:769px), print{
	#footer {
		font-size: 16px;
		line-height: 28px;
	}
	#footer .inner {
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
		padding-block: 95px 90px;
	}
	#footer address a[href^="mailto:"] {
		background: linear-gradient(90deg,rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 0) 50%);
		background-repeat: no-repeat;
		background-size: 200% 100%;
		background-position: 101% 0;
		transition-duration: .3s;
		transition-property: color,background-position;
	}
	#footer address a[href^="mailto:"]:hover {
		color: #0db7d6;
		background-position: 0 0;
	}
	#footer .bottom {
		text-align: right;
	}
	#footer .instagram a {
		display: inline-block;
		transition-duration: .3s;
		transition-property: transform;
		transform-origin: center center;
		transition-timing-function: ease-out;
	}
	#footer .instagram a:hover {
		transform: scale(1.2);
	}
	#footer .instagram img { width: 30px; }
	#footer .copyright { font-size: 14px; }
}
@media screen and (max-width:768px){
	#footer {
		font-size: 12px;
		line-height: 21px;
	}
	#footer .inner {
		padding-block: 19px 45px;
	}
	#footer .bottom {
		display: flex;
		align-items: flex-end;
		flex-direction: row-reverse;
		justify-content: space-between;
	}
	#footer .instagram img { width: 22.5px; }
	#footer .copyright {
		margin-top: 12px;
		font-size: 10.5px;
	}
}