@charset "UTF-8";

.en { font-family: 'EB Garamond', serif; letter-spacing: 0; }
.midashi {  font-family: 'Shippori Mincho B1', serif; }
/*==================================================================================================

       リセット

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

        html, body, div, span, applet, object, iframe, strong,
        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, sub, sup, tt, var,
        dl, dt, dd, ol, ul, li,
        fieldset, form, legend, caption, 
        tbody, tfoot, thead, table, label, tr, th, td{
        margin: 0;
        padding: 0;
        border: 0;
        outline: 0;
        font-style: inherit;
        font-family: inherit;
        vertical-align: baseline;
        list-style:none;
        }
        ul { 
        letter-spacing: -1em;
        word-spacing: -1em;
        }
        :root ul {
        letter-spacing: -1px;
        word-spacing: -1px;
        }
        li { 
        letter-spacing: normal;
        word-spacing: normal;
        *display: inline;
        *zoom: 1;
        }
        figure { margin:0;}
        figure video { max-width: 100%;}
        img,iframe	{ vertical-align:bottom;}
        
/*==================================================================================================

       メイン設定

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

html,body { width:100%; min-width: 320px; *width:320px; font-size:16px; }
body {
        background:#FFF;
        font-family: 'Noto Sans JP', sans-serif;
        letter-spacing:0.05em;
        color:#2E3033;
        font-weight:400;
        text-align:left;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        line-height:200%;
        font-feature-settings: "palt" 1;
        }

        .wrapper    { overflow:hidden;}
        article		{ position:relative; width:100%; z-index: 0;}
        section		{ position:relative; }
        main        { display: block; position: relative; z-index: 1; }

        .section-ll	{ padding-top:22rem; padding-bottom:22rem; }
        .section-l	{ padding-top:20rem; padding-bottom:20rem; }
        .section	{ padding-top:15rem; padding-bottom:15rem; }
        .section-m	{ padding-top:10rem; padding-bottom:10rem; }
        .section-s	{ padding-top:8rem; padding-bottom:8rem; }
        .section-ss	{ padding-top:4rem; padding-bottom:4rem; }
        .section-sss	{ padding-top:2.75rem; padding-bottom:2.75rem; }

        .second  	{ padding-top:0 !important; }

        .outer-l	{ padding-left:5vw; padding-right:5vw; box-sizing:border-box; }
        .outer		{ padding-left:2.78vw; padding-right:2.78vw; box-sizing:border-box; }
        .outer-thin	{ padding-left:1rem; padding-right:1rem; box-sizing:border-box; }

        .inner-wrap    { padding:1rem 3% 0; box-sizing:border-box; }
        .inner-wrap-s  { padding:1rem; box-sizing:border-box; }
        .box-inner     { padding: 0 1rem; box-sizing: border-box; }

        .inner-outer-l { padding-left:8%; padding-right:8%; box-sizing:border-box; }
        .inner-outer   { padding-left:24px; padding-right:24px; box-sizing:border-box; }
        .inner-outer-s   { padding-left:3%; padding-right:3%; box-sizing:border-box; }

        .row			{ margin-left:auto; margin-right:auto; position: relative;}
        .row .row		{ min-width: 0px; }
        .row:before,
        .row:after      { content:""; display:table; }
        .row:after      { clear: both; }
        .row            { zoom: 1; }

        h1,h2,h3,h4,h5 { letter-spacing: 0.05em; line-height: 160%; font-weight:700; font-family: 'Shippori Mincho B1', serif; }
        
        .en h1,.en h2,.en h3,.en h4,.en h5,
        h1.en,h2.en,h3.en,h4.en,h5.en { font-weight:500; }
        .white h2,.white h3 { color:#FFF;}
        h1 a,h2 a,h3 a,h4 a,h5 a {  }

        small { font-size:.75rem; }
        .bold { font-weight:bold;}
        
        .ls0   { letter-spacing: 0; }
        .ls01  { letter-spacing: .1em; }
        .ls015  { letter-spacing: .15em; }
        .ls02  { letter-spacing: .2em; }
        .ls03  { letter-spacing: .3em; }
        .ls05  { letter-spacing: .5em; }
        
        .op10  { opacity: .1 ; }
        .op30  { opacity: .3 ; }
        .op50  { opacity: .5 ; }
        .op75  { opacity: .75 ; }
        .op80  { opacity: .8 ; }
        
        .normal { font-weight:400 !important; }
        .float-l { float:left; }
        .float-r { float:right; }
        .margin-auto { margin-left:auto; margin-right:auto; }
        .bottom-none    { padding-bottom:0 !important;}
        
        .left-center    { text-align:left;}
        @media screen and (max-width: 1350px) {
        html,body, .wrapper	{  }
        }
        @media screen and (max-width: 1024px) {
        html,body, .wrapper	{ font-size:15px; line-height: 190%;}
        h1,h2,h3,h4,h5      { line-height: 180%; }
        .outer-l	       { padding-left:2.5rem; padding-right:2.5rem; }
        .outer			   { padding-left:30px; padding-right:30px; }
        .outer-thin	       { padding-left:.75rem; padding-right:.75rem; }
        .tablet-outer-thin { padding-left:.75rem; padding-right:.75rem; }

        .inner-wrap    { padding:1rem 3% 0; }
        .inner-wrap-s  { padding:1rem 0; }
        .inner-outer   { padding-left:18px; padding-right:18px; }
        .inner-wrap.inner-tablet-none { padding:0; }
        
        .section-ll	       { padding-top:18rem; padding-bottom:18rem; }
        .section-l	       { padding-top:14rem; padding-bottom:14rem; }
        .section	       { padding-top:11rem; padding-bottom:11rem; }
        .section-m	       { padding-top:7rem; padding-bottom:7rem; }
        .section-s	       { padding-top:5rem; padding-bottom:5rem; }
        .section-ss	       { padding-top:3rem; padding-bottom:3rem; }
        .section-sss       { padding-top:2rem; padding-bottom:2rem; }
        .tab-bottom-none    { padding-bottom:0 !important;}
        
        .left-center-tab    { text-align:center;}
        .tablet-center      { margin-left: auto; margin-right: auto; text-align: center; }
        }
        @media only screen and (max-width: 767px) {
        html,body, .wrapper	{ font-size:15px; letter-spacing: 0; line-height: 180%;}
        body			{ -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%;}
        h1,h2,h3,h4,h5      { line-height: 160%; }
        
        .section-ll	    { padding-top:13rem; padding-bottom:13rem; }
        .section-l	    { padding-top:9.5rem; padding-bottom:9.5rem; }
        .section	    { padding-top:9rem; padding-bottom:9rem; }
        .section-m	    { padding-top:6.5rem; padding-bottom:6.5rem; }
        .section-s	    { padding-top:5rem; padding-bottom:5rem; }
        .section-ss	    { padding-top:3.5rem; padding-bottom:3.5rem; }
        .section-sss    { padding-top:2.5rem; padding-bottom:2.5rem; }
        .sp-bottom-none    { padding-bottom:0 !important;}

        .outer-l	    { padding-left:24px; padding-right:24px; }
        .outer			{ padding-left:7.5vw; padding-right:7.5vw; }
        .outer-thin	    { padding-left:10px; padding-right:10px; }
        .tablet-outer-thin	       { padding-left:7px; padding-right:7px; }
        
        .sp-outer      { padding-left:27px; padding-right:27px; box-sizing: border-box; }
        
        .outer-thin .outer-thin	    { padding-left:14px; padding-right:14px; }
        .outer-left		{ padding-left:24px; }
        
        .outer.sp-outer-none      { padding-left:0; padding-right:0; }
        
        .inner-wrap    { padding:1rem 1rem 1.5rem; }
        .inner-wrap-s  { padding:1rem; }
        .inner-wrap-tablet    { padding:21px 0 0; }
        .box-inner     { padding: 1rem; }

        .inner-outer   { padding-left:12px; padding-right:12px; }
        .inner-outer-s   { padding-left:12px; padding-right:12px; }
        .inner-outer-sp   { padding-left:12px; padding-right:12px; box-sizing: border-box; }
        .outer-thin .inner-outer   { padding-left:12px; padding-right:12px; }
        
        .sp-center     { text-align: center !important; }
        .sp-margin-auto     { margin-left:auto; margin-right:auto; }
        .float-r.sp-center { float:none; margin-left: auto; margin-right:auto; }
        .float-l.sp-center { float:none; padding:0 0 5px;  }
        .center-left    { text-align:left;}
        .left-center    { text-align:center;}
        .margin-auto-sp { margin-left:auto; margin-right:auto; }
        }
        @media only screen and (max-width:374px) {
        html,body, .wrapper	{ font-size:14px; }
        }

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

       Link

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

a {
        text-decoration:none;
        color:#2E3033;
        cursor:pointer;
        opacity: 1;
        -webkit-transition: all .3s ease;
        transition: all .3s ease;
        }
        a:hover {
        opacity: .7;
        }
        .news-item-box a:hover {
        opacity: 1;
        }
        a.hover100:hover,a.hover100:hover img {
        opacity: 1;
        }
        a img {
        -webkit-transition: all .3s ease;
        transition: all .3s ease;
        }
        a:hover img {
        opacity:0.7;
        filter: alpha(opacity=70);
        -ms-filter: "alpha( opacity=70 )";
        }

.mobile-link-b a {
        color:#2E3033;
        display: inline-block;
        }
        .mobile-link-w a {
        color:#FFF;
        display: inline-block;
        }

        .link { padding-bottom:.125rem ; border-bottom:1px solid #2E3033;  font-weight: 500; color:#2E3033; }
        .link:hover { border-bottom:1px solid #555; color:#555; }
        .bg-light .link { padding-bottom:.125rem ; border-bottom:1px solid #333; color:#333;}
        .bg-light .link:hover { border-bottom:1px solid #666; color:#666; }

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

       ボタン

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

.more {
        position:relative;
        width:100%;
        max-width:300px;
        height:52px;
        }
        .more a {
        width:100%;
        height:52px;
        line-height:52px;
        text-align: center;
        border-radius:0px;
        box-sizing: border-box;
        background: #FFF;
        color:#222;
        overflow: hidden;
        font-weight:600;
        font-size:1rem;
        white-space: nowrap;
        text-decoration:none !important;
        position: relative;
        z-index: 1;
        letter-spacing: 0em;
        display: inline-block;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more.center a { text-align: center; padding-left:0; }
        .more a:after {
        position: absolute;
        content: "";
        width: 0;
        height:100%;
        bottom:0;
        right: 0;
        z-index: -1;
        border-radius:0;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        background:#B4A56C;
        }      
        .more a:hover {
        opacity:1;
        color:#FFF;
        }
        .more a:hover:after {
        left: 0;
        width: 100%;
        }
        .more.w100p { max-width:100%; }

        @media only screen and (max-width:1024px) {
        .more { height:52px; }
        .more a { height:52px; line-height:50px; }
        }
        @media only screen and (max-width:767px) {
        .more { height:48px; }
        .more a { height:48px; line-height:46px; }
        }





.more-link {
        position:relative;
        width:100%;
        max-width:210px;
        height:46px;
        }
        .more-link  a {
        width:100%;
        height:46px;
        line-height:44px;
        text-align: center;
        border-radius:5px;
        background:rgba(255,255,255,.85);
        border:1px solid rgba(0,0,0,.6);
        box-sizing: border-box;
        color:#222;
        overflow: hidden;
        font-weight:400;
        font-size:1rem;
        white-space: nowrap;
        text-decoration:none !important;
        position: relative;
        z-index: 1;
        letter-spacing: 0em;
        display: inline-block;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more-link  a:after {
        position: absolute;
        content: "";
        width: 0;
        height:100%;
        bottom:0;
        right: 0;
        z-index: -1;
        border-radius:0;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        background:rgba(42,62,83,.8);
        }      
        .more-link  a:hover {
        opacity:1;
        color:#FFF;
        }
        .more-link  a:hover:after {
        left: 0;
        width: 100%;
        }



.more-under {
        position: relative;
        display: inline-block;
        text-align: left;
        }
        .more-under a {
        display:inline-block;
        padding:.5rem 0;
        line-height: 100%;
        color:#363531;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        }
        .more-under a:before {
        content:"";
        display: inline-block;
        position: absolute;
        bottom:0;
        left:0;
        width:100%;
        height:1px;
        background:#363531;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        }
        .more-under a:after {
        content:"";
        display: inline-block;
        position: absolute;
        bottom:0;
        left:0;
        width:0;
        height:2px;
        background:#363531;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        }
        .more-under a:hover:after {
        width:100%;
        }
        

        @media only screen and (max-width:1024px) {
        .more-bar a { padding-right:3rem; }
        .more-bar a:hover { padding-right:3rem; }
        }
        @media only screen and (max-width:767px) {
        .more-under { text-align: center; }
        }

.more-tab {
        position:relative;
        width:100%;
        height:80px;
        }
        .more-tab a {
        width:100%;
        height:80px;
        line-height:140%;
        padding-top:18px;
        text-align: center;
        border-radius: 0px;
        background:#2E3033;
        box-sizing: border-box;
        color:#FFF;
        overflow: hidden;
        font-weight:400;
        font-size:1rem;
        white-space: nowrap;
        text-decoration:none !important;
        position: relative;
        z-index: 1;
        letter-spacing: 0.05em;
        display: inline-block;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more-tab a:after {
        position: absolute;
        content: "";
        width: 0;
        height:100%;
        bottom:0;
        right: 0;
        z-index: -1;
        border-radius:0;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        background:rgba(255,255,255,.3);
        }      
        .more-tab a:hover {
        opacity:1;
        color:#FFF;
        }
        .more-tab a:hover:after {
        left: 0;
        width: 100%;
        }
        @media only screen and (max-width:374px) {
        .more-tab { height:73px; }
        .more-tab a { height:73px; }
        }



.more-arrow { width:185px; }
.more-arrow a {
        position: relative;
        display:inline-block;
        padding: 0;
        }
        .more-arrow a:after {
        content:"→";
        display:inline-block;
        position: absolute;
        top:0%;
        padding-left:1rem;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more-arrow a:hover:after {
        padding-left:2rem;
        }


.more-sns {
        position:relative;
        width:100%;
        height:120px;
        overflow: hidden;
        }
        .more-sns a {
        width:100%;
        height:120px;
        line-height:83px;
        text-align: center;
        border-radius:0px;
        box-sizing: border-box;
        background:#151614;
        color:#FFF;
        overflow: hidden;
        white-space: nowrap;
        text-decoration:none !important;
        position: relative;
        z-index: 1;
        letter-spacing: 0em;
        display: inline-block;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more-sns a:after {
        position: absolute;
        content: "";
        width: 0;
        height:100%;
        bottom:0;
        right: 0;
        z-index: -1;
        border-radius:0;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        background:rgba(255,255,255,.2);
        }      
        .more-sns a:hover {
        opacity:1;
        }
        .more-sns a:hover:after {
        left: 0;
        width: 100%;
        }
        .more-sns a img { height:45px; width:auto; }
        .more-sns.more-instagram a { background:#26430A; }

        @media only screen and (max-width:1350px) {
        .more-sns { height:100px; }
        .more-sns a { height:100px; line-height:72px; }
        .more-sns a img { height:42px; }
        }
        @media only screen and (max-width:1024px) {
        .more-sns { height:70px; }
        .more-sns a { height:70px; line-height:53px; }
        .more-sns a img { height:35px; }
        }
        @media only screen and (max-width:767px) {
        .more-sns { height:58px; }
        .more-sns a { height:58px; line-height:45px; text-align: left; padding-left:50%; }
        .more-sns a img { height:30px; margin-left:-74px; }

        }

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

       table

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

.table-a {
        width:100%;
        border-collapse:collapse;
        border-spacing:0;
        text-align:left;
        letter-spacing:0;
        box-sizing: border-box;
        line-height: 170%;
        font-size:1rem;
        font-weight:500;
        border-top:1px solid rgba(0,0,0,.2);
        }
        .table-a.top-none { border-top:none; }
        .table-a tr { border-bottom:1px solid rgba(0,0,0,.2);}
        .table-a th {
        padding:.5rem .75rem .5rem 0;
        vertical-align: middle;
        font-weight:700;
        text-align:left;
        }
        .table-a td {
        position: relative;
        padding:.5rem 0 .5rem 0;
        font-weight:400;
        vertical-align: middle;
        text-align:left;
        }
        .table-a.th-center th { text-align: center;}
        .table-a.td-right td { text-align: right;}
        .table-a.th-right th { text-align: right;}
        .table-a.center td,.table-a.center th { text-align: center;}


.table-b {
        width:100%;
        border-collapse:separate;
        border-spacing:2px;
        text-align:left;
        letter-spacing:0;
        box-sizing: border-box;
        line-height: 170%;
        font-size:1rem;
        border: 1px solid rgba(0,0,0,.2);
        }
        .table-b th {
        padding:.55rem 1.25rem .55rem 1.25rem;
        vertical-align: middle;
        font-weight:500;
        text-align:left;
        background:#2A3E53;
        color:#FFF;
        }
        .table-b td {
        padding:.55rem 1.25rem .55rem 1.25rem;
        text-align:left;
        vertical-align: middle;
        background:rgba(42,62,83,.06);
        border: 1px solid rgba(0,0,0,.2);
        }

        .bg-dark .table-b th { background: rgba(217,208,198,.25); }
        .bg-dark .table-b td { background: rgba(217,208,198,.1); }

        .table-b th.center { text-align:center;}
        .table-b.td-right td { text-align: right;}
        .table-b.th-right th { text-align: right;}
        .table-b.th-center th { text-align: center;}
        .table-b th.right { text-align: right;}
        .table-b.center td,.table-b.center th { text-align: center;}


.table-menu {
        width:100%;
        border-collapse:collapse;
        border-spacing:0;
        text-align:left;
        letter-spacing:0;
        box-sizing: border-box;
        line-height: 170%;
        font-size:1rem;
        border-top:1px solid rgba(0,0,0,.2);
        }
        .table-menu tr { border-bottom:1px solid rgba(0,0,0,.2); }
        .table-menu th {
        padding:.55rem 1.25rem .55rem 0;
        vertical-align: middle;
        font-weight:600;
        text-align:left;
        }
        .table-menu td {
        padding:.55rem 0 .55rem 1.25rem;
        text-align:right;
        box-sizing: border-box;
        vertical-align: middle;
        }

        .table-scroll { overflow: inherit !important; }

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

        .table-scroll.is-tablet { overflow: auto !important; white-space: nowrap; }
        .table-scroll.is-tablet table { margin-bottom:6px; }
        .table-scroll.is-tablet ::-webkit-scrollbar { height: 5px; }
        .table-scroll.is-tablet ::-webkit-scrollbar-track { background: #F1F1F1; }
        .table-scroll.is-tablet ::-webkit-scrollbar-thumb { background: #BCBCBC; }
        }
        @media screen and (max-width: 767px) {
        .table-a.sp-top-none { border-top:none; }
        .table-a.sp-table { border:none; }
        .table-a.sp-table td:after { display: none; }
        .table-a.sp-table th { width:100% !important; display: block !important; padding:.5em 0 .25rem; box-sizing: border-box; text-align: left; border-top:none; border-bottom:2px solid rgba(0,0,0,.7); background: none; font-weight:500; }
        .table-a.sp-table.sp-dotted th { border-bottom:1px dotted rgba(0,0,0,.7); }
        
        .table-a.sp-table td { width:100% !important; display: block !important; padding:.5em 0 ; box-sizing: border-box;  }
        .table-a.sp-table tr { display: block; padding-bottom:1rem; border:none;}
        .table-a.sp-table tr:last-child { padding-bottom:0rem;}
        .table-a.sp-table td:nth-of-type(2) { border-top:none;}
        
        .table-b { }
        .table-b th { padding:.5rem 1rem ;  }
        .table-b td { padding:.5rem 1rem; }
        
        .table-b.sp-table { border:none; }
        .table-b.sp-table th { width:100% !important; display: block !important; padding:.55em 1em; box-sizing: border-box; text-align: left; border-bottom: none; }
        .table-b.sp-table td { width:100% !important; display: block !important; padding:.55em 1em ; box-sizing: border-box;   }
        .table-b.sp-table tr { display: block; padding-bottom:1rem;}
        .table-b.sp-table tr:last-child { padding-bottom:0rem;}
        .table-b.sp-table td:nth-of-type(2) { border-top:none;}
        .table-b.sp-td-right td { text-align: right; } 
        
        .table-b.sp-table .table th { padding:.25rem 0; border-bottom:1px solid #777;}
        .table-b.sp-table .table td { padding:.25rem 0;}

        .table-menu.sp-top-none { border-top:none; }

        .table-scroll.is-mobile { overflow: auto hidden !important; white-space: nowrap; min-height: 80px; }
        .table-scroll.is-mobile table { margin-bottom:6px; }
        .table-scroll.is-mobile ::-webkit-scrollbar { height: 5px; }
        .table-scroll.is-mobile ::-webkit-scrollbar-track { background: #F1F1F1; }
        .table-scroll.is-mobile ::-webkit-scrollbar-thumb { background: #BCBCBC; }
        }


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

       アイコン

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

.icon-before {
        width:1.5rem;
        height:1.5rem;
        display:inline-block;
        margin-right:.65rem;
        position: relative;
        top: .25rem;
        }
        .icon-before-m {
        width:1.35rem;
        height:1.35rem;
        display:inline-block;
        margin-right:.5rem;
        position: relative;
        top: .25rem;
        }
        .icon-before-s {
        width:1.15rem;
        height:1.15rem;
        display:inline-block;
        margin-right:.5rem;
        position: relative;
        top: .125rem;
        }
.icon-after {
        width:1.2rem;
        height:1.2rem;
        display:inline-block;
        margin-left:1rem;
        position: relative;
        top: .125rem;
        }
        .icon-after-s {
        width:1rem;
        height:1rem;
        display:inline-block;
        margin-left:.5rem;
        position: relative;
        top: .125rem;
        }

        .icon-question     { background: url("../images/icons/icon-question.svg") center center / cover; }
        .icon-cart     { background: url("../images/parts/icon-cart.svg") center center / cover; }
        .icon-map      { background: url("../images/icons/icon-map.svg") center center / cover; }
        .icon-air      { background: url("../images/icons/icon-air.svg") center center / cover; }
        .icon-bus      { background: url("../images/icons/icon-bus.svg") center center / cover; }
        .icon-car      { background: url("../images/icons/icon-car.svg") center center / cover; }
        .icon-car-w    { background: url("../images/icons/icon-car-w.svg") center center / cover; }
        .icon-hito      { background: url("../images/icons/icon-hito.svg") center center / cover; }
        .icon-pdf      { background: url("../images/icons/icon-pdf.svg") center center / cover; }
        .icon-check    { background: url("../images/icons/icon-check.svg") center center / cover; }
        .icon-train    { background: url("../images/icons/icon-train.svg") center center / cover; }
        .icon-train-w  { background: url("../images/icons/icon-train-w.svg") center center / cover; }
        .icon-link     { background: url("../images/icons/icon-link.svg") center center / cover; }
        .icon-link-b   { background: url("../images/icons/icon-link-b.svg") center center / cover; }
        .icon-link-blue  { background: url("../images/icons/icon-link-blue.svg") center center / cover; }
        .icon-link-w   { background: url("../images/icons/icon-link-w.svg") center center / cover; }
        .icon-link-chain     { background: url("../images/icons/icon-link-chain.svg") center center / cover; }
        .icon-link-chain-w     { background: url("../images/icons/icon-link-chain-w.svg") center center / cover; }
        .icon-calendar     { background: url("../images/parts/icon-calendar.svg") center center / cover; }

/*================================================
      　calendar
================================================*/

        .g-calendar iframe {
        width: 100%;
        height: 550px;
        }
        @media all and (max-width: 767px) {
        .g-calendar iframe { height: 450px; }
        }

/*================================================
      　form
================================================*/

        @media screen and (max-width: 767px) {
        .input, .textarea { font-size:16px !important;}
        }

/*================================================
      　access
================================================*/

.access-logo { width:200px; padding-bottom:.5rem}

        @media screen and (max-width: 1024px) {
        .access-logo { width:200px; }
        }
        @media screen and (max-width: 767px) {
        .access-logo { width:190px; margin-left:auto; margin-right:auto; }
        }

.access-text span {
        text-indent: 0;
        display: inline-block;
        padding: 5px 12px;
        margin: 2px 5px 4px;
        line-height: 150%;
        letter-spacing: 0;
        background: rgba(255,255,255,.5);
        border: 1px solid rgba(0,0,0,.1);
        border-radius:2px;
        }
        .access-text span:last-child { background:#0F360F; color:#FFF; border:none; }

/*================================================
      　map
================================================*/

    .map {
        position: relative;
        padding-bottom: 550px;
        height: 0;
        overflow: hidden;
        box-sizing: border-box;
        border: 1px solid #BFBFBF;
        border-radius: 0px;
        z-index: 2;
        }
        .map iframe,
        .map object,
        .map embed {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        }
    .street-view {
        position: relative;
        padding-bottom: 360px;
        height: 0;
        overflow: hidden;
        box-sizing: border-box;
        border: 1px solid #CCC;
        z-index: 20;
        }
        .street-view.large { padding-bottom:62%; }
        .street-view iframe,
        .street-view object,
        .street-view embed {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        }
        @media screen and (max-width: 1024px) {
        .map { padding-bottom: 450px; border: 1px solid #BFBFBF; border-radius: 0px; }
        .map-s { padding-bottom: 350px; }
        }
        @media screen and (max-width: 767px) {
        .map { padding-bottom: 90%; border: 1px solid #BFBFBF; border-radius: 0px; }
        .map-s { padding-bottom: 70%;  }
        .street-view { padding-bottom:60%;}
        }

/*=================================================
        Facebook Resize
==================================================*/

        .facebook-wrapper {
        max-width: 600px;
        margin: 0 auto;
        }
        .facebook-wrapper > .fb-page {
        width: 100%;
        }
        .facebook-wrapper > .fb-page > span,
        .facebook-wrapper iframe {
        width: 100% !important;
        }

/*================================================
      　youtube
================================================*/

.youtube {
        position: relative;
        padding-bottom: 56.25%;
        height: 0;
        overflow: hidden;
        box-sizing: border-box;
        }
        .youtube iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        }


/*================================================
      　list
================================================*/

.nomber-list {
        padding-left:1.5rem;
        }
        .nomber-list > li {
        padding: 0 0 .5em 0;
        position: relative;
        line-height: 160%;
        list-style-type: decimal;
        }
        .nomber-list li ol { padding-top:.5rem;}
        
        .nomber-list .nomber-list { padding-top:.5em; padding-bottom:1em;}
        .nomber-list .nomber-list li { list-style-type: lower-roman ;}
        .nomber-list .nomber-list .nomber-list li { list-style-type: katakana-iroha ; }
        
        .nomber-list li:last-child { padding-bottom:0; }
        .nomber-list .nomber-list { padding-bottom:0; }
        .nomber-list .nomber-list .nomber-list { padding-bottom:0; }
        
.kana-list {
        padding-left: 1.5rem;
        }
        .kana-list li {
        padding:0 0 .5rem 0;
        position:relative;
        line-height: 160%;
        list-style-type: katakana;
        }
        
        
        
.normal-list { position: relative; line-height: 175%;}
        .normal-list li {
        padding: 0 0 0 .75rem ;
        position: relative;
        display:inline-block;
        margin-right:1rem;
        }
        .normal-list li:before {
        content: "・";
        display:block;
        position: absolute;
        left: 0;
        font-size:1rem;
        vertical-align: middle;
        }
.maru-list {
        position: relative;
        line-height: 175%;
        border-top:2px dotted #707070;
        }
        .maru-list li {
        padding: .65em 0 .65em 1rem ;
        position: relative;
        margin-right:1rem;
        border-bottom:2px dotted #707070;
        }
        .maru-list li:before {
        content: "●";
        display:inline-block;
        position: absolute;
        left: 0;
        font-size:10px;
        vertical-align: middle;
        }
.check-list {
        position: relative;
        line-height: 175%;
        }
        .check-list li {
        padding: .65em 0 .65em 1.5rem ;
        position: relative;
        line-height: 125%;
        margin-right:1rem;
        border-top:2px dotted rgba(0,0,0,.3);
        }
        .check-list li:last-child { border-bottom:2px dotted rgba(0,0,0,.3); }
        .check-list li:before {
        content: "";
        display:inline-block;
        position: absolute;
        left: 0;
        top:50%;
        transform: translateY(-50%);
        background: url("../images/parts/icon-check.svg") center center / cover;
        width:20px;
        height:20px;
        vertical-align: middle;
        }
        @media screen and (max-width: 1024px) {
        .check-list li:before { width:18px; height:18px; }
        }
        @media screen and (max-width: 767px) {
        .check-list li:before { width:16px; height:16px; }
        }

.link-list {
        position: relative;
        line-height: 175%;
        }
        .link-list li {
        padding: 0 0 0 1.5rem ;
        position: relative;
        line-height: 150%;
        }
        .link-list li:before {
        content: "";
        display:inline-block;
        position: absolute;
        left: 0;
        top:.35rem;
        line-height: 150%;
        background: url("../images/parts/arrow.svg") center center / cover;
        width:13px;
        height:13px;
        }
        @media screen and (max-width: 1024px) {
        .link-list li:before { width:12px; height:12px; }
        }
        @media screen and (max-width: 767px) {
        .link-list li:before { width:11px; height:11px; }
        }

.list {
        border-top:1px dotted rgba(0,0,0,.5);
        }
        .list li {
        padding: .5rem 0 .5rem 0;
        box-sizing: border-box;
        position: relative;
        border-bottom:1px dotted rgba(0,0,0,.5);
        }
        
.kome-list {
        }
        .kome-list li {
        padding: 0;
        position: relative;
        padding-left:1.25em;
        }
        .kome-list li:before {
        content: "※";
        display:block;
        position: absolute;
        top: 0;
        left: 0;
        font-size:1em;
        vertical-align: middle;
        }

.disk-list {
        }
        .disk-list li {
        padding-left:1rem ;
        position: relative;
        }
        .disk-list li:before {
        content: "・";
        display:block;
        position: absolute;
        top:0;
        left: 0;
        font-size:1rem;
        vertical-align: middle;
        }
        .disk-list.large li:before { top:.5em; }
        .kome-list .disk-list li:before {content: "・"; }

        @media screen and (max-width: 767px) {
        .disk-list li { margin-bottom:.5em; }
        }

        .kome-list.center-left li {
        display:inline-block;
        }

.foodmenu-list {
        position: relative;
        line-height: 175%;
        word-break: keep-all;
        }
        .foodmenu-list li {
        position: relative;
        display:inline-block;
        margin-right:1rem;
        }


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

       padding margin 設定

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

        .pt-05em	{ padding-top:.5rem;}
        .pt-1em		{ padding-top:1rem;}
        .pt-1hem	{ padding-top:1.5rem;}
        .pt-1h-1    { padding-top:1.5rem;}
        .pt-2em		{ padding-top:2rem;}
        .pt-3em		{ padding-top:3rem;}
        .pt-4em		{ padding-top:4rem;}
        .pt-5em		{ padding-top:5rem;}
        .pt-1-0		{ padding-top:1rem;}
        .pt-1-05		{ padding-top:1rem;}
        .pt-2-0		{ padding-top:2rem;}
        .pt-2-1h	{ padding-top:2rem;}
        .pt-2-1		{ padding-top:2rem;}
        .pt-3-2		{ padding-top:3rem;}
        .pt-3-3-0	{ padding-top:3rem;}


        .pb-05em	{ padding-bottom:.5rem;}
        .pb-1em		{ padding-bottom:1rem;}
        .pb-1hem	{ padding-bottom:1.5rem;}
        .pb-2em		{ padding-bottom:2rem;}
        .pb-2hem	{ padding-bottom:2.5rem;}
        .pb-3em		{ padding-bottom:3rem;}
        .pb-4em		{ padding-bottom:4rem;}
        .pb-5em		{ padding-bottom:5rem;}
        .pb-6em		{ padding-bottom:6rem;}
        .pb-10em	{ padding-bottom:10rem;}
        .pb-1-0  	{ padding-bottom:1rem;}
        .pb-1-05	{ padding-bottom:1rem;}
        .pb-1h-0  	{ padding-bottom:1.5rem;}
        .pb-1h-1  	{ padding-bottom:1.5rem;}
        .pb-2-0		{ padding-bottom:2rem;}
        .pb-2-05	{ padding-bottom:2rem;}
        .pb-2-1		{ padding-bottom:2rem;}
        .pb-2-1h	{ padding-bottom:2rem;}
        .pb-2h-1	{ padding-bottom:2.5rem;}
        .pb-2h-1h	{ padding-bottom:2.5rem;}
        .pb-2h-2	{ padding-bottom:2.5rem;}
        .pb-220	    { padding-bottom:2rem;}
        .pb-221	    { padding-bottom:2rem;}
        .pb-3-1		{ padding-bottom:3rem;}
        .pb-3-1h	{ padding-bottom:3rem;}
        .pb-3-2		{ padding-bottom:3rem;}
        .pb-3-4		{ padding-bottom:3rem;}
        .pb-4-0		{ padding-bottom:4rem;}
        .pb-4-2		{ padding-bottom:4rem;}
        .pb-4-3		{ padding-bottom:4rem;}
        .pb-5-2		{ padding-bottom:5rem;}
        .pb-5-3		{ padding-bottom:5rem;}
        .pb-5-4		{ padding-bottom:5rem;}
        .pb-6-2		{ padding-bottom:6rem;}
        .pb-880		{ padding-bottom:8rem;}
        .pb-1px     { padding-bottom:1px;}
        .pb-10px    { padding-bottom:10px;}

        .pl-05em     { padding-left:.5rem; }
        .pl-1em     { padding-left:1rem; }
        .pl-1hem     { padding-left:1.5rem; }
        .pl-2em     { padding-left:2rem; }
        .pl-2-0     { padding-left:2rem; }
        
        .ml-1hem     { margin-left:1.5rem; }
        
        .pr-05em     { padding-right:.5rem; }

        .mt-05em		{ margin-top:.5rem;}
        .mt-1em		{ margin-top:1rem;}
        .mt-2em		{ margin-top:2rem;}
        .mt-3em		{ margin-top:3rem;}
        .mt-4em		{ margin-top:4rem;}
        .mt-5em		{ margin-top:5rem;}
        .mt-10em	{ margin-top:10rem;}
        .mt-4-2		{ margin-top:4rem;}
        .mt-10-5	{ margin-top:10rem;}
        
        .mt-3-0     { margin-top:3rem; }

        .mb-05em	{ margin-bottom:.5rem;}
        .mb-1em		{ margin-bottom:1rem;}
        .mb-1hem	{ margin-bottom:1.5rem;}
        .mb-2em		{ margin-bottom:2rem;}
        .mb-3em		{ margin-bottom:3rem;}
        .mb-4em		{ margin-bottom:4rem;}
        .mb-5em		{ margin-bottom:5rem;}
        .mb-6em		{ margin-bottom:6rem;}
        .mb-7em		{ margin-bottom:7rem;}
        .mb-8em		{ margin-bottom:8rem;}
        .mb-1-0		{ margin-bottom:1rem;}
        .mb-1-05		{ margin-bottom:1rem;}
        .mb-1h-1	{ margin-bottom:1.5rem;}
        .mb-2-0		{ margin-bottom:2rem;}
        .mb-2-1		{ margin-bottom:2rem;}
        .mb-2-1h	{ margin-bottom:2rem;}
        .mb-2h-2	{ margin-bottom:2.5rem;}
        .mb-3-0		{ margin-bottom:3rem;}
        .mb-3-1		{ margin-bottom:3rem;}
        .mb-3-2		{ margin-bottom:3rem;}
        .mb-3-4		{ margin-bottom:3rem;}
        .mb-4-2		{ margin-bottom:4rem;}
        .mb-543		{ margin-bottom:5rem;}
        .mb-6-4		{ margin-bottom:6rem;}
        .mb-1-1-05		{ margin-bottom:1rem;}
        .mb-2-2-1		{ margin-bottom:2rem;}

        .mr-1em     { margin-right: 1rem ; }
        .mr-2em     { margin-right: 2rem ; }

        @media only screen and (max-width: 1024px) {
        .pt-1-0		{ padding-top:.5rem;}
        .pt-2-1		{ padding-top:1rem;}
        .pt-3-2		{ padding-top:2rem;}
        .pt-3-3-0	{ padding-top:3rem;}
        .tab-pt-1em	{ padding-top:1rem;}

        .pb-1-0		{ padding-bottom:.5rem;}
        .pb-1-05	{ padding-bottom:.5rem;}
        .pb-1h-1  	{ padding-bottom:1rem;}
        .pb-2-0		{ padding-bottom:0rem;}
        .pb-2-1		{ padding-bottom:1rem;}
        .pb-2h-1	{ padding-bottom:1.5rem;}
        .pb-2h-1h	{ padding-bottom:2rem;}
        .pb-2h-2	{ padding-bottom:2.25rem;}
        .pb-220	    { padding-bottom:2rem;}
        .pb-3-1		{ padding-bottom:2rem;}
        .pb-3-1h	{ padding-bottom:2rem;}
        .pb-3-2		{ padding-bottom:2rem;}
        .pb-3-4		{ padding-bottom:4rem;}
        .pb-4-2		{ padding-bottom:3rem;}
        .pb-4-3		{ padding-bottom:3rem;}
        .pb-5-2		{ padding-bottom:2rem;}
        .pb-5-3		{ padding-bottom:4rem;}
        .pb-4-0		{ padding-bottom:3rem;}
        .pb-6-2		{ padding-bottom:4rem;}

        .mt10p      { margin-top:0%; }

        .mb-1-0		{ margin-bottom:0rem;}
        .mb-2-0		{ margin-bottom:0rem;}
        .mb-2-1		{ margin-bottom:1rem;}
        .mb-2h-2	{ margin-bottom:2.25rem;}
        .mb-3-1		{ margin-bottom:2rem;}
        .mb-3-2		{ margin-bottom:2rem;}
        .mb-3-4		{ margin-bottom:4rem;}
        .mb-4-2		{ margin-bottom:2rem;}
        .mb-543		{ margin-bottom:4rem;}
        .mb-6-4		{ margin-bottom:5rem;}
        .mb-1-1-05		{ margin-bottom:1rem;}
        .mb-2-2-1		{ margin-bottom:2rem;}
        
        .tablet-pt-1hem { padding-top:1.5rem; }
        }

        @media only screen and (max-width: 767px) {
        .pt-1-0		{ padding-top:0rem;}
        .pt-1-05		{ padding-top:.5rem;}
        .pt-1h-1    { padding-top:1rem;}
        .pt-2-0		{ padding-top:0rem;}
        .pt-2-1h	{ padding-top:1.5rem;}
        .pt-3-3-0	{ padding-top:0rem;}
        .sp-pt-1em	{ padding-top:1rem;}

        .pb-1-0		{ padding-bottom:0rem;}
        .pb-1h-0  	{ padding-bottom:0rem;}
        .pb-2-05	{ padding-bottom:.5rem;}
        .pb-2h-1	{ padding-bottom:1rem;}
        .pb-2-1h	{ padding-bottom:1.5rem;}
        .pb-2h-1h	{ padding-bottom:1.5rem;}
        .pb-2h-2	{ padding-bottom:2rem;}
        .pb-3-1h	{ padding-bottom:1.5rem;}
        .pb-4-0		{ padding-bottom:0rem;}
        .pb-4-2		{ padding-bottom:2rem;}
        .pb-5-3		{ padding-bottom:3rem;}
        .pb-5-4		{ padding-bottom:4rem;}
        .pb-3-1		{ padding-bottom:1rem;}
        .pb-220 	{ padding-bottom:0rem;}
        .pb-221	    { padding-bottom:1rem;}
        .pb-6-2		{ padding-bottom:2rem;}
        .pb-880		{ padding-bottom:0rem;}
        
        .pl-2-0     { padding-left:0rem; }
        
        .sp-pb-1em  { padding-bottom:1rem; }
        .sp-pb-2em  { padding-bottom:2rem; }

        .mt-4-2		{ margin-top:2rem;}
        .mt-10-5	{ margin-top:4rem;}

        .mr10p      { margin-right:0%;}
        .mr20p      { margin-right:0;}
        .ml10p      { margin-left:0%;}
        .ml20p      { margin-left:0%;}

        .mb-1-05		{ margin-bottom:.5rem;}
        .mb-1h-1	{ margin-bottom:1rem;}
        .mb-3-0		{ margin-bottom:0rem;}
        .mb-3-1		{ margin-bottom:1rem;}
        .mb-2-1h	{ margin-bottom:1.5rem;}
        .mb-2h-2	{ margin-bottom:2rem;}
        .mb-543		{ margin-bottom:3rem;}
        .mb-6-4		{ margin-bottom:4rem;}
        
        .mt-3-0     { margin-top:0rem; }
        .sp-pl-none { padding-left:0;}
        }

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

       Width ( wrap + wrap-1200 )

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

        .wrap       { width:100%; margin-left:auto; margin-right:auto; position: relative; z-index:0; }

        .wrap-2400  { max-width:2400px; }
        .wrap-2000  { max-width:2000px; }
        .wrap-1900  { max-width:1900px; }
        .wrap-1800  { max-width:1800px; }
        .wrap-1700  { max-width:1700px; }
        .wrap-1600  { max-width:1600px; }
        .wrap-1500  { max-width:1500px; }
        .wrap-1460  { max-width:1460px; }
        .wrap-1400  { max-width:1400px; }
        .wrap-1300  { max-width:1300px; }
        .wrap-1260  { max-width:1260px; }
        .wrap-1200  { max-width:1200px; }
        .wrap-1120  { max-width:1120px; }
        .wrap-1100  { max-width:1100px; }
        .wrap-1050  { max-width:1050px; }
        .wrap-1000  { max-width:1000px; }
        .wrap-960   { max-width: 960px; }
        .wrap-900   { max-width: 900px; }
        .wrap-840   { max-width: 840px; }
        .wrap-800   { max-width: 800px; }
        .wrap-750   { max-width: 750px; }
        .wrap-700   { max-width: 700px; }
        .wrap-600   { max-width: 600px; }
        .wrap-600-500   { max-width: 600px; }
        .wrap-500   { max-width: 500px; }
        .wrap-450   { max-width: 450px; }
        .wrap-400   { max-width: 400px; }
        .wrap-300   { max-width: 300px; }

        .max90      { max-width:90px; width:100%;}
        .max170     { max-width:170px; width:100%;}
        .max280     { max-width:280px; width:100%;}
        .max300     { max-width:300px; width:100%;}
        .max320     { max-width:320px; width:100%;}
        .max380     { max-width:380px; width:100%;}
        .max400     { max-width:400px; width:100%;}
        .max420     { max-width:420px; width:100%;}
        .max450     { max-width:450px; width:100%;}
        .max500     { max-width:500px; width:100%;}
        .max550     { max-width:550px; width:100%;}
        .max600     { max-width:600px; width:100%;}
        .max650     { max-width:650px; width:100%;}
        .max700     { max-width:700px; width:100%;}
        .max750     { max-width:750px; width:100%;}
        .max550-widescreen { max-width:550px; width:100%;}
        .max1100     { max-width:1100px; width:100%;}
        .max1800     { max-width:1800px; width:100%;}
        
        .min600 { min-width: 600px; }

        .w2em { width:2em; }
        .w3em { width:3em; }
        .w4em { width:4em; }
        .w5em { width:5em; }
        .w6em { width:6em; }
        .w7em { width:7em; }
        .w8em { width:8em; }
        .w9em { width:9em; }
        .w10em { width:10em; }
        .w11em { width:11em; }
        .w12em { width:12em; }
        .w13em { width:13em; }
        .w14em { width:14em; }

        .w11p { width:11.111111%; }
        .w12p { width:12.5%; }
        .w16p { width:16.666666%; }
        .w20p { width:20%; }
        .w20p-40p { width:20%; }
        .w25p { width:25%; }
        .w30p { width:30%; }
        .w33p { width:33%; }
        .w38p { width:38%; }
        .w50p { width:50%; }
        .w50-70p { width:50%; }

        .h100p { height:100%; }

        @media screen and (max-width: 1215px) {
        .max1000-desktop { max-width:1000px; width:100%;}
        .w50-70p { width:69%; }
        }
        @media screen and (max-width: 1024px) {
        .wrap { max-width:750px; }
        .wrap-700   { max-width: 700px; }
        .wrap-600   { max-width: 600px; }
        .wrap-600-500   { max-width: 500px; }
        .wrap-500   { max-width: 500px; }
        .wrap-450   { max-width: 450px; }
        .wrap-400   { max-width: 400px; }
        .wrap-300   { max-width: 300px; }
        
        .wrap-600-tablet   { max-width: 600px; }
        .w500-tablet { max-width:500px; margin-left:auto; margin-right:auto; }
        }
        @media only screen and (max-width: 767px) {
        .wrap { max-width:375px; }
        .wrap-300   { max-width: 300px; }
        .sp-wauto th.w50p { width: auto; }
        .sp-w9em { width: 9em;}
        .w20p-35p { width:35%; }
        }

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

       Other

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

figcaption {
        font-size:1rem;
        padding:0;
        }
.hidden { overflow: hidden; }
img,.img-auto img {
        max-width: 100%;
        height: auto;
        width /***/:auto;
        vertical-align:bottom;
        }
        .z0 { position: relative; z-index: 0; }
        .z1 { position: relative; z-index: 1; }
        .z2 { position: relative; z-index: 2; }
        .z3 { position: relative; z-index: 3; }
        .z4 { position: relative; z-index: 4; }
        .z5 { position: relative; z-index: 5; }
        .relative { position: relative;}
        
        .hidden { overflow: hidden; }

        .radius,
        .radius video,
        .radius img { border-radius: 10px; }
        .radius-s,
        .radius-s img { border-radius: 6px; }
        @media screen and (max-width: 1024px) {
        .radius,
        .radius video,
        .radius img { border-radius: 7px; }
        .radius-s,
        .radius-s img { border-radius: 5px; }
        }
        @media screen and (max-width: 767px) {
        .radius,
        .radius video,
        .radius img { border-radius: 5px; }
        .radius-s,
        .radius-s img { border-radius: 4px; }
        .sp-radius-none,.sp-radius-none img { border-radius: 0; }
        }
.shadow	{
        -webkit-box-shadow: 0px 3px 6px rgba(0,0,0,.2);
        box-shadow:	        0px 3px 6px rgba(0,0,0,.2);
        }
.shadow-png	{
        -webkit-filter: drop-shadow(0px 3px 6px rgba(0,0,0,.2));
        filter: drop-shadow(0px 3px 6px rgba(0,0,0,.2));
        }

.anchor { padding-top:90px; margin-top:-90px; }

hr.line {
        position: relative;
        border: none;
        padding:0;
        margin: 0 auto;
        height:1px;
        background:#C8C8C8;
        width:100%;
        z-index: 1;
        opacity: .7;
        }

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

      　slick slider

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

.slide-caption {
        position: absolute;
        bottom:0;
        left:0;
        width:100%;
        padding:.75rem 1rem;
        box-sizing: border-box;
        background: rgba(0,0,0,.4);
        color:#FFF;
        text-align: right;
        line-height: 125%;
        z-index: 1;
        }
.slick-wrap {
        position: relative;
        width:100%;
        z-index: 0;
        }
        .slick-wrap.h66p:after {
        content: "";
        display: block;
        padding-bottom:66.666666%;
        }
        .slick-wrap.h55p:after {
        content: "";
        display: block;
        padding-bottom:55%;
        }
        .slick-wrap.h60p:after {
        content: "";
        display: block;
        padding-bottom:60%;
        }
        .slick-wrap.h62p:after {
        content: "";
        display: block;
        padding-bottom:62.857143%;
        }
        .slick-wrap.h133p:after {
        content: "";
        display: block;
        padding-bottom:133.333333%;
        }
        .slick-wrap .slick-inner {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        }
.slick-text {margin-bottom:45px; }
        @media screen and (max-width: 1024px) {
        .slick-text {margin-bottom:35px; }
        }
        @media screen and (max-width: 1024px) {
        .slick-text {margin-bottom:0; }
        }

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

      　flex-slider

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

.flexslider-wrap {
        position: relative;
        width:100%;
        z-index: 0;
        }
        .flexslider-wrap.h36p:after {
        content: "";
        display: block;
        padding-bottom:36%;
        }
        .flexslider-wrap.h66p:after {
        content: "";
        display: block;
        padding-bottom:66.666666%;
        }
        .flexslider-wrap.h60p:after {
        content: "";
        display: block;
        padding-bottom:60%;
        }
        .flexslider-wrap.h55p:after {
        content: "";
        display: block;
        padding-bottom:55%;
        }
        .flexslider-wrap.h80p:after {
        content: "";
        display: block;
        padding-bottom:80%;
        }
        .flexslider-wrap .flexslider {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        }
        .flexslider-tumb-margin {
        margin-bottom:9%; /* 4枚 12% サムネイル幅の比率から調整 */
        }
        @media screen and (max-width: 767px) {
        .flexslider-tumb-margin { margin-bottom:18%; }
        }
        .flex-caption {
        padding: 3px 10px;
        margin: 0;
        color: #fff;
        font-size: .975rem;
        }

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

      　hover_zoom

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

.hover-zoom__image {
        overflow: hidden;
        position: relative;
        width:100%;
        -webkit-transition: all .4s ease;
        -moz-transition: all .4s ease;
        -ms-transition: all .4s ease;
        -o-transition: all .4s ease;
        transition: all .4s ease;
        }    
        .hover-zoom__image figure {
        -webkit-transition: all .4s ease;
        -moz-transition: all .4s ease;
        -ms-transition: all .4s ease;
        -o-transition: all .4s ease;
        transition: all .4s ease;
        }
        .hover-zoom__image:hover figure,
        a:hover .hover-zoom__image figure {
        opacity: 1;
        -moz-transform:    scale(1.1);
        -webkit-transform: scale(1.1);
        -ms-transform:     scale(1.1);
        transform:         scale(1.1);
        }
        .hover-zoom__image a:hover img,
        .hover-zoom__image a:hover,
        a:hover .hover-zoom__image img,
        a:hover .hover-zoom__image {
        opacity:1;
        filter: alpha(opacity=100);
        -ms-filter: "alpha( opacity=100 )";
        }

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

       サムネ付きNEWS用設定

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

        .img-3by2 {
        position: relative;
        width:100%;
        height:0;
        padding-bottom:66%;
        overflow: hidden;
        }
        .img-3by2 img {
        position: absolute;
        top:50%;
        left:50%;
        transform: translate(-50%,-50%);
        width:100%;
        min-height: 100%;
        }
        .img-5by3 {
        position: relative;
        width:100%;
        height:0;
        padding-bottom:60%;
        overflow: hidden;
        }
        .img-5by3 img {
        position: absolute;
        top:50%;
        left:50%;
        transform: translate(-50%,-50%);
        width:100%;
        min-height: 100%;
        }
        .img-9by5 {
        position: relative;
        width:100%;
        height:0;
        padding-bottom:55.5555555%;
        overflow: hidden;
        }
        .img-9by5 img {
        position: absolute;
        top:50%;
        left:50%;
        transform: translate(-50%,-50%);
        width:100%;
        min-height: 100%;
        }

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

       text link

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

        .center		{ text-align:center;}
        .center-left{ text-align:center;}
        .center-left-tablet{ text-align:center;}
        .left-center{ text-align: left;}
        .left-center-tablet{ text-align: left;}
        .right-center-tablet{ text-align: right;}
        .text-l		{ text-align:left;}
        .text-r		{ text-align:right;}
        @media screen and (max-width: 1024px) {
        .center-left-tablet{ text-align: left;}
        .left-center-tablet{ text-align: center;}
        .right-center-tablet{ text-align: center;}
        }
        @media only screen and (max-width: 767px) {
        .center-left    { text-align:left;}
        .left-center    { text-align:center;}
        }

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

        テキスト

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

.small { font-size: .875rem;}
.smaller { font-size: .75rem;}
.tategaki {
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        }
        .tategaki-right {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        }
        .tategaki-right .tategaki-outer {
        text-align: right;
        flex: 1;
        }
        .tategaki-right .tategaki-inner {
        text-align: left;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        display: inline-block;
        box-sizing: border-box;
        }
        .tategaki-left {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        }
        .tategaki-left .tategaki-outer {
        text-align: left;
        flex: 1;
        }
        .tategaki-left .tategaki-inner {
        text-align: left;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        display: inline-block;
        box-sizing: border-box;
        }
        
        .tategaki-h240 { height: 240px;}
        
        .tategaki-nomber { /* 数字のみ横 */
        display: inline;
        padding-bottom:.17em;
        -webkit-text-combine: horizontal;
        -ms-text-combine-horizontal: all;
        text-combine-upright: all;
        -ms-text-combine-horizontal: digits 2; /* IE */
        }
        .tategaki-center {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        }
        .tategaki-center .tategaki-outer {
        text-align: center;
        flex: 1;
        }
        .tategaki-center .tategaki-inner {
        text-align: left;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        display: inline-block;
        box-sizing: border-box;
        }
        
        .tategaki-inner.text-r { text-align: right; }

        .tategaki-center h2 {  }
        .tategaki-center h3 {  }
        .tategaki-center.vertical-lr .tategaki-inner { writing-mode: vertical-lr; -ms-writing-mode: tb-lr; }
        @media screen and (max-width: 1024px) {
        .tategaki-center.tablet-yokogaki .tategaki-inner { -ms-writing-mode: lr-tb; writing-mode: horizontal-tb; text-align: center; }
        .tategaki-center.tablet-yokogaki h2 { letter-spacing: .05em; margin-right:0; }
        .tategaki-center.tablet-yokogaki .ls02 { letter-spacing: .05em; }
        .tategaki-center.tablet-yokogaki h3 { letter-spacing: .05em; }
        .tategaki-left.tablet-yokogaki .tategaki-inner { -ms-writing-mode: lr-tb; writing-mode: horizontal-tb; text-align: left; }
        .tategaki-left.tablet-yokogaki h2 { letter-spacing: .05em; margin-right:0; }
        .tategaki-left.tablet-yokogaki h3 { letter-spacing: .05em; }
        }
        @media screen and (max-width: 767px) {
        .tategaki.sp-yokogaki { -ms-writing-mode: lr-tb; writing-mode: horizontal-tb; display: block; }
        
        .tategaki-center.sp-yokogaki .tategaki-inner { -ms-writing-mode: lr-tb; writing-mode: horizontal-tb; display: block; }
        .tategaki-center.sp-yokogaki.sp-center .tategaki-inner { text-align:center; }
        .tategaki-center.sp-yokogaki .tategaki-outer { text-align: left;}
        .tategaki-center.sp-yokogaki h2 { letter-spacing: .05em; margin-right:0; }
        .tategaki-center.sp-yokogaki h3 { letter-spacing: .05em; }
        .tategaki-center.sp-yokogaki .ls02 { letter-spacing: .05em; }
        
        .tategaki-left.sp-yokogaki .tategaki-inner { -ms-writing-mode: lr-tb; writing-mode: horizontal-tb; display: block; }
        .tategaki-left.sp-yokogaki.sp-center .tategaki-inner { text-align:center; }
        .tategaki-left.sp-yokogaki .tategaki-outer { text-align: left;}
        
        .tategaki-left.sp-center .tategaki-outer { text-align: center; }
        
        .tategaki-right.sp-yokogaki .tategaki-inner { -ms-writing-mode: lr-tb; writing-mode: horizontal-tb; display: block; }
        .tategaki-right.sp-yokogaki.sp-center .tategaki-inner { text-align:center; }
        .tategaki-right.sp-yokogaki .tategaki-outer { text-align: left;}
        
        .sp-tategaki-right {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        }
        .sp-tategaki-right .tategaki-outer {
        text-align: right;
        flex: 1;
        }
        .sp-tategaki-right .tategaki-inner {
        text-align: left;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        display: inline-block;
        box-sizing: border-box;
        }
        
        .tategaki-h0-sp { height:auto; }
        }

        .f10 {font-size:10px;}
        .f12 {font-size:12px;}
        .f13 {font-size:13px;}
        .f14 {font-size:14px;}
        .f15 {font-size:15px;}
        .f16 {font-size:16px;}
        .f17 {font-size:17px;}
        .f18 {font-size:18px;}
        .f21 {font-size:21px;}
        .f24 {font-size:24px;}
        .f27 {font-size:27px;}
        .f30 {font-size:30px;}
        .f33 {font-size:33px;}
        .f36 {font-size:36px;}
        .f39 {font-size:39px;}
        .f45 {font-size:45px;}
        .f51 {font-size:51px;}
        .f60 {font-size:60px;}
        .f69 {font-size:69px;}
        .f72 {font-size:72px;}
        .f75 {font-size:75px;}
        .f90 {font-size:90px;}
        .f120{font-size:120px;}
        .f180{font-size:180px;}

        .lh100 { line-height:100%; }
        .lh125 { line-height:125%; }
        .lh135 { line-height:135%; }
        .lh150 { line-height:150%; }
        .lh160 { line-height:160%; }
        .lh175 { line-height:175%; }
        .lh180 { line-height:180%; }
        .lh200 { line-height:200%; }
        .lh220 { line-height:220%; }
        .lh235 { line-height:235%; }
        .lh250 { line-height:250%; }
        .lh300 { line-height:300%; }

        @media screen and (max-width: 1350px) {
        .f16 {font-size:15px;}
        .f17 {font-size:16px;}
        .f18 {font-size:17px;}
        .f21 {font-size:20px;}
        .f24 {font-size:22px;}
        .f27 {font-size:25px;}
        .f30 {font-size:27px;}
        .f33 {font-size:28px;}
        .f36 {font-size:30px;}
        .f39 {font-size:34px;}
        .f45 {font-size:36px;}
        .f51 {font-size:45px;}
        .f60 {font-size:52px;}
        .f69 {font-size:60px;}
        .f72 {font-size:63px;}
        .f75 {font-size:58px;}
        .f90 {font-size:81px;}
        .f180{font-size:162px;}
        }
        @media screen and (max-width: 1024px) {
        .f12 {font-size:11px;}
        .f13 {font-size:12px;}
        .f14 {font-size:12px;}
        .f15 {font-size:13px;}
        .f16 {font-size:14px;}
        .f17 {font-size:15px;}
        .f18 {font-size:17px;}
        .f21 {font-size:18px;}
        .f24 {font-size:19px;}
        .f27 {font-size:22px;}
        .f30 {font-size:24px;}
        .f33 {font-size:25px;}
        .f36 {font-size:29px;}
        .f39 {font-size:30px;}
        .f45 {font-size:32px;}
        .f51 {font-size:39px;}
        .f60 {font-size:45px;}
        .f69 {font-size:55px;}
        .f72 {font-size:32px;}
        .f75 {font-size:45px;}
        .f90 {font-size:60px;}
        .f120{font-size:90px;}
        .f180{font-size:135px;}

        .lh180 { line-height:170%; }
        .lh220 { line-height:200%; }
        .lh235 { line-height:210%; }
        .lh250 { line-height:220%; }
        .lh300 { line-height:200%; }
        }
        @media screen and (max-width: 767px) {
        .f12 {font-size:10px;}
        .f13 {font-size:11px;}
        .f14 {font-size:12px;}
        .f15 {font-size:13px;}
        .f16 {font-size:14px;}
        .f17 {font-size:15px;}
        .f18 {font-size:16px;}
        .f21 {font-size:17px;}
        .f24 {font-size:18px;}
        .f27 {font-size:20px;}
        .f30 {font-size:21px;}
        .f33 {font-size:21px;}
        .f36 {font-size:24px;}
        .f39 {font-size:26px;}
        .f45 {font-size:27px;}
        .f51 {font-size:30px;}
        .f60 {font-size:37px;}
        .f69 {font-size:40px;}
        .f72 {font-size:42px;}
        .f75 {font-size:36px;}
        .f90 {font-size:38px;}
        .f120{font-size:45px;}
        .f180{font-size:80px;}

        .lh175 { line-height:160%; }
        .lh180 { line-height:160%; }
        .lh200 { line-height:180%; }
        .lh220 { line-height:180%; }
        .lh235 { line-height:190%; }
        .lh250 { line-height:200%; }
        .lh300 { line-height:180%; }
        }
        @media screen and (max-width: 374px) {
        }

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

       デバイス

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

        .sp-none        { }
        .sp-on		    { display:none;}
        .sp-inline-on   { display:none;}
        .tablet-on		{ display:none;}
        .tablet-none	{ display:block; }
        .w1200-none       { display:block; }
        .w1240-on       { display:none; }
        .w1350-on       { display:none; }
        .tablet-inline-none	{ display:inline-block; } 
        
        
        .w1650-none { display: block; }
        @media screen and (max-width:1650px) {
        .w1650-none { display: none; }
        }
        @media screen and (max-width: 1350px) {
        .w1350-none     { display:none; }
        .w1350-on     { display:block; }
        }
        @media screen and (max-width: 1240px) {
        .w1240-none     { display:none; }
        .w1240-on     { display:block; }
        }
        @media screen and (max-width: 1200px) {
        .w1200-none       { display:none; }
        }
        @media screen and (max-width: 1024px) {
        .tablet-on		{ display:inherit;}
        .tablet-none	{ display:none; }
        .vertical-center.tablet-none		{ display:none;}
        .tablet-on.sp-none { display:block;}
        .tablet-none.sp-on { display:none;}
        .tablet-inline-none	{ display:none; } 
        }
        @media screen and (max-width: 767px) {
        .sp-none		{ display:none;}
        .vertical-center.sp-none		{ display:none;}
        .sp-on			{ display:inherit;}
        .sp-inline-on   { display:inline;}
        .tablet-on.sp-none { display:none;}
        .tablet-none.sp-on { display:block;}
        }

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

       Flex

===================================================================================================*/
 
.flex-wrap {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content:center;
        align-items: center;
        align-content:stretch;
        display: -webkit-flex;
        -webkit-flex-direction: row;
        -webkit-flex-wrap: nowrap;
        }
        .flex-wrap.is-align-stretch { /* 上端揃え */
        align-items: stretch;
        }
        .flex-wrap.is-align-start { /* 上端揃え */
        align-items: flex-start;
        }
        .flex-wrap.is-align-end { /* 下端揃え */
        align-items: flex-end;
        }
        .is-align-end { /* 親に設定 */
        align-items: flex-end;
        }
        .flex-side-center { /* 子要素の左右の中央揃え IE一部バグあり */
        display: flex;
        justify-content: center;
        }
        .flex-wrap.is-between { /* 子要素の等間隔 + 両端揃え */
        justify-content: space-between;
        }
        .flex-wrap.is-content-start { /* 子要素の等間隔 + 両端揃え */
        justify-content: flex-start;
        }
        .flex-wrap.is-content-center { /* 子要素の等間隔 + 中央揃え */
        justify-content: center;
        }
        .flex-wrap.is-wrap { /* 子要素折り返し */
        flex-wrap: wrap;
        }
    
        /* **** 子要素 **** */
        .flex {
        flex: none;
        display: block;
        flex-basis: auto;
        flex-grow: 1;
        flex-shrink: 1;
        width: 100%;
        min-width:0;
        box-sizing: border-box;
        }

        /* **** Width **** */
        .flex300    { max-width:300px; min-width:300px; width:300px; }
        .flex500    { max-width:500px; min-width:500px; width:500px; }
        .flex900    { max-width:900px; min-width:900px; width:900px; }

        .flex-1-right { margin-right:.5rem; }
        .flex-2-right { margin-right:1rem; }
        .flex-3-right { margin-right:1.5rem; }
        .flex-4-right { margin-right:2rem; }
        .flex-5-right { margin-right:2.5rem; }
        .flex-6-right { margin-right:3rem; }

        .flex-1-left { margin-left:.5rem; }
        .flex-2-left { margin-left:1rem; }
        .flex-3-left { margin-left:1.5rem; }
        .flex-4-left { margin-left:2rem; }
        .flex-5-left { margin-left:2.5rem; }
        .flex-6-left { margin-left:3rem; }

        .flex-pb-1 .flex { padding-bottom:.25em; }
        .flex-pb-2 .flex { padding-bottom:.5em; }
        .flex-pb-3 .flex { padding-bottom:.75em; }
        .flex-pb-4 .flex { padding-bottom:1em; }
        .flex-pb-5 .flex { padding-bottom:1.25em; }
        .flex-pb-6 .flex { padding-bottom:1.5em; }
        .flex-pb-7 .flex { padding-bottom:1.75em; }
        .flex-pb-8 .flex { padding-bottom:2em; }

        .flex-112   { order: 1; }
        .flex-221   { order: 2; }
        .flex-333   { order: 3; }

        .column .inner { width:100%;}
        .vertical-center { /* columnに付与 直下にinner設置 */
        display: flex;
        align-items: center;
        }
        .reverse-row-order {
        flex-direction: row-reverse;
        }
        .is-align-end { /* 下端揃え 親要素へ付与 */
        align-items: flex-end;
        }

        @media screen and (max-width: 1024px) {
        .is-flex-tablet { -webkit-flex-direction: column; flex-direction: column; flex: none; display: block; }
        .is-flex-tablet .flex { margin-right:0 !important; margin-left:0 !important; max-width:100% !important; min-width:100% !important;}
        
        }
        @media screen and (max-width: 767px) {
        .is-flex-mobile { -webkit-flex-direction: column; flex-direction: column; flex: none; display: block; }
        .is-flex-mobile .flex { margin-right:0 !important; margin-left:0 !important; max-width:100% !important; min-width:100% !important;}
        .flex-112   { order: 2; }
        .flex-221   { order: 1; }
        .flex-333   { order: 3; }
        }

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

      　pace

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

.intro {
        position: fixed;
        width:100%;
        height: 100%;
        z-index:-10;
        background:#FFF;
        animation: fadeOut 1.2s ease 0s 1 normal;
        -webkit-animation: fadeOut 1.2s ease 0s 1 normal;
        opacity: 0;
        }
        @keyframes fadeOut {
        0% {opacity: 1; z-index:90000;}
        25% {opacity: 1; z-index:90000;}
        99% {opacity: 0; }
        100% { z-index:-10;}
        }
        /*
.intro-logo {
        position: absolute;
        top:50%;
        left:50%;
        transform: translate(-50%,-50%);
        width:210px;
        opacity: 1;
        z-index: 2;
        animation: introLogo 1s ease 0s 1 normal;
        -webkit-animation: introLogo 1s ease 0s 1 normal;
        }
        @keyframes introLogo {
        0% { opacity: 0; filter: blur(10px); }
        50% { opacity: 1; filter: blur(0);}
        80% { opacity: 1; filter: blur(0);}
        100% { opacity: 0; z-index: -10; }
        }
        */





