@charset "utf-8";
/* ************************************************** */
/* g-wh by Rocket dev. */
/* ************************************************** */
/* reset style */
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; font-size: 100%; font: inherit; vertical-align: baseline; }
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section { display: block; }
body { line-height: 1; }
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; }
/* -------------------------------------------------- */
body {
	font-size: 14px;
	line-height: 2;
	color: #333;
	font-family: YuGothic, 'Yu Gothic', 'Yu Gothic UI', 'ヒラギノ角ゴシック', 'Hiragino Sans', sans-serif;
	/* for footer bottom line */
	display: flex;
	flex-direction: column;
	height: 100%;
}
p { margin-bottom: 1em; }
.kakugo { font-family: 'ヒラギノ角ゴ StdN','Hiragino Kaku Gothic StdN', sans-serif; }
a:link, a:visited { text-decoration: underline; color: #333; }
a:hover, a:active { text-decoration: none; color: #7f7f80; }
a.non-link:link, a.non-link:visited { text-decoration: none; color: #333; }
table { width: 100%; }
th, td { padding: 2px 4px; vertical-align: middle; }
th { text-align: left; color: #000; line-height: 1.4; }
td img { display: inline-block; vertical-align: middle; }
td.center { text-align: center; }
td.right { text-align: right; }
img.responsive { display: block; max-width: 100%; height: auto; margin: 0 auto; }
input,
textarea,
select,
label { font-size: 14px; }
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
textarea,
button,
input[type="submit"],
input[type="button"] {
	border-radius: 0;
	box-sizing: border-box;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
}
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
textarea,
select {
	width: 100%;
	padding: 4px 8px;
	border: solid 1px #7f7f80;
	background-color: transparent;
	border-radius: 0;
}
::placeholder { color: #ddd; }
select { background-color: #eee; }
input[type="checkbox"] { vertical-align: middle; }
button,
input[type="submit"],
input[type="button"],
.btn {
	padding: 2px 8px;
	border-radius: 4px;
	outline: 0;
	border: none;
	background-color: #8B4E14;
	color: #fff;
	font-size: 14px;
	cursor: pointer;
}
input[type="submit"]:hover,
input[type="submit"]:active,
.btn:hover,
.btn:active { opacity: 0.6; cursor: pointer; }
.clearfix { display: block; }
.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}
.nowrap { width: 100%; margin: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hidden { display: none; }
/* -------------------- */
/* Enlarged Photo */
#enlarged-photo { display: none; }
#enlarged-photo img { max-width: 90%; border: solid 3px #fff; box-shadow: 1px 1px 6px #222; }
#enlarged-photo-back{
	display: none;
	position: absolute;
	left: 0;
	top: 0;
	text-align: center;
	background: rgba(0, 0, 0, 0.5);
}
.doEnlarged { cursor: pointer; }
/* -------------------- */
/* ui dialog reset */
.ui-widget-header { background-color: #000; color: #fff; }
.ui-dialog-content,
.ui-button { height: 35px; font-size: 14px!important; }
.ui-dialog-titlebar-close { display: none; }
/* -------------------- */
#show-dialog { display: none; }
/* -------------------------------------------------- */
.wrapper { width: 1024px; margin: 0 auto; }
.inner { width: 96%; padding: 2%; }
.error { margin-bottom: 10px; color: red; }
.notice { margin-bottom: 10px; color: blue; }
img.img { width: 100%; }
.result-msg { margin-top: 10px; }
/* ---------- */
/* menu navi */
ul.menu-navi li { display: inline-block; margin: 0 4px; font-size: 90%; }
ul.menu-navi li a:link, ul.menu-navi li a:visited { text-decoration: none; color: #8B4E14; }
ul.menu-navi li a:hover, ul.menu-navi li a:active { text-decoration: underline; color: #fff; }
/* ---------- */
/* page navi */
.page-navi { margin: 10px auto; text-align: center; }
.page-navi li {
    display: inline-block;
    width: auto;
    margin: 0 5px;
    border: 2px solid lightblue;
    border-radius: 10px;
    overflow: hidden;
}
.page-navi li:first-child,
.page-navi li:last-child { border: none; }
.page-navi li .back,
.page-navi li .next { background-color: transparent; color: #333; }
.page-navi li span,
.page-navi li a { display: block; padding: 2px 4px; }
.page-navi li span.current{ background-color: lightblue; }
/* ---------- */
/* img upload button */
.btn-upload input { display: none; }
.btn-upload label { padding: 10px; background-color: #c4a547; color: #fff; border: none; }
.btn-upload label:hover,
.btn-upload label:active { opacity: 0.6; cursor: pointer; }
.btn-upload span { display: inline-block; margin-left: 10px; }
.remove-img-checkbox { display: block; /*width: 100%; text-align: right;*/ }
/* ================================================== */
.pc { display: block; }
.sp { display: none; }
/* -------------------- */
/* header */
header { background-color: #DDBA8A; }
header .left { float: none; width: 100%; }
header h1.title { color: #fff; font-size: 120%; font-weight: bold; }
header a:link, header a:visited { text-decoration: none; color: #fff; }
header a:hover, header a:active { text-decoration: underline; color: #fff; }
/* -------------------- */
/* humberger menu */
.btn-humberger { padding-top: 8px; text-align: right; }
#btn-humberger {
	display: inline-block;
	position: relative;
	width: 40px;
	height: 35px;
	border: solid 1px #8B4E14;
}
#btn-humberger .close { background: transparent; }
#btn-humberger .close:before,
#btn-humberger .close:after { margin-top: 0; }
#btn-humberger .close:before { transform: rotate(-45deg); -webkit-transform: rotate(-45deg); }
#btn-humberger .close:after { transform: rotate(-135deg); -webkit-transform: rotate(-135deg); }
#humberger-icon,
#humberger-icon:before,
#humberger-icon:after {
	display: block;
	position: absolute;
	width: 32px;
	height: 2px;
	background-color: #8B4E14;
}
#humberger-icon { top: 45%; left: 10%; transition: .2s; }
#humberger-icon:before,
#humberger-icon:after { top: 50%; left: 0; transition: .3s; content: ''; }
#humberger-icon:before { margin-top: -6px; }
#humberger-icon:after { margin-top: 4px; }
#humberger-menu {
	display: none;
	float: none;
	width: 100%;
	position: absolute;
	top: 56px;
	left: 0;
	background-color: #DDBA8A;
    font-size: 120%;
	border-top: solid 1px #8B4E14;
	z-index: 99;
}
#humberger-menu li { padding: 2px 0 2px 20px; border-bottom: solid 1px #8B4E14; }
#humberger-menu li a { display: block; }
#humberger-menu li a:link, #humberger-menu li a:visited { text-decoration: none; }
#humberger-menu li a:hover, #humberger-menu li a:active { text-decoration: none; }
/* -------------------- */
/* footer */
footer { background-color: #DDBA8A; text-align: center; }
footer .menu-navi { margin-bottom: 10px; }
/* -------------------- */
main {}
.about { margin-bottom: 30px; text-align: center; color: #8B4E14; }
.key-visual { margin-bottom: 30px; }
.key-visual img { width: 100%; }
.guidance { padding: 10px; margin: 20px 0; text-align: center; color: #8B4E14; border: solid 1px #8B4E14; }
.guidance .pdf { margin-top: 10px; }
h2.page-title { padding: 0 10px; background-color: #8B4E14; color: #fff; }
/* top page */
main section { margin: 20px 0 40px; }
main section .title {
	padding-top: 4px;
	padding-left: 8px;
	border-top: solid 1px #8B4E14;
	border-left: solid 8px #8B4E14;
	color: #8B4E14;
}
main section .body { margin: 10px; line-height: 1.6; }
main section .bottom { text-align: right; }
.past-seminar td { padding: 10px 10px 10px 0; border-bottom: solid 1px #DDBA8A; vertical-align: top; }
.past-seminar td.date { width: 90px; }
.past-seminar td.img img { width: auto; max-width: 200px; }
/* -------------------- */
/* seminar */
.seminar .list { margin-top: 20px; }
.seminar .list .body { margin-bottom: 4px; padding-bottom: 4px; border-top: solid 1px #DDBA8A; border-bottom: solid 1px #DDBA8A; }
.seminar .list .body .date,
.seminar .list .body .title { color: #8B4E14; }
.seminar .list .body .text { padding-top: 4px; border-top: dotted 1px #DDBA8A; line-height: 1.6; }
.seminar .list .body .img { margin-top: 10px; }
.seminar .list .body .img img { width: auto; max-width: 600px; }
.seminar .list .bottom { margin-bottom: 20px; font-size: 90%; text-align: right; }
/* -------------------- */
/* overview */
.overview table { margin: 10px 0 30px; }
.overview .cm td.prof { width: 100px; padding: 20px; vertical-align: top; }
.overview .cm .sign { text-align: right; }
.overview .ov th, .overview .ov td { padding: 4px 8px; border: solid 1px #8B4E14; }
.overview .ov th { background-color: #DDBA8A; }
.overview img { width: 100%; max-width: 200px; }
/* -------------------- */
/* member */
.member .name { margin-top: 20px; padding: 0 10px; background-color: #8B4E14; color: #fff; }
.member table.main { border: solid 1px #8B4E14; }
.member td { padding: 8px; vertical-align: top; }
.member td.pimg { width: 100px; }
.member td.qr { width: 100px; text-align: right; }
.member td.img { width: 200px; }
.member img { width: 100%; }
/* -------------------- */
/* link */
.link .body { margin-top: 20px; line-height: 1.6; }
/* -------------------- */
/* inquiry */
.inquiry form { margin: 20px 0 50px; }
.inquiry .bottom-navi { text-align: center; }
/* ================================================== */
/* CMS */
/* ================================================== */
.cms button,
.cms input[type="submit"],
.cms input[type="button"],
.cms .btn { background-color: #000; }
/* header */
header.cms {
	position: fixed;
	width: 98%;
	padding: 10px 1%;
	background-color: #000;
	color: #fff;
	z-index: 99;
}
header.cms .left,
header.cms .right { float: left;  width: 50%; }
header.cms .right { text-align: right; }
header.cms a:link, header.cms a:visited,
header.cms a:hover, header.cms a:active { color: #fff; }
header.cms .title a { text-decoration: none; }
header.cms span.menu-link  { display: inline-block; margin-left: 8px; font-size: 90%; }
header.cms .login-name { text-align: right; }
/* -------------------- */
/* footer */
footer.cms {
	padding: 10px;
	background-color: #000;
	color: #fff;
	text-align: center;
	font-size: 90%;
	line-height: 1.4;
	/* for footer bottom line */
	position: fixed;
	bottom: 0;
	width: 100%;
}
footer.cms a:link, footer.cms a:visited,
footer.cms a:hover, footer.cms a:active { color: #fff; }
/* -------------------- */
/* main */
main.cms { margin-top: 90px; margin-bottom: 50px; }
.cms .wrapper { width: 90%; margin: 20px auto; }
.cms .top-navi { border-bottom: 10px; text-align: right; }
.cms .bottom-navi { width: 100%; margin: 20px 0; text-align: center; }
.cms .bottom-navi input { margin-left: 10px; }
.cms .bottom-navi span { display: inline-block; margin: 0 4px; }
.cms .conditions td.navi { text-align: right; }
.cms .conditions td.navi input { margin-left: 4px; }
.cms .btn-upload { margin: 0!important; }
.cms .btn-upload label { padding: 6px; border-radius: 4px; background-color: #000; }
/* -------------------- */
/* list */
.cms .list { margin-top: 10px; border: solid 1px #000; }
.cms .list th {
	background-color: #000;
	border-bottom: solid 1px #fff;
	border-left: solid 1px #fff;
	color: #fff;
	text-align: center;
}
.cms .list th:nth-child(1) { border-left: solid 1px #000; }
.cms .list th.navi { width: 60px; }
.cms .list td { border-bottom: solid 1px #000; border-left: solid 1px #000; }
.cms .list td.id, .cms .list td.navi { text-align: center; }
/*.cms .list :nth-child(even) td { background-color: #efefef; }*/
.cms .list .no-data { color: orangered; }
/* -------------------- */
/* edit */
.cms .edit { padding-top: 10px; }
.cms .edit th {
	background-color: #000;
	border-bottom: solid 1px #fff;
	color: #fff;
	text-align: center;
}
.cms .edit tr:last-child th { border-color: #000; }
.cms .edit td { border: solid 1px #000; }
.cms .edit th, .cms .edit td { padding: 6px; }
/* ************************************************** */
@media screen and (max-width: 767px) {
	.pc { display: none; }
	.sp { display: block; }
	ul.menu-navi li { font-size: 110%; }
	.wrapper { width: 100%; }
	.past-seminar td.img img { display: none; }
	header .left { float: left; width: 80%; }
	header .right { float: left; width: 20%; }
	footer ul.menu-navi li { display: block; }
	.member td { display: block; width: auto; }
	.member td.qr { text-align: left; }
	.member img { width: auto; max-width: 200px; }
		/* ================================================== */
	/* CMS */
	/* ================================================== */
	/* main */
	main.cms { padding-bottom: 50px; }
	.cms .wrapper { width: 94%; margin-bottom: 0; }
	/* list */
	.cms .list th { text-align: left; }
	/* edit */
	.cms .edit th { border-bottom: none; text-align: left; }
	.cms .edit th,
	.cms .edit td { display: block; }
}
@media screen and (max-width: 1023px) {
	.wrapper { width: 100%; }
}