@charset "utf-8";

html, body                 {width:100%;margin:0 auto;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}
body                       {-webkit-text-size-adjust:100%;}
div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, 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,
table, caption, tbody, tfoot, thead, tr, th, td, p,
fieldset, form, label, legend, input,
article, aside, canvas, figure, figcaption,
footer, header, nav, section,
b, u, i                    {margin:0;padding:0;list-style:none;font-style:normal;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}

a                          {outline:none;}
img                        {border:0 none;vertical-align:top;max-width:100%;height:auto;}
em                         {font-style:normal;font-weight:bold;}
nav ul, nav li             {list-style:none;}
.h a, .f a,
nav a, nav span            {text-decoration:none;}
table                      {border-collapse:collapse;}

.no-link                   {pointer-events:none;}

/* ----------------------------------------------- font */
@font-face                 {font-family:'Yu Gothic M';src:local("Yu Gothic Medium"),local("Yu Gothic");font-weight:500;}

html                       {font-size:62.5%;}
body                       {font-size:15px;font-family: "YuGothic M", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;}
h1, h2,  h3                {font-weight:normal;}
h1                         {font-size:160%;}
h2                         {font-size:140%;}
h3                         {font-size:120%;}
.mincho                    {font-family: "Times New Roman", Times, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;}
.wf-notosansjapanese       {font-family: "Noto Sans JP";}

/* ============================================================== base */
html, body                 {height:100%;}
body                       {background:#fff;color:#333;-webkit-text-size-adjust:100%;}
.wfx                       {max-width:1000px;margin:0 auto;}
.wfx_cf:after              {content:"";display:block;clear:both;height:0;font-size:0;}
.bg_fixed                  {background-size:cover;background-repeat:no-repeat;background-position:50% 50%;}

a                          {}
a:visited                  {}
a:hover                    {}
a > img                    {vertical-align:top;transition:0.2s;}
a:hover > img              {opacity:0.75;}

@media screen and (min-width: 1000px){
	.bg_fixed                  {background-attachment:fixed;background-position:50% 100%;}
	_:-ms-fullscreen, :root .bg_fixed {background-attachment:scroll;}
}

/* ============================================================== header */
body:before                {height:44px;content:"";display:block;width:0;position:relative;}
.anchor                    {margin-top:-44px;position:absolute;height:0;font-size:0;}
.h                         {background:rgba(255,255,255,0.99);border-bottom:5px solid #33cccc;position:fixed;z-index:90;width:100%;top:0;transition:.3s;}
.h .wfx                    {position:relative;padding:0;overflow:hidden;}
.h_logo                    {font-size:75%;padding:12px 10px;}
.h_logo a                  {display:inline-block;}
.h_logo a img              {height:20px;}

/* ----------------------------------------------- hamburger */
.gn_btn                    {background:transparent;border:1px solid transparent;width:32px;height:32px;right:5px;top:6px;position:absolute;line-height:1em;text-align:center;z-index:3;}
.gn_btn i                  {margin-top:34px;font-size:75%;position:relative;display:block;text-align:center;vertical-align:bottom;}
.gn_btn:before,
.gn_btn:after,
.gn_btn i:after            {background:#33cccc;position:absolute;content:"";display:block;width:20px;height:2px;left:calc(50% - 10px);transition:0.2s;}
.gn_btn i:after            {top:-20px;}
.gn_btn:before             {top:6px;}
.gn_btn:after              {top:22px;}
.gn_on .gn_btn             {border-color:transparent;}
.gn_on .gn_btn:before,
.gn_on .gn_btn:after       {top:14px;height:2px;background:#fff;}
.gn_on .gn_btn:before      {transform:rotate(45deg);}
.gn_on .gn_btn:after       {transform:rotate(-45deg);}
.gn_on .gn_btn i:after     {display:none;}

/* ----------------------------------------------- navigation */
.gn                        {background:#33cccc;height:100%;width:80%;top:0;right:-80%;position:fixed;z-index:2;overflow:scroll;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;transition:0.2s;}
.gn_bg                     {top:0;left:0;position:fixed;z-index:1;background:rgba(255,255,255,0);width:100%;height:100%;transition:0.2s;display:none;}
.gn_on                     {overflow-y:hidden;position:fixed;}
.gn_on .c                  {-webkit-filter:blur(5px);filter:blur(5px);}
.gn_on .gn                 {right:0;box-shadow:-3px 0 3px rgba(0,0,0,0.2);}
.gn_on .gn_bg              {background:rgba(255,255,255,0.8);display:block;}
.gn ul                     {padding:4em 1em 1em;}
.gn ul li                  {margin-bottom:0.5em;padding-bottom:0.5em;padding-right:1em;border-bottom:1px solid rgba(255,255,255,0.5);position:relative;}
.gn ul li:last-child       {border-bottom:0 none;}
.gn ul li a                {color:#fff;position:relative;line-height:1.6em;padding:0.5em;display:block;font-weight:bold;font-family:"Noto Sans JP", "YuGothic M", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック";}

@media screen and (min-width: 768px){
	.gn_on .gn_bg,
	.gn_bg,
	.gn_btn                    {display:none;}
	.gn_on .gn,
	.gn                        {top:0;right:0;width:auto;height:auto;overflow:visible;overflow-y:visible;position:absolute;clear:both;background-color:transparent;box-shadow:0 0 0 none;height: 2rem;}
	.gn ul                     {padding:0.5em 0;display:flex;justify-content:flex-end;align-items:flex-end;position:relative;margin:0 auto;}
	.gn ul li                  {margin:0;padding:0 0.5em;border-bottom:0 none;position:relative;}
	.gn ul li a                {font-weight:bold;color:#4f4f4f;font-size:87.5%;line-height:135%;text-align:center;display:block;padding:0.3em 0.5em;}
	.gn ul .crt a              {border:1px solid rgba(128,128,128,0.5);}
	.gn ul li a:after          {background:#33cccc;position:absolute;content:"";display:block;width:0;height:1px;left:50%;bottom:0.2em;transition:0.2s;}
	.gn ul li a:hover:after    {width:80%;left:10%;}
	.gn ul li a i              {display:block;}

/* 第二階層ナビゲーション ここから */
.h.new .wfx {
    overflow: inherit;
}
.h.new .gn {
    display: flex;
    height: 2rem;
    margin: 0 auto;
}
.h.new .gn ul {
	align-items: inherit;
}
.h.new .gn li {
    width: 25%;
}
.h.new .gn li {
    list-style: none;
    position: relative;
}
.h.new .gn ul li li a {
    background: #33cbcb;
    color: #fff;
    display: block;
    text-align: center;
    text-decoration: none;
    width: 110px;
}

.h.new .gn ul li ul {
	display: block;
    position: absolute;
    left: -25px;
    top: 10px;
    margin-top: 0px;
}
.h.new .gn ul li ul li a {
    border-top: 1px solid #eee;
    padding: 11px 0 11px 0;
}
.h.new .gn ul li ul li {
	width: 100%;
    height: 0;
    overflow: hidden;
    transition: .5s;
}
.h.new .gn ul li:hover > ul li:first-child {
	margin-top: 5px;
}
.h_mini .h.new .gn ul li:hover > ul li:first-child {
	margin-top: 15px;
}
.h.new .gn ul li:hover > ul > li {
    height: 4rem;
    line-height: 3rem;
    overflow: visible;
}
.h.new .gn ul li:hover > ul > li a:hover {
	opacity: .9;
	transition:0.2s;
}
/* 第二階層ナビゲーション ここまで */
}
@media screen and (min-width: 1000px){
	body:before                {height:90px;}
	.h_logo                    {padding:20px 10px;transition:0.2s;}
	.h_logo a img              {height:50px;transition:0.2s;}
	.gn ul                     {padding:18px 0;transition:0.2s;}

	.h_mini .h_logo            {padding:10px;}
	.h_mini .h_logo a img      {height:30px;}
	.h_mini .gn ul             {padding:0.4em 0;}
}
/* ============================================================== footer */
.pagetop                     {font-size:0;text-align:center;}
.pagetop span                {background:#33cccc;color:#fff;padding:15px 0;transition:0.2s;cursor:pointer;display:block;}
.pagetop span:hover          {opacity:0.8;}

.f                           {}
.f_logo                      {padding:1em 0;text-align:center;}
.f_logo a                    {display:inline-block;max-width:135px;}
.f_nav ul                    {text-align:center;margin-bottom:0.5em;}
.f_nav li                    {font-size:75%;display:inline-block;margin:0 0.8em;}
.f_nav a                     {color:#126;display:inline-block;font-weight:bold;font-family:"Noto Sans JP", "YuGothic M", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック";}
.f_copyright                 {margin-top: 30px;color:#126;padding:0.5em 0;font-size:68.75%;line-height:150%;text-align:center;font-weight:bold;font-family:arial, sans-serif;}
.f_copyright i               {display:inline-block;}

@media screen and (min-width: 768px){
	.pagetop span                {padding:25px 0;}
	.f .wfx                      {display:flex;align-items:center;padding:1.5em 1em;max-width:800px;}
	.f_logo                      {padding:0;margin-right:20px;}
	.f_nav ul                    {text-align:left;margin-bottom:0;}
	.f_nav li                    {margin:0;padding:0 2em;position:relative;}
	.f_nav li:after              {height:1.3em;width:1px;top:0.1em;left:-0.2em;background:#111;transform:rotate(15deg);content:"";display:block;position:absolute;}
	.f_nav li:nth-of-type(1)     {padding-left:0;}
	.f_nav li:nth-of-type(1):after {display:none;}
	.f_nav a:hover               {opacity:0.75;}
	.f_copyright                 {text-align:left;letter-spacing:0.1em;}
}
