@charset "utf-8";

/*--------------------------------------------------------------
  html, body
--------------------------------------------------------------*/
html {
	font-size: 16px;
}

body {
	font-family: "ヒラギノ丸ゴ Pro W4", "ヒラギノ丸ゴ Pro", "Hiragino Maru Gothic Pro", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro", "HG丸ｺﾞｼｯｸM-PRO", "HGMaruGothicMPRO";
	background-image: url(../img/background.png);
	letter-spacing: 1px;
	line-height: 1.5;
	color: #630;
}

/*--------------------------------------------------------------
  each element
--------------------------------------------------------------*/

a {
	color: #630;
}

h1 {
	margin-bottom: 10px;
	font-size: 1.85em;
	text-align: center;
	letter-spacing: 5px;
	font-weight: bold;
}

h2 {
	margin-bottom: 5px;
	font-size: 1.2em;
	font-weight: bold;
}

.img-area {
	line-height: 0;
}

img {
	max-width: 100%;
}

.paragraph {
	margin-bottom: 25px;
}

* > .paragraph:last-child {
	margin-bottom: 0;
}

.ellipsis {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

.br-line2 {
	line-height: 2em;
}

.br-line3 {
	line-height: 3em;
}

/*--------------------------------------------------------------
  container
--------------------------------------------------------------*/
#container {
	width: 100%;
	height: 100%;
}

#container .page-frame {
	max-width: 1040px;
	margin: 0 auto;
}

#container .white-frame {
	padding: 30px;
    background-color: rgba(255, 255, 255, .8);
    border-radius: 10px;
    box-shadow: 0 0 8px 1px rgba(0, 0, 0, .2);
}

/*--------------------------------------------------------------
  header
--------------------------------------------------------------*/
#header {
	width: 100vw;
	height: 100vh;
	position: relative;
}

#header .header-line {
	display: flex;
}

#header .header-inner {
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-content: center;
	flex-wrap: wrap;
}

#header .header-inner > * {
	width: 100%;
	text-align: center;
}

#header .header-inner .logo-area {
	margin-top: -10vh;
}

#header .header-inner .logo-area .img-area img {
	width: 350px;
	-webkit-filter: drop-shadow(2px 2px 4px rgba(255, 255, 255, .6));
}

#header .header-inner .nav-area {
	width: 300px;
	margin-top: 25px;
	position: relative;
}

#header .header-inner .nav-area .site-menu {
	width: 100%;
	padding: 12px 0;
    background-color: rgba(255, 255, 255, .5);
    border: solid 1px #ccc;
    border-radius: 5px;
    box-shadow: 0 2px 2px rgba(50, 50, 50, .2);
    font-family: inherit;
	font-size: 1.15em;
	position: absolute;
	top: 0;
	cursor: pointer;
	transition: .35s;
	z-index: 1;
}

#header .header-inner .nav-area .site-menu:hover {
	background-color: rgba(255, 255, 255, .85);
	box-shadow: 0 5px 5px rgba(50, 50, 50, .3);
}

#header .header-inner .nav-area .site-menu li {
	height: 0;
	overflow: hidden;
}

#header .header-inner .nav-area .site-menu li:first-child {
	height: auto;
	font-weight: bold;
}

#header .header-inner .nav-area .site-menu:hover li {
	height: auto;
	padding-bottom: 12px;
}

#header .header-inner .nav-area .site-menu:hover li:last-child {
	padding-bottom: 0;
}

#header .header-inner .nav-area .site-menu li a {
	text-decoration: none;
	position: relative;
}

#header .header-inner .nav-area .site-menu li a .menu-text {
	display: inline-block;
	position: relative;
}

#header .header-inner .nav-area .site-menu li a .menu-text::after {
	width: 0;
    content: "";
    border-bottom: solid 2px #630;
    display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	transition: .35s;
}

#header .header-inner .nav-area .site-menu li a:hover .menu-text::after {
	width: 100%;
}

#header .header-inner .nav-area .site-menu li i {
	margin-right: 10px;
	transition: .35s;
}

#header .header-inner .nav-area .site-menu:hover li:first-child i {
	transform: rotate(90deg)
}

#header .header-background {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

#header .header-background video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/*--------------------------------------------------------------
  header (underlayer-page)
--------------------------------------------------------------*/
.underlayer-page #header {
	height: auto;
	position: relative;
}

.underlayer-page #header::before {
	content: "";
    width: 100%;
    height: 100%;
    background-color: rgba(100, 100, 100, 0.4);
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}

.underlayer-page #header .header-line {
    position: inherit;
    z-index: 1;
}

.underlayer-page #header .header-inner {
    padding: 12vh 0;
}

/*--------------------------------------------------------------
  header (follow)
--------------------------------------------------------------*/
#header .header-inner .nav-area.follow {
	margin-top: 0;
    position: fixed;
    top: 10px;
	right: 10px;
	z-index: 1;
}

#header .header-inner .nav-area.follow .site-menu {
	background-color: rgba(255, 255, 255, .6);
}

#header .header-inner .nav-area.follow .site-menu:hover {
	background-color: rgba(255, 255, 255, .85);
	top: 0;
}

/*--------------------------------------------------------------
  main
--------------------------------------------------------------*/
#main .main-inner {
	padding: 30px 0;
}

#main .main-inner section {
	padding: 30px 0;
}

main .link-btn p {
	text-align: center;
}

main .link-btn p a {
	width: 350px;
	margin: 0 auto;
	padding: 15px 0;
	background-color: #e3bd41;
	border-radius: 5px;
	color: #fff;
	text-decoration: none;
	letter-spacing: 2px;
	display: block;
	transition: .35s;
}

main .link-btn p a:hover {
	letter-spacing: 3px;
	opacity: .7;
}

main .link-btn p a i {
	margin-right: 10px;
}

/*--------------------------------------------------------------
  main - form
--------------------------------------------------------------*/
form input,
form select,
form textarea {
    font-family: inherit;
    font-size: 1em;
    letter-spacing: 1px;
}

form input[type="text"],
form input[type="email"],
form select,
form textarea {
    width: 100%;
	height: 35px;
    padding: 5px;
    border: solid 1px #ccc;
    border-radius: 3px;
	-webkit-appearance: none;
	font-family: inherit;
    font-size: 1em;
    letter-spacing: 1px;
}

form input[type="checkbox"],
form input[type="radio"] {
    margin: 15px 5px 15px 10px;
    vertical-align: middle;
    display: inline-block;
}

form textarea {
    height: 120px;
}

form input[type="submit"] {
	width: 50%;
    margin: 0 auto;
    padding: 15px 0;
    background-color: #e3bd41;
    border: 0;
    color: #fff;
    cursor: pointer;
    transition: .5s;
	-webkit-appearance: none;
}

form input[type="submit"]:hover {
    opacity: .7;
    border-radius: 18px;
}

/*--------------------------------------------------------------
  footer
--------------------------------------------------------------*/
#footer {
	width: 100%;
	height: auto;
	margin-bottom: 60px;
}

#footer .footer-inner {
	width: 100%;
	height: 100%;
}

#footer .footer-inner .sns-area {
	display: flex;
	justify-content: center;
}

#footer .footer-inner .sns-area li {
	width: 40px;
	margin: 0 10px;
	font-size: 2.5em;
}

#footer .footer-inner .sns-area li a {
	line-height: 0;
	display: block;
}

#footer .footer-inner .sns-area li.twitter a {
	color: #00aced;
}

#footer .footer-inner .sns-area li.facebook a {
	color: #3b5998;
}

#footer .footer-inner .sns-area li.line a {
	color: #00c300;
}

#footer .footer-inner .sns-area li.instagram a {
	color: #686868;
}

#footer .footer-inner .nav-area {
	margin: 20px 0;
}

#footer .footer-inner .nav-area .site-menu {
	display: flex;
	justify-content: center;
}

#footer .footer-inner .nav-area .site-menu li {
	padding: 0 20px;
	border-right: solid 1px #630;
	letter-spacing: 2px;
}

#footer .footer-inner .nav-area .site-menu li:last-child {
	border-right: none;
}

#footer .footer-inner .copy-write {
	margin-bottom: 20px;
	text-align: center;
	font-size: .8em;
	font-weight: bold;
}

/*--------------------------------------------------------------
  follow-area
--------------------------------------------------------------*/
#follow-area > * {
	position: fixed;
}

#follow-area .to-top {
	right: 8px;
    bottom: 0;
    z-index: 1;
}


#follow-area .to-top p a {
	padding: 0 5px;
	font-size: 2.6em;
	display: block;
	transition: .35s;
}

#follow-area .to-top p a:hover {
	opacity: .7;
}

#follow-area .to-diagnosis {
	width: 100%;
	height: 0;
	bottom: 0;
	background-color: #ffb6a9;
	-webkit-box-shadow: 0 -1px 10px 0 rgba(140, 140, 140, .5);
    -moz-box-shadow: 0 -1px 10px 0 rgba(140, 140, 140, .5);
    box-shadow: 0 -1px 10px 0 rgba(140, 140, 140, .5);
	display: flex;
    justify-content: center;
	align-items: center;
	overflow: hidden;
	transition: .5s;
}

#follow-area .to-diagnosis.active {
	height: 60px;
}

#follow-area .to-diagnosis p {
	width: 100%;
	height: 100%;
}

#follow-area .to-diagnosis p a {
	width: 100%;
	height: 100%;
	line-height: 60px;
	font-size: 1.25em;
	color: #fff;
	text-decoration: none;
	text-align: center;
	letter-spacing: 5px;
	display: block;
}

#follow-area .to-diagnosis p a i {
	margin-right: 10px;
}

/*--------------------------------------------------------------
  device
--------------------------------------------------------------*/
.pc {
	display: inline-block;
}

.sp {
	display: none;
}

/*--------------------------------------------------------------
  responsive
--------------------------------------------------------------*/
@media screen and (max-width:768px) {
	/*-----------------------------------------
	  common
	-----------------------------------------*/
	#container .page-frame {
		max-width: 100%;
		padding: 0 4%;
	}

	h1 {
		font-size: 6vw;
		letter-spacing: 3px;
	}

	/*-----------------------------------------
	  header
	-----------------------------------------*/
	#header .header-inner .logo-area .img-area img {
		width: 75%;
	}

	/*-----------------------------------------
	  header (follow)
	-----------------------------------------*/
	#header .header-inner .nav-area.follow {
		width: 95%;
	}

	#diagnosis #header .header-inner .nav-area.follow {
		position: relative;
	}

	/*-----------------------------------------
	  container
	-----------------------------------------*/
	#container .white-frame {
		padding: 15px;
	}

	/*-----------------------------------------
	  footer
	-----------------------------------------*/
	#footer .footer-inner .nav-area .site-menu {
		display: block;
	}

	#footer .footer-inner .nav-area .site-menu li {
		padding: 5px 0;
		border-right: none;
		text-align: center;
	}

	/*--------------------------------------------------------------
	  device
	--------------------------------------------------------------*/
	.pc {
		display: none;
	}

	.sp {
		display: inline-block;
	}
}