@charset "UTF-8";
/* ---------------------------------------------------------------------------------------------------- */
/* Reset */

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, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, nav, section, article, aside, figure, figcaption, hgroup, footer, header, audio, video, canvas { margin:0; padding:0; border:0; outline:0; font-weight:inherit; font-style:inherit; font-family:inherit; vertical-align:baseline; }
:focus { outline:0; }
body { line-height:1; }
ol, ul { list-style:none; }
table { border-collapse:separate; border-spacing:0; }
caption, th, td { text-align:left; font-weight:normal; }
blockquote:before, blockquote:after, q:before, q:after { content:''; }
blockquote, q { quotes:'' ''; }

/* ---------------------------------------------------------------------------------------------------- */
/* Type */

body { font-family:'body',serif; font-size:120%; line-height:1.35em; color:#606060; }

em { font-style:italic; }
strong { font-weight:bold; }

a { text-decoration:underline; color:#606060; }
a:visited { color:#606060; }
a:hover { color:#d92b2b; }
a:active { color:#d92b2b; }

a, a:hover, a:active, a:focus, a:visited,
input, input:hover, input:active, input:focus { transition:all 250ms ease; }

h1 { padding:0; margin:0.00em 0 0.00em 0; font-size:7.00em; line-height:1.00em; font-weight:normal; font-family:'heading',sans-serif; text-shadow:0.05em 0.05em 0 rgba(0,0,0,0.15); }
h2 {
	color: #EB7A77;
	border: solid 3px #EB7A77;
	padding: 0.5em;
	border-radius: 0.5em;
	background-color: #fff;
	font-size: 2em;
	font-weight: 700;
}

h3:first-letter {
	font-size: 2em;
	color: #7172ac;
}

p,
blockquote,
table,
ul,
ol { margin:1.5em 0; }

ul { list-style:disc outside; }
ol { list-style:decimal outside; }

hr
{
	max-width:40em;
	margin:0 auto;
	border:none;
	border-bottom:1px solid #cccccc;
}

@media screen and ( max-width:50em )
{
	hr { display:none; }
}

/* ---------------------------------------------------------------------------------------------------- */
/* Type size */

@media screen and ( max-width:80em ) { body { font-size:115%; } }
@media screen and ( max-width:70em ) { body { font-size:105%; } }
@media screen and ( max-width:60em ) { body { font-size: 95%; } }
@media screen and ( max-width:45em ) { body { font-size: 90%; } }
@media screen and ( max-width:30em ) { body { font-size: 85%; } }
/* @media screen and (max-width: 768px) { body { font-size: 85%; } }*/

/* ---------------------------------------------------------------------------------------------------- */
/* Definitions */

dl{
	padding:1.5em; margin:1.5em -1.5em;
	background:rgba(0,0,0,0.065);
	transform-origin:center top;
}

dt{
	margin:0.75em 0;
	font-size:1.50em;
}

dd { padding:0 0 0 10%; }

/* ---------------------------------------------------------------------------------------------------- */
/* Misc */

/* Clearfix */
.clearfix, .columns, .column, .wrapper { *zoom:1; }
.clearfix:after, .columns:after, .column:after, .wrapper:after { content:''; display:table; clear:both; }

/* Border/padding box model */
* { box-sizing:border-box; }

/* Strip top/bottom margin on first/last child elements */
* > :first-child { margin-top:0 !important; }
* > :last-child { margin-bottom:0 !important; }

/* Plain lists */
.plain, .plain > li { list-style:none; }
.plain > li { margin:0; }

/* ---------------------------------------------------------------------------------------------------- */
/* Columns */

.columns { margin:1.5em -1.5em; }

.column { padding:0 1.5em; margin:0.75em 0; float:left; }

.column_right { float:right; }

.column_xlarge  { width:100%; }
.column_large   { width:61.8034%; }
.column_mlarge   { width:76.3932%; }
.column_medium  { width:38.1966%; }
.column_small   { width:23.6068%; }
.column_xsmall  { width:14.5898%; }
.column_xxsmall { width: 9.0170%; }

/* Collapsing columns */

@media screen and ( max-width:50em )
/* @media screen and (max-width: 768px) */
{
	.columns_content > .column { width:100%; margin:1.5em 0; float:none; }
}

/* ---------------------------------------------------------------------------------------------------- */
/* Buttons */

.button {
}

.button a{
	display: block;
	padding: 0 1em;
	margin: 0;
	border: 1px solid #EB7A77;
	border-radius: 5px;
	background: #fff;
	color: #EB7A77;
	text-decoration: none;
	cursor:pointer;
	-webkit-appearance: none;
	line-height: 10px;
	box-shadow:0px 0px 6px 3px rgba(255,255,255,0.8);
}

.button_alt {
}

.button_alt a{
}
/* ---------------------------------------------------------------------------------------------------- */
/* Main elements */

html, body { width:100%; height:100%; position:relative; background:white; }

body {
	 font-family: "Lucida Grande", "segoe UI", "ヒラギノ丸ゴ ProN W4", "Hiragino Maru Gothic ProN", Meiryo, Arial, sans-serif;
}

.wrapper{
	/*
	width: 100%;
	*/
}

/* ---------------------------------------------------------------------------------------------------- */
/* Sections */

.section{
	width: 96%;
	top: 50px;
	margin: 0 auto;
	padding: 6em 1.5em;
	position:relative;
	overflow:hidden;
	background: #ffeaea;
}

@media screen and ( max-width:50em ) { .section { padding:3.0em 1.5em; } }
@media screen and ( max-width:30em ) { .section { padding:1.5em 1.5em; } }
/*
@media screen and (max-width: 768px) { .section { padding:3.0em 1.5em; } }
*/

/* ---------------------------------------------------------------------------------------------------- */
/* Header */
header{
	position: relative;
	height: 93vh;
	margin: 0 auto;
}
header img{
	width: 100vw;
}

.header{
	width:100%;
	padding:0.75em 1.5em;
	position:fixed; top:0; left:0; right:0; z-index:100;
	background:#606060;
}

#box__bg_photo{
	width:100%;
	height: 93vh;
	background-image: url("../../img/sasaizumi/top/501b.png");
	background-size: cover;
	background-position: center;
	text-align: center;
}

#box__bg_photo p{
	position:relative;
	top: 25%;
	color: #fff;
	margin: 30px auto;
}
.ft1{
	font-size: 3em;
	font-weight: 900;
	text-shadow: 1px 2px 3px #808080;
}
.ft2{
	font-size: 2em;
	font-weight: 700;
	text-shadow: 1px 2px 3px #808080;
}

/* @media screen and (max-width: 768px) {*/
@media screen and ( max-width:30em ){
	body { padding:0; }

	.header	{
		padding:0;
		position:static;
		top:auto;
		left:auto;
		right:auto;
		z-index:0;
	}
}
@media screen and ( max-width:60em ){
	.ft1{
		font-size: 2em;
	}
	.ft2{
		font-size: 1.5em;
	}
	header{
		height: 85vh;
	}
	#box__bg_photo{
		height: 85vh;
	}
}
/* ---------------------------------------------------------------------------------------------------- */
/* Footer */

.footer{
	overflow:hidden;
	perspective:500px; transform-style:preserve-3d;
}

.footer_block{
	padding:5% 1.5em;
	transform-origin:center bottom;
	background:#606060;
	color:#b0b0b0;
}

.footer a { color:#b0b0b0; }
.footer a:hover { color:white; }

/* ---------------------------------------------------------------------------------------------------- */
/* Navigation */

nav {
	background-color: #EB7A77;
	width: 100%;
	height: 7vh;
}

.nav_onpage { float:none; }
.nav_offsite { float:right; }

.nav ul {
	/*
	margin:0 -1.00em;
	*/
	height: 7vh;
	text-align:center;
}
.nav li {
	margin:0 2em;
	height: 7vh;
	display:inline-block;
}

.nav a{
	display:block;
	text-decoration:none;
	height: 7vh;
	line-height: 7vh;
}

.nav_item_text a{
	padding:0 0.5em;
	color: #fff;
	font-size: 1.2em;
	height: 7vh;
	line-height: 7vh;
}

.nav_item_text a:hover{
	color:white;
}

@media screen and ( max-width:50em ){
	.longtext { display:none; }
}

@media screen and ( max-width:60em ){
/*@media screen and (max-width: 768px) {*/
	.longtext { display:inline; }
	.nav {
		float:none;
		font-size:0.8em;
	}
	.nav ul {
		margin:0;
		text-align:center;
	}
	.nav li {
		margin:0;
		float:none;
		display:inline-block;
	}
	.nav .nav_item_text {
		margin:0 0.25em;
	}
	.nav .nav_item_button { display:block; float:none; clear:both; }
	.nav a {
		padding:0;
		text-align:center;
	}
}

/* ---------------------------------------------------------------------------------------------------- */
/* Effects */

.effects{
	margin:-0.75em !important;
}

.effect{
	border:0.75em solid white;
	float:left;
	background:rgba(0,0,0,0.065);
}

.wd1{
	width:25%;
}

.wd2{
	width:100%;
}

.effect_box{
	display:block;
	width:100%; height:0;
	padding:0 0 100% 0;
}

.effect_box img{
	width: 100%;
}

.effect_box_opacity   { background:#fff; }
.effect_box_scale     { background:#2b82d9; }
.effect_box_rotate    { background:#d92b2b; }
.effect_box_translate { background:#93ca3a; }

@media screen and ( max-width:50em ){
	.effect { width:25%; }
}
/*
@media screen and (max-width: 768px) { */
 @media screen and ( max-width:30em ){
	.effect { width:50%; }
}

/* ---------------------------------------------------------------------------------------------------- */
/* box */
.box{
	width: 100%;
	text-align: center;
	margin-top: 30px;
}

.box p{
	padding: 0.8em 0;
	background: #EB7A77;
	color: #fff;
	border-radius: 10px;
	font-size: 3em;
}

.box a{
	width: 100%;
	text-decoration: none;
	padding: 0.3em;
	font-size: 1.5em;
	background: #7172ac;
	color: #fff;
	border-radius: 10px;
}
/* ---------------------------------------------------------------------------------------------------- */
/* for header fix */
.is-fixed {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 2;
	width: 100%;
}

/* ---------------------------------------------------------------------------------------------------- */
/* footer */
footer{
	text-align: center;
	color: #fff;
	height: 20px;
	background: #EB7A77;
	margin-top: 100px;
}
/* ---------------------------------------------------------------------------------------------------- */