@charset "UTF-8";

.en { font-family: "Gilda Display","Sorts Mill Goudy", serif; font-optical-sizing: auto; letter-spacing: 0em; font-style: normal; font-weight:400; }
.serif { font-family: "Noto Serif","Shippori Mincho", 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 { -webkit-text-size-adjust: 100%; }
html,body { width:100%; min-width: 320px; font-size:16px; }
body {
        background:#FFF;
        font-family: "Noto Sans JP", sans-serif;
        letter-spacing:0.05em;
        color:#3C3C3B;
        font-weight:400;
        text-align:left;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
        line-height:200%;
        font-feature-settings: "palt" 1;
        overflow: inherit;
        }
        @media screen and (min-width: 1025px) {
        body { overflow: inherit !important; }
        }
        
        body.hidden { overflow: hidden; }
        .wrapper    { overflow:hidden;}
        article		{ position:relative; width:100%; z-index: 0;}
        section		{ position:relative; }
        main        { display: block; position: relative; z-index: 1; }

        .section	{ padding-top:165px; padding-bottom:165px; }
        .section-m	{ padding-top:165px; padding-bottom:165px; }
        .section-s	{ padding-top:125px; padding-bottom:125px; }
        .section-ss	{ padding-top:50px; padding-bottom:50px; }

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

        .outer		{ padding-left:3.5vw; padding-right:3.5vw; box-sizing:border-box; }
        .outer-middle{ padding-left:2.78vw; padding-right:2.78vw; box-sizing:border-box; }

        .inner-wrap    { padding:2rem 7%; box-sizing:border-box; }
        .inner-outer    { box-sizing:border-box; padding-left:24px; padding-right:24px; }

        .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 { font-family: "Shippori Mincho", serif; }
        h1,h2,h3,h4,h5 { line-height: 160%; font-weight:600; }
        
        h1.en,h2.en,h3.en,h4.en,h5.en {  font-weight:400; font-family: "Gilda Display","Sorts Mill Goudy", serif; }


        small { font-size:.75rem; }
        .bold { font-weight:700;  }
        .font-black { font-weight:900;}
        
        .ls0   { letter-spacing: 0; }
        .ls01  { letter-spacing: .1em; }
        .ls015  { letter-spacing: .15em; }
        .ls02  { letter-spacing: .2em; }
        .ls03  { letter-spacing: .3em; }
        .ls05  { letter-spacing: .5em; }
        
        .op5   { opacity: .05 ; }
        .op10  { opacity: .1 ; }
        .op15  { opacity: .15 ; }
        .op30  { opacity: .3 ; }
        .op40  { opacity: .4 ; }
        .op50  { opacity: .5 ; }
        .op60  { opacity: .6 ; }
        .op70  { opacity: .7 ; }
        .op75  { opacity: .75 ; }
        .op80  { opacity: .8 ; }
        
        .normal { font-weight:400 !important; }
        .float-l { float:left; }
        .float-r { float:right; }
        .margin-auto { margin-inline:auto; }
        .bottom-none    { padding-bottom:0 !important;}
        
        .left-center    { text-align:left;}
        .right-center    { text-align:right;}
        .center-right    { text-align:center;}
        
        @media screen and (max-width: 1650px) {
        .section	{ padding-top:10vw; padding-bottom:10vw; }
        .section-m	{ padding-top:10vw; padding-bottom:10vw; }
        .section-s	{ padding-top:7vw; padding-bottom:7vw; }
        .section-ss	{ padding-top:40px; padding-bottom:40px; }
        }

        @media screen and (max-width: 1024px) {
        html,body, .wrapper	{ font-size:15px; line-height: 190%;}
        .outer			   { padding-left:4.5vw; padding-right:4.5vw; }
        .outer-middle      { padding-left:2.2222vw; padding-right:2.2222vw; }

        .inner-wrap    { padding:2rem 7%; }
        .inner-outer   { padding-left:18px; padding-right:18px; }
        
        .section	       {  }
        
        .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%;}

        .section	    { padding-top:20vw; padding-bottom:20vw; }
        .section-m	    { padding-top:14vw; padding-bottom:14vw; }
        .section-s	{ padding-top:10vw; padding-bottom:10vw; }
        .section-ss	{ padding-top:35px; padding-bottom:35px; }

        .outer			{ padding-left:7.5vw; padding-right:7.5vw; }
        .outer-middle   { padding-left:4vw; padding-right:4vw; }

        .inner-wrap    { padding:2rem; }
        .inner-outer   { padding-left:12px; padding-right:12px; }
        
        .sp-center     { text-align: center !important; }
        .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;}
        .right-center    { text-align:center;}
        .center-right    { text-align:right;}
        .sp-margin-auto { margin-left:auto; margin-right:auto; }
        }
        @media only screen and (max-width:374px) {
        html,body, .wrapper	{ font-size:14px; }
        }

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

       Image

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

        .img-fit { height:100%; }
        .img-fit img {
        height:100%;
        width:100%;
        object-fit: cover;
        }
        @media only screen and (max-width:1024px) {
        .img-fit img { height:auto; }
        }

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

       Link

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

a {
        text-decoration:none;
        color:#3C3C3B;
        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 )";
        }
        a .white { color:#FFF; }

        .hover-under a:hover {
        text-decoration:underline;
        }

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

        .link { padding-bottom:.125rem ; border-bottom:2px solid #3C3C3B;  font-weight: 700; color:#3C3C3B; }
        .link:hover { opacity:.6; }


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

       ボタン

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

.more {
        position:relative;
        width:100%;
        max-width:270px;
        line-height: 1;
        }
        .more a {
        display: inline-block;
        position: relative;
        width:100%;
        height:50px;
        line-height:48px;
        text-align: center;
        color:#3C3C3B;
        font-weight:400;
        border:1px solid #3C3C3B;
        box-sizing: border-box;
        font-size:1rem;
        white-space: nowrap;
        text-decoration:none !important;
        z-index: 1;
        letter-spacing: 0em;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .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:#3C3C3B;
        }
        .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) {
        }
        @media only screen and (max-width:767px) {
        .more {  max-width:100%; }
        .more a { height:46px; line-height:44px; }
        }

.more-white {
        position:relative;
        width:100%;
        line-height: 1;
        }
        .more-white a {
        display: inline-block;
        position: relative;
        width:100%;
        height:76px;
        line-height:76px;
        text-align: center;
        color:#3C3C3B;
        font-weight:500;
        background: #FFF;
        box-sizing: border-box;
        font-size:1rem;
        white-space: nowrap;
        text-decoration:none !important;
        z-index: 1;
        letter-spacing: 0em;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .bg-blue .more-white a { color:#3C3C3B; }
        .more-white 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:#292A2B;
        }
        .more-white a:hover {
        opacity:1;
        color:#FFF;
        }
        .bg-blue .more-white a:hover { color:#FFF; }
        .more-white a:hover:after {
        left: 0;
        width: 100%;
        }
        @media only screen and (max-width:1024px) {
        .more-white a { height:66px; line-height:66px; }
        }
        @media only screen and (max-width:767px) {
        .more-white a { height:60px; line-height:60px; }
        }

.more-blue {
        position:relative;
        width:100%;
        line-height: 1;
        }
        .more-blue a {
        display: inline-block;
        position: relative;
        width:100%;
        height:76px;
        line-height:76px;
        text-align: center;
        color:#FFF;
        font-weight:500;
        background: #5B6C7D;
        box-sizing: border-box;
        font-size:1rem;
        white-space: nowrap;
        text-decoration:none !important;
        z-index: 1;
        letter-spacing: 0em;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more-blue 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:#292A2B;
        }
        .more-blue a:hover {
        opacity:1;
        color:#FFF;
        }
        .more-blue a:hover:after {
        left: 0;
        width: 100%;
        }
        @media only screen and (max-width:1024px) {
        .more-blue a { height:66px; line-height:66px; }
        }
        @media only screen and (max-width:767px) {
        .more-blue a { height:60px; line-height:60px; }
        }

.more-url {
        position:relative;
        display: inline-block;
        margin-top:5px;
        width:auto;
        line-height: 1;
        }
        .more-url a {
        display: inline-block;
        position: relative;
        width:100%;
        height:28px;
        line-height:28px;
        padding:0 1.75rem;
        text-align: center;
        color:#FFF;
        font-weight:400;
        background: #3C3C3B;
        box-sizing: border-box;
        font-size:13px;
        white-space: nowrap;
        text-decoration:none !important;
        z-index: 1;
        letter-spacing: 0em;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more-url 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:rgb(255 255 255 / .3);
        }
        .more-url a:hover {
        opacity:1;
        }
        .more-url a:hover:after {
        left: 0;
        width: 100%;
        }

        @media only screen and (max-width:767px) {
        .more-url a { height:32px; line-height:32px; }
        }

.more-sns {
        position:relative;
        width:100%;
        height:auto;
        line-height: 1;
        font-size:0;
        }
        .more-sns a {
        width:100%;
        height:78px;
        line-height:82px;
        text-align: center;
        border-radius:3px;
        box-sizing: border-box;
        background:#FFF;
        color:#3C3C3B !important;
        font-weight:400;
        font-size:18px;
        overflow: hidden;
        white-space: nowrap;
        text-decoration:none !important;
        position: relative;
        z-index: 1;
        letter-spacing: 0;
        display: inline-block;
        -webkit-transition: all 0.5s ease;
        transition: all 0.5s ease;
        }
        .more-sns a:hover {
        opacity:.6;
        }
        @media only screen and (max-width:1350px) {
        .more-sns a { font-size:17px; height:70px; line-height:74px; }
        }
        @media only screen and (max-width:1024px) {
        .more-sns a { font-size:16px; height:64px; line-height:68px; }
        }
        @media only screen and (max-width:767px) {
        .more-sns a { height:58px; line-height:62px; text-align:left; padding-left:1.75rem; }
        }

.more-arrow {
        position:relative;
        display: inline-block;
        line-height: 1;
        }
        .more-arrow a {
        position: relative;
        display: inline-block;
        padding-right:60px;
        line-height:1.5;
        text-align: left;
        box-sizing: border-box;
        color:#3C3C3B;
        font-weight:400;
        font-size:18px;
        white-space: nowrap;
        text-decoration:none !important;
        z-index: 1;
        letter-spacing: 0;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        }
        .more-arrow a:after {
        content:"";
        display:block;
        position:absolute;
        top:50%;
        right:0;
        width:45px;
        height:1px;
        background:#3C3C3B;
        z-index: 0;
        -webkit-transition: all 0.3s ease;
        transition: all 0.3s ease;
        }
        .more-arrow a:hover {
        opacity:1;
        padding-right:75px;
        }
        .more-arrow a:hover:after {
        width:60px;
        }
        
        .bg-black .more-arrow a:after { background: #FFF; }
        .bg-blue .more-arrow a:after { background: #FFF; }

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

       table

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

.table-a {
        width:100%;
        border-collapse:collapse;
        border-spacing:0px;
        text-align:left;
        letter-spacing:0;
        box-sizing: border-box;
        line-height: 180%;
        font-size:1rem;
        font-weight:400;
        border-top:1px solid rgb(60 60 59 / .5);
        }
        .table-a.top-none { border-top:none; }
        .table-a tr { border-bottom:1px solid rgb(60 60 59 / .5);}
        .table-a th {
        position: relative;
        padding: 60px 1rem 60px 0;
        vertical-align: middle;
        text-align:left;
        font-weight:400;
        }
        .table-a td {
        position: relative;
        padding:60px 0 60px 1rem;
        vertical-align: middle;
        text-align:left;
        font-weight:400;
        }
        .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-a.white-line { border-top:1px solid rgb(255 255 255 / .5); }
        .table-a.white-line tr { border-bottom:1px solid rgb(255 255 255 / .5); }

        .table-a.border-none { border-top:none; }
        .table-a.border-none tr:last-child { border-bottom:none; }

        @media screen and (max-width: 1800px) {
        .table-a th { padding: 3.3333vw 1rem 3.3333vw 0; }
        .table-a td { padding:3.3333vw 0 3.3333vw 1rem; }
        }
        @media screen and (max-width: 1024px) {
        .table-a th { padding: 2rem 1rem 2rem 1rem; }
        .table-a td { padding:2rem 0 2rem 1rem; }
        }
        @media screen and (max-width: 767px) {
        .table-a.sp-table { border-top:none; }
        .table-a.sp-table th { width:100% !important; display: block !important; padding:.0 0 1rem; box-sizing: border-box; border-bottom:1px solid rgb(60 60 59 / .5); }
        .table-a.sp-table td { width:100% !important; display: block !important; padding:1rem 0; box-sizing: border-box; border:none;  }
        .table-a.sp-table tr { display: block;  border-bottom:none; padding-bottom:2rem; }
        .table-a.sp-table tr:last-child { padding-bottom:0rem; }
        
        .table-a.white-line th{ border-bottom:1px solid rgb(255 255 255 / .5); }
        }


.table-b {
        width:100%;
        border-collapse:collapse;
        border-spacing:0;
        text-align:left;
        letter-spacing:0;
        box-sizing: border-box;
        line-height: 150%;
        font-size:1rem;
        }
        .table-b th {
        padding:1rem 1.5rem;
        vertical-align: middle;
        font-weight:600;
        text-align:left;
        background: url("../images/parts/dark.jpg") left top repeat;
        border:1px solid #B6A0A0;
        color:#FFF;
        }
        .table-b td {
        padding:1rem 1.5rem;
        text-align:left;
        vertical-align: middle;
        background:rgb(65 53 20 / .06);
        border: 1px solid rgb(65 53 20 / .3);
        box-sizing: border-box;
        }

        .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-c {
        width:100%;
        border-collapse:collapse;
        border-spacing:0px;
        text-align:left;
        letter-spacing:0;
        box-sizing: border-box;
        line-height: 180%;
        font-size:1rem;
        font-weight:500;
        }
        .table-c tr { border-bottom:1px solid rgb(60 60 59 / .5); }
        .table-c tr:last-child { border-bottom:none; }
        .table-c th {
        position: relative;
        padding: 1.25rem 1rem 1.25rem 1rem;
        vertical-align: top;
        text-align:left;
        font-weight:600;
        color:#292A2B;
        }
        .table-c td {
        position: relative;
        padding:1.25rem 0 1.25rem 1rem;
        vertical-align: middle;
        text-align:left;
        font-weight:500;
        }
        .table-c.th-center th { text-align: center;}
        .table-c.td-right td { text-align: right;}
        .table-c.th-right th { text-align: right;}
        .table-c.center td,.table-c.center th { text-align: center;}
        
        @media screen and (max-width: 1024px) {
        .table-c th { padding: 1rem 1rem 1rem 1rem; }
        .table-c td { padding:1rem 0 1rem 1rem; }
        }


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

        @media screen and (max-width: 1024px) {
        .table-a.tablet-table { border:none; }
        .table-a.tablet-table td:after { display: none; }
        .table-a.tablet-table th { width:100% !important; display: block !important; padding:.25em .75rem .25rem; box-sizing: border-box; text-align: left; border-top:none; border-bottom:none; background: rgba(0,0,0,.05); font-weight:500; }
        .table-a.tablet-table td { width:100% !important; display: block !important; padding:.5em .75rem ; box-sizing: border-box;  }
        .table-a.tablet-table tr { display: block; padding-bottom:.5rem; border:none;}
        .table-a.tablet-table tr:last-child { padding-bottom:0rem;}
        .table-a.tablet-table td:nth-of-type(2) { border-top:none;}
        
        
        .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-b { border-collapse:collapse; border-spacing:0px; }
        .table-b th { padding:1.5rem 1rem; }
        .table-b td { padding:1.5rem 1rem; }
        
        .table-wrap { border:none; padding:3px; box-sizing: border-box; }
        .table-b.sp-table { border:none; }
        .table-b.sp-table th { width:100% !important; display: block !important; padding:.75em 1.25em; box-sizing: border-box; text-align: left; border-bottom: none; text-shadow: none; border-radius: 0 ;}
        .table-b.sp-table td { width:100% !important; display: block !important; padding:.75em 1.25em ; box-sizing: border-box; border-radius:0 0 ; text-align: left;  }
        .table-b.sp-table tr { display: block; margin-bottom: 10px; }
        .table-b.sp-table tr:last-child { padding-bottom:0rem; margin-bottom:0; }
        .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-b.sp-table.sp-center th { text-align: center; }
        .table-b.sp-table.sp-center td { text-align: center; }

/*
        .table-b thead th:first-child { border-radius:0; }
        .table-b tbody td:first-child { border-radius:0; }
        .table-b thead th:last-child { border-radius:0; }
        .table-b tbody td:last-child { border-radius:0; }
        
        .table-b { border-collapse:separate; border-spacing:0px; }
        .table-b tr:first-child th { border-radius:10px 0 0 0; }
        .table-b tr:first-child td { border-radius:0 10px 0 0; }
        .table-b tr:last-child th { border-radius:0 0 0 10px; }
        .table-b tr:last-child td { border-radius:0 0 10px 0; }
*/

        .table-c { border-collapse:separate; border-spacing:0px; border-top:none; }
        .table-c.sp-table th { width:100% !important; display: block !important; padding:.75em 0 0; box-sizing: border-box; text-align: left; border-bottom: none; text-shadow: none; border-radius: 0 ; font-size:1.075rem;}
        .table-c.sp-table td { width:100% !important; display: block !important; padding:.5em 0 1.5rem; box-sizing: border-box; border-radius:0 0 ; text-align: left;  }
        .table-c.sp-table tr { display: block; margin-bottom: 10px; }
        .table-c.sp-table tr:last-child { padding-bottom:0rem; margin-bottom:0; border-bottom:none; }
        .table-c.sp-table td:nth-of-type(2) { border-top:none;}
        .table-c.sp-td-right td { text-align: right; } 
        .table-c.sp-table .table th { padding:.25rem 0; border-bottom:1px solid #777;}
        .table-c.sp-table .table td { padding:.25rem 0;}
        .table-c tr:first-child th { border-radius:10px 10px 0 0; }
        .table-c tr:first-child td { border-radius:0 0 10px 10px; }
        .table-c tr:last-child th { border-radius:10px 10px 0 0; }
        .table-c tr:last-child td { border-radius:0 0 10px 10px; }
        
        
        .table-c.sp-table th { border-radius:10px 10px 0 0; }
        .table-c.sp-table td { border-radius:0 0 10px 10px; }



        .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; }
        }

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

       dl

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

        .indent {
        padding-left:3rem;
        box-sizing: border-box;
        }

        .nomber-dl {
        display: flex;
        flex-wrap: wrap;
        line-height: 200%;
        }
        .nomber-dl dt {
        width:2rem;
        font-size:1rem;
        font-weight:700;
        color:#C09D68;
        }
        .nomber-dl dd {
        width:calc(100% - 2rem);
        }
        .checkin-dl {
        display: flex;
        flex-wrap: wrap;
        }
        .checkin-dl dt {
        width:12em;
        }
        .checkin-dl dd {
        width:calc(100% - 12em);
        }
        
        .dl-table {
        display: flex;
        flex-wrap: wrap;
        line-height: 200%;
        }
        .dl-table dt {
        width:5rem;
        font-size:1rem;
        font-weight:700;
        }
        .dl-table dd {
        width:calc(100% - 5rem);
        }

        @media screen and (max-width: 767px) {
        .dl-table dt { width:100%; border-bottom:1px dotted rgb(0 0 0 / .75); padding-bottom:.125rem; margin-bottom:.25rem; font-size:1.125rem; }
        .bg-black .dl-table dt { border-bottom:1px dotted rgb(255 255 255  / .75); }
        .dl-table dd { width:100%; padding-bottom:1.5rem; line-height: 160%; }
        }

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

       アイコン

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

.icon-before {
        width:24px;
        height:24px;
        display:inline-block;
        margin-right:.5rem;
        position: relative;
        top: .2rem;
        }
        .icon-before-l {
        width:30px;
        height:30px;
        display:inline-block;
        position: absolute;
        left:0;
        top:auto;
        }
        .icon-before-sns {
        width:20px;
        height:20px;
        display:inline-block;
        margin-right:.65rem;
        position: relative;
        top:3px;
        }
        .icon-before-s {
        width:18px;
        height:18px;
        display:inline-block;
        margin-right:.65rem;
        position: relative;
        top: .15rem;
        }
        .icon-before-m {
        width:30px;
        height:30px;
        display:inline-block;
        margin-right:.9rem;
        position: relative;
        top: .4rem;
        }
        .icon-before-btn {
        width:1rem;
        height:1rem;
        display:inline-block;
        margin-right:.65rem;
        position: relative;
        vertical-align: text-bottom;
        }
        
.icon-after {
        width:1.2rem;
        height:1.2rem;
        display:inline-block;
        margin-left:.5rem;
        position: relative;
        top: .125rem;
        }
        .icon-after-s {
        width:.8rem;
        height:.8rem;
        display:inline-block;
        margin-left:.75rem;
        position: relative;
        top: .25rem;
        }

        .icon-facebook-s      { background: url("../images/parts/icon-facebook.svg") center center / cover; }
        .icon-instagram-s      { background: url("../images/parts/icon-instagram.svg") center center / cover; }
        .icon-line-s      { background: url("../images/parts/icon-line.svg") center center / cover; }
        .icon-youtube-s      { background: url("../images/parts/icon-youtube.svg") center center / cover; }

        .icon-free      { background: url("../images/parts/icon-free.svg") center center / cover; }
        .icon-link      { background: url("../images/parts/icon-link.svg") center center / cover; }


        @media all and (max-width:1024px) {
        .icon-before { width:1.15rem; height:1.15rem; }
        .icon-before-m { top: .4rem; }
        .icon-after { margin-left:.75rem; }
        .icon-before-sns { top:4px; }
        }
        @media all and (max-width: 767px) {
        .icon-before-m { width:24px; height:24px; top: .3rem; margin-right:.7rem; }

        }

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

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

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

.access-logo { width:170px; }

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

/*================================================
      　audio
================================================*/

        .audio audio { width:100%; }

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

    .map {
        position: relative;
        padding-bottom: 560px;
        height: 0;
        overflow: hidden;
        box-sizing: border-box;
        border: 1px solid #3A3935;
        border-radius:0px;
        z-index: 2;
        }
        .map iframe,
        .map object,
        .map embed {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        }
        
    .map-gray iframe {
        -webkit-filter: grayscale(60%);
        filter: grayscale(60%);
        }    

        @media screen and (max-width: 1024px) {
        .map { padding-bottom: 550px; }
        }
        @media screen and (max-width: 767px) {
        .map { padding-bottom: 110%; }
        }

/*================================================
      　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 {
        margin-left:1.5rem;
        }
        .nomber-list li {
        padding: .5em 0;
        position: relative;
        list-style-type: decimal;
        }

.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;
        }

.link-list {
        position: relative;
        line-height: 175%;
        display: flex;
        flex-wrap: wrap;
        margin-left:-1rem;
        margin-right:-1rem;
        }
        .link-list li {
        width:50%;
        flex: none;
        display: block;
        box-sizing: border-box;
        padding: 0 1rem 0 1rem ;
        position: relative;
        line-height: 150%;
        }
        .link-list li a {
        display: block;
        position: relative;
        box-sizing: border-box;
        padding: .75rem 0 .75rem 1.5rem;
        border-bottom:1px solid rgba(0,0,0,.2);
        -webkit-transition:all .5s ease;
        transition       : all .5s ease;
        }
        .link-list li a:before {
        content: "";
        display:inline-block;
        position: absolute;
        left: 0;
        top:50%;
        transform: translateY(-50%);
        line-height: 150%;
        background: url("../images/icons/link-arrow.svg") center center / cover;
        width:13px;
        height:13px;
        -webkit-transition:all .5s ease;
        transition       : all .5s ease;
        }
        .link-list li:nth-child(1) a { border-top:1px solid rgba(0,0,0,.2); }
        .link-list li:nth-child(2) a { border-top:1px solid rgba(0,0,0,.2); }

        .link-list li a:hover {
        padding-left:2.25rem;
        }
        .link-list li a:hover:before {
        left:.75rem;
        }
        @media screen and (max-width: 1024px) {
        .link-list li a:before { width:12px; height:12px; }
        }
        @media screen and (max-width: 767px) {
        .link-list li { width:100%; }
        .link-list li:nth-child(2) a { border-top:none; }
        .link-list li a: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);
        }

.line-list {
        }
        .line-list li {
        position: relative;
        padding: .35rem 0 .35rem 1.25rem;
        border-bottom:1px dotted rgb(65 53 20 / .5);
        }
        .line-list li:first-child { border-top:1px dotted rgb(65 53 20 / .5); }

        .line-list li:before {
        content: "・";
        display:block;
        position: absolute;
        top:auto;
        left: 0;
        font-size:1rem;
        vertical-align: middle;
        }
.half-list {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        }
        .half-list li {
        position: relative;
        padding: .25rem 0 .25rem 1.25rem;
        border-bottom:1px dotted rgb(65 53 20 / .5);
        width:calc(50% - 10px);
        box-sizing: border-box;
        }
        .half-list li:before {
        content: "・";
        display:block;
        position: absolute;
        top:auto;
        left: 0;
        font-size:1rem;
        vertical-align: middle;
        }
        @media screen and (max-width: 767px) {
        .half-list li { width:100%; }
        }


.disk-list {
        }
        .disk-list li {
        position: relative;
        padding: 0 0 0 1.25rem;
        }
        .disk-list li:before {
        content: "・";
        display:block;
        position: absolute;
        top:auto;
        left: 0;
        font-size:1rem;
        vertical-align: middle;
        }
        .disk-list li:last-child { border-bottom: none; }
        .disk-list.half li {
        width:45%;
        margin-right:5%;
        line-height: 250%;
        padding:0 0 0 1.25rem;
        box-sizing: border-box;
        float: left;
        border-bottom: 1px solid rgb(0 0 0 / .5);
        }

        @media screen and (max-width:1024px) {
        .disk-list.half li { width:100%; margin-right:0; float: none; }
        }
        @media screen and (max-width: 767px) {
        .disk-list.half li { line-height:180%; padding-bottom:.25rem; }
        }

.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;
        }
        
        .kome-list.center {
        text-align: center;
        }
        .kome-list.center li {
        display: inline-block;
        }

        @media screen and (max-width: 1024px) {
        }
        @media screen and (max-width: 767px) {
        .kome-list.center { text-align: left; }
        .kome-list.center li { display: block; }
        }
.center-kome-list {
        }
        .center-kome-list li {
        text-align: center;
        padding: 0;
        position: relative;
        padding-left:1.25em;
        }
        .center-kome-list li:before {
        content: "※";
        display:inline-block;
        position: absolute;
        top: 0;
        margin-left:-1.25rem;
        font-size:1em;
        vertical-align: middle;
        }
        @media screen and (max-width: 1024px) {
        .center-kome-list.tablet-left li { text-align: left; }
        }
        @media screen and (max-width: 767px) {
        .center-kome-list.sp-left li { text-align: left; }      
        }

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

       padding margin 設定

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

        /*=================================================
                %
        ==================================================*/

        .pb-1p     { padding-bottom:1%;}
        .pb-2p     { padding-bottom:2%;}
        .pb-3p     { padding-bottom:3%;}
        .pb-4p     { padding-bottom:4%;}
        .pb-5p     { padding-bottom:5%;}
        .pb-6p     { padding-bottom:6%;}
        .pb-7p     { padding-bottom:7%;}
        .pb-8p     { padding-bottom:8%;}
        .pb-9p     { padding-bottom:9%;}
        .pb-10p     { padding-bottom:10%;}
        .pb-11p     { padding-bottom:11%;}
        .pb-12p     { padding-bottom:12%;}
        .pb-13p     { padding-bottom:13%;}
        .pb-14p     { padding-bottom:14%;}
        .pb-15p     { padding-bottom:15%;}
        
        .pt-1p     { padding-top:1%;}
        .pt-2p     { padding-top:2%;}
        .pt-3p     { padding-top:3%;}
        .pt-4p     { padding-top:4%;}
        .pt-5p     { padding-top:5%;}
        .pt-6p     { padding-top:6%;}

        /*=================================================
                px
        ==================================================*/


        .pb-1px     { padding-bottom:1px;}
        .pb-2px     { padding-bottom:2px;}
        .pb-3px     { padding-bottom:3px;}
        .pb-4px     { padding-bottom:4px;}
        .pb-5px     { padding-bottom:5px;}

        .mb-1px     { margin-bottom:1px;}
        .mb-2px     { margin-bottom:2px;}
        .mb-3px     { margin-bottom:3px;}
        .mb-4px     { margin-bottom:4px;}
        .mb-5px     { margin-bottom:5px;}

        /*=================================================
                em
        ==================================================*/

        .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-2hem		{ padding-top:2.5rem;}
        .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-1h	{ padding-top:3rem;}
        .pt-3-2		{ padding-top:3rem;}
        .pt-3-3-0	{ padding-top:3rem;}
        .pt-4-0  	{ padding-top:4rem;}
        .pt-4-2  	{ padding-top:4rem;}
        .pt-4-3  	{ padding-top:4rem;}
        .pt-6-3  	{ padding-top:6rem;}


        
        .pb-0-1 	{ padding-bottom:0rem;}
        .pb-0-1h	{ padding-bottom:0rem;}
        .pb-025em	{ padding-bottom:.25rem;}
        .pb-05em	{ padding-bottom:.5rem;}
        .pb-075em	{ padding-bottom:.75rem;}
        .pb-05-0	{ padding-bottom:.5rem;}
        .pb-05-025	{ 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-025	{ padding-bottom:1rem;}
        .pb-1-05	{ padding-bottom:1rem;}
        .pb-1h-0  	{ padding-bottom:1.5rem;}
        .pb-1h-05  	{ 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-0		{ padding-bottom:3rem;}
        .pb-3-1		{ padding-bottom:3rem;}
        .pb-3-1h	{ padding-bottom:3rem;}
        .pb-3-2		{ padding-bottom:3rem;}
        .pb-3-2h	{ padding-bottom:3rem;}
        .pb-3-4		{ padding-bottom:3rem;}
        .pb-4-0		{ padding-bottom:4rem;}
        .pb-4-1		{ 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-6-3		{ padding-bottom:6rem;}
        .pb-880		{ padding-bottom:8rem;}
        .pb-1px     { padding-bottom:1px;}
        .pb-10px    { padding-bottom:10px;}

        .pl-05em    { padding-left:.5rem; }
        .pl-05-0    { padding-left:.5rem; }
        .pl-1em     { padding-left:1rem; }
        .pl-1-0     { padding-left:1rem; }
        .pl-1hem    { padding-left:1.5rem; }
        .pl-2em     { padding-left:2rem; }
        .pl-2-0     { padding-left:2rem; }
        .pl-2-1-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-2-0  	{ margin-top:2rem;}
        .mt-4-2		{ margin-top:4rem;}
        .mt-10-5	{ margin-top:10rem;}
        
        .mt-3-0     { margin-top:3rem; }

        .mb-025em	{ margin-bottom:.25rem;}
        .mb-05em	{ margin-bottom:.5rem;}
        .mb-075em	{ margin-bottom:.75rem;}
        .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-4-3		{ margin-bottom:4rem;}
        .mb-5-3		{ margin-bottom:5rem;}
        .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-1h	{ padding-top:2.25rem;}
        .pt-3-3-0	{ padding-top:3rem;}
        .tab-pt-1em	{ padding-top:1rem;}
        .pt-4-2  	{ padding-top:3rem;}
        .pt-4-3  	{ padding-top:3.5rem;}
        .pt-6-3  	{ padding-top:5rem;}
        
        .pl-2-1-0     { padding-left:1rem; }
        .pl-1-0     { padding-left:.5rem; }

        .pb-05-0	{ padding-bottom:.25rem;}
        .pb-05-025	{ padding-bottom:.375rem;}
        .pb-1-0		{ padding-bottom:.5rem;}
        .pb-1-025	{ padding-bottom:.5rem;}
        .pb-1-05	{ padding-bottom:.5rem;}
        .pb-1h-05  	{ padding-bottom:1rem;}
        .pb-1h-1  	{ padding-bottom:1rem;}
        .pb-2-0		{ padding-bottom:0rem;}
        .pb-2-1		{ padding-bottom:1rem;}
        .pb-2-1h	{ padding-bottom:1.75rem;}
        .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-0		{ padding-bottom:2rem;}
        .pb-3-1		{ padding-bottom:2rem;}
        .pb-3-1h	{ padding-bottom:2rem;}
        .pb-3-2		{ padding-bottom:2rem;}
        .pb-3-2h	{ padding-bottom:2.75rem;}
        .pb-3-4		{ padding-bottom:4rem;}
        .pb-4-1		{ padding-bottom:3rem;}
        .pb-4-2		{ padding-bottom:3rem;}
        .pb-4-3		{ padding-bottom:3.5rem;}
        .pb-5-2		{ padding-bottom:2rem;}
        .pb-5-3		{ padding-bottom:4rem;}
        .pb-4-0		{ padding-bottom:3rem;}
        .pb-6-2		{ padding-bottom:4rem;}
        .pb-6-3		{ padding-bottom:5rem;}

        .mt10p      { margin-top:0%; }
        .mt-2-0  	{ margin-top:1rem;}

        .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:3rem;}
        .mb-4-3		{ margin-bottom:3.5rem;}
        .mb-5-3		{ margin-bottom:4rem;}
        .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-1h	{ padding-top:1.5rem;}
        .pt-3-3-0	{ padding-top:0rem;}
        .sp-pt-1em	{ padding-top:1rem;}
        .pt-4-0  	{ padding-top:0rem;}
        .pt-4-2  	{ padding-top:2rem;}
        .pt-4-3  	{ padding-top:3rem;}
        .pt-6-3  	{ padding-top:3rem;}

        .pb-0-1 	{ padding-bottom:1rem;}
        .pb-0-1h	{ padding-bottom:1.5rem;}
        .pb-05-0	{ padding-bottom:0;}
        .pb-05-025	{ padding-bottom:.25rem;}
        .pb-1-0		{ padding-bottom:0rem;}
        .pb-1-025	{ padding-bottom:.25rem;}
        .pb-1h-0  	{ padding-bottom:0rem;}
        .pb-1h-05  	{ padding-bottom:.5rem;}
        .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-0		{ padding-bottom:0rem;}
        .pb-3-1h	{ padding-bottom:1.5rem;}
        .pb-3-2h	{ padding-bottom:2.5rem;}
        .pb-4-0		{ padding-bottom:0rem;}
        .pb-4-1		{ padding-bottom:1rem;}
        .pb-4-2		{ padding-bottom:2rem;}
        .pb-4-3		{ padding-bottom:3rem;}
        .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-6-3		{ padding-bottom:3rem;}
        .pb-880		{ padding-bottom:0rem;}
        
        .pl-05-0    { padding-left:0rem; }
        .pl-1-0     { padding-left:0rem; }
        .pl-2-0     { padding-left:0rem; }
        .pl-2-1-0     { padding-left:0rem; }
        
        .sp-pb-1em  { padding-bottom:1rem; }
        .sp-pb-2em  { padding-bottom:2rem; }

        .mt-2-0  	{ margin-top:0rem;}
        .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-4-2		{ margin-bottom:2rem;}
        .mb-4-3		{ margin-bottom:3rem;}
        .mb-5-3		{ margin-bottom:3rem;}
        .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-920   { max-width: 920px; }
        .wrap-900   { max-width: 900px; }
        .wrap-860   { max-width: 860px; }
        .wrap-840   { max-width: 840px; }
        .wrap-800   { max-width: 800px; }
        .wrap-750   { max-width: 750px; }
        .wrap-700   { max-width: 700px; }
        .wrap-660   { max-width: 660px; }
        .wrap-650   { max-width: 650px; }
        .wrap-600   { max-width: 600px; }
        .wrap-600-500   { max-width: 600px; }
        .wrap-500   { max-width: 500px; }
        .wrap-450   { max-width: 450px; }
        .wrap-420   { max-width: 420px; }
        .wrap-400   { max-width: 400px; }
        .wrap-350   { max-width: 350px; }
        .wrap-300   { max-width: 300px; }

        .max90      { max-width:90px; width:100%;}
        .max170     { max-width:170px; width:100%;}
        .max210     { max-width:210px; width:100%;}
        .max240     { max-width:240px; 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%;}
        .max800     { max-width:800px; width:100%;}
        .max900     { max-width:900px; 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; }
        .w15em { width:15em; }
        .w16em { width:16em; }

        .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%; }
        .w35p { width:35%; }
        .w38p { width:38%; }
        .w40p { width:40%; }
        .w50p { width:50%; }
        .w60p { width:60%; }
        .w70p { width:70%; }
        .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-420   { max-width: 420px; }
        .wrap-400   { max-width: 400px; }
        .wrap-350   { max-width: 350px; }
        .wrap-300   { max-width: 300px; }
        .tablet-max500 { max-width:500px; }
        .tablet-w540 { max-width:540px; }
        .tablet-w500 { max-width:500px; }
        
        .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%; }
        .tablet-w540 { max-width:330px; }
        .sp-w270 { max-width:270px; }
        }

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

       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; }
        
        @media screen and (max-width: 767px) {
        .sp-z2 { position: relative; z-index: 2; }
        }
        
        .relative { position: relative;}
        
        .hidden { overflow: hidden; }

        .img-border {
        box-sizing: border-box;
        border:1px solid rgb(0 0 0 / .3);
        }

        .radius,
        .radius video,
        .radius img { border-radius:25px; }
        .radius-s,
        .radius-s img { border-radius:15px; }
        .radius-ss,
        .radius-ss img { border-radius: 10px; }

        @media screen and (max-width: 1024px) {
        .radius,
        .radius video,
        .radius img { border-radius:15px; }
        .radius-s,
        .radius-s img { border-radius:8px; }
        .radius-ss,
        .radius-ss img { border-radius: 8px; }
        }
        @media screen and (max-width: 767px) {
        .radius,
        .radius video,
        .radius img { border-radius:8px; }
        .radius-s,
        .radius-s img { border-radius:7px; }
        .radius-ss,
        .radius-ss img { border-radius: 6px; }
        .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:rgb(0 0 0 / .5);
        width:100%;
        z-index: 1;
        }
        hr.line-w {
        position: relative;
        border: none;
        padding:0;
        height:1px;
        background:rgb(255 255 255 / .5);
        width:100%;
        z-index: 1;
        }
hr.dotted-line {
        position: relative;
        border: none;
        padding:0;
        margin:0 auto;
        height:6px;
        background: url("../images/parts/dotted-line.png") repeat-x;
        width:100%;
        z-index: 1;
        }
        @media screen and (max-width: 1024px) {
        hr.line {  }
        }
        @media screen and (max-width: 767px) {
        hr.line { }
        }

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

      　slick slider

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

.slide-caption {
        position: absolute;
        top:0;
        left:0;
        display: inline-block;
        padding:.5rem 1rem;
        box-sizing: border-box;
        background: rgb(0 0 0 / .65);
        color:#FFF;
        line-height: 100%;
        font-size:12px;
        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.h60p:after {
        content: "";
        display: block;
        padding-bottom:60%;
        }
        .slick-wrap.h62p:after {
        content: "";
        display: block;
        padding-bottom:62%;
        }
        .slick-wrap.h55p:after {
        content: "";
        display: block;
        padding-bottom:55%;
        }
        .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 .5s ease;
        transition: all .5s ease;
        }    
        .hover-zoom__image figure {
        -webkit-transition: all .5s ease;
        transition: all .5s ease;
        }
        .hover-zoom__image:hover figure,
        a:hover .hover-zoom__image figure {
        opacity: 1;
        -webkit-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);
        }

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

       サムネ付き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-h80  { height:  80px;}
        .tategaki-h120 { height: 120px;}
        .tategaki-h130 { height: 130px;}
        .tategaki-h140 { height: 140px;}
        .tategaki-h165 { height: 165px;}
        .tategaki-h166 { height: 166px;}
        .tategaki-h200 { height: 200px;}
        .tategaki-h210 { height: 210px;}
        .tategaki-h240 { height: 240px;}

        
        .tategaki-nomber { /* 数字のみ横 */
        display: inline;
        padding-bottom:.1em;
        padding-top:.1em;
        -webkit-text-combine: horizontal;
        text-combine-upright: all;
        }
        .tategaki-en { text-orientation: upright; }
        .combine { /* 一部横書き　まとめるタイプ */
        -ms-text-combine-horizontal: all;
        -webkit-text-combine: horizontal;
        text-combine-upright: all;
        padding-bottom: 0.65rem; /* 必要に応じて */
        }
        
        .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;
        }
        .vertical-lr .tategaki-inner {
        -ms-writing-mode: tb-lr;
        writing-mode: vertical-lr;
        }
        
        .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: 1350px) {
        .tategaki-h80  { height:  70px;}
        .tategaki-h120 { height: 105px;}
        .tategaki-h130 { height: 122px;}
        .tategaki-h166 { height: 152px;}
        .tategaki-h200 { height: 180px;}
        .tategaki-h210 { height: 200px;}
        }
        
        @media screen and (max-width: 1024px) {
        .tategaki-center.tablet-yokogaki .tategaki-outer { text-align: left;}
        .tategaki-center.tablet-yokogaki .tategaki-inner { -ms-writing-mode: lr-tb; writing-mode: horizontal-tb; display: block; }
        .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; }
        .tablet-yokogaki .tategaki-nomber {  font-family: "Zen Old Mincho", serif; }
        .tablet-left.tategaki-center .tategaki-outer { text-align: left; }
        .tategaki-center.tablet-yokogaki.tablet-left .tategaki-inner { text-align: left; }
        .tategaki-right.tablet-center .tategaki-outer { text-align: center; }
        
        .tategaki-h80  { height:  65px;}
        .tategaki-h120 { height:  98px;}
        .tategaki-h130 { height: 104px;}
        .tategaki-h140 { height: 130px;}
        .tategaki-h165 { height: 155px;}
        .tategaki-h166 { height: 128px;}
        .tategaki-h200 { height: 170px;}
        .tategaki-h210 { height: 165px;}
        .tategaki-h240 { height: 200px;}
        }
        @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; }
        .sp-yokogaki .ls015 { letter-spacing: .05em; }
        .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-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-yokogaki .tategaki-indent { display: inline; text-indent:0; }

            .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; }

            .tategaki-h80  { height:  55px;}
            .tategaki-h120 { height:  88px;}
            .tategaki-h130 { height: 100px;}
            .tategaki-h140 { height: 122px;}
            .tategaki-h165 { height: 150px;}
            .tategaki-h166 { height: 125px;}
            .tategaki-h200 { height: 162px;}
            .tategaki-h210 { height: 162px;}
            .tategaki-h240 { height: 165px;}

            .sp-hfree { 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;}
        .f20 {font-size:20px;}
        .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%; }
        .lh110 { line-height:110%; }
        .lh120 { line-height:120%; }
        .lh125 { line-height:125%; }
        .lh135 { line-height:135%; }
        .lh140 { line-height:140%; }
        .lh145 { line-height:145%; }
        .lh150 { line-height:150%; }
        .lh160 { line-height:160%; }
        .lh170 { line-height:170%; }
        .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;}
        .f20 {font-size:19px;}
        .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:39px;}
        .f51 {font-size:45px;}
        .f60 {font-size:50px;}
        .f69 {font-size:60px;}
        .f72 {font-size:63px;}
        .f75 {font-size:58px;}
        .f90 {font-size:81px;}
        .f180{font-size:162px;}
        
        .lh250 { line-height:240%; }
        }
        @media screen and (max-width: 1024px) {
        .f12 {font-size:11px;}
        .f13 {font-size:12px;}
        .f14 {font-size:12px;}
        .f15 {font-size:14px;}
        .f16 {font-size:15px;}
        .f17 {font-size:15px;}
        .f18 {font-size:17px;}
        .f20 {font-size:18px;}
        .f21 {font-size:20px;}
        .f24 {font-size:20px;}
        .f27 {font-size:21px;}
        .f30 {font-size:24px;}
        .f33 {font-size:25px;}
        .f36 {font-size:26px;}
        .f39 {font-size:32px;}
        .f45 {font-size:36px;}
        .f51 {font-size:39px;}
        .f60 {font-size:43px;}
        .f69 {font-size:55px;}
        .f72 {font-size:32px;}
        .f75 {font-size:45px;}
        .f90 {font-size:60px;}
        .f120{font-size:90px;}
        .f180{font-size:135px;}

        .lh170 { line-height:160%; }
        .lh180 { line-height:170%; }
        .lh220 { line-height:200%; }
        .lh235 { line-height:210%; }
        .lh250 { line-height:235%; }
        .lh300 { line-height:250%; }
        }
        @media screen and (max-width: 767px) {
        .f12 {font-size:10px;}
        .f13 {font-size:11px;}
        .f14 {font-size:12px;}
        .f15 {font-size:14px;}
        .f16 {font-size:15px;}
        .f17 {font-size:15px;}
        .f18 {font-size:16px;}
        .f20 {font-size:17px;}
        .f21 {font-size:19px;}
        .f24 {font-size:19px;}
        .f27 {font-size:21px;}
        .f30 {font-size:22px;}
        .f33 {font-size:25px;}
        .f36 {font-size:27px;}
        .f39 {font-size:29px;}
        .f45 {font-size:30px;}
        .f51 {font-size:32px;}
        .f60 {font-size:36px;}
        .f69 {font-size:40px;}
        .f72 {font-size:42px;}
        .f75 {font-size:42px;}
        .f90 {font-size:50px;}
        .f120{font-size:55px;}
        .f180{font-size:80px;}

        .lh170 { line-height:150%; }
        .lh175 { line-height:160%; }
        .lh180 { line-height:160%; }
        .lh200 { line-height:180%; }
        .lh220 { line-height:190%; }
        .lh235 { line-height:200%; }
        .lh250 { line-height:220%; }
        .lh300 { line-height:250%; }
        }
        @media screen and (max-width: 374px) {
        .f36 {font-size:22px;}
        .f27 {font-size:19px;}
        }

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

       デバイス

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

        .sp-none        { }
        .sp-on		    { display:none;}
        .sp-inline-on   { display:none;}
        .sp-inline-none { display: inline-block; }
        .tablet-on		{ display:none;}
        .tablet-none	{ display:block; }
        .w1480-on       { display: none; }
        .w1450-none     { display:inline-block; }
        .w1120-none     { display:inline-block; }
        .w1120-on       { display:none; }
        .w1280-none     { display:inline-block; }
        .w1200-none     { display:inline-block; }
        .w1200-on       { display:none; }
        .w1240-on       { display:none; }
        .w1240-none     { display: inline-block;}
        .w1300-none     { display:inline-block; }
        .w1300-on       { display:none; }
        .w1350-on       { display:none; }
        .w1215-on       { display:none; }
        .w1600on        { display: none; }
        .w820-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:1600px) {
        .w1600on { display: block; }
        }
        @media screen and (max-width:1500px) {
        .w1500-none { display: none; }
        }
        @media screen and (max-width:1480px) {
        .w1480-on { display: block; }
        }
        @media screen and (max-width:1450px) {
        .w1450-none { display: none; }
        }
        @media screen and (max-width: 1350px) {
        .w1350-none     { display:none; }
        .w1350-on     { display:block; }
        }
        @media screen and (max-width: 1300px) {
        .w1300-none       { display:none; }
        .w1300-on       { display:inline-block; }
        }
        @media screen and (max-width: 1280px) {
        .w1280none     { display:none; }
        }
        @media screen and (max-width: 1240px) {
        .w1240-none     { display:none; }
        .w1240-on     { display:block; }
        }
        @media screen and (max-width: 1215px) {
        .w1215-on       { display:block; }
        }
        @media screen and (max-width: 1200px) {
        .w1200-none       { display:none; }
        .w1200-on       { display:block; }
        }
        @media screen and (max-width: 1120px) {
        .w1120-none     { display:none; }
        .w1120-on       { display:block; }
        }
        @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: 820px) {
        .w820-on       { display:block; }
        }
        @media screen and (max-width: 767px) {
        .sp-none		{ display:none;}
        .sp-inline-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-122   { order: 1; }
        .flex-211   { order: 2; }
        .flex-333   { order: 3; }
        
        .flex-111   { order: 1; }
        .flex-233   { order: 2; }
        .flex-322   { 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;
        }
        .columns.is-content-center { /* 子要素の等間隔 + 中央揃え */
        justify-content: center;
        }
        .columns.is-flex-end { /* 子要素の右揃え */
        justify-content: 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;}
        .flex-122   { order: 2; }
        .flex-211   { order: 1; }
        .flex-333   { order: 3; }
        .flex-233   { order: 3; }
        .flex-322   { order: 2; }
        }
        @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; width:100%; }

        .flex-223   { order: 3; }
        .flex-332   { order: 2; }
        }

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

      　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;
        }
        
.intro-top {
        position: fixed;
        width:100%;
        height: 100%;
        z-index:-10;
        background:#000;
        animation: fadeOut 3.5s ease 0s 1 normal;
        -webkit-animation: fadeOut 3.5s 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:170px;
        opacity: 0;
        z-index: 2;
        animation: introLogo 2.5s ease 0s 1 normal;
        -webkit-animation: introLogo 2.5s ease 0s 1 normal;
        }
        @keyframes introLogo {
        0% { opacity: 0; filter: blur(10px); }
        35% { opacity: 1; filter: blur(0);}
        70% { opacity: 1; filter: blur(0);}
        90% { opacity: 0; filter: blur(10); z-index: -10;}
        100% { opacity: 0; z-index: -10; }
        }



