﻿@charset "UTF-8";

before,after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
html { height: 100%; }
body { margin: 0; padding: 0; width: 100%; height: 100%; -webkit-text-size-adjust: 100%; line-height: 1.85; font-family:'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif; background-image: url("../img/bg.png") }
h1,h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, caption, th, td, img, form, div { margin: 0; padding: 0; border: none; font-style: normal; font-weight: normal; font-size: 100%; text-align: left; font-family: 'Meiryo', 'メイリオ', 'ヒラギノ 角ゴPro W3', 'Hiragino Kaku Gothic Pro', 'MS PGothic', 'ＭＳ Ｐゴシック'; color: #505050; list-style-type: none; }
iframe { border: 0; }
textarea { font-size: 100%; }
section, article, aside, hgroup, header, footer, nav, figure, figcaption, summary { display: block; }
img       { border: 0; vertical-align: bottom; }
a         { margin: 0; padding: 0; text-decoration: none; }
a:link    { margin: 0; padding: 0; color: #ff0000; }
a:visited { margin: 0; padding: 0; color: #ff0000; }
a:hover   { margin: 0; padding: 0; color: #ff6600; }
a:active  { margin: 0; padding: 0; color: #808080; }

.clear { clear: both; }

.space10 { height: 10px; }
.space20 { height: 20px; }
.space30 { height: 30px; }
.space40 { height: 40px; }
.space50 { height: 50px; }
.space60 { height: 60px; }

/* 幅指定 */

body,#header,#globalNav,#footer { min-width: 1020px; }

@media screen and (max-width: 1020px) {
 body,#header,#globalNav,#footer { min-width: 720px; }
 }

@media screen and (max-width: 750px) {
 body,#header,#globalNav,#footer { min-width: 320px; }
 }

/* ▼▼▼▼▼▼▼▼▼▼▼▼▼　PC Styling　▼▼▼▼▼▼▼▼▼▼▼▼▼ */

/* wrap */

html { padding: 0; width: auto; max-width: 100%; }
body { width: 100%; display: block; width: 100% !important; height: 100% !important; }

/* view */

.viewRW   { display: block !important; }
br.viewRW { display: inline !important; }
.viewPC   { display: none !important; }

/* view - contents  */

.txt { line-height: 1.65; font-size: 12px; line-height: 1.5; }

.min.txt { font-size: 10px !important; }

.scope { margin: 0 10px; }

.read { line-height: 1.5; margin-top: 13px; }

/* --------------------------------------------------------------------- */
/* header */
/* --------------------------------------------------------------------- */

.inner { width: 980px; margin: 0 auto; position: relative; color: #1F2887; }
.inner:after { content:""; clear: both; display: block; }

/*--------header-----------*/

#top-head         { top: -80px; position: absolute; width: 100%; height: 80px; margin: 80px auto 0 auto; padding: 20px 0; line-height: 1; z-index: 999; opacity: 0.95; background: linear-gradient(-135deg, #ffa1a1, #ff5555); }
#top-head         { color: #000; text-decoration: none; }
#top-head a       { color: #000; text-decoration: none; }
#top-head .inner  { position: relative; }
#top-head .logo   { float: left; position: relative; }
#top-head .logo a { position: absolute; width: 100%; }

#global-nav ul                   { list-style: none; position: absolute; top: 30px; right: 0; font-size: 18px; }
#global-nav ul li                { float: left; padding: 0 5px; border-left: }
#global-nav ul li a              { padding: 5px 5px; position: relative; display: inline-block; color: #FFF8F8; }
#global-nav ul li a::after       { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 2px; -webkit-transform: scaleX(0); -ms-transform: scaleX(0); transform: scaleX(0); background-color: #fff; -webkit-transition: all .3s ease; transition: all .3s ease; }
#global-nav ul li a:hover::after { -webkit-transform: scaleX(1); -ms-transform: scaleX(1); transform: scaleX(1); }

nav span { background: #666; height: 2px; display: block; position: relative; width: 50px; left: 0; }

/*--------固定化されたときのCSS-----------*/

#top-head.fixed                     { margin-top: 0; top: 0; position: fixed; padding: 15px 0; top 0.65s ease-in; -webkit-transition: top 0.65s ease-in; -moz-transition: top 0.65s ease-in; background: linear-gradient(-135deg, #ffa1a1, #ff5555); }
#top-head.fixed .logo a             { position: absolute; width: 100%; }

/*-----------トグルボタン-------------*/

#nav-toggle { display: none; position: absolute; right: 12px; top: 14px; width: 34px; height: 36px; cursor: pointer; z-index: 101; }
#nav-toggle div { position: relative; }
#nav-toggle span { display: block; position: absolute; height: 4px; width: 100%; background: #FEF7F8; left: 0; -webkit-transition: .35s ease-in-out; -moz-transition: .35s ease-in-out; transition: .35s ease-in-out; }
#nav-toggle span:nth-child(1) { top: 0; }
#nav-toggle span:nth-child(2) { top: 11px; }
#nav-toggle span:nth-child(3) { top: 22px; }

/* --------------------------------------------------------------------- */
/* contents */
/* --------------------------------------------------------------------- */

#main        { width: 100%; margin-top: 120px; }
#main header { margin: 0 auto; text-align: center; width: 100%; padding: 20px 0 90px 0; }

header h2 img { max-width: 100%; }

#button { width: 960px; margin: 0 auto; text-align: center; }

.circle { width: 30%; float: left; }

#sns             { width: 66%; margin: 0 auto; text-align: center; padding: 60px 0 70px 0; }
#sns img         { width: 48px; margin: 0px 18px 0px 18px; }
#sns a:hover img { opacity: 0.7; filter: alpha(opacity=70); -ms-filter: "alpha(opacity=70)"; }

.ih-item         { margin: 0 35px; padding: 0; position: relative; -webkit-transition: all 0.35s ease-in-out; -moz-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }
.ih-item,
.ih-item *       { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.ih-item a       { color: #333; }
.ih-item a:hover { text-decoration: none; }
.ih-item img     { width: 100%; height: 100%; }

.ih-item.circle             { position: relative; width: 250px; height: 250px; border-radius: 50%; }
.ih-item.circle .img        { position: relative; width: 250px; height: 250px; border-radius: 50%; }
.ih-item.circle .img:before { position: absolute; display: block; content: ''; width: 100%; height: 100%; border-radius: 50%; box-shadow: inset 0 0 0 16px rgba(255, 188, 188, 0.6), 0 1px 2px rgba(0, 0, 0, 0.3); -webkit-transition: all 0.35s ease-in-out; -moz-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }
.ih-item.circle .img img    { border-radius: 50%; }
.ih-item.circle .info       { position: absolute; top: 0; bottom: 0; left: 0; right: 0; text-align: center; border-radius: 50%; -webkit-backface-visibility: hidden; backface-visibility: hidden; }

.ih-item.square       { position: relative; width: 316px; height: 216px; border: 8px solid #fff; box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.3); }
.ih-item.square .info { position: absolute; top: 0; bottom: 0; left: 0; right: 0; text-align: center; -webkit-backface-visibility: hidden; backface-visibility: hidden; }

.ih-item.circle.effect .img                        { opacity: 1; -webkit-transform: scale(1); -moz-transform: scale(1); -ms-transform: scale(1); -o-transform: scale(1); transform: scale(1); -webkit-transition: all 0.35s ease-in-out; -moz-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }
.ih-item.circle.effect.colored .info               { background: #1a4a72; }
.ih-item.circle.effect .info                       { background: #ffbcbc; opacity: 0; -webkit-transition: all 0.35s ease-in-out; -moz-transition: all 0.35s ease-in-out; transition: all 0.35s ease-in-out; }
.ih-item.circle.effect .info h3                    { text-align: center; color: #fff; text-transform: uppercase; position: relative; letter-spacing: 2px; font-size: 22px; margin: 0 30px; padding: 40px 0 0 0; text-shadow: 0 0 1px white, 0 1px 2px rgba(0, 0, 0, 0.3); }
.ih-item.circle.effect .info h4                    { text-align: center; color: #fff; text-transform: uppercase; position: relative; letter-spacing: 2px; font-size: 22px; margin: 0 30px; padding: 0 0 10px 0; text-shadow: 0 0 1px white, 0 1px 2px rgba(0, 0, 0, 0.3); }
.ih-item.circle.effect .info p                     { text-align: center; color: #fff; padding: 10px 5px; font-style: italic; margin: 0 30px; font-size: 14px; border-top: 1px solid rgba(255, 255, 255, 0.5); }
.ih-item.circle.effect.scale_up .info              { -webkit-transform: scale(0.5); -moz-transform: scale(0.5); -ms-transform: scale(0.5); -o-transform: scale(0.5); transform: scale(0.5); }
.ih-item.circle.effect.scale_up a:hover .img       { opacity: 0; -webkit-transform: scale(1.5); -moz-transform: scale(1.5); -ms-transform: scale(1.5); -o-transform: scale(1.5); transform: scale(1.5); }
.ih-item.circle.effect.scale_up a:hover .info      { opacity: 1; -webkit-transform: scale(1); -moz-transform: scale(1); -ms-transform: scale(1); -o-transform: scale(1); transform: scale(1); }
.ih-item.circle.effect.scale_down .info            { -webkit-transform: scale(1.5); -moz-transform: scale(1.5); -ms-transform: scale(1.5); -o-transform: scale(1.5); transform: scale(1.5); }
.ih-item.circle.effect.scale_down a:hover .img     { opacity: 0; -webkit-transform: scale(0.5); -moz-transform: scale(0.5); -ms-transform: scale(0.5); -o-transform: scale(0.5); transform: scale(0.5); }
.ih-item.circle.effect.scale_down a:hover .info    { opacity: 1; -webkit-transform: scale(1); -moz-transform: scale(1); -ms-transform: scale(1); -o-transform: scale(1); transform: scale(1); }
.ih-item.circle.effect.scale_down_up .info         { -webkit-transform: scale(0.5); -moz-transform: scale(0.5); -ms-transform: scale(0.5); -o-transform: scale(0.5); transform: scale(0.5); -webkit-transition: all 0.35s ease-in-out 0.2s; -moz-transition: all 0.35s ease-in-out 0.2s; transition: all 0.35s ease-in-out 0.2s; }
.ih-item.circle.effect.scale_down_up a:hover .img  { opacity: 0; -webkit-transform: scale(0.5); -moz-transform: scale(0.5); -ms-transform: scale(0.5); -o-transform: scale(0.5); transform: scale(0.5); }
.ih-item.circle.effect.scale_down_up a:hover .info { opacity: 1; -webkit-transform: scale(1); -moz-transform: scale(1); -ms-transform: scale(1); -o-transform: scale(1); transform: scale(1); }

/* --------------------------------------------------------------------- */
/* footer*/
/* --------------------------------------------------------------------- */

/* view */

.viewRW,br.viewRW { display: none !important; }
.viewPC { display: block; }

#footer { padding: 30px 0 0 0; background-repeat: no-repeat, repeat; background-position: bottom right, top left; position: relative; display: block;  margin-top: 10px; opacity: 0.95; background: linear-gradient(-135deg, #ffa1a1, #ff5555); }
#footer ul { list-style: none; display: block;  }

#footer .footerBody {  margin: 0 60px; padding: 0 0 40px 0; position: relative;  }

#footer .obj {  position: absolute; bottom: 67px; right: 0px; }

/* copy block */

#footer .copyBlock        {  border-top: 1px solid #e1e1e1; text-align: center; padding: 21px 0 15px 0; background: url(../img/footer_bg.gif) repeat left top;  }
#footer .copyBlock p      {  width: 100%; height: 152px; overflow: hidden; margin: 0 auto; background: url(../img/footer_copy.png) no-repeat center top; background-size: contain;  }
#footer .copyBlock p span {  padding-top: 500px; display: block;  }

/* menu */

#footer .menu                 {  width: auto; text-align: center; border-bottom: 1px solid #434343; padding-bottom: 30px; margin: 30px 0px 30px 0p;  }
#footer .menu ul              {  display: inline-block; border-left: 1px solid #434343; padding: 3px 0;  }
#footer .menu ul li           {  display: inline; font-size: 1.2rem; font-weight: bold; border-right: 1px solid #434343; padding: 3px 0;  }
#footer .menu ul li a         {  opacity: 0.5; padding: 0 13px; text-decoration: none;  }
#footer .menu ul li a.current {  opacity: 1;  }
#footer .menu ul li a:hover   {  opacity: 1;  }

/* information */

#footer .info                     {  display: table;  }
#footer .info .addressBox         {  display: table-cell; vertical-align: top; background: url(../img/line_y_01.gif) repeat-y left top; padding: 0 25px;  }
#footer .info .telBox             {  display: table-cell; vertical-align: top; background: url(../img/line_y_01.gif) repeat-y left top; padding: 0 25px;  }
#footer .info .addressBox address {  display: inline;  }
#footer .info .addressBox p       {  color: #fff; font-size: 1rem; line-height: 1.33;  }
#footer .info .addressBox address {  color: #fff; font-size: 1rem; line-height: 1.33;  }
#footer .info .telBox p           {  color: #fff; font-size: 1rem; line-height: 1.33;  }
#footer .other p                  {  color: #fff; font-size: 1rem; line-height: 1.33;  }

/* other */

#footer .other                    {  margin-top: 35px; }
#footer .other .right             {  position: absolute; right: 0; bottom: 40px;  }
#footer .other .right p           {  font-size: 0.8rem; display: inline;  }
#footer .other .right .fb a       {  border: 1px solid #515151; padding: 7px 10px 7px 10px; border-radius: 2px; margin-left: 15px; text-decoration: none; color: #ababab;  }
#footer .other .right .fb a:hover {  border-color: #fff; background: #fff; color: #555;  }

address { font-style: normal; }

/* ===================================================================== */

/* ▲▲▲▲▲▲▲▲▲▲▲▲▲　PC Styling　▲▲▲▲▲▲▲▲▲▲▲▲▲ */
/* ▼▼▼▼▼▼▼▼▼▼▼▼▼　Tablet Styling　▼▼▼▼▼▼▼▼▼▼▼▼▼ */

@media screen and (max-width: 1024px) {

/* ===================================================================== */

/* --------------------------------------------------------------------- */
/* header */
/* --------------------------------------------------------------------- */

.head-inner { display: none; }
.slick-next { right: 0; }

#top-head { width: 100%; padding: 0; top: 0; position: fixed; margin-top: 0; height: 100px; }
#top-head img { margin: 8px 0 0 30px; height: 70px; }
.inner { width: 100%; padding: 0; }

 /* Fixed reset */

#top-head.fixed       { padding-top: 0; background: transparent; }

#mobile-head { background: linear-gradient(-135deg, #ffa1a1, #ff5555); width: 100%; height: 100px; z-index: 999; position: relative; transition: top 0.65s ease-in; -webkit-transition: top 0.65s ease-in; -moz-transition: top 0.65s ease-in; }

#global-nav       { position: absolute; /* 開いてないときは画面外に配置 */ top: -456px; background: linear-gradient(-135deg, #ffbebe, #ffa1a1); width: 100%; text-align: center; padding: 5px 0; -webkit-transition: .5s ease-in-out; -moz-transition: .5s ease-in-out; transition: .5s ease-in-out; }
#global-nav ul    { list-style: none; position: static; right: 0; bottom: 0; font-size: 18px; }
#global-nav ul li { float: none; position: static; padding: 0; color: #fff; margin: 10px; text-align: center; }

#nav-toggle { display: block; right: 25px; top: 40px; }

 /* #nav-toggle 切り替えアニメーション */

.open #nav-toggle span:nth-child(1) { top: 11px; -webkit-transform: rotate(315deg); -moz-transform: rotate(315deg); transform: rotate(315deg); }
.open #nav-toggle span:nth-child(2) { width: 0; left: 50%; }
.open #nav-toggle span:nth-child(3) { top: 11px; -webkit-transform: rotate(-315deg); -moz-transform: rotate(-315deg); transform: rotate(-315deg); }

 /* #global-nav スライドアニメーション */

.open #global-nav { /* #global-nav top + #mobile-head height */ -moz-transform: translateY(556px); -webkit-transform: translateY(556px); transform: translateY(556px); }

/* --------------------------------------------------------------------- */
/* contents */
/* --------------------------------------------------------------------- */

#sns             { width: 100%; margin: 0 auto; text-align: center; padding: 50px 0 20px 0; }
#sns img         { width: 10%; }
#sns a:hover img { opacity: 0.7; filter: alpha(opacity=70); -ms-filter: "alpha(opacity=70)"; }

/* --------------------------------------------------------------------- */
/* footer*/
/* --------------------------------------------------------------------- */

#footer  { margin-top: 40px; }

/* ===================================================================== */

}

/* ▲▲▲▲▲▲▲▲▲▲▲▲▲　Tablet Styling　▲▲▲▲▲▲▲▲▲▲▲▲▲ */
/* ▼▼▼▼▼▼▼▼▼▼▼▼　SmartPhone Styling　▼▼▼▼▼▼▼▼▼▼▼▼ */

@media screen and (max-width: 768px) {

/* wrap */

html { padding: 0; width: auto; max-width: 100%; }
body { width: 100%; display: block; width: 100% !important; height: 100% !important; }

/* view */

.viewRW   { display: block !important; }
br.viewRW { display: inline !important; }
.viewPC   { display: none !important; }

/* view - contents  */

.txt { line-height: 1.65; font-size: 12px; line-height: 1.5; }

.min.txt { font-size: 10px !important; }

.scope { margin: 0 10px; }

.read { line-height: 1.5; margin-top: 13px; }

/* --------------------------------------------------------------------- */
/* header */
/* --------------------------------------------------------------------- */

h1 img { padding: 7px 0 24px 0; }

.head-inner { display: none; }

.slick-next { right: 0; }

#top-head { height: 50px; width: 100%; padding: 0; top: 0; position: fixed; margin-top: 0; }

.inner { width: 100%; padding: 0; }

 /* Fixed reset */

#mobile-head { background: linear-gradient(-135deg, #ffa1a1, #ff5555); width: 100%; height: 40px; z-index: 999; position: relative; transition: top 0.65s ease-in; -webkit-transition: top 0.65s ease-in; -moz-transition: top 0.65s ease-in; }

#global-nav       { position: absolute; /* 開いてないときは画面外に配置 */ top: -506px; background: linear-gradient(-135deg, #ffbebe, #ffa1a1); width: 100%; text-align: center; padding: 5px 0; -webkit-transition: .5s ease-in-out; -moz-transition: .5s ease-in-out; transition: .5s ease-in-out; }
#global-nav ul    { list-style: none; position: static; right: 0; bottom: 0; font-size: 18px; }
#global-nav ul li { float: none; position: static; padding: 0; color: #fff; }

#top-head #global-nav ul li a       { width: 100%; display: block; color: #fff; padding: 10px 0; }
#top-head.fixed #global-nav ul li a { width: 100%; display: block; color: #fff; padding: 10px 0; }

#nav-toggle { display: block; right: 25px; top: 10px; width: 30px; }

 /* #nav-toggle 切り替えアニメーション */

.open #nav-toggle span:nth-child(1) { top: 11px; -webkit-transform: rotate(315deg); -moz-transform: rotate(315deg); transform: rotate(315deg); }
.open #nav-toggle span:nth-child(2) { width: 0; left: 50%; }
.open #nav-toggle span:nth-child(3) { top: 11px; -webkit-transform: rotate(-315deg); -moz-transform: rotate(-315deg); transform: rotate(-315deg); }

 /* #global-nav スライドアニメーション */

.open #global-nav { /* #global-nav top + #mobile-head height */ -moz-transform: translateY(556px); -webkit-transform: translateY(556px); transform: translateY(556px); }

#main header { margin: 0 auto; text-align: center; width: 100%; padding: 20px 0 30px 0; }

header h1 img { max-width: 100%; }

/* --------------------------------------------------------------------- */
/* contents */
/* --------------------------------------------------------------------- */

#main { width: 100%; margin-top: 85px; }

/* --------------------------------------------------------------------- */
/* footer */
/* --------------------------------------------------------------------- */

#footer  { margin-top: 40px; }

#footer .viewRW { display: inline !important; }
#footer .viewPC { display: none !important; }

/* copy block */

#footer .copyBlock p { width: 254px; height: 76px; background: url(../img/footer_copy.png) no-repeat center top; background-size: contain; }

#footer .footerBody { margin: 0 auto -20px auto; padding: 0; }

#footer .menu { display: none; }

#footer .rwInfo   { margin: 0 auto; width: 300px; display: block !important; text-align: center; }
#footer .rwInfo * { font-size: 0.8rem; line-height: 1.6; color: #fff; }
#footer .rwInfo .addressBox {  }

#footer .other .right   { width: auto; position: static; text-align: center; margin: 0 auto; padding: 5px 0; background: linear-gradient(-135deg, #ffbebe, #ffa1a1); }
#footer .other .right p { font-size: 0.65rem; }

/* ===================================================================== */

}

/* ▲▲▲▲▲▲▲▲▲▲▲▲　SmartPhone Styling　▲▲▲▲▲▲▲▲▲▲▲▲ */