/*
 Theme Name:   generic Child 
 Theme URI:    https://picostrap.com
 Description:  Child theme for Picostrap5. Experience the power of SASS, merged with the WordPress Customizer. Implementing Bootstrap 5.3.6. Please refer to the <a target="_blank" href="https://picostrap.com/documentation/">documentation</a> to get started. 
 Author:       The LiveCanvas Team
 Author URI:   https://livecanvas.com
 Version:      4.0.1
 Template: generic 
*/

/*


Do not edit this file.

To add your own CSS, edit  the file: 

sass/_custom.scss 

...and add your own CSS (or SCSS!) statements.

To recompile the SASS bundle, click the "RECOMPILE SASS" link on top.

To edit the  SCSS pipeline, view and edit the file: sass/main.scss


*/





/*****  ICON
--------------------------------------------- */

@font-face {
  font-family: 'icomoon';
  src:  url('font/icomoon.eot?mgdqi2');
  src:  url('font/icomoon.eot?mgdqi2#iefix') format('embedded-opentype'),
    url('font/icomoon.ttf?mgdqi2') format('truetype'),
    url('font/icomoon.woff?mgdqi2') format('woff'),
    url('font/icomoon.svg?mgdqi2#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
}
[class^="icon-"], [class*=" icon-"] {
    font-family: 'icomoon' !important;
    speak: never;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}


.icon-instagram:before {
    content: "\ea92";
    font-weight: normal;
}

.icon-youtube:before {
    content: "\ea9d";
    font-weight: normal;
}

.icon-youtube2:before {
    content: "\ea9e";
    font-weight: normal;
}

.circle-circle:before {
    content: "\ea56";
    font-weight: normal;
}

.icon-allow:before {
    content: "\ea1c";
    font-weight: normal;
}


.box-social .icon {
    font-size: 25px;
    font-weight: 100;
}

.box-social ul {
    padding: 2px;
}

.box-social li {
    float: left;
    padding: 0 10px 0 0;
}




/*****  FONTS
--------------------------------------------- */

@font-face {
	font-family: 'hff-ultrasound';
		src: url('fonts/hff-ultrasound.woff') format('woff'),
		url('fonts/hff-ultrasound.woff2') format('woff2'),
		url('fonts/hff-ultrasound.ttf') format('truetype');
}
@font-face {
	font-family: 'gasca';
		src: url('fonts/gasca.woff') format('woff'),
		url('fonts/gasca.woff2') format('woff2'),
		url('fonts/gasca.ttf') format('truetype');
}
@font-face {
	font-family: 'square';
		src: url('fonts/square.woff') format('woff'),
		url('fonts/square.woff2') format('woff2'),
		url('fonts/square.ttf') format('truetype');
}
.montserrat-font {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}
.bebas-neue-regular {
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  font-style: normal;
}

/*======================================================================
||
||    COMMON
||
======================================================================*/

*, *::before, *::after {
    box-sizing: border-box;
}

.font-hffultrasound {
    font-family: hff-ultrasound;
}
.font- {
    font-family: square;
}
.font-FROSTBITE-Narrow-Bold {
    font-family: FROSTBITE-Narrow-Bold;
}


.font-bebas-neue-regular {
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.font-gasca {
  font-family: "gasca", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.press-start-2p-regular {
  font-family: "Press Start 2P", system-ui;
  font-weight: 400;
  font-style: normal;
}
.saira-stencil-one-regular {
  font-family: "Saira Stencil One", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.rubik-font {
  font-family: "Rubik", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

/*======================================================================
||
||    FOOTER
||
======================================================================*/

.site-footer {
    background-color: #062f4f;
    color: #ffffff;
}
.footer-main {
    max-width: calc(1200px + 2rem);
    margin: 0 auto;
    padding-top: 4em;
    padding-bottom: 1em;
    overflow: hidden;
    background-attachment: fixed;
}
.footer-main .icon-logo-head:before {
    content: "\e900";
    font-weight: normal;
    color: #ffffff;
    font-size: 5.5rem;
    padding: 0;
}

.footer-main .container {
    max-width: calc(1260px + 2rem);
    background: unset !important;
}

.footer-main .copyright {
    color: #fff;
    font-size: 1.2rem;
}

.footer .footer-link-box {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    display: inline-block;
}
#footer-info-box {
    width: 35%;
    float: left;
    padding: 25px;
}
#footer-link-box {
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
    max-width: 50%;
    width: 100%;
    margin: 0 auto;
    padding: 25px;
    float: right;
}
#footer-info {
    font-size: 14px;
    line-height: 1.3;
    list-style: none;
}
#footer-link-box dl {
    margin-bottom: 30px;
}

#footer-link-box dl {
    margin-bottom: 30px;
}
#footer-link-box dt {
    margin-bottom: 4px;
    font-size: 1.5rem;
    font-weight: 600;
}
#footer-link-box dd {
    margin-bottom: 5px;
    font-size: 1.2rem;
    letter-spacing: 0;
}
#footer-link-box a {
    color: #fff;
    text-decoration: none;
}

.footer-main .map-google {
    padding: 20px;
    display: block;
    height: auto;
}

.breadcrumbs__list {
    margin: 0;
    padding: 1.2rem 0;
}
.breadcrumbs__item {
    display: inline;
    margin-left: .5em;
    font-size: 1.5rem;
    font-family: Noto Sans JP, 'Lato', sans-serif;
}
.breadcrumbs__item:before {
    margin-right: .25em;
    content: ">";
    font-family: 'Oswald', sans-serif;
    font-size: 1.6rem;
}


@media only screen and (max-width:1180px){
#footer-link-box {
    max-width: 65%;
}
}

@media only screen and (max-width:970px){
#footer-link-box {
    display: inline-block;
}
#footer-link-box div {
    width: 50%;
    display: block;
    float: left;
}
}
.footer-logo {
    color: #fff;
    font-family: 'altehaasgroteskbold';
    font-size: 3.8rem;
    font-weight: 100;
    padding: 5px 0 15px;
    line-height: 1;
    letter-spacing: 0;
    width: 100%;
}
.footer-logo-index {
    color: #fff;
    font-size: 2.8rem !important;
    font-weight: 600;
    line-height: 1.5;
    padding: 0 0 10px 0 !important;
    margin: 0;
    background: unset !important;
    letter-spacing: 2.5px;
}
.footer-logo-sub {
    color: #fff;
    font-size: 1.4rem !important;
    padding: 0 !important;
    margin: 0;
    background: unset !important;
    letter-spacing: 2.5px;
}

.footer-adds {
    color: #fff !important;
    font-size: 1.6rem;
    background: unset !important;
    line-height: 1.6;
    padding: 0 0 0 0px;
    margin: 0;
}
.footer-tel {
    color: #fff !important;
    font-size: 2rem;
    padding: 2px 0 !important;
    font-family: 'Bebas Neue', cursive;
    background: unset !important;
    font-weight: 100;
    line-height: 0.8;
}

@media only screen and (max-width:768px){
#footer-info-box, #footer-link-box {
    width: 100%;
    max-width: 100%;
    padding: 40px 10px 50px;
}
#footer-link-box {
    padding: 5px;
}
#footer-link-box div {
    width: 100%;
}
#footer-link-box dl {
    margin: 0;
    width: 100%;
    display: flow-root;
}
#footer-link-box dt {
    padding: 15px 0 5px 0;
    margin: 0;
    font-size: 1.5rem;
    text-align: left;
}
#footer-link-box dd {
    margin: 0;
    padding: 0 8px 0;
    float: left;
}
.footer-logo-index {
    text-align: center;
}
}
@media only screen and (max-width:480px){
#footer-link-box {
    padding: 5px;
}
#footer-link-box dt {
    padding: 15px 0 0 0;
    margin: 0;
    font-size: 1.4rem;
}
.footer-logo, .footer-logo-sub, .footer-adds, .footer-tel {
    text-align: center;
    background: unset !important;
    color: #fff !important;
}
}

@media only screen and (max-width:360px){
#footer-link-box div {
    width: 100%;
    display: block;
    float: left;
}
#footer-link-box dl {
    margin: 0;
    padding: 0 0 15px;
    display: table;
    width: 100%;
}

.joto-logo {
    font-size: 34px !important;
    width: 100% !important;
}
}

.footer-copy {
    text-align: center;
    display: inline-block;
    width: 100%;
}



/*======================================================================
||
||    GENERAL STYLES
||
======================================================================*/
html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    font-size: 62.5%;;
}

body {
    font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Noto Sans JP,sans-serif;
    line-height: 1.5;
    color: #5c6b80;
    margin: 0;
    background: unset;
    -webkit-font-smoothing: antialiased; 
}

#header, #container, #footer {
    padding: 0;
}
#header {
    background: unset;
}
p {
    margin: 0;
    padding: 0;
    font-size: 1.65rem;
    line-height: 1.8;
}
strong {
    font-size: 1.4rem;
}

ol, ul {
    box-sizing: border-box;
    list-style: none;
}


h1, h2, h3, h4, h5, h6 {
    margin: 0 0 15px 0;
    font-family: "Helvetica Neue", 'Noto Sans JP',Helvetica,Arial,sans-serif;
    font-weight: normal;
    color: #444;
    text-transform: none;
}

audio, canvas, img, svg, video {
    width: 100%;
    height: auto;
    box-sizing: border-box;
}

/*======================================================================
||
||    LINK STYLES
||
======================================================================*/
a:hover, a:focus, a:visited:hover, a:visited:focus {
    color: #dddddd;
}
a:link {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0.3);
    text-decoration: none;
    color: #212121;
}
a:visited {
    color: #212121;
}
.footer a:visited {
    color: #e9e9e9;
}
h1 a, .h1 a, h2 a, .h2 a, h3 a, .h3 a, h4 a, .h4 a, h5 a, .h5 a {
    color: #212121;
    text-decoration: none;
}

h1, .h1 {
    font-size: 2.5em;
    line-height: 1.3;
}
h2, .h2 {
  font-size: 1.75em;
  line-height: 1.4em;
  margin-bottom: 0.375em; }

h3, .h3 {
  font-size: 1.125em; }

h4, .h4 {
  font-size: 1.1em;
  font-weight: 700; }

h5, .h5 {
  font-size: 0.846em;
  line-height: 2.09em;
  text-transform: uppercase;
  letter-spacing: 2px;
}

#content {
    margin-top: 0;
    display: inline-block;
    width: 100%;
    padding: 100px 0;
}

.post-template-default #content {
    padding: 0;
}
.post-template-default #content {
    background: #eeeeee
}
.post-template-default .entry-content {
    padding: 20px;
    min-height: 700px;
}
.post-template-default .entry-content .inbox {
    background: #fff;
    border-radius: 15px;
    padding: 35px 25px;
    min-height: 600px;
}


/*======================================================================
||
||    ARCHIVE
||
======================================================================*/


/*======================================================================
||
||    SINGLE
||
======================================================================*/

.section-entry-index {
    position: relative;
}

.section-entry-index .bg-image.master, .section-entry-index .bg-shader.master {
    height: 600px;
    position: absolute;
    z-index: 1;
    top: 0;
    right: 0;
    left: 0;
}

.section-entry-index .bg-image.master {
    background-repeat: no-repeat;
    background-position: center top;
}
.section-entry-index .bg-image {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.section-entry-index .bg-image.master, .section-entry-index .bg-shader.master {
    height: 460px;
    position: absolute;
    z-index: 1;
    top: 0;
    right: 0;
    left: 0;
}
.single .section-entry-index .section-inner {
    padding: 150px 15px 0;
    position: relative;
    z-index: 10;
    min-height: 260px;
    width: 100%;
    max-width: 1050px;
    margin: 0 auto;
    position: relative;
}
.section-entry-index .blog-title {
    color: #fff;
    background: unset;
    font-size: 6rem;
    font-family: "Quicksand", sans-serif;
    margin: 0;
    padding: 0;
    font-weight: 600;
    line-height: 0.9;
    color: white;
}
.section-entry-index .blog-title span {
    font-size: 2.3rem;
    padding: 8px 0;
    margin: 0;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.8);
    text-align: left;
    display: block;
    position: relative;
}

.entry-content {
    max-width: 1000px;
}

.entry-content, .entry-page {
    background: #fff;
    padding: 3px;
    margin-bottom: 25px;
    margin: 0 auto 60px;
    position: relative;
    z-index: 3;
}
.editor-styles-wrapper, .entry-content {
    counter-reset: footnotes;
}



.single h1.entry-title a {
    color: #2b2a2a;
    text-decoration: none;
}
.single-post h2 {
    font-size: 2.3rem;
    padding: 6px 10px !important;
    background: #f1eaea;
    border-radius: 3px;
}
.single-post h3 {
    font-size: 1.6rem;
    color: #5a5555;
    background: #eee;
    border-radius: 3px;
    padding: 6px 8px !important;
    margin: 5px 0 3px 0 !important;
}
.single-post h4 {
    font-size: 2rem;
    padding: 5px !important;
}
.single-post h5 {
    font-size: 1.8rem;
    padding: 5px !important;
}
.single-post h6 {
    font-size: 1.7rem !important;
    padding: 4px 5px !important;
}
.page #content p, .single-post #content p {
    font-size: 1.6rem;
    line-height: 1.8;
    margin: 0;
    padding: 8px 5px 15px;
}
.page p {
    font-size: 1.62rem;
    line-height: 1.9;
    margin: 0;
    padding: 15px;
}
.page h3, .page h4, .page h5, .page h6 {
    margin: 0;
    line-height: 1.4;
    letter-spacing: 0.1rem;
}
.single-post p {
    font-size: 1.6rem;
    line-height: 1.9;
    margin: 0;
    padding: 15px;
    color: #4b4b4b;
}


.post .entry-meta {
    font-size: 16px;
    color: #040404;
    margin: 0;
    padding: 2px 1px;
    text-align: right;
}


.entry-content {
    max-width: 1000px;
}

.entry-content .inbox {
    padding: 30px 30px 40px;
    min-height: 700px;
    height: auto;
}
.type-post footer{
    max-width: 1000px;
    margin: 20px auto;
    text-align: right;
}

.genre {

}

.info {
    background: #ef0e0e;
}
.blog {
    background: #009688;
}
.event {
    background: #1383dc;
}

type-post {
    max-width: 1000px;
    position: relative;
    margin: 0 auto;
    z-index: 3;
}
.entry-title {
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.3;
}

.singular-article {
    padding: 30px 35px;
}

.singular-header__meta {
    font-size: 1.5rem;
}


.post-navigation {
    max-width: 1050px;
    margin: 0 auto;
    display: flex;
    padding: 25px;
}
.nav-links {
    margin-top: 30px;
    display: inline-block;
    width: 100%;
}
.nav-links a, #nav-above a {
    text-decoration: none;
    word-break: break-all;
}
.nav-previous, .nav-next {
    width: 100%;
    display: inline-block;
}

@media only screen and (max-width: 1060px) {
.type-post {
    padding: 15px;
}
}
@media only screen and (max-width: 860px) {
.single-post .title-section .section-inner {
    padding: 180px 20px 0;
    min-height: 290px;
}
.entry-content .inbox {
    padding: 20px 18px 30px;
}
.entry-title {
    font-size: 2.4rem;
}
#content p {
    font-size: 1.5rem;
}
.single-post .blog-title {
    font-size: 4rem;
}
}
@media only screen and (max-width: 580px) {
.entry-title {
    font-size: 2rem;
}
.page #content p, .single-post #content p {
    font-size: 1.4rem !important;
}
.single-post .blog-title {
    font-size: 3rem;
}
.single-post .blog-title span {
    font-size: 1.8rem;
}
}


.entry-content a {
}
.size-medium {
    width: 32.7%;
    padding: 1px;
    margin: 0;
}
@media only screen and (max-width: 860px) {
.size-medium {
    width: 48.5%;
}
}
@media only screen and (max-width: 440px) {
.size-medium {
    width: 100%;
}
.nav-links a, #nav-above a {
    font-size: 1.2rem;
}
}


.wp-block-algori-pdf-viewer-block-algori-pdf-viewer {
    width: 100%;
    margin: 15px auto;
    max-width: 780px;
    min-height: 500px;
    max-height: 800px;
}

.page-template-booking .table-contact {
    padding: 0;
    margin: 0 0 0px;
    border-spacing: 0 5px;
    border-top: 0px;
}

.table-contact p, .full-tr .page p {
    padding: 0 15px;
}


.section-page-calender {
    padding: 20px 20px 50px;
}

.section-page-calender iframe {
    border: 0;
    border-radius: 10px;
}
.section-page-calender .Sp1EOc {
    display: none;
}

@media only screen and (max-width: 860px) {
.section-page-calender {
    padding: 20px 0px 50px;
}
.section-page-calender p {
        font-size: 1.5rem;
        padding: 0;
}
.table-contact p, .full-tr .page p {
    padding: 0;
}
input, textarea {
    font-size: 16px;
    padding: 8px;
}
}





.box-first-banner ul {
    max-width: 1310px;
    margin: 0 auto;
    padding: 3px;
    display: flow-root;
}
.box-first-banner li {
    width: 50%;
    margin: 0 auto;
    padding: 10px 10px;
    float: left;
}

.box-first-banner {
    height: auto;
    display: flow-root;
}

.box-first-banner li {
    padding: 3px 6px;
    display: inline-flex;
}
.box-first-banner p {
    color: #7f4443;
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1;
    padding: 5px;
}

.box-first-banner .icon {
    float: left;
    padding: 2px 0;
    background-color: unset;
}


.box-first-banner .icon:before {
    font-size: 2.4rem;
    color: #7f4443;
    background: unset;
}
.box-first-banner .inbox {
    display: inline-block;
    height: auto;
    border: 5px solid #7f4443;
    border-radius: 15px;
    position: relative;
    padding: 0;
    width: 100%;
}

.box-first-banner .txt {
    padding: 35px 10px;
}





.box-first-banner2 .icon:before {
    font-size: 2.4rem;
    color: #7f4443;
    background: unset;
}
.box-first-banner2 .inbox {
    display: inline-block;
    height: auto;
    border: 0px solid #000000;
    border-radius: 5px;
    position: relative;
    padding: 0;
    width: 100%;
}
.box-first-banner2 .txt {
    padding: 7px 10px;
}
.box-first-banner2 p {
    color: #000000;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1;
    padding: 6px 0 0 0;
    margin: 0;
}
.box-first-banner2 .icon {
    float: left;
    padding: 3px 0;
    background-color: unset;
}
.box-first-banner2 .icon:before {
    font-size: 2rem;
    color: #000000;
    background: unset;
}




.ec-message-shadow01 {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  color: #ffffff;
  font-size: 50px;
  text-shadow: 2px 2px 3px rgba(4, 4, 4, 0.4);
  font-weight: bold;
}



@media only screen and (max-width:900px){
.box-first-banner p {
    color: #7f4443;
    font-size: 1.5rem;
}
.box-first-banner .icon {
    display: inline-block;
    width: 25px;
}
.box-first-banner .icon:before {
    font-size: 2rem;
}
}
@media only screen and (max-width:760px){
    .box-first-banner li {
        width: 100%;
        margin: 0 auto;
        padding: 6px 8px;
    }
    .box-first-banner .inbox {
        height: auto;
    }
    .box-first-banner .txt {
        padding: 22px 10px;
    }
.box-first-banner .icon {
    padding: 3px 0;
}
.box-first-banner p {
    font-size: 1.7rem;
    font-weight: 600;
}
}


.to_nextform {
    height: auto;
    padding: 0 10px 10px;
    position: relative;
    z-index: 100;
    text-align: right;
    max-width: 1120px;
    margin: 0 auto;
}
.to_nextform .icon {
    float: right;
    color: unset;
    background: unset;
    height: 32px;
    width: 32px;
    padding: 2px;
    position: relative;
}
.to_nextform .icon-play2:before {
    content: "\ea15";
    font-weight: normal;
    color: #ffffff;
    font-size: 25px;
}
.to_nextform p {
    color: #fff;
    font-size: 1.9rem !important;
    font-weight: 500;
    padding: 5px;
    line-height: 1;
}
.wpcf7 form .wpcf7-response-output {
    font-size: 130%;
}
@media only screen and (max-width:1100px){
.to_nextform {
    height: auto;
    padding: 0 3% 10px;
}
}
@media only screen and (max-width:520px){
.to_nextform {
    height: auto;
}
.to_nextform p {
    color: #fff;
    font-size: 1.5rem !important;
    font-weight: 500;
    padding: 5px;
    line-height: 1;
}
.to_nextform .icon {
    height: 28px;
    width: 28px;
}
.to_nextform .icon-play2:before {
    content: "\ea15";
    font-weight: normal;
    color: #ffffff;
    font-size: 20px;
}
}



.paddingtop20px {
    padding-top: 30px;
}


/*======================================================================
||
||    COMMON
||
======================================================================*/

.width1400 {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 15px;
}
.width1300 {
    width: 100%;
    max-width: 1300px;
    margin: 0 auto;
    padding: 15px;
}

.color232323 {
    color: #232323;
}
.colore24822 {
    color: #e24822;

}

.borderradius10 {
    border-radius: 10px;
}


/*  ???
--------------------------------------------- */
.box-btn02r {
    padding: 10px;
    position: absolute;
    bottom: 5px;
    left: 5px;
}
.btn02 {
    width: 200px;
    text-align: center;
    display: inline-block;
    padding: 0.3em 1em;
    color: #ffffff !important;
    background: #781616;
    border: solid 3px #781616;
    border-radius: 32px;
    transition: .4s;
    font-size: 1.6rem;
    font-weight: 500;
    font-family: 'Noto Sans JP', sans-serifP;
    -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, .30);
    box-shadow: 0 3px 5px rgba(0, 0, 0, .30);
}
.btn02:hover {
    background: #ffffff;
    color: #d40077 !important;
    border: solid 3px #d40077;
}

@media (max-width: 768px) {
.btn02 {
    width: 125px;
    padding: 0.3em 1em;
    border: solid 3px #781616;
    border-radius: 32px;
    font-size: 1.3rem;
    font-weight: 500;
}
}

.sv_effect {
    opacity: 0;
    visibility: hidden;
    transform: translateY(40px);
    transition: all 1s;
}
.is-show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
}

.boxshadow01 {
    box-shadow: 0 3px 5px rgba(0, 0, 0, .30);
}

.sm-ec {
    display: none;
}


.box-jump {
    width: 100%;
    max-width: 500px;
    padding: 10px 0 30px;
    display: block;
    float: right;
}
.list-jump03 {
    width: 100%;
    margin: 0;
    float: right;
    border-right: 1px solid;
    display: contents;
}
.list-jump03 li {
    float: left;
    width: 33.333%;
    text-align: center;
    border-right: 1px solid #555;
}
.list-jump03 li p {
    font-family: jambetica-light;
    text-align: center;
    font-weight: 600;
    padding: 5px;
}
@media only screen and (max-width:768px){
.sm-ec {
    display: block;
}
.pc-ec {
    display: none;
}
}

@media only screen and (max-width:600px){
.box-jump {
    width: 100%;
    margin: 0 auto;
    padding: 10px 0 30px;
    display: block;
    float: unset;
}

.list-jump03 li {
    width: 33.333%;
    display: block;
    float: left;
    padding: 5px;
    border-right: 0;
    border-bottom: 0;
}
.list-jump03 li p {
    font-size: 0.9rem;
    border: 1px solid;
}
}
@media only screen and (max-width:540px){
.list-jump03 li {
    width: 50%;
}
}
.icon_page_top {
    max-width: 60px !important;
    height: auto;
}
#page_top {
    position: fixed;
    bottom: 10px;
    right: 20px;
    z-index: 7000;
}
#page_top a {
    text-align: center;
    text-decoration: none;
    padding: 0;
    font-size: 0;
}
#page_top a:hover {
    background-color: #555;
    text-decoration: none;
}

/*======================================================================
||
||    TABLE
||
======================================================================*/


.table02 {
    border-collapse: separate;
    border-spacing: 2px;
    float: left;
    width: 100%;
    padding: 8px;
}
.table02 th, .table02 td {
    font-family: 'Noto Sans JP', sans-serifP;
    font-size: 1.3rem;
    line-height: 1.3;
    padding: 10px;
    vertical-align: top;
    font-weight: 500;
}
.table02 th {
    font-size: 1.6rem;
    margin-bottom: 0;
    font-weight: 500;
    text-shadow: -1px -1px #6c6161, 1px 1px 3px #1a1818;
    padding: 10px 25px;
    text-align: left;
    background: #750303;
    width: 20%;
    color: #fff;
    border-radius: 3px;
}
.table02 td {
    color: #2f2d2d;
    font-size: 1.6rem;
    margin-bottom: 0;
    font-weight: 500;
    background: #f5f5f5;
    border-radius: 3px;
}

@media screen and (max-width:680px){
.table02 {
    border-collapse: separate;
    border-spacing: 4px;
    float: left;
    padding: 0;
}
.table02 th, .table02 td {
    padding: 10px !important;
    text-shadow: unset;
    display: block;
    width: 100%;
    font-size: 1.4rem;
}
}

/* TABLE01 */
.table-price td, .table-price th {
    padding: 3px;
    width: 20%;
}
.box-table {
    padding: 0px;
    border: none;
    width: 100%;
    display: inline-block;
}
.table-price {
    border-collapse: separate;
    border-spacing: 4px;
    float: left;
    width: 100%;
    padding: 10px;
    margin: 0;
}

.table-price th, .table-price td {
    font-size: 1.3rem;
    line-height: 1.3;
    padding: 18px 10px;
    vertical-align: top;
    font-weight: 500;
}
.table-price th {
    font-size: 1.5rem;
    font-family: 'Noto Sans JP', sans-serifP;
    margin-bottom: 0;
    font-weight: 500;
    text-shadow: -1px -1px #6c6161, 1px 1px 3px #1a1818;
    text-shadow: -1px -1px #444, 1px 1px 3px #444;
    padding: 18px 25px;
    text-align: left;
    background: #433f58;
    width: 20%;
    color: #fff;
}
.table-price td {
    color: #f8f9fa;
    font-size: 1.5rem;
    font-family: 'Noto Sans JP', sans-serifP;
    margin-bottom: 0;
    font-weight: 500;
}

.table-price th {
    margin-bottom: 0;
    padding: 10px 25px;
    text-align: left;
    width: 15em;
}
.table-price .td01 {
    background: url(img/wall01.png);
}
.table-price .td02 {
    background: #b14a6b;
    text-align: center;
}
.table-price .td03 {
    background: #a23f5f;
    text-align: center;
}
.table-price .td04 {
    background: #a23f5f;
    padding: 15px 10px;
    letter-spacing: 0.5px;
}
.table-price .td05 {
    background: #ffffff;
    padding: 15px 0 0 10px;
    color: #000000;
}
.table-price .td05 span {
    display: none;
}
.box-table p {
    font-size: 1.5rem;
    font-weight: 400;
}
.section-about .coution {
    display: inline-block;
    padding: 0 15px;
}


@media screen and (max-width:680px){
.box-table {
    padding: 5px;
}
.table-price {
    border-collapse: separate;
    border-spacing: 5px;
    float: left;
    width: 100%;
    padding: 0;
}
.table-price .td05 {
    border-width: 2px;
}
.table-price th, .table-price td {
    font-size: 1.5rem;
    line-height: 1.3;
    padding: 15px 10px;
    vertical-align: top;
    font-weight: 500;
    border-color: unset;
}
.table-price td {
    display: block;
    width: 100%;
}
.table-price .td02, .table-price .td03 {
    display: none;
}
.table-price .td04 {
    background: #a23f5f;
    padding: 8px 10px;
    letter-spacing: 0.5px;
}
.table-price .td05 {
    background: #ffffff;
    padding: 8px 0 8px 10px;
    color: #000000;
    border-color: #f1f0ea;
    font-size: 1.3rem;
}
.table01 .td05 {
    padding: 24px 0 0 10px;
    border-bottom: 4px solid #fff;
}
.table-price .td05 span {
    display: block;
    float: left;
    padding: 0 5px 0 0;
}
}


/*======================================================================
||
||    LAYOUT
||
======================================================================*/




.layout-left-pic, .layout-right-pic {
    padding: 75px 0 30px;
    margin: 0 auto;
    display: table;
    position: relative;
    width: 100%;
}
.layout-left-pic ul, .layout-right-pic ul {
    display: inline-block;
    font-size: 0;
}
.layout-left-pic li, .layout-right-pic li {
    width: 25%;
    float: left;
    padding: 2px;
    font-size: 0;
}

.layout-left-pic img, .layout-right-pic img {
    width: 100%;
    padding: 0px;
    border-radius: 8px;
    background: #ffffff;
}


.layout-right-pic .right {
    float: right;
    margin: 0 0 0 2.8vw;
    padding: 0;
    width: 50%;
}
.layout-left-pic .left {
    float: left;
    margin: 0 2.8vw 0 0;
    padding: 0;
    width: 50%;
}
.layout-left-pic h3, .layout-right-pic h3 {
    font-size: clamp(1.8rem, 4vw, 3.3rem);
    padding: 0 0 20px;
    font-weight: 400;
}
.layout-left-pic h4, .layout-right-pic h4 {
    font-size: 3rem;
    font-weight: 400;
}
@media(max-width:768px) {
.layout-left-pic, .layout-right-pic {
    padding: 0px;
    width: 100%;
}
.layout-right-pic .right, .layout-left-pic .left {
    float: unset;
    margin: 0;
    width: 100%;
}
.layout-left-pic li, .layout-right-pic li {
    font-size: 0;
}
.layout-right-pic img, .layout-right-pic img {
    width: 100%;
    margin: 0;
}
.layout-left-pic h3, .layout-right-pic h3 {
    padding: 15px 0 20px;
}
.layout-left-pic h4, .layout-right-pic h4 {
    font-size: 2.1rem;
}
}

.section-about {
    padding: 50px 0;
}


/*=== TOP>BACKGOROUND-AREA ====*/

.bg-photo {
    display: flex;
    align-items: center;
    /* justify-content: center; */
    flex-direction: column;
    position: relative;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}
.bg-photo::before {
    content: "";
    background-color: rgba(0, 0, 0, 0.3);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 0;
}

.bg-photo .in-box {
    z-index: 1;
    width: 100%;
    margin: 0 auto;
    max-width: 1300px;
    height: 100vh;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    position: relative;
}

/*=== ROLLING ====*/

.fullPageScroll {
    width: 100%;
    height: 100vh;
    overflow-y: inherit;
    height: auto;
}

.section {
}

.pagination a.active {
  transform: scale(1.8);
}
.roll-section {
    width: 100%;
    height: 100vh;
    min-height: 99vh;
    overflow: hidden;
    backface-visibility: hidden;
}

.heighauto {
    height: auto !important;
}

.pagination a.active {
  transform: scale(1.8);
}


/*======================================================================
||
||    PAGE COMMON
||
======================================================================*/

.index-page01 {
    font-size: 4rem;
    font-weight: 300;
    margin: 0;
}

.index-section01 {
    text-align: center;
    margin: 0 auto;
    padding: 60px 0 10px;
    display: block;
    letter-spacing: 1px;
    line-height: 1.2;
    color: #000;
    font-size: 3.5rem;
    font-family: jambetica-light;
}

.index-section01 {
    padding: 30px 10px 10px;
    margin: 0 auto;
}

.index-section01 h3 {
    font-size: 10vw;
    text-align: left;
    font-weight: 200;
    line-height: 0.85;
    padding: 0;
    border-bottom: 3px solid;
    margin: 0;
    font-family: "Bebas Neue", sans-serif;
}

.index-section01 h3 span {
    font-size: 3rem;
    letter-spacing: 1px;
    padding: 0 15px;
    font-weight: 300;
}



.index-section02 {
    padding: 30px 10px 10px;
    margin: 0 auto;
}
.index-section02 h3 {
    font-size: 5.5vw;
    text-align: center;
    display: flex;
    font-weight: 200;
    line-height: 0.8;
    padding: 0;
    border-bottom: 3px solid;
    margin: 0;
    font-family: "Bebas Neue", sans-serif;
    flex-direction: row;
    align-items: baseline;
    flex-wrap: nowrap;
}
.index-section02 h3 span {
    font-size: 30%;
    letter-spacing: 1px;
    padding: 0 15px;
    font-weight: 400;
}

.index-section05 {
    padding: 30px 10px 10px;
    margin: 0 auto;
}
.index-section05 h3 {
    font-size: 6.5vw;
    text-align: right;
    display: flex;
    font-weight: 200;
    line-height: 0.8;
    padding: 0;
    border-bottom: 3px solid;
    margin: 0;
    font-family: "Bebas Neue", sans-serif;
    flex-direction: row-reverse;
    align-items: baseline;
}
.index-section05 h3 span {
    font-size: 3rem;
    letter-spacing: 1px;
    padding: 0 15px;
    font-weight: 400;
}
@media only screen and (max-width:979px){
.index-section01 {
    font-size: 6.5vw;
}
}
@media(max-width:768px) {
.index-section01 {
    font-size: 2.5rem;
}
.index-section01 h3 {
    font-size: 7vw;
}
}
@media only screen and (max-width:680px){
.index-section01 {
    font-size: 2rem;
}
.index-section01 div {
    line-height: 1.5;
    font-size: 2rem;
}
}

/*======================================================================
||
||    HEADER STYLES
||
======================================================================*/

.header {
    position: fixed;
    z-index: 15;
    width: 100%;
}

#logo {
    margin: 0.75em 0;
}

#logo a {
    color: #ffffff;
    font-family: Vollkorn;
    font-size: 2rem;
    font-weight: 600;
}


/*======================================================================
||
||    TITLE
||
======================================================================*/

.site-title {
    margin: 0;
    padding: 0;
    font-size: unset;
}
.mc-brand__sub {
    font-size: clamp(15px, 3vw, 34px);
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;
    margin: 0;
    padding: 0;
    letter-spacing: 2px;
}

.mc-brand__name {
    font-size: clamp(13px, 2vw, 14px);
    font-weight: 500;
    letter-spacing: 2px;
    padding: 0 0 0 10px;
}

.single-post .mc-brand__sub, .single-post .mc-brand__name {
    color: #fff;
    text-shadow: 0px 0px 1px #e5e5e5, 0px 0px 1px #b9b9b9, 0px 0px 3px #838383, 0px 0px 3px #676767, 0px 0px 4px #333333;
}

@media (max-width: 880px) {
    .mc-brand__sub {
        font-size: 2.5rem;
    }
}
@media (max-width: 380px) {
    .mc-brand__sub {
        font-size: 2rem;
    }
.mc-brand__name {
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0;
    padding: 0 0 0 3px;
}
}


/*======================================================================
||
||    LOGO
||
======================================================================*/


.center-logo {
    CONTAIN-INTRINSIC-BLOCK-SIZE: AUTO 100PX;
    padding: 12% 0 0 0;
    color: #000000;
    width: 36vw;
    font-size: 2vw;
    font-family: Noto Sans JP;
    line-height: 1.1;
    font-weight: 400;
    z-index: 9;
    position: relative;
    color: #ffffff;
}
.center-logo span {
    font-size: 14.6vw;
    letter-spacing: 2px;
    display: flex;
    align-content: flex-end;
    align-items: baseline;
    justify-content: center;
}

.center-logo span div {
    font-size: 40%;
}


@media (max-width: 970px) {
.center-logo {
    padding: 37% 0 0 0;
    width: 60vw;
    font-size: 4vw;
    line-height: 1.1;
    z-index: 9;
    position: relative;
}
.center-logo span {
        font-size: 17.2vw;
    }
}


/*********************

NAVIGATION STYLES

*********************/


.global-navigation {
    padding: 0 80px 0 0;
}
.nav {
    border-bottom: 0;
    position: relative;
    display: flex;
    padding: 0;
    width: 100%;
    margin: 0;
    gap: 20px;
}
.nav ul {
     background: #323944;
     margin-top: 0; 
}
.nav li {
    position: relative;
    font-weight: 600;
    padding: 0;
    width: auto;
    margin: 0 auto;
    text-align: center;
}

.hidden-menu-main .item0 a::after {
    content: unset;
}

.menu-last::after {
    content: "" !important;
}

.nav li a {
    font-size: 1.7rem;
    font-weight: 500;
    font-family: "Quicksand", sans-serif;
    float: left;
    letter-spacing: 2.2px;
    line-height: 1.1;
    padding: 0 5px;
    color: #040404;
}
.nav li span {
    font-size: 10px;
    display: block;
    line-height: 1.1;
    width: auto;
    text-align: center;
    padding: 0 0px 3px;
    font-family: 'Josefin Sans', sans-serif;
}
.nav li a:hover, .nav li a:focus {
    text-decoration: underline;
}
.nav li a:hover {
    text-decoration: none !important;
    color: #d0c1c1 !important;
}

.nav li ul.sub-menu, .nav li ul.children {
    margin-top: 0;
    border: 1px solid #ccc;
    border-top: 0;
    position: absolute;
    visibility: hidden;
    z-index: 8999;
}
        .nav li ul.sub-menu li,
        .nav li ul.children li {
          /*
          if you need to go deeper, go nuts
          just remember deeper menus suck
          for usability. k, bai.
          */ }
          .nav li ul.sub-menu li a,
          .nav li ul.children li a {
            padding-left: 10px;
            border-right: 0;
            display: block;
            width: 180px;
            border-bottom: 1px solid #ccc; }
          .nav li ul.sub-menu li:last-child a,
          .nav li ul.children li:last-child a {
            border-bottom: 0; }
          .nav li ul.sub-menu li ul,
          .nav li ul.children li ul {
            top: 0;
            left: 100%; }
.nav li:hover > ul {
    top: auto;
    visibility: visible;
}

.menu-last a::after {
    content: ' ' !important;
    margin: 0;
}
.nav li ul.sub-menu li a, .nav li ul.children li a {
    padding-left: 30px;
}



.wrap {
    max-width: 1320px;
    width: 100%;
    margin: 0 auto;
}
.wrap-header {
    padding: 0;
}





.neon0 {
    text-shadow: 0px 0px 1px #ffffff, 0px 0px 1px #f7f7f7, 0px 0px 1px #f2f2f2, 0px 0px 1px #ece9e9, 0px 0px 8px #dedbdb;
    0px 0px 100px #ffffff: ;
}
.neon1 {
    text-shadow: 0px 0px 1px #ffffff, 0px 0px 1px #f7f7f7, 0px 0px 3px #f2f2f2, 0px 0px 3px #ece9e9, 0px 0px 4px #eaeaea;
    0px 0px 100px #ffffff: ;
}
.neon2 {
    text-shadow: 0px 0px 5px #ffffff, 0px 0px 20px #f7f7f7, 0px 0px 10px #f2f2f2, 0px 0px 8px #ece9e9, 0px 0px 8px #dedbdb;
    0px 0px 100px #ffffff: ;
}
.neon3 {
    text-shadow: 0px 0px 1px #e5e5e5, 0px 0px 1px #b9b9b9, 0px 0px 3px #838383, 0px 0px 3px #676767, 0px 0px 4px #333333;
}

.normal-header {
    transition: opacity 0.3s ease;
    display: flex;
    padding: 25px 15px 0;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    max-width: 1460px;
    margin: 0 auto;
}

.normal-header .box-site-title {
    padding: 0;
    font-size: 0;
}

@media(max-width:980px) {
.normal-header {
        padding: 17px 15px 0;
    }
.nav {
    gap: 10px;
}
.nav li {
    padding: 6px 0 7px;
}
.nav li a {
    font-size: 1.5rem;
    letter-spacing: 2px;
}
.hidden-menu-main li::after {
    padding: 0 10px;
}
}
.global-navigation .menu-last::after {
    padding: 0;
}

@media(max-width:890px) {
.nav {
    padding: 0 0 0 10px;
    display: none;
}
.nav li a {
    font-size: 1.5rem;
    letter-spacing: 1px;
    padding: 4px 1px 10px;
}
}

@media(max-width:768px) {
.global-navigation {
    display: none;
}
}

/*======================================================================
||
||    HIDDEN-NAVI
||
======================================================================*/

.home .hidden-nav {
    height: auto;
    background-color: #fff;
    display: none;
    box-shadow: 0 2px 2px rgba(0, 0, 0, .2);
    position: absolute;
    width: 100%;
    z-index: 99;
}
.hidden-nav {
    display: none;
}


.hidden-nav .inbox {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    padding: 0 10px;
    display: table;
}

.hidden-nav .inbox {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    padding: 0 10px 5px;
    display: table;
    color: #e24822;
    font-weight: 600;
    font-size: 2.6rem;
    letter-spacing: 1.7px;
}
.hidden-logo a {
    color: #ffffff;
    width: auto;
    float: left;
    line-height: 1.1;
    font-weight: 600;
    z-index: 100;
    position: relative;
    padding: 14px 5px 4px;
}
.hidden-logo .roma {
    font-size: clamp (14px, 3vw, 26px);
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;
    margin: 0;
    padding: 0;
    letter-spacing: 2px;
}
.single-post .hidden-logo .roma {
    color: #000;
    text-shadow: unset;
}
.hidden-item {
    margin: 0 auto;
    padding: 0;
    list-style: none;
    width: auto;
    display: flex;
    justify-content: center;
}
.hidden-item li {
    height: auto;
    text-align: center;
}
.hidden-item a {
    display: block;
    height: auto;
    line-height: initial;
    text-decoration: none;
}
.hidden-nav.clone-nav {
  position: fixed;
  top: -100px;
  left: 0;
  transition: all 1s;
  background-color: #fff;
  box-shadow: 0 2px 2px rgba(0,0,0,.2);
}
.hidden-nav.clone-nav.is-fixed-nav {
    display: block;
    background: #771111;
    top: 0;
}
.admin-bar .hidden-nav.clone-nav.is-fixed-nav {
    top: 0px;
}
.hidden-nav .box-site-title {
    display: none;
}
.hidden-menu-main {
    float: right;
    padding: 0 80px 0 0;
}
.hidden-menu-main li {
    width: auto;
    height: auto;
    padding: 0;
}
.hidden-menu-main li a {
    font-size: 16px;
    height: auto;
    font-weight: 500;
    font-family: "Quicksand", sans-serif;
    letter-spacing: 2px;
    padding: 0;
    color: #2d2d2d;
}
.hidden-menu-main li span {
    font-size: 10px;
    display: block;
    line-height: 1.1;
    width: auto;
    text-align: center;
    padding: 0 0px 3px;
    font-family: 'Josefin Sans', sans-serif;
}
.hidden-menu-sns {
    width: auto;
    float: left;
    display: none;
}
.hidden-menu-sns li {
    width: auto;
    text-shadow: 0px 2px 2px rgba(0,0,0,0.3), 0px 5px 4px rgba(0,0,0,0.1), 0px 18px 18px rgba(0,0,0,0.1);
}
.icon-hidden-instagram {
    padding: 18px 5px 0 5px;
}
.icon-hidden-instagram:before {
    color: #fff;
    font-size: 2.6rem;
}
.icon-hidden-facebook {
    padding: 18px 5px 0 5px;
}
.icon-hidden-facebook:before {
    color: #fff;
    font-size: 2.6rem;
}
.icon-hidden-youtube {
    padding: 18px 5px 0 8px;
}
.icon-hidden-youtube:before {
    color: #fff;
    font-size: 2.7rem;
}

.hidden-nav .hidden-menu-main {
    display: flex;
    float: right;
    padding: 22px 110px 22px 0;
    position: relative;
    gap: 20px;
}
.hidden-nav .hamburger {
    position: absolute;
    top: 18px;
    right: 12px;
    width: 50px;
    height: 40px;
    cursor: pointer;
    z-index: 300;
}


/*======================================================================
||
||    SMART PHONE MENU
||
======================================================================*/

.hamburger {
    position: absolute;
    right: 25px;
    top: 25px;
    width: 50px;
    height: 40px;
    cursor: pointer;
    z-index: 300;
}

.admin-bar .hamburger {
    top: 25px;
}

.home .admin-bar .hidden-nav {
    height: auto;
    background-color: #fff;
    display: none;
    box-shadow: 0 2px 2px rgba(0, 0, 0, 5);
    position: absolute;
    width: 100%;
    z-index: 99;
}
.hamburger span {
    display: block;
    position: absolute;
    width: 40px;
    height: 2px;
    left: 6px;
    background: #232323;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
}
.hamburger span:nth-child(1) {
    top: 7px;
}
.hamburger span:nth-child(2) {
  top: 19px;
}
.hamburger span:nth-child(3) {
  top: 31px;
}

.hidden-menu-main .hamburger span {
    background: #000000;
}

.hamburger.active span:nth-child(1) {
  top : 16px;
  left: 6px;
  background :#fff;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 16px;
  background :#fff;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
}

/* ?????? */
nav.globalMenuSp {
    position: fixed;
    z-index: 2;
    top: 0;
    left: 0;
    color: #fff;
    background: rgb(121 34 64);
    text-align: center;
    width: 100%;
    transform: translateX(100%);
    transition: all 0.6s;
    padding: 90px 0 0 0;
    height: 100%;
}

nav.globalMenuSp ul {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

nav.globalMenuSp ul li {
    list-style-type: none;
    padding: 0;
    width: 100%;
    transition: .4s all;
    border-bottom: 1px solid #787878;
}
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp ul li:hover{
  background :#ddd;
}

.bt-menu h3 {
    padding: 0;
    margin: 0;
}

nav.globalMenuSp ul li a {
    display: block;
    color: #fff;
    padding: 10px 10px 7px;
    text-decoration: none;
    font-family: 'Josefin Sans', font-family;
    font-size: 14px;
}

/* ?????jQuery?????? */
nav.globalMenuSp.active {
    opacity: 100;
    display: block;
    transform: translateX(0%);
    height: 100%;
    padding: 90px 0 0 0;
}






@media (max-width: 970px) {
    .admin-bar .hamburger {
        top: 19px;
    }
    .hamburger {
        top: 14px;
        right: 15px;
    }
    .hidden-logo {
        padding: 16px 5px 4px;
    }
    .hidden-logo .roma {
        font-size: 25px;
        padding: 0px;
    }
.hidden-logo a {
    font-size: 2.2rem;
    padding: 0 0;
}
.hidden-menu-main {
    padding: 0 60px 0 0;
}
.hidden-menu-main li a {
    font-size: 1.35rem;
    letter-spacing: 0;
}
}

@media (max-width: 768px) {
    .hidden-logo {
        padding: 14px 5px 12px;
        text-align: left;
    }
.menuBtn {
    position: absolute;
    top: 8px !important;
    right: 15px !important;
}
.hidden-nav .hidden-menu-main {
    display: none;
}
}



/*======================================================================
||
||    H MENU
||
======================================================================*/


.hamburger__line--1 {
  top: 1px;
}

.hamburger__line--2 {
  top: 18px;
}

.hamburger__line--3 {
  top: 36px;
}

.open .hamburger__line--1 {
  transform: rotate(-45deg);
  top: 11px;
}

.open .hamburger__line--2 {
  opacity: 0;
}

.open .hamburger__line--3 {
  transform: rotate(45deg);
  top: 11px !important;
}

@media only screen and (max-width:880px){
.hamburger {
        top: 10px;
    }
}

@media only screen and (max-width:768px){
.hamburger {
    top: 12px;
    z-index: 300;
}
}





.sp-nav {
    position: fixed;
    right: -100%;
    top: 0;
    width: 70%;
    height: 100vh;
    background-color: #000000c2;
    transition: all 0.5s;
    z-index: 200;
    overflow-y: auto;
    color: #fff;
    padding: 40px 15px 0;
}
.open .sp-nav {
  right: 0;
}

.black-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 5;
  background-color: #000;
  opacity: 0;
  visibility: hidden;
  transition: all 0.5s;
  cursor: pointer;
  z-index: 100;
}

.open .black-bg {
  opacity: 0.3;
  visibility: visible;
}

.sp-nav h6 {
    color: #fff;
    font-size: 2rem;
    font-weight: 400;
    border-bottom: 1px solid;
    margin: 0 0 15px;
    padding: 35px 5px 0px !important;
}
.sp-nav ul {
    padding: 0;
    width: 100%;
    list-style: none;
    margin: 0 0 30px;
}
..sp-nav li {
    width: 140px;
}
.sp-nav li, .bt-menu-full {
    width: 100%;
    font-size: 1.7rem;
    padding: 10px 0 0px 5px;
    border-top: 0px solid #000;
    float: left;
}

.sp-nav li a:link, .sp-nav li a:visited {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0.3);
    text-decoration: none;
    color: #ffffff;
    letter-spacing: 1px;
    font-size: clamp(16px, 3vw, 33px);
    font-family: "Quicksand", sans-serif;
}
.sp-nav li a span {
    font-size: 55%;
    font-weight: 300;
    padding: 0px 0 0 10px;
}
@media (min-width: 992px) {
    .mt-lg-n7 {
        margin-top: -6rem !important;
        min-height: 600px;
        margin: 0 auto 50px;
    }
}
@media (max-width: 580px) {
.sp-nav {
    width: 90%;
}
}




#js-clone-nav {
  /* ????? */
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;

  /* ?????????????????????? */
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;

  /* ??????????????????? */
  transition: opacity 0.3s ease, visibility 0.3s ease !important;
}


#js-clone-nav.is-fixed-nav {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    display: block;
    background: #2e3747;
    z-index: 100;
}

.hidden-logo {
   float: left;
}

.box-site-title.is-hidden,
.normal-header.is-hidden {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}


.is-fixed-hamburger {
    position: absolute;
    right: 20px;
    top: 12px;
}
.is-fixed-hamburger span {
    background: #ffffff;
}

@media screen and (max-width:768px) {
    .is-fixed-hamburger {
        position: absolute;
        right: 15px;
        top: 9px;
    }
}
@media(max-width:440px) {
}

/*======================================================================
||
||    POST
||
======================================================================*/

.single-post #inner-header {
}
.single-post .nav li a {
    color: #fff;
Overridden by animation styles. Open Animations panel
    text-shadow: 0px 0px 1px #e5e5e5, 0px 0px 1px #b9b9b9, 0px 0px 3px #838383, 0px 0px 3px #676767, 0px 0px 4px #333333;
}
.single-post .hamburger span  {
    background: #000000;
}
@media (min-width: 1200px) {
.display-4 {
    font-size: 2.2rem;
    font-weight: 500;
}
}

.block-three01 {
    width: 100%;
    max-width: 1380px;
    margin: 0 auto;
    padding: 15px 5px;
    display: table;
}
.block-three01 li {
    width: 33.333%;
    float: left;
    font-size: 0;
    padding: 10px;
}
.block-three01 .in-box {
    width: 100%;
    padding: 0;
    background: #fff;
    border-radius: 0;
    display: inline-block;
}

.block-three01 img {
    width: 100%;
    height: auto;
    padding: 0;
    vertical-align: bottom;
    background: #ffffff;
    border-radius: 0;
}
.block-three01 .picarea {
    position: relative;
}
.block-fouthree01r01 .txtarea {
    margin: 8px 0 0 0;
    width: 100%;
    background: #fff;
    border-radius: 15px;
    min-height: 120px;
}

.block-three01 h3 {
    font-size: 1.7rem;
    padding: 5px 2px 5px;
    line-height: 1.3;
    min-height: 60px;
    color: #454545;
}
.block-three01 h5 {
    font-size: 2.5rem;
    font-family: 'Cinzel', serif;
    line-height: 1.3;
    color: #46383d;
    padding: 0px 3px 5px;
    text-align: center;
}

.block-three01 {
    margin: 0 auto;
    padding: 0;
    position: relative;
    width: 100%;
    font-size: 0;
}
.block-three01 li {
    padding: 10px;
    width: 33.333%;
    position: relative;
    font-size: 0;
    display: inline-block;
}

.block-three01 li .inbox {
    position: relative;
}

.block-three01 a {
    display: block;
    position: relative;
    overflow: hidden;
}
.block-three01 img {
    width: 100%;
    height: auto;
    padding: 0;
    border-radius: 5px;
    border: 2px solid #ffffff;
}

.block-three01 li .txtarea {
    color: #ffffff;
    position: absolute;
    width: 100%;
    background: url(img/black30per.png);
    right: 0;
    top: 0;
    z-index: 1;
    padding: 0;
    height: 100%;
    display: inline-block;
}


.block-three01 h3 {
    font-family: 'Noto Sans JP', sans-serifP;
    font-size: 1.7rem;
    min-height: 90px;
    font-weight: 600;
    line-height: 1.6em;
    padding: 5px 2px 5px;
}
.block-three01 h3 span {
    font-size: 1.3rem;
    font-family: Oswald;
    line-height: 1;
    color: #ffffff;
    font-weight: 300;
    display: block;
    padding: 4px 0 0 0;
    text-align: right;
}
.block-three01 .box-bt {
    background: #ededed;
    float: right;
    width: 120px;
    height: auto;
    margin: 0 0 0 5px;
    padding: 4px;
}
.block-three01 .box-bt-reserve, .block-three01 .box-bt-found {
}

.block-three01 h4 {
    font-size: 1.8rem;
    text-align: center;
    color: #892925;
    font-family: 'Noto Serif JP', serif;
    margin: 0;
}
.block-three01 h5 {
    font-size: 1.5rem;
    text-align: center;
    padding: 1px 0;
    margin: 0;
    line-height: 1;
    color: #000000;
    font-family: 'Lato', sans-serif;
    font-weight: 600;
    letter-spacing: 0;
}
.block-three01 .txtarea a:hover h5 {
    color: #c62d1f;
} 
.block-three01 p {
    font-size: 1.7rem;
    text-align: center;
    padding: 3px 0 0;
    margin: 0;
    line-height: 1.2;
    color: #000000;
    font-family: antonio-bold;
    font-weight: 600;
}
.block-three01 .cover:before {
	z-index: 30;
	content: "";
	display: block;
	position: absolute;
    z-index: 1;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.block-three01 .cover:hover::before {
	 background-color: unset;
	 opacity: 1;
}
.box-second a:hover {
	 background: none;
	 opacity: 0.8;
}

.block-three01 .cover {
    position: relative;
    text-decoration: none;
    padding: 0;
    text-align: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    background: url(img/black10per.png);
}
.block-three01 .cover p {
    color:#fff;
    position:relative;
    z-index:2;
}

@media (max-width: 1270px) {
.block-three01 {
    padding: 5px;
}
.block-three01 li {
    padding: 5px;
}
.block-three01 h3 {
    font-size: 1.6rem;
}
.block-three01 h3 span {
    font-size: 1.1rem;
    padding: 4px 0 0 0;
}
.block-three01 .box-bt-reserve, .block-three01 .box-bt-found {
    width: 100px;
    padding: 4px;
}
.block-three01 h5 {
    font-size: 1.4rem;
    padding: 2px 0 0;
}
}

@media (max-width: 980px) {
.block-three01 {
    padding: 5px;
}
.block-three01 li {
    padding: 5px;
    width: 50%;
}
.block-three01 h3 {
    font-size: 1.5rem;
}
}

.block-four01 {
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(16px, 3vw, 30px);
    align-items: start;
}
.block-four01 li {
    padding: 0;
    min-width: 0;
    font-size: inherit;
}

.block-four01 .inbox {
    width: 100%;
    padding: 0;
    background: #fff;
    border-radius: 0;
    display: block;
}

.block-four01 .inbox > a {
    display: block;
    text-decoration: none;
    color: inherit;
}

.block-four01 .thumb {
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #d9d9d9;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}


.block-four01 .thumb img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: 0;
    vertical-align: unset;
    background: transparent;
}

.block-four01 .thumb .post_meta {
    position: absolute;
    z-index: 5;
    left: 0;
    bottom: 0;
    margin: 0;
    padding: 5px 12px;
    width: 100%;
    max-width: 90px;
    text-align: center;
    font-size: 1.15rem;
    line-height: 1.25;
    letter-spacing: 0.04em;
    font-weight: 600;
    color: #2e3747;
    background: #ffffffd1;
    border: 0;
    border-radius: 0px;
    box-sizing: border-box;
}
.block-four01 .post_title {
    margin: 0;
    padding: 10px 0 0;
    line-height: 1.45;
    min-height: 0;
    font-size: 1.5rem;
    letter-spacing: 0.06em;
    color: #2e3747;
    font-weight: 500;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    word-break: break-word;
}

.block-four01 .picarea {
    position: relative;
}
.block-four01 .txtarea {
    margin: 8px 0 0 0;
    width: 100%;
    background: #fff;
    border-radius: 15px;
    min-height: 120px;
}

.block-four01 .post_date {
    margin: -25px 3px 0 0;
    padding: 0;
    line-height: 1.3;
    text-align: right;
    width: auto;
    background: #fff;
}
.block-four01 .release_date {
    font-size: 1.4rem;
    background: #ffffffb8;
    padding: 2px 5px;
}
.block-four01 h5 {
    font-size: 2.5rem;
    font-family: 'Cinzel', serif;
    line-height: 1.3;
    color: #46383d;
    padding: 0px 3px 5px;
    text-align: center;
}

.box-link-more {
    padding: 0 15px;
    text-align: right;
}
.box-link-more div {
    font-size: 1.6rem;
    color: #fff;
}



@media (max-width: 880px) {
.block-four01 {
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
}
}

@media (max-width: 768px) {
.block-four01 {
        grid-template-columns: repeat(2, 1fr);
        gap: 18px;
    }
}
@media (max-width: 520px) {
.block-four01 {
    grid-template-columns: 1fr;
    gap: 20px;
}
}

@media (max-width: 680px) {
.block-three01 li {
    padding: 5px;
}
.block-three01 h3 {
    font-size: 1.5rem;
    right: 30px;
}
}

@media (max-width: 580px) {
.block-three01 h3 {
    font-size: 1.3rem;
    right: 10px;
    top: 27px;
    text-align: right;
}
}


@media only screen and (max-width: 440px) {
.block-four01 h3.post_title,
.block-four01 h3 {
    font-size: 1.35rem;
    padding: 8px 0 0;
    line-height: 1.35;
    min-height: 0;
}
.block-four01 h3, .block-four01 .txtarea {
    min-height: auto;
}
}


/*======================================================================
||
||    VIDEO
||
======================================================================*/

#video-header {
    position: relative;/*h1????????????????relative*/
    height: 100vh;/*???????????*/
} 

#video-area {
    position: fixed;
    z-index: -1;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    overflow: hidden;
    box-sizing: inherit;
}

#video {
    position: absolute;
    z-index: -1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 177.77777778vh;
    height: 56.25vw;
    min-height: 100%;
    min-width: 100%;
    display: inline-block;
    box-sizing: inherit;
    max-width: unset;
}


@media(max-width:767px) {
#video {
    width: 0px;
    min-height: 228.777778vh;
    min-width: 106%;
}
}
/*========= ?????????CSS ===============*/

#top-contents {
    background: #3d3b3b;
    padding: 0 0;
    text-align: center;
}

/*======================================================================
||
||    SECTION
||
======================================================================*/

.center-all01 {

}
.section-leftbox {
    width: 74%;
    float: left;
    padding: 5px;
}
.section-rightbox {
    width: 25%;
    float: right;
    padding: 5px;
}

/*======================================================================
||
||    INDEX
||
======================================================================*/
.index01 {
    font-family: Vollkorn;
    font-size: 6rem;
    color: #000;
    padding: 0 20px;
    margin: 4.5rem 0 0 0;
}
.index01 span{
    font-size: 1.5rem;
    padding: 0 5px;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 600;
}


@media(max-width:800px) {
.index01 {
    font-size: 3rem;
    padding: 0 20px;
    margin: 2rem 0 0 0;
}
}
/*======================================================================
||
||    BOX INDEX
||
======================================================================*/
.index001 {
    padding: 0px 5px 20px;
    margin: 0 auto;
    text-align: center;
    font-family: Noto Sans JP;
    font-size: 1.7rem;
    font-weight: 400;
    line-height: 1.3;
}
.index001-en {
    padding: 0 5px;
    margin: 0 auto;
    text-align: center;
    font-size: 5rem;
    line-height: 1.3;
}

.index001-txt {
    padding: 10px;
    margin: 0 auto;
    text-align: center;
    font-size: 18px;
    letter-spacing: 1px;
    color: #fff;
    line-height: 1.8;
    font-family: 'Noto Sans JP', sans-serif;
}
.index-top-item01, .index-top-item02 {
    padding: 5% 15px 10px;
    width: 100%;
    display: block;
    line-height: 0.9;
    margin: 0 auto;
    font-size: 5.5rem;
    letter-spacing: 5px;
    color: #fff;
    font-family: 'jambetica-light';
}


.index-top-item01 {
    text-align: left;
}
.index-top-item02 {
    text-align: right;
}
.top_photoarea_txt, .movie_front_txt  {
    padding: 5px 15px;
    color: #fff;
    line-height: 1.7;
    font-size: 1.2rem;
    display: inline-block;
}

.index-top-item01 span, .index-top-item02 span {
    display: block;
    font-size: 80%;
}

.top_photoarea_txt {
    text-align: left;
    float: left;
}
.movie_front_txt {
    text-align: right;
    float: right;
}
@media only screen and (max-width:1300px){
.index-top-item01, .index-top-item02 {
    padding: 100px 15px 0;
    font-size: 5rem;
}
}
@media only screen and (max-width:1100px){
.top_photoarea_txt, .movie_front_txt {
    line-height: 1.7;
    font-size: 16px;
}
}

@media only screen and (max-width:1100px){
.top_photoarea_txt, .movie_front_txt {
    font-size: 14px;
}
}
@media only screen and (max-width:768px){
.index-heading01 {
    padding: 10px 0 10px;
    font-size: 2rem;
}
.index001 {
    font-size: 2rem;
}
.index-top-item01, .index-top-item02 {
    padding: 50px 10px 0;
    font-size: 2.9rem;
}
}
@media only screen and (max-width:680px){
.index001 {
    font-size: 29px;
}
.index-top-item01, .index-top-item02 {
    padding: 35px 10px 0;
    font-size: 2.9rem;
}
.index001-txt {
    font-size: 14px;
    text-align: left;
}
.top_photoarea_txt, .movie_front_txt {
    font-size: 14px;
    padding: 5px 10px;
}
}

@media only screen and (max-width:490px){
.index001 {
    font-size: 24px;
    padding: 50px 5px 0;
}
.index001-en {
    font-size: 18px;
}
}










/*======================================================================
||
||    TOP>INSTA_LIST
||
======================================================================*/

.aaa {
    display: inline-block;
    width: 100%;
}

/*======================================================================
||
||    TOP>ITEM-LIST
||
======================================================================*/
.area-roll {
    overflow: visible;
    width: 100%;
    height: 100vh;
    -webkit-scroll-behavior: smooth;
    scroll-behavior: smooth;
    -webkit-scroll-snap-type: mandatory;
    scroll-snap-type: mandatory;
    -webkit-scroll-snap-points-y: repeat(100%);
    scroll-snap-points-y: repeat(100%);
}

.box-bg-black {
  background-color: #333;
}
.box-bg-gray {
  background-color: #ccc;
}
.box-bg-photo {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}




.intro_link_to {
    margin: 0 auto;
    position: absolute;
    display: table;
    width: 100%;
    max-width: 500px;
    text-align: center;
    left: 0;
    right: 0;
    bottom: 100px;
    padding: 0;
}
.box-prof .intro_link_to {
    max-width: 100%;
}
.intro_link_to li {
    padding: 5px;
    border-radius: 0;
    position: relative;
    display: inline-block;
    width: 50%;
    float: left;
    vertical-align: top;
    color: #000;
}
.intro_link_to li .inbox {
    padding: 3px 2px;
    border: 3px solid #e8e8e8;
    width: 100%;
    float: left;
    height: 35px;
    background: #ffffff47;
}
.intro_link_to li .inbox h3 {
    padding: 0;
    margin: 0;
    color: #ffffff;
    font-size: 1.2rem;
    font-weight: 500;
    font-family: 'Noto Sans JP', sans-serif;
}
@media only screen and (max-width:470px){
.intro_link_to li {
    padding: 4px 20px;
    width: 100%;
}
.intro_link_to li .inbox {
    padding: 0;
    border: 3px solid #ffffff;
}
.intro_link_to li .inbox h3 {
    font-size: 1rem;
    padding: 2px 0;
}
}

/*======================================================================
||
||    TOP>ITEM
||
======================================================================*/

.box-background-item01 {
    width: 100%;
    max-width: 1300px;
    position: absolute;
    padding: 5px;
    bottom: 30px;
}
.box-background-item02 {
    width: 100%;
    max-width: 440px;
    position: absolute;
    bottom: 5%;
    right: 0;
}
.pic-list02 {
    width: 100%;
    max-width: 650px;
    display: table;
    padding: 0;
    margin: 0;
}
.pic-list02 li {
    width: 25%;
    float: left;
    padding: 6px;
}
.pic-list02 li .pic-box {
    padding: 0;
}

.pic-list02 li img {
    width: 100%;
    padding: 4px;
    background: #ffffff45;
}

@media only screen and (max-width:870px){
.pic-list02 {
}
}

@media only screen and (max-width:470px){
.pic-list02 li {
    float: left;
    padding: 2.5px;
}
.pic-list02 li img {
    padding: 2px;
}
}

.box_movie_area {
    max-width: 470px;
    width: 100%;
    padding: 5px 20px;
    border-radius: 2px;
    float: right;
}
.youtube2 {
    position: relative;
    width: 100%;
    padding-top: 0;
}
.youtube2 iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}

.box-topitem-link01, .box-topitem-link02 {
    margin: 0 auto;
    padding: 4px 2px;
    position: relative;
    display: table;
    width: 100%;
    text-align: center;
}
.box-topitem-link01 {
    float: left;
    max-width: 650px;
}
.box-topitem-link02 {
    float: right;
    max-width: 500px;
    padding: 0 15px;
}
.box-topitem-link01 li, .box-topitem-link02 li {
    padding: 4px;
    border-radius: 0;
    position: relative;
    display: inline-block;
    width: 50%;
    float: left;
    vertical-align: top;
}
.box-topitem-link01 li .inbox, .box-topitem-link02 li .inbox {
    padding: 5px;
    width: 100%;
    background: url(img/bk-white80per.png);
    border-radius: 2px;
    height: 35px;
}
.box-topitem-link01 li .inbox h3, .box-topitem-link02 li .inbox h3 {
    padding: 0;
    margin: 0;
    color: #292828;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.1rem;
    font-weight: 500;
}

@media only screen and (max-width:670px){
.box_movie_area {
    max-width: 450px;
}
.box-topitem-link01, .box-topitem-link02 {
    max-width: 450px;
}
}
@media only screen and (max-width:470px){
.box-background-item01, .box-background-item02 {
    bottom: 30px;
}
.box-topitem-link01 li, .box-topitem-link02 li {
    padding: 4px 2px;
    width: 50%;
}
.box-topitem-link01 li .inbox, .box-topitem-link02 li .inbox {
    padding: 1px;
    height: 27px;
}
.box-topitem-link01 li .inbox h3, .box-topitem-link02 li .inbox h3 {
    font-size: 0.8rem;
}

}


/*======================================================================
||
||    TOP>BACKGOROUND-AREA
||
======================================================================*/

.box-top-instagram {
    display: table;
    background: #ffffff;
    padding: 60px 5px;
}
.box-top-instagram .inbox {
    padding: 20px 5px;
    margin: 0 auto;
    max-width: 1300px;
    width: 100%;
    display: flex;
}
.box-top-instagram ul {
    padding: 0;
    font-size: 0;
    display: inline-block;
    max-width: 1300px;
    width: 100%;
}
.box-top-instagram li {
    float: left;
    width: 25%;
    padding: 10px;
}
.box-top-instagram img {
    width: 100%;
}
/*======================================================================
||
||    MAINIMAGE
||
======================================================================*/

.ec-picture {
    width: 689px;
    margin: 0 0 40px 0;
    clear: both;
}

.pc-slide {
    display: block;
}
.sp-slide {
    display: none;
}

@media only screen and (max-width:768px){
.pc-slide {
    display: none;
}
.sp-slide {
    display: block;
}
}

.section-ec {
    height: auto;
    padding: 0;
    position: relative;
    width: 100%;
    margin: 0;
    font-size: 0;
}
/* Swiper ?????? #hero ?????????EC ????????? */
.section-ec .swiper-wrapper .swiper-slide {
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    height: 100vh;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    padding: 0;
}
.swiper-button-next, .swiper-button-prev {
    color: #ffffff !important;
}

.swiper-horizontal>.swiper-scrollbar {
    display: none;
}

.center-logo {
    text-align: center;
    margin: 0 auto;
}

.area-slide {
    display: block;
    height: auto;
    margin: 0 auto;
    overflow: hidden;
    position: relative;
    width: 100%;
    padding: 0;
    max-width: 1920px;
    z-index: 3;
    background: #ffffff;
}
.box-ec {
    margin: 0 auto;
    display: block;
    height: auto;
    padding: 0;
}
.box-ec img {
    padding: 0;
    width: 100%;
    border-radius: 0;
}
.box-ec .bt-taisaku {
    z-index: 30;
    max-width: 21%;
    position: absolute;
    bottom: 2.8%;
    left: 3.5%;
}

@media only screen and (max-width:890px){
.box-ec {
    width: 100%;
}
}
@media only screen and (max-width:768px){
.box-ec .bt-taisaku {
    z-index: 30;
    max-width: 29%;
    position: absolute;
    bottom: 12.8%;
    left: 3.5%;
}
}

.box-ec .bt-taisaku:hover{
  animation: hoverShake .1s  infinite;
  opacity: 0.8;
}
 
@keyframes hoverShake {
  0% {transform: skew(0deg,0deg);}
  25% {transform: skew(1deg, 1deg);}
  75% {transform: skew(-1deg, -1deg);}
  100% {transform: skew(0deg,0deg);}
}


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

/*======================================================================
||    
||   ARCHIVE / WORKS
||
======================================================================*/

.main-archive {
    padding: 0;
    width: 100%;
    min-height: 600px;
    max-width: 880px;
    margin: 0 auto;
}


@media (max-width: 767px) {
.main-archive {
    float: left;
    padding-right: 0;
    width: 100%;
}
}


/*======================================================================
||    
||   MOVIE WORKS
||
======================================================================*/

.section-movie-works {
    padding: 15px;
}

.section-movie-works .post {
    border-bottom: 3px #c2c2c2 dotted;
    margin: 0;
}


.box_youtube_url {
    max-width: 50%;
    padding: 30px 5px;
    border-radius: 0;
    width: 100%;
    float: right;
}

.box_youtube_txt {
    max-width: 50%;
    padding: 30px 5px;
    border-radius: 0;
    width: 100%;
    float: left;
}

.box_youtube_url .inbox {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    background: #acacac;
    border: 2px solid #acacac;
}
.box_youtube_url .inbox iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}

.youtube_index {
    font-size: 1.15rem;
    letter-spacing: 0.2px;
    color: #333333;
    margin: 0;
    font-weight: 500;
    font-family: 'Noto Sans JP', sans-serif;
}
.youtube_text {
    font-size: 0.9rem;
    letter-spacing: 0.2px;
    color: #333333;
    margin: 15px 0;
    font-family: 'Noto Sans JP', sans-serif;
}

@media only screen and (max-width:670px){
.box_movie_area {
    max-width: 450px;
}
}


/*======================================================================
||
||    TOP > SCHEDULE
||
======================================================================*/
.box-calendar {
    padding: 15px;
}

/*======================================================================
||
||    TOP>STORE
||
======================================================================*/
.section-top-photolist {
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
    font-size: 0;
}
.section-top-photolist .inbox {
    background: #fff;
    padding: 20px;
}
.section-top-photolist ul {
    margin: 0 auto;
    padding: 20px 0 0 0;
    position: relative;
    display: table;
    width: 100%;
    max-width: 1300px;
    text-align: center;
}
.section-top-photolist li {
    padding: 5px;
    border-radius: 0;
    position: relative;
    display: inline-block;
    width: 50%;
    float: left;
    vertical-align: top;
}
.section-top-photolist li .inbox {
    padding: 10px;
    width: 100%;
    float: left;
}
.section-top-photolist ul a:hover {
    border-bottom: 2px solid #ea2b8a;
}


@media(max-width:839px) {
.section-top-photolist li {
    padding: 10px;
}
}
@media(max-width:768px) {
.section-top-photolist .inbox {
	background: unset;
    padding: 10px;
}
.section-top-photolist li {
    padding: 10px;
    width: 50%;
}
}






/*======================================================================
||
||    TOP>MOVIE
||
======================================================================*/

.section-top-movie {
    background: url(img/bk-pink01.png);
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
    font-size: 0;
}

.area-movie {
    max-width: 540px;
    width: 100%;
    margin: 0 auto;
    padding: 15px 20px 50px 20px;
}
.area-movie h4 {
    font-size: 1.2rem;
    letter-spacing: 0.2px;
    color: #333333;
    margin: 15px 0;
    text-align: center;
    font-weight: 500;
    font-family: 'Noto Sans JP', sans-serif;
}
.box-movie {
    width: 100%;
    border-radius: 5px;
    height: 0;
    position: relative;
    padding-top: 56.25%;
    overflow: hidden;
}

.box-movie iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}
/*======================================================================
||
||    TOP>ABOUT
||
======================================================================*/
.section-top-about {
    background: url(img/bk-blue01.png);
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
}
.about-pic-btn {
    margin: 0 auto;
    text-align: center;
}
.about-pic-btn img {
    max-width: 710px;
    width: 100%;
    height: auto;
    padding: 50px 15px;
}

.about-pic-btn a:hover {
 opacity: 0.6;
  filter: alpha(opacity=60);
  -ms-filter: "alpha(opacity=60)";
}


/*======================================================================
||
||    TOP>NEWS
||
======================================================================*/
.section-top-news {
    background: #ffffff;
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
}

.boxlist01 {
    margin: 0;
    padding: 20px 0 70px;
    position: relative;
    display: inline-grid;
    width: 100%;
    font-size: 0;
}
.boxlist01 li {
    padding: 5px 20px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    width: 100%;
    max-width: 1060px;
    vertical-align: top;
}
.boxlist01 li .inbox {
    padding: 10px 2px 18px;
    border-bottom: 1px solid #505050;
    background: #fff;
    float: left;
    text-align: left;
    width: inherit;
    display: unset;
}
.boxlist01 {
}
.boxlist01 a {
    display: inline-block;
    width: auto;
    padding: 0;
}
.boxlist01 a:hover {
    color: #2980b9;
    border-bottom: 1px solid;
}

.boxlist01 h4 {
    font-size: 1rem;
    line-height: 1.6;
    font-weight: 600;
    margin: 0 0 0 110px;
    padding: 0;
    word-break: break-all;
    min-height: auto;
}
.boxlist01 .date {
    font-size: 1rem;
    float: left;
    width: auto;
    padding: 0;
}

.date-01 {
    font-family: roboto-bold;
    left: 0;
    position: absolute;
    bottom: 4px;
    color: #454545;
    width: 100%;
    border-top: 1px solid #ededed;
    padding: 6px 0 0 8px;
    font-size: 1.5rem;
}
.date-01 .index {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.4rem;
    padding: 2px 0 3px;
    background: #565656;
    line-height: 1.4rem;
    margin: 2px 5px 0 0;
    width: 50px;
    float: left;
    text-align: center;
    color: #ffffff;
    font-weight: 500;
    letter-spacing: 1px;
}

/*======================================================================
||
||    PAGE>COMMON
||
======================================================================*/

.padding10px {
    padding: 10px;
}
.under-header-space {
    padding: 160px 0 0 0;
    background: #fbfbfb;
}


.box-title-page {
    padding: 30px 20px 10px;
}
.title-page {
    margin: 0;
    font-family: jambetica-light;
    font-size: 4rem;
    font-weight: 500;
    color: #000;
    text-align: right;
    letter-spacing: 0;
    padding: 0 5px 0;
    border-bottom: 2px solid;
}

.title-item-type {
    display: inline-block;
    font-family: jambetica-light;
    padding: 80px 2px 0;
    width: 100%;
    margin: 0;
    font-size: 2.4rem;
    font-weight: 600;
    color: #333333;
    border-bottom: 1px solid;
}
.bottom-bt{
    padding: 0 0 50px;
}
@media(max-width:880px) {
.title-page {
    margin: 0;
    font-size: 3rem;
    padding: 0 5px 0;
}
}
@media(max-width:768px) {
.bottom-bt {
    padding: 10px 10px 45px 10px;
}
}



@media(max-width:640px) {
.title-item-type {
    padding: 40px 2px 0;
    font-size: 1.6rem;
}
}


/*======================================================================
||
||    PAGE > ABOUT
||
======================================================================*/

#content-page {
    background: url(img/bk-back.jpg);
    padding: 90px 0 0 0;
    min-height: 600px;
}

.section-page-about {
    padding: 20px;
}

.section-profile01 {
    padding: 50px 0 50px;
    display: table;
}

.box-table {
    display: table;
    width: 100%;
}
.section-map {
    padding: 10px;
}

.about-peaple-photo img {
    width: 100%;
    height: auto;
    padding: 0;
}

.section-profile01 .left {
    width: 67%;
    padding: 0 10px 0 0;
    float: left;
}
.section-profile01 .right {
    width: 33%;
    padding: 0 0 0 20px;
    float: right;
}

.section-profile01 .right img {
    width: 100%;
    height: auto;
    border-radius: 6px;
}

.profile-fields .index {
    font-family: antonio-bold;
    font-size: 1.8rem;
    padding: 20px 0 0 4px !important;
    margin: 0;
    display: block;
    text-align: left;
    letter-spacing: 1.5px;
    width: 150px;
}

.profile-fields .prf {
    font-size: 1.8rem;
    padding: 20px 0 0 0;
    text-align: left;
    font-weight: 400;
    letter-spacing: 1.5px;
}

.box-plan-profile .layout01 img {
    width: 100%;
    height: auto;
    border-radius: 4px;
    padding: 2px;
    border: 0;
    background: #e8e8e8;
}

.box-contens-link {
    padding: 10px 0 0;
}

.box-contens-link h5 {
    font-family: jambetica-bold;
    font-size: 1.3rem;
    line-height: 1;
    margin: 0 0 8px;
    padding: 5px 2px 4px;
    border-bottom: 1px solid #cccccc;
}

box-contens-link .box-youtube-bt {
    padding: 4px 4px 0;
    margin: 5px 0;
}

#g-ytsubscribe {

}


@media only screen and (max-width:979px){
.section-profile01 .left {
    padding: 0;
}
}


@media only screen and (max-width:780px){
.section-profile01 .left, .section-profile01 .right {
    width: 100%;
    padding: 0;
}
}


.section-profile01 .index {
    font-family: antonio-bold;
    font-size: 1.8rem;
    padding: 20px 0 0 4px !important;
    margin: 0;
    display: block;
    text-align: left;
    letter-spacing: 1.5px;
    width: 150px;
}

.section-profile01 .prf {
    font-size: 1.8rem;
    padding: 20px 0 0 0;
    text-align: left;
    font-weight: 400;
    letter-spacing: 1.5px;
}
.profile-title {
    margin: 15px 0 0;
    color: #333;
    font-family: jambetica-light;
    letter-spacing: 1px;
}

.profile-title a {
    font-family: 'Noto Sans JP', sans-serif, antonio-bold;
    margin: 0;
    padding: 3px;
    letter-spacing: 0;
    font-weight: 600;
    word-break: break-all;
    line-height: 1.2;
}
.profile-alphabet {
    font-family: Telegrafico;
    margin: 0;
    padding: 1px 3px;
    font-size: 2.2rem;
    color: #ddd;
    letter-spacing: 0;
    font-weight: 400;
    word-break: break-all;
    line-height: 1;
}
.profile-first-intro h3 {
    color: #353535;
    font-size: 1.5rem;
    padding: 6px 4px;
    font-family: 'Noto Sans JP', sans-serif;
}
.profile-first-intro p {
    font-size: 1.1rem;
    line-height: 1.7;
    padding: 5px;
    color: #4c4c4c;
    font-family: 'Noto Sans JP', sans-serif;
}

@media only screen and (max-width:979px){
.single-title {
    font-size: 2rem;
}
.profile-first-intro h3 {
    font-size: 1.2rem;
    margin: 0;
    padding: 16px 4px 2px;
}
.profile-alphabet {
    padding: 2px;
    font-size: 1.8rem;
}
.profile-fields .index {
    font-size: 1.7rem;
   border-bottom: 1px solid #ddd;
   padding: 0;
}
.profile-fields .prf {
    font-size: 1.6rem;
    padding: 4px 4px 8px;
}
}


@media only screen and (max-width:780px){
.staff-title {
    font-size: 3rem;
}
}

@media only screen and (max-width:680px){
.section-profile01 .index, .section-profile01 .prf {
    width: 100%;
    display: block;
}
.section-profile01 .index {
    font-size: 1.7rem;
   border-bottom: 1px solid #ddd;
   padding: 0;
}
.section-profile01 .prf {
    font-size: 1.6rem;
    padding: 4px 4px 8px;
}
}




.cover-index01 {
    background: url(img/background-skay01.jpg);
    padding: 70px 0 0;
}
.cover-index01 h1 {
    color: #ffffff;
    font-family: antonio-bold;
    font-size: 2rem;
    font-weight: normal;
    letter-spacing: 0;
    width: 100%;
    position: relative;
    line-height: 1.1;
    margin: 0 auto;
    padding: 20px 10px 15px;
    display: block;
    max-width: 1320px;
}

@media only screen and (max-width:768px){
.cover-index01 {
    padding: 60px 0 0;
}
.cover-index01 h1 {
    font-size: 1.5rem;
    padding: 10px 10px 5px;
}
}
.box-photo-profile {

}
.box-photo-profile ul {
    font-size: 0;
}
.box-photo-profile li {
    width: 12.5%;
    display: inline-block;
    list-style: none;
    padding: 4px;
}

@media only screen and (max-width:979px){
.box-photo-profile li {
    width: 25%;
    padding: 5px;
}
}
@media only screen and (max-width:768px){
.box-photo-profile li {
    width: 20%;
    padding: 5px;
}
}
@media only screen and (max-width:679px){
.box-photo-profile li {
    width: 25%;
    padding: 5px;
}
}

.box-photo-profile img {
    width: 100%;
    height: auto;
    padding: 0;
    border-radius: 0;
    background: #f5f5f5;
}



.box-table-profile {
    padding: 0 0 60px;
}
.table-profile {
    width: 100%;
}


.table-profile tr {
    width: 100%;
}
.table-profile .index {
    font-family: 'Noto Sans JP', sans-serif;
    border-bottom: 1.2px solid #555555;
    display: block;
    margin: 18px 0 0 0;
    padding: 15px 2px 0;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1.4;
    color: #463f3f;
    letter-spacing: 0;
    width: 100%;
    text-align: left;
}
.table-profile .index span {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.9rem;
    color: #191818;
    padding: 0 5px;
}
.table-profile .prf {
    font-size: 1rem;
    font-family: 'Noto Sans JP', sans-serif;
    color: #565656;
    padding: 10px 2px 20px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.7;
    display: block;
    text-align: left;
    width: 100%;
}

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

.table-profile .index, .table-profile .prf {
    width: 100%;
    display: block;
    padding: 4px 4px 8px;
}
.table-profile .index {
    border-bottom: 1.2px solid #555555;
    display: block;
    margin: 18px 0 0 0;
    padding: 15px 2px 0;
    font-size: 1.2rem;
    font-weight: 600;
    line-height: 1.4;
    color: #463f3f;
    letter-spacing: 0;
    width: 100%;
    text-align: left;
}
.table-profile .index span {
    font-size: 0.8rem;
}
.table-profile .prf {
    font-size: 1rem;
    padding: 4px 4px 8px;
}
}




div.item-list-tabs {
    padding: 0;
    width: 100%;
    display: table;
    margin: 0;
}
div.item-list-tabs ul {
    width: 100%;
    background: #eaeaea;
    padding: 8px;
    display: inline-block;
    border-radius: 3px;
}
div.item-list-tabs ul li {
    width: auto;
    padding: 0 6px 0 0;
    text-align: center;
    height: auto;
    float: left;
}
div.item-list-tabs ul li.selected a, div.item-list-tabs ul li.current a {
    background-color: #fff;
    line-height: 1.2;
    font-size: 1rem;
    color: #555;
    font-weight: 600;
    text-align: center;
    padding: 3px 10px 4px;
    border-radius: 3px;
}









.section-page-reservation {
    background: url(img/bk-beige01.png);
    padding: 0;
    display: inline-block;
    margin: 0;
    width: 100%;
    max-width: 100%;
}
.about-pic-btn {
    margin: 0 auto;
    text-align: center;
}
.about-pic-btn img {
    max-width: 710px;
    width: 100%;
    height: auto;
    padding: 50px 15px;
}

.about-pic-btn a:hover {
 opacity: 0.6;
  filter: alpha(opacity=60);
  -ms-filter: "alpha(opacity=60)";
}










.box-plan-profile {
    padding: 0 20px;
}

.layout01 {
    padding: 30px 0;
    border-bottom: 1px solid #dddddd;
    margin: 0 auto;
    display: table;
    width: 100%;
    position: relative;
}
.layout01 .inbox {
    width: 100%;
    border: 0;
    display: inline-block;
    padding: 0;
    position: relative;
}
.layout01 img {
    width: 100%;
}
.layout01 .right {
    width: 30%;
    height: auto;
    float: left;
    padding: 5px 0;
    border-radius: 2px;
}
.layout01 .left {
    width: 70%;
    float: right;
    height: auto;
    padding: 0 0 0 30px;
}

.layout01 h3 {
    margin: 0;
    padding: 0 0 20px;
    color: #191919;
    font-size: 1.4rem;
    line-height: 1.5;
    font-weight: 700;
    font-family: 'Noto Sans JP', sans-serif;
}
.layout01 h3 div {
    font-size: 1rem;
    background: #e0299f;
    color: #fff;
    padding: 5px 5px 0px;
    margin: 0 5px 0 0;
    display: inline-block;
    font-family: antonio-bold;
}
.layout01 h3 span {
    font-family: mlbphill;
    font-size: 2.6rem;
    font-weight: normal;
}

.layout01 p {
    font-size: 1rem;
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1.5;
    font-weight: 500;
    color: #4e4e4e;
}

.pt-plan-reserve a {
    background: #f50b56;
    color: #ffffff;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.9rem;
    padding: 3px 0px 4px;
    display: block;
    text-align: center;
    width: 100%;
    font-weight: 500;
    border-radius: 1px;
}
.pt-plan-reserve a:hover {
    background: #de8686 !important;
    color: #f5f5f5 !important;
}


.prof-price-box {
    padding: 0 0 10px 0;
    margin: 0;
    font-weight: 100;
    color: #ea0751;
    font-size: 1.8rem;
    letter-spacing: 0.8px;
    line-height: 1.2;
    font-family: 'Anton', sans-serif;
    width: 100%;
}
.prof-price-box .kakaku {
    font-weight: 600;
    font-size: 1.3rem;
}

.prof-price-box .enmark {
    font-weight: 600;
    font-size: 1.3rem;
}

@media (max-width: 970px) {
.layout01 h3 {
    font-size: 2rem;
}
.layout01 h3 {
    font-size: 1.3rem;
    font-weight: 900;
}
}
@media (max-width: 768px) {
.layout01 .right {
    width: 25%;
}
.layout01 .left {
    width: 75%;
    padding: 0 0 0 15px;
}
.layout01 h3 {
    padding: 5px 0 15px;
    font-size: 1.2rem;
    font-weight: 700;
}
.pt-plan-reserve a {
    font-size: 0.8rem !important;
    padding: 4px 0px 5px !important;
}
.prof-price-box {
    font-size: 1.4rem !important;
}
.prof-price-box span {
    font-weight: 500 !important;
    font-size: 1rem !important;
}
.pt-plan-reserve a {
    font-size: 0.8rem;
    padding: 4px 0px 5px;
}
.prof-price-box {
    font-size: 1.4rem !important;
}
.prof-price-box span {
    font-weight: 500 !important;
    font-size: 1rem !important;
}
}
@media only screen and (max-width:580px){
.layout01 .right {
    width: 100%;
}
.layout01 .left {
    width: 100%;
    padding: 10px 0 0 0px;
}
}

.layout-vertical {
    padding: 50px 15px 10px;
}

.layout-vertical h3 {
    font-size: 1.2rem;
    color: #585858;
    padding: 4px 2px;
}

.layout-vertical h3 span {
    font-family: Telegrafico;
    font-size: 1.8rem;
    background: #565656;
    color: #fff;
    padding: 7px 5px;
    margin: 0 6px 0 0;
    border-radius: 1px;
    font-weight: 300;
}

.layout-vertical .answer {
    padding: 5px 10px;
    font-size: 0.8rem;
    background: #f5f5f5;
}
.layout-vertical p {
    font-size: 1rem;
    line-height: 1.7;
}

@media only screen and (max-width:1080px){
.layout-vertical {
    padding: 30px 0 10px;
}
.layout-vertical h3 {
    font-size: 1rem;
    padding: 4px 2px;
}
.layout-vertical h3 span {
    font-family: Telegrafico;
    font-size: 1.2rem;
    background: #565656;
    color: #fff;
    padding: 6px 4px;
    border-radius: 50%;
    font-weight: 300;
    margin: 0 2px 0 0;
}
.layout-vertical p {
    font-size: 0.8rem;
    line-height: 1.7;
}
}



/*======================================================================
||
||    CONTACT
||
======================================================================*/

.table-ctf7 tr { width: 100%; border-bottom: 1px solid #dddddd; }
.table-ctf7 th { width: 30%; font-weight: 600; color: #565656; font-size: 1.7rem; padding: 15px 10px; }
.table-ctf7 td { font-size: 1.5rem; width: 70%; padding: 15px 10px; }
.table-ctf7 input { border: 0; width: 100%; height: 35px; padding: 0 10px; background: #f5f5f5; border-radius: 3px; font-size: 15px; border: 3px solid #e5e5e5; }
.table-ctf7 textarea { width: 100%; min-height: 100px; padding: 0 8px; background: #efefef; border-radius: 6px; font-size: 15px; border: 3px solid #dfdfdf; }
.wpcf7-not-valid-tip { color: #dc3232; font-size: 1.5rem; font-weight: 600; display: block; padding: 8px; }
.contact-privacy { width: 100%; height: 300px; padding: 20px 30px; border: 6px solid #eee; overflow: overlay; background: #fdfdfd; }
.contact-privacy p { font-size: 14px; color: #565656; line-height: 2; }
@media (max-width: 768px) {
  .table-ctf7 tr, .table-ctf7 td { width: 100%; display: block; padding: 0 0 10px; }
  .table-ctf7 th { font-size: 1rem; padding: 20px 2px 5px; }
}


.wpcf7 {
    margin: 30px 0;
}
.table-ctf7 {
    margin: 0px;
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0 5px;
}
fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}
.table-ctf7 tr {
    width: 100%;
    border-bottom: 1px solid #dddddd;
}

.table-ctf7 tr th, .table-ctf7 td {
    line-height: 1.3;
}
.table-ctf7 th, .table-ctf7 td {
    text-align: left;
    vertical-align: middle;
    padding: 15px 10px;
}
.table-ctf7 th {
    width: 30%;
    font-weight: 600;
    color: #565656;
    font-size: 1.7rem;
}
.table-ctf7 td {
    font-size: 1.5rem;
    width: 70%;
}
.wpcf7-radio span {
    background: none !important;
    line-height: 1;
    font-size: 1.4rem;
}

.wpcf7-radio span {
    line-height: 2.1;
    display: flex;
    flex-direction: row;
    align-items: center;
}

.table-ctf7 input {
    border: 0;
    width: 100%;
    height: 35px;
    padding: 0px 10px;
    background: #f5f5f5;
    border-radius: 3px;
    transition: all 0.4s ease;
    font-size: 15px;
    margin: 0;
    border: 3px solid #e5e5e5;
}

.table-ctf7 textarea {
    width: 100%;
    min-height: 100px;
    padding: 0px 8px;
    background: #efefef;
    border-radius: 6px;
    transition: all 0.4s ease;
    font-size: 15px;
    margin: 0;
    border: 3px solid #dfdfdf;
}

input[type="radio"] {
    line-height: 2;
    box-sizing: border-box;
    float: left;
    position: relative;
    font-size: 10px;
    width: 15px;
    padding: 0;
    margin: 0 7px 0 0;
}
input[type="checkbox"] {
    margin: -3px 0 0 8px;
}
span.wpcf7-list-item * {
}

.box-contact-privacy {
    width: 100%;
    padding: 8px;
}
.contact-privacy {
    width: 100%;
    height: 300px;
    padding: 20px 30px;
    margin: 0 auto;
    border: 6px solid #eee;
    overflow: hidden;
    overflow: overlay;
}

.wpcf7-form h5 {
    background: #f5f5f5 none repeat scroll 0 0;
    border-radius: 2px;
    font-family: Noto Sans Japanese;
    font-size: 1.8rem;
    font-weight: normal;
    margin: 20px 0;
    padding: 10px 15px;
    color: #565656;
}
.contact-privacy h5 {
    font-size: 1.8rem;
    font-weight: 500;
    color: #565656;
    text-align: center;
    line-height: 1.4;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.contact-privacy p {
    font-size: 1.36rem;
    color: #565656;
    line-height: 2;
}
.box-send input {
    background: #1595ff none repeat scroll 0 0;
    border: 0 none;
    color: #fff;
    display: block;
    font-family: Noto Sans Japanese;
    font-size: 2.2rem;
    font-weight: 500;
    letter-spacing: 10px;
    margin: 0 auto;
    max-width: 300px;
    padding: 20px 0 25px;
    border-radius: 52px;
    text-align: center;
    vertical-align: middle;
    width: 100%;
}

@media (max-width: 768px) {
    .table-ctf7 tr, .table-ctf7 td {
        width: 100%;
        display: block;
        padding: 0px 0 10px;
    }
    .table-ctf7 tr th, .table-ctf7 td {
        border-bottom: 0;
        line-height: unset;
        
    }
    .table-ctf7 th {
        font-size: 1rem;
        padding: 20px 2px 5px;
    }
}


.box-plan-profile  {
    padding: 0;
}

.box-plan-profile .layout01 {
    display: block;
}
.prf-msb {
    display: none;
}



.area-flow {
    max-width: 880px;
    width: 100%;
    text-align: center;
    margin: 0 auto 60px;
    padding: 0 30px;
    display: block;
}

.area-flow .inbox {
    width: 100%;
    background: #fff;
    border-radius: 12px;
    padding: 24px 24px;
    display: block;
    background: #ffffff;
}

.box-flow {
    background: #F8EAE4;
    font-family: 'Noto Sans JP', sans-serif;
    padding: 18px;
    border-radius: 8px;
    display: inline-block;
    width: 100%;
}

.box-flow .number {
    float: left;
    font-family: Lato;
    font-size: 4.5rem;
    background: #fff;
    color: #E35A2E;
    padding: 0 30px;
    line-height: 1.5;
    border-radius: 50%;
}

.box-flow .txt {
    float: left;
    padding: 0 0 0 20px;
    width: 70%;
}
.box-flow h3 {
    padding: 0;
    margin: 0;
    width: auto;
    font-weight: 500;
    text-align: left;
    font-size: 1.5rem;
    font-family: 'Noto Sans JP', sans-serif;
}
.box-flow p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.08rem;
    font-weight: 500;
    margin: 8px 0;
    line-height: 1.6;
    color: #565656;
    width: auto;
    text-align: left;
}
.box-flow p span {
    font-size: 1rem;
}

.box-flow img {
    float: right;
    max-width: 100px;
}

.sm-flow {
    display: none;
}
@media only screen and (max-width:840px){
.box-flow .number {
    font-size: 4rem;
    padding: 0 28px;
    line-height: 1.5;
}
.box-flow .txt {
    padding: 0 0 0 18px;
    width: 67%;
}
}
@media only screen and (max-width:768px){
.area-flow {
    padding: 0 15px;
}
.box-flow {
    background: unset;
    padding: 18px 0;
}
.box-flow .txt {
    padding: 0;
    width: 100%;
}
.sm-flow {
    display: block;
    float: unset !important;
    width: 100%;
    max-width: 180px !important;
    margin: 0 auto;
}
.box-flow .number {
    display: none;
}
.box-flow h3 {
    font-size: 1.8rem;
    text-align: center;
}
.box-flow p {
    font-size: 1.2rem;
    text-align: center;
    margin: 15px 0;
    width: 100%;
}
.box-flow p span {
    font-size: 1.05rem;
}
.pic-flow {
    display: none;
}
.area-flow .responsive-arrow {
    max-width: 50px !important;
}
}



.note01 {
    max-width: 880px;
    width: 100%;
    text-align: center;
    margin: 0 auto 60px;
    padding: 0 30px;
    display: block;
}
.note01 .inbox {
    width: 100%;
    background: #fff;
    border-radius: 12px;
    padding: 6px 20px 40px;
    display: block;
}

.note01 h3 {
    background: #F7E0D7;
    color: #DE6036;
    padding: 3px;
    width: 100%;
    font-size: 1.5rem;
    font-family: 'Noto Sans JP', sans-serif;
}
.note01 p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.6;
    color: #565656;
}

.responsive-arrow {
    display: none;
}

.area-flow .responsive-arrow {
    max-width: 40px;
    padding: 8px;
    display: block;
    text-align: center;
    margin: auto;
}
@media only screen and (max-width:768px){
.responsive-arrow {
    display: block;
    max-width: 56px;
    text-align: center;
    margin: 0 auto;
}
.note01 h3 {
    font-size: 2rem;
}
.note01 p {
    font-size: 1.3rem;
}
}

@media only screen and (max-width:640px){
.note01 h3 {
    font-size: 1.2rem;
}
.note01 p {
    font-size: 1rem;
    margin: 0;
    padding: 0px 2px;
}
.responsive-arrow {
    max-width: 26px;
    padding: 12px 0 0 0;
}
}

.box-table02 {
    width: 100%;
    max-width: 880px;
    padding: 20px 30px 60px;
    margin: 0 auto;
}
.tb02 {
    margin: 20px auto;
    border-collapse: collapse;
    width: 100%;
    table-layout: fixed;
}

.tb02 thead {
    background: #F7E6C0;
}

.tb02 .non, .tb02 .col01 {
    border-right: 3px dashed #dacece;
}
.tb02 .col02 {
    border-right: 0;
}

.tb02 p {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  margin: 60px auto 40px;
}

.tb02 th, .tb02 td {
  padding: 1em 10px 1em 1em;
  border-right: 2px solid #fff;
}

.tb02 tr {
    border-bottom: 3px solid #dacece;
}
.tb02 th {
    color: #151515;
    padding: 10px;
    font-family: APJapanesefontT;
    font-size: 1.3rem;
    font-weight: normal;
    border-right: 3px dashed #dacece;
}
.tb02 td {
    padding: 10px;
    font-family: APJapanesefontT;
    font-size: 1.3rem;
}
.tb02 .td_first {
    border-right: 3px dashed #dacece;
}

@media screen and (max-width: 768px) {
.tb02 tr {
    border-bottom: unset;
}
.tb02 th, .tb02 td {
    border-right: unset;
    display: block;
    width: 100%;
    font-size: 1.1rem;
}
.tb02 th {
    background: #d1e4d9;
    padding: 4px;
}
.tb02 .td_first {
    border-bottom: 1px solid #696767;
    border-right: unset;
}
.tb02 thead {
    border: none;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
.tb02 td {
    display: block;
    font-size: 1.1em;
    text-align: right;
    position: relative;
    padding: .625em .625em .625em 4em;
    border-right: none;
  }
  
.tb02 td::before {
    font-size: 1.2rem;
    content: attr(data-label);
    font-weight: bold;
    position: absolute;
    left: 10px;
    color: #167F92;
}
}
/*======================================================================
||
||    PAGE>COLOR
||
======================================================================*/
.section-top-color {
    background: url(img/bk-green01.png);
    padding: 0 0 80px;
    margin: 0;
    width: 100%;
    max-width: 100%;
    font-size: 0;
}
.box-half01, .box-half02 {
    width: 100%;
    max-width: 1200px;
    padding: 35px 45px;
    display: table;
    margin: 0 auto;
}

.box-half01 h2, .box-half02 h2 {
    margin: 0 0 2rem;
    padding: 0 4px 8px;
    color: #121212;
    font-family: 'Noto Serif JP', serif;
    font-size: 1.5rem;
    font-weight: 700;
    border-bottom: 2px solid #3C3237;
    letter-spacing: 1.5px;
    line-height: 1.4;
}
.box-half01 h3, .box-half02 h3 {
    color: #4AA446;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.3rem;
    font-weight: 600;
    margin: 0;
    padding: 0 5px;
}

.box-half01 p, .box-half02 p {
    color: #353535;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.1rem;
    line-height: 1.7;
    font-weight: 500;
    letter-spacing: 1px;
    margin: 20px 4px;
}


.box-half01 img, .box-half02 img {
    border: 0;
    width: 100%;
    padding: 2px;
    border-radius: 8px;
}

.box-half01 .right {
    width: 50%;
    float: right;
    padding: 0 0 0 15px;
}
.box-half01 .left {
    width: 50%;
    float: left;
    padding: 10px 0 0 0;
}


.box-half02 .right {
    width: 50%;
    float: right;
    padding: 10px 0 0 0;
}
.box-half02 .left {
    width: 50%;
    float: left;
    padding: 0 15px 0 0;
}

.date_list {
    max-width: 100%;
    line-height: 25px;
    margin-top: 70px;
    border-top: 1px dotted #000;
}

.date_list li {
    border-bottom: 1px dotted #000;
    overflow: hidden;
}

.date_list li .index {
    font-size: 1.8rem;
    padding: 10px 10px;
    float: left;
    width: 25%;
    font-family: alternategotno2d,sans-serif;
    margin: 0;
}
.date_list li .txt {
    font-size: 1.2rem;
    padding: 17px 25px 18px 0;
    float: left;
    width: 75%;
    margin: 0;
}

@media only screen and (max-width:980px){
.box-half01 .left, .box-half02 .right {
    width: 51%;
}
.box-half01 .right, .box-half02 .left {
    width: 49%;
}
.box-half01, .box-half02 {
    padding: 0;
}
.box-half01 h2, .box-half02 h2 {
    font-size: 1.25rem;
    margin: 0 0 1rem;
}
.box-half01 h3, .box-half02 h3 {
    font-size: 1.1rem;
}
.box-half01 p, .box-half02 p {
    font-size: 1rem;
    margin: 10px 4px;
}
}



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

.section-top-color {
    background: unset;
}

.section-top-color {
    background: url(img/bk-green01.png);
}
.box-half01, .box-half02 {
    background: #fff;
    padding: 20px;
}
.box-half01 .left, .box-half02 .right, .box-half01 .right, .box-half02 .left {
    width: 100%;
    padding: 10px 0 0;
}
.box-half01 .right {
    border-bottom: 2px solid;
    padding: 10px 0 30px;
}
.box-half01 h2, .box-half02 h2 {
    font-size: 1.85rem;
    margin: 0 0 1rem;
    text-align: center;
    border: unset;
}
.box-half01 h3, .box-half02 h3 {
    font-size: 1.5rem;
    line-height: 1.8;
    text-align: center;
}
.box-half01 p, .box-half02 p {
    font-size: 1.1rem;
    margin: 20px 0;
    text-align: center;
}
}



/*======================================================================
||
||    PAGE>NEO
||
======================================================================*/

.section-page-neo {
    background: url(img/bk-blue01.png);
    padding: 0;
    display: inline-block;
    margin: 0;
    width: 100%;
    max-width: 100%;
}


.intro-neo {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1rem;
    text-align: center;
    font-weight: 500;
    color: #000;
    line-height: 1.9;
    padding: 0 0 20px;
}

.note02 {
    max-width: 760px;
    width: 100%;
    text-align: center;
    margin: 0 auto 60px;
    padding: 0 30px;
    display: block;
}
.note02 .inbox {
    width: 100%;
    background: #fff;
    border-radius: 12px;
    padding: 20px 30px 40px;
    display: block;
}

.list03 {
    display: inline-block;
    font-size: 0;
}
.list03 li {
    width: 100%;
    padding: 20px 0 20px 10px;
    display: inline-block;
}
.list03 .pic-box {
    width: 36%;
    float: left;
}
.list03 .pic-box img {
    width: 100%;
    height: auto;
}

.list03 .txt-box {
    width: 64%;
    padding: 37px 0 0 30px;
    float: left;
}
.list03 .txt-box h3 {
    font-family: 'Noto Serif JP', serif;
    font-size: 1.5rem;
    margin: 0 0 20px;
    text-align: left;
    float: left;
    width: 100%;
}

.list03 .txt-box p {
    text-align: left;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.05rem;
    line-height: 1.8;
    font-weight: 500;
    color: #000000;
}


@media(max-width:768px) {
.section-page-neo {
    background: unset;
    padding: 0;
    display: inline-block;
    margin: 0;
    width: 100%;
    max-width: 100%;
}
.list03 .pic-box {
    width: 100% !important;
    max-width: 440px;
    text-align: center;
    margin: 0 auto;
    float: unset !important;
}

.list03 .txt-box {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
    padding: 40px 0 20px 0;
    float: unset;
    border-bottom: 2px solid #000000;
}
.list03 .txt-box h3 {
    text-align: center;
    margin: 0 0 0px;
}
.list03 .txt-box p {
    text-align: center;
    width: 100%;
    display: inline-block;
}
}


/*======================================================================
||
||    404
||
======================================================================*/

.page-404 h1 {
    padding: 40px 0 0 0;
    font-size: 20vw;
    line-height: 17vw;
    text-align: center;
    color: #dd8080;
}
.page-404 h2 {
    font-size: 6vw;
    text-align: center;
    color: #dd8080;
}
.page-404 p {
    text-align: center;
    font-size: 2vw;
}

.page-404 .back-to-top {
    text-align: center;
    width: 100%;
    margin: 10px auto 50px;
    display: inline-block;
}

.page-404 .back-to-top h6 {
    text-align: center;
    background: #de8282;
    color: #fff;
    width: 200px;
    margin: 0px auto;
    padding: 8px;
    display: inline-block;
    border-radius: 22px;
}
.page-404 a, .page-404 a:visited {
    color: #ebeae5;
}

/*======================================================================
||
||    ANOUTE
||
======================================================================*/



.box-prof .left p {
    font-size: 16px;
    line-height: 1.8;
}
.box-prof .left strong {
    font-size: 1.5rem;
    margin: 0px 0 0 -2px;
}




.box-place {
    max-width: 990px;
    padding: 10px 5px 30px;
    margin: 0 auto;
}

.box-place .pics {
    padding: 20px;
}

.box-place .txt {
    padding: 0 20px;
}
.box-place h2 {
    font-size: 1.6em;
    line-height: 1.4em;
    margin: 20px 0;
    font-weight: 600;
    color: #6b6b6b;
}

.box-place p {
    margin: 0;
    padding: 0;
    line-height: 1.8;
    font-size: 16px;
}
.box-prof-intro {
    display: block;
    width: 100%;
    max-width: 960px;
    padding: 15px;
    margin: 0 auto;
}

.box-prof-intro p {
    font-size: 15px;
    line-height: 1.5;
}

.box-prof {
    max-width: 990px;
    width: 100%;
    margin: 35px auto;
    padding: 10px 5px 40px;
    display: flex;
    border-bottom: 2px dotted #cccccc;
}
.box-prof .left {
    width: 55%;
    padding: 0 10px 0 20px;
    float: left;
}
.box-prof .right {
    width: 45%;
    padding: 0 10px 0 20px;
    float: left;
}
.box-prof .right {
    padding: 0px 25px 0 15px;
}
.box-prof .right img {
    width: 100%;
    padding: 10px;
    height: auto;
}
.prof_name {
    font-size: 4rem;
    line-height: 1;
    margin: 0 0 0 -5px;
    padding: 0 0 54px;
    font-family: 'jambetica-light';
}


@media only screen and (max-width:1200px){
.intro-index01 {
    font-size: 1.7rem;
}
}

@media only screen and (max-width:980px){
.intro-index01 {
    font-size: 1.5rem;
}
.intro-text01 {
    font-size: 1.05rem;
}
}

@media only screen and (max-width:768px){
.box-prof .left, .box-prof .right {
    width: 100%;
    padding: 15px;
}
.intro-name-en, .intro-name {
    text-align: center;
}
.intro-index01, .intro-index02 {
    font-size: 1.3rem;
}
.intro-text01, .intro-text02 {
    font-size: 1rem;
    line-height: 1.9;
}
.prof_name {
    font-size: 4rem;
    line-height: 1;
    margin: 0 0 0 -5px;
    padding: 0 0 20px;
    font-family: 'jambetica-light';
}
.box-prof .left strong {
    font-size: 1.2rem;
}
.box-place p, .box-prof .left p  {
    font-size: 14px;
    line-height: 1.8;
}
}


@media only screen and (max-width:680px){
.box-prof {
    max-width: unset;
    width: 100%;
    margin: 0;
    padding: 5px;
    display: block;
}
.box-place .pics {
    padding: 12px;
}
.box-prof .right img {
    padding: 0;
}
.box-prof-intro p {
    font-size: 12px;
    line-height: 1.7;
    padding: 0 5px;
}
.box-place h2 {
    font-size: 17px;
    line-height: 1.5;
    margin: 0 0 15px 0;
}
.box-place .txt {
    padding: 0 10px;
}
}





/*======================================================================
||
||    FLOW
||
======================================================================*/

.flow_design08 {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 980px;
    margin: 0 auto;
    padding: 15px;
}
.flow08 {
    padding: 5px;
    width: 100%;
}

.flow08 > li {
    list-style-type: none;
    border-radius: 5px;
    background: #ffffff;
    position: relative;
    padding: 20px;
}

.flow08 > li:not(:last-child) {
  margin-bottom: 20px;
}

.flow08 > li dl {
    display: inline-block;
}
.flow08 > li dl dt {
    font-size: 1.2em;
    font-weight: 700;
    width: 100%;
    min-width: 7em;
    margin: 0 0 5px;
}

.flow08 > li .icon08 {
  color: #8EB83C;
  margin-right: 0.5em;
}

.flow08 > li dl dd {
    margin: 0;
    width: 100%;
}



/*======================================================================
||
||    MAP
||
======================================================================*/

.box-map {
    max-width: 990px;
    width: 100%;
    margin: 35px auto;
    padding: 10px 5px 40px;
    display: flex;
}

.box-map .wrap {
    width: 100%;
    margin: 0 auto;
    padding: 20px;
}

.box-map h3 {
    margin: 0 0 15px 0;
    font-family: jambetica-light;
    font-weight: 600;
    color: #444;
    text-align: right;
    font-size: 1.2rem;
    text-transform: none;
}

.box-map h4 {
    font-size: 1.1em;
    font-weight: 500;
    text-align: right;
}


/*======================================================================
||
||    CONTACT
||
======================================================================*/


.contact-link-head {
    max-width: 500px;
    width: 100%;
    display: inline-block;
    float: right;
}
.contact-link-head li {
    width: 50%;
    padding: 5px;
    float: left;
}

.contact-link-head li p {
    text-align: center;
    color: #3c3c3c;
    padding: 14px 5px;
    background: #f3f3f3;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.1rem;
    font-weight: 500;
}

.contact-page h2 {
    font-size: 2.8em;
    border-bottom: 1px solid #ddd;
    padding-bottom: .1em;
    color: #37657c;
}
.box-bt-send input {
    background: #fff none repeat scroll 0 0;
    border: 3px solid #ddd;
    color: #555;
    display: block;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.8rem;
    margin: 0 auto;
    max-width: 200px;
    padding: 2px;
    vertical-align: middle;
    width: 100%;
}



.conversion-box {
    display: flex;
}
.box-number {
    width: 50%;
    padding: 10px;
}
.box-number .inbox {
    border-radius: 8px;
    background: #fff;
    background: unset;
}

.tel-number {
    padding: 20px 20px 0 20px;
    margin: 0;
    font-size: 4rem;
    font-weight: 300;
    text-align: center;
    line-height: 1.5;
}
.tel-number span {
    font-size: 70%;
    padding: 0 5px 0 0;
}
.tel-open {
    text-align: center;
}

@media only screen and (max-width:768px){
.tel-number {
    font-size: 3rem;
}
}
@media only screen and (max-width:630px){
.conversion-box {
    display: block;
}
.box-number {
    width: 100%;
    padding: 10px;
}
}






/* Archive
--------------------------------------------- */

#container {
    background: #f9f9f9;
}
.home #container {
    background: unset;
}
.page-template-plan  #container {
    background: #F4F1EA;
}
.tm-content {
    padding: 150px 0 120px 0;
    margin: 0 auto;
    text-align: center;
}

.archive h1 {
    text-align: left;
}
.archive .uk-article-title {
    font-size: 85px;
    line-height: 0.7;
    font-weight: normal;
    font-family: 'jambetica-light';
    padding: 10px 5px;
    text-transform: none;
    margin: 0 auto;
    max-width: 914px;
}
.archive .tm-article-image {
    text-align: center;
    margin: 0 auto;
}

.archive .tm-article-image picture img {
    max-width: 890px;
    width: 100%;
}

@media all and (max-width: 760px) {
.archive .uk-article-title {
    font-size: 75px;
}
}
@media all and (max-width: 600px) {
.archive .uk-article-title {
    font-size: 10vw;
    line-height: 0.45;
    padding: 10px 14px;
}
}
@media all and (max-width: 480px) {
article.uk-panel-box {
    padding: 0 15px 20px 15px;
}
}


/* Single
--------------------------------------------- */

.single .uk-article-title {
    font-size: 24px;
    line-height: 42px;
    font-weight: normal;
    text-transform: none;
    display: none;
}

/* LANA
--------------------------------------------- */
.page-template-lana .box-ec {
    margin: 0 auto;
    display: block;
    float: right;
    width: 100%;
    height: auto;
    padding: 0;
}


.page-template-lana .index-top-item01 {
    text-align: right;
    line-height: 1;
}

.page-template-lana .txt-top-item01 {
    text-align: right;
    line-height: 1.5;
    font-size: 1.5rem;
    color: #fff;
    padding: 30px 0 0;
    font-weight: 500;
}

.h4_intro_lana {
    color: #ffffff;
    text-align: right;
    padding: 0 20px;
    margin: 0;
    font-size: 1.5rem;
}













/* PLAN
--------------------------- */


.plans {
    max-width: 1330px;
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    position: relative;
    margin: 0 auto;
    padding: 5px;
}
.plans .plan-box {
    display: flex;
    width: 33.3333%;
    margin: 0;
    min-height: auto;
    padding: 15px;
}
.plans .plan-box .best-choice {
    background: #D5FFFC;
    text-transform: uppercase;
    font-weight: 600;
    color: #437299;
    margin-top: auto;
}

.plans .plan-box:hover .plan-name {
    color: black;
}
.plans .plan-box:hover .plan-price {
    text-align: center;
}

.plans .plan-box:hover .more-options a {
    color: #9E2B20;
    text-decoration: none;
}

.price div {
    font-size: 18px;
    font-family: 'Cinzel', serif;
}
@media all and (max-width: 940px) {
.plans .plan-box {
    width: 50%;
}
}

@media all and (max-width: 700px) {
.plans {
    padding: 5px 0;
}
    .plans .plan-box:first-child {
        margin-bottom: 20px;
    }
}
.plans .plan-box:nth-child(2) {
    margin-top: 0;
    position: relative;
}

.plan-details {
    padding: 0 20px;
}

@media all and (max-width: 700px) {
    .plans .plan-box {
        width: 100%;
    }
}
.plans .plan-name {
    text-align: center;
    margin: 0;
    padding: 20px;
}
.plans .plan-price {
    background: #ff6096;
    color: white;
    display: flex;
    padding: 20px 10px;
    text-align: center;
}
.plan-price strong {
    font-size: 1.1rem;
    min-height: 3.5rem;
}

.plans .plan-details strong {
    font-size: 15px;
    letter-spacing: 1px;
    line-height: 2;
    color: #000000;
    display: block;
}
.plans .plan-options {
    display: flex;
    flex-flow: column;
    width: 100%;
    background: #ffffff;
}
.plans .plan-options li {
    border-bottom: 1px solid #cdcdcd;
    padding: 5px 0;
    margin: 5px 0;
}
.plans .plan-options .button, .plans .option-options .button {
    margin: 0 auto 15px;
    display: block;
    background: #dc356b;
    color: white;
    text-align: center;
    text-decoration: none;
    padding: 10px;
    width: 187px;
    border-radius: 33px;
    display: none;
}
.plans .plan-options .button:hover {
    background: #ed380f;
}

.plans .option-box {
    display: flex;
    width: 33.3333%;
    margin: 0;
    min-height: auto;
    padding: 15px;
}
.plans .option-options {
    display: flex;
    flex-flow: column;
    width: 100%;
    background: #ffffff;
}
.plans .option-price {
    background: #ff6096;
    color: white;
    display: flex;
    padding: 20px 10px;
    text-align: center;
}


.plans .option-price strong {
    font-size: 1rem;
    min-height: 2.8rem;
}
.option-details {
    padding: 0 20px;
}
.plans .option-options li {
    border-bottom: 1px solid #cdcdcd;
    padding: 5px 0;
    margin: 5px 0;
}
.plans .option-details strong {
    font-size: 15px;
    letter-spacing: 1px;
    line-height: 2;
    color: #000000;
    display: block;
}

@media all and (max-width: 940px) {
.plans .option-box {
    width: 50%;
}
}
@media (max-width: 700px) {
.plans .option-box {
    width: 100%;
}
}


/* CONTACT ????
------------------------------------------------------------------------------------------------------------------- */

input:focus, textarea:focus {
    border: 1px solid #1a237e;
}

.form__name, .form__tel {
    background-color: #f8f8f8;
    border: none;
    box-sizing: border-box;
    padding: 15px;
}
.form__name {
    min-width: 350px;
}
input, select {
    vertical-align: middle;
}


page-template-join .site-container, page-template-contact .site-container {
    background: #ffffff;
}

.contact-page {
    margin: 0 auto;
    width: 100%;
    max-width: 968px;
    padding: 50px 15px 80px;
}



/* JOIN
------------------------- */

.page-template-join .coution-contact h4 {
    font-size: 20px;
    text-align: center;
}
.page-template-join .coution-contact p {
    margin: 0px 0 19px 8px;
    padding: 0;
}

.box-kiyaku-check {
    padding: 20px 12px 40px;
}

/* LINE ?
------------------------- */

.box-line-form {
    align-items: flex-start;
    border-bottom: 1px solid #ccc;
    display: flex;
    padding: 40px 10px 40px;
}
.box-line-form-full {
    align-items: ;
    border-bottom: 1px solid #ccc;
    display: block;
    padding: 40px 10px 40px;
}
.inbox-line-form {
    align-items: center;
    display: block;
    justify-content: space-between;
    margin: 8px 55px 0 0;
    width: 30%;
}
.box-line-form-full .inbox-line-form {

    width: 100%;
}


/* LAVEL ???
------------------------- */

.box-line-form label {
    font-weight: 600;
    font-size: 17px;
    line-height: 1.5;
    letter-spacing: 0;
    float: left;
}
.box-line-form-full label {
    font-weight: 600;
    font-size: 17px;
    padding: 0;
    letter-spacing: 0;
    line-height: 1.2;
    float: left;
}
.box-line-form-full .inbox-answer {
    display: inline-block;
    padding: 20px 0 0 0;
    width: 100%;
}

/* REQUIRED ??
------------------------- */

.required-input {
    background-color: #009688;
    box-sizing: border-box;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    min-width: 54px;
    padding: 1px 6px 3px;
    margin: 0 0 0 10px;
    text-align: center;
    float: left;
    line-height: 1.6;
}

/* SUBJUNCTION ??
------------------------- */
.subjunction-contact {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 10px 0 10px 0 !important;
    border: 0px solid #ddd;
    border-radius: 2px;
    padding: 5px 0px !important;
    color: #e71c61;
}

/* INPUT
------------------------- */

.inbox-answer {
    height: 28px;
}
.inbox-answer p{
    margin: 0;
    padding: 0;
}

.inbox-answer .wpcf7-text, .inbox-answer .wpcf7-textarea {
    background-color: #ffffff;
    border: none;
    box-sizing: border-box;
    padding: 8px 10px;
}

.wpcf7-form-control-wrap {
    position: relative;
}

.wpcf7-list-item-label{
    font-size: 1.5rem;
    letter-spacing: 0;
}
.wpcf7-list-item {
    margin: 0 12px 0 0 !important;
}
.wpcf7-list-item-label {
    font-size: 1.5rem !important;
    font-weight: 500;
    color: #232323;
    line-height: 1.8;
}

/* LINE CONTACT
------------------------- */

.line-contact {
    padding: 0px 0 0 0;
    margin: 0 0 28px;
    display: grid;
    width: 100%;
}
.line-contact .inbox {
    font-size: 1.5rem;
    font-weight: 400;
    border-radius: 5px;
    padding: 20px;
    background: #fff;
    border: none;
}

.line-contact h5 {
    font-size: 18px;
    padding: 0;
    font-weight: 600;
}

.line-contact p {
    margin: 0;
    padding: 0;
    line-height: 1;
    font-size: 15px;
    line-height: 1.5;
}
.line-contact .left {
    width: auto;
    float: left;
}
.line-contact .right {
    max-width: 135px;
    float: right;
}

/* CONTACT PROIVACY
------------------------- */

.box-contact-privacy {
    width: 100%;
    padding: 8px;
}
.contact-privacy {
    width: 100%;
    height: 300px;
    padding: 20px 30px;
    margin: 0 auto 0;
    border: 6px solid #eee;
    overflow: hidden;
    overflow: overlay;
    background: #fdfdfd;
}
.contact-privacy h5 {
    font-size: 18px;
    margin: 30px 0 0 0;
    padding: 0;
    font-weight: 500;
    color: #565656;
    text-align: center;
    line-height: 1.4;
    text-transform: uppercase;
    letter-spacing: 1px;
    background: unset;
}
.contact-privacy p {
    font-size: 14px;
    color: #565656;
    line-height: 2;
}

.wpcf7-not-valid-tip {
    color: #dc3232;
    font-size: 1.5rem;
    font-weight: 600;
    display: block;
    padding: 8px;
}

.table-kiyaku {
    width: 100%;
    margin: 0 0 30px 0;
}


@media screen and (max-width:750px) {
.contact-page {
    width: 100%;
    max-width: 580px;
    padding: 50px 15px 80px;
}
.box-line-form {
    flex-direction: column;
    padding-left: 0;
    width: 100%;
    padding: 15px 0px 8px;
    border: 0;
}
.box-line-form-full {
    align-items: ;
    border-bottom: 0;
    display: block;
    padding: 24px 0px 40px;
}
.inbox-line-form {
    justify-content: flex-start;
    margin-bottom: 20px;
    width: 100%;
}
.box-line-form label {
    font-weight: 600;
    font-size: 15px;
}
.inbox-answer {
    width: 100%;
}
.required-input {
    font-size: 12px;
    min-width: 50px;
    margin: 0 0 0 5px;
    padding: 2px;
}
.box-contact-privacy {
    padding: 0px;
}
}

@media screen and (max-width:480px) {
.coution-contact h3 {
    font-size: 4.4vw;
    padding: 20px 0 0 0;
}
}



/* COUTION
------------------------- */

.coution-contact {
    padding: 0px 0 0 0;
    margin: 0 0 28px;
}
.coution-contact .inbox {
    font-size: 1.5rem;
    font-weight: 400;
    border-radius: 5px;
    padding: 20px;
    background: #fff;
    border: none;
}

.coution-contact h3 {
    font-size: 21px;
    padding: 45px 0 0 0;
    font-weight: 500;
}
.coution-contact h5 {
    background: unset;
    border-radius: 2px;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 17px;
    font-weight: 600;
    margin: 0 0 12px;
    padding: 0;
    color: #565656;
}

.coution-contact p {
    font-size: 14px;
    line-height: 1.8;
}

/* CONTACT ????????
---------------------------------------------------------------------------------------------------------------*/









.section-page01 {
    margin: 0 auto;
    max-width: 1240px;
    padding: 10px 10px 50px;
}





.box-list03 {
    margin: 0 auto;
    padding: 0;
    position: relative;
    width: 100%;
    font-size: 0;
}
.box-list03 li {
    padding: 10px;
    width: 33.333%;
    position: relative;
    font-size: 0;
    display: inline-block;
}

.box-list03 li img {
    border-radius: 10px;
}



#company table {
    width: 100%;
    border-top: #ccc 1px solid;
    margin: 50px auto;
}
#company table tr {
    border-bottom: #ccc 1px solid;
}
#company table tr th {
    width: 30%;
    padding: 1.5em 1em;
    box-sizing: border-box;
    font-weight: 500;
    letter-spacing: 1px;
}
#company table tr td {
    width: 70%;
    font-weight: 500;
    padding: 1.5em 1em;
    box-sizing: border-box;
    line-height: 2;
}
#company table tr td a, #company table tr td span {
    color: #b01e23;
    text-decoration: none;
}


@media screen and (max-width:768px) {
#company table tr th {
    width: 100%;
    font-size: 1.5rem;
    box-sizing: border-box;
    display: block;
    font-weight: bold;
    padding: 1rem 1rem 0px;
    text-align: left;
}
#company table tr td {
    font-size: 1.6rem;
    width: 100%;
    display: block;
    box-sizing: border-box;
    line-height: 2;
    padding: 0em 1em 1em;
}
}

#company table tr td a, #company table tr td span { color: #b01e23; text-decoration: none; }
@media screen and (max-width:768px) {
  #company table tr th { width: 100%; display: block; font-size: 1.5rem; padding: 1rem 1rem 0; }
  #company table tr td { font-size: 1.6rem; width: 100%; display: block; padding: 0 1em 1em; }
}



.bg-eyecatch {
    display: flex;
    align-items: center;
    /* justify-content: center; */
    flex-direction: column;
    position: relative;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}
.bg-eyecatch::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 0;
}

.bg-eyecatch .in-box {
    z-index: 1;
    width: 100%;
    margin: 0 auto;
    max-width: 1300px;
    height: 100vh;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    position: relative;
}

/* =====================================================================
   generic-child: minimal-cafe-skin ????????????
   minimal-cafe-skin ??????? style.css ???????????
   ===================================================================== */

html {
    background: #fff;
}

body {
    background: #fff !important;
    padding-top: 0;
    color: #444;
    font-family: "Hiragino Kaku Gothic ProN", "Yu Gothic", "Noto Sans JP", Meiryo, sans-serif;
    line-height: 1.9;
}

body:not(.minimal-cafe-skin) #header.header {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: 100% !important;
    z-index: 120 !important;
    background: #fff !important;
    padding: 0 !important;
    border-bottom: 1px solid #eee;
    box-sizing: border-box;
}

body:not(.minimal-cafe-skin) #header.header .mc-header-inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 30px 16px 0;
    text-align: center;
}

body:not(.minimal-cafe-skin) #header.header .box-site-title {
    float: none;
    position: relative;
    left: auto;
    top: auto;
    padding: 0;
    margin: 0;
    text-align: center;
    width: 100%;
}

body:not(.minimal-cafe-skin) #header.header .box-site-title a,
body:not(.minimal-cafe-skin) #header.header .box-site-title a:visited {
    position: relative !important;
    color: #444 !important;
    font-size: inherit !important;
    text-shadow: none !important;
}

body:not(.minimal-cafe-skin) #header.header #nav.mc-mock-nav {
    max-width: 960px;
    margin: 0 auto 30px;
    padding: 0 8px;
    text-align: center;
}

body:not(.minimal-cafe-skin) #header.header #nav.mc-mock-nav .nav.top-nav {
    text-align: center;
    margin: 0;
    padding: 0;
    list-style: none;
}

body:not(.minimal-cafe-skin) #header.header #nav.mc-mock-nav .nav li {
    float: none;
    display: inline-block;
    margin: 0 -2px;
    vertical-align: top;
}

body:not(.minimal-cafe-skin) #header.header #nav.mc-mock-nav .nav li a,
body:not(.minimal-cafe-skin) #header.header #nav.mc-mock-nav .nav li a:visited {
    color: #333 !important;
    font-family: "Noto Serif JP", "Hiragino Mincho ProN", serif !important;
    font-size: 13px !important;
    font-weight: bold !important;
    padding: 12px clamp(14px, 3vw, 30px) !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

body:not(.minimal-cafe-skin) #header.header #nav.mc-mock-nav .nav li a:hover {
    background: #eee !important;
    color: #333 !important;
}

body:not(.minimal-cafe-skin) #header.header .neon3,
body:not(.minimal-cafe-skin) #header.header a.neon3 {
    text-shadow: none !important;
    box-shadow: none !important;
}

#js-clone-nav.is-fixed-nav {
    background: #ffffffed;
    box-shadow: none !important;
}

#js-clone-nav .hidden-menu-main li a, #js-clone-nav .hidden-menu-main li a:visited, #js-clone-nav .hidden-logo a, #js-clone-nav .hidden-logo a:visited {
    color: #2d2d2d;
    text-shadow: none;
}

.is-fixed-hamburger span {
    background: #333 !important;
}

.index-section01,
.index-section02,
.index-section05 {
    text-align: center;
    padding: 40px 20px 16px;
    margin: 0 auto;
    max-width: 960px;
    width: 100%;
    font-size: 16px;
    color: #444;
    box-sizing: border-box;
}

.index-section01 h3,
.index-section02 h3,
.index-section05 h3 {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.35em 0.6em;
    font-family: "Noto Serif JP", "Hiragino Mincho ProN", serif !important;
    font-size: 18px !important;
    font-weight: bold !important;
    line-height: 1.5 !important;
    letter-spacing: 0.05em;
    text-align: center;
    border-bottom: 2px solid #444 !important;
    padding: 0 0 5px !important;
    margin: 0 auto 24px !important;
    max-width: 640px;
}

.index-section01 h3 span,
.index-section02 h3 span,
.index-section05 h3 span {
    font-family: "Noto Sans JP", sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    letter-spacing: 0.06em;
    padding: 0 !important;
}

#top-contents {
    margin: 0;
    padding: 0;
}

.mc-top-header {
    width: 100%;
    text-align: center;
    background: #fff;
}

.mc-hero--slider {
    position: relative;
    width: 100%;
    margin: 0 auto;
    background: #fff;
}

.mc-hero-swiper {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
}

.mc-hero-slide {
    aspect-ratio: 2 / 1;
    background-size: cover;
    background-position: center;
}

.mc-top-wide-contents {
    width: 100%;
    border-bottom: solid 1px #eee;
}

.mc-top-wide-inner {
    max-width: 960px;
    margin: 0 auto;
    padding: 10px 20px 30px;
}

.mc-top-widget-title.mincho {
    font-family: "Noto Serif JP", "Hiragino Mincho ProN", serif !important;
    font-weight: bold;
    font-size: 18px;
    text-align: center;
    padding: 30px 0 5px;
    margin: 0 auto 10px;
    border-bottom: 2px solid #444;
    color: #444;
}

.mc-textwidget p {
    color: #444;
    line-height: 1.7;
    text-align: center;
    margin: 0 0 24px;
}








/* ===========================
   HERO SLIDER
=========================== */
#hero {
    width: 100%;
    max-width: 1470px;
    margin: 0px auto;
    border-radius: 0;
    padding: 80px 15px 0;
    overflow: visible;
    position: relative;
    z-index: 1;
}

#hero .hero-swiper {
    width: 100%;
    max-width: 1430px;
    padding: 0;
    margin: 0 auto;
    aspect-ratio: 18 / 9;
    overflow: hidden;
    border-radius: 12px;
}
#hero .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media only screen and (max-width: 970px) {
#hero {
    padding: 70px 15px 0;
}
#hero .hero-swiper {
    aspect-ratio: 16 / 9;
}
}

@media only screen and (max-width: 890px) {
#hero {
    padding: 65px 15px 0;
}
}
@media only screen and (max-width: 640px) {
#hero .hero-swiper {
    aspect-ratio: 12 / 9;
}
}


/* ===========================
   CATCH TEXT
=========================== */
#catch {
    text-align: center;
    padding: 50px 15px 20px;
}

#catch .catch-text {
    font-family: "Quicksand", sans-serif;
    font-size: clamp(2rem, 6vw, 3.5rem);
    letter-spacing: 2px;
    line-height: 1.5;
    color: #2e3747;
    font-weight: 700;
}



/* ===========================
   WORKS
=========================== */
#works {
    padding: 40px 0 70px;
}
#information {
    padding: 40px 0 70px;
}
#about-us {
    padding: 40px 0 70px;
}
#information {
    padding: 40px 0 70px;
}
#contact {
    padding: 40px 0 70px;
}

.home .section-inner {
    width: 100%;
    max-width: calc(1300px - 30px);
    padding: 0 15px;
    margin: 0 auto;
}

.home .section-inner p {
    font-size: 1.62rem;
    line-height: 1.8;
    margin: 0;
    padding: 0;
}

.section-header {
    margin-bottom: 2px;
}

.section-title {
    font-family: "Quicksand", sans-serif;
    font-size: clamp(2.2rem, 6vw, 3.6rem);
    letter-spacing: 0.1em;
    color: #2e3747;
    font-weight: 700;
    display: flex;
    align-items: baseline;
    gap: 12px;
    text-align: left;
    justify-content: flex-start;
    border-bottom: none;
    padding: 0;
    margin: 40px auto 5px;
    max-width: 1300px;
}

.section-title-sub {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: clamp(1.5rem, 3vw, 1.8rem);
    font-weight: 600;
    color: #303647;
    letter-spacing: 0.05em;
    padding: 0;
}


@font-face {
  font-family: 'icomoon';
  src:  url('font/icomoon.eot?mgdqi2');
  src:  url('font/icomoon.eot?mgdqi2#iefix') format('embedded-opentype'),
    url('font/icomoon.ttf?mgdqi2') format('truetype'),
    url('font/icomoon.woff?mgdqi2') format('woff'),
    url('font/icomoon.svg?mgdqi2#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
}
[class^="icon-"], [class*=" icon-"] {
    font-family: 'icomoon' !important;
    speak: never;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.icon-instagram:before { content: "\ea92"; }
.icon-youtube:before { content: "\ea9d"; }
.icon-youtube2:before { content: "\ea9e"; }
.circle-circle:before { content: "\ea56"; }
.icon-allow:before { content: "\ea1c"; }
.box-social .icon { font-size: 25px; font-weight: 100; }
.box-social ul { padding: 2px; }
.box-social li { float: left; padding: 0 10px 0 0; }

/*****  FONTS
--------------------------------------------- */
@font-face {
  font-family: 'hff-ultrasound';
  src: url('fonts/hff-ultrasound.woff') format('woff'),
       url('fonts/hff-ultrasound.woff2') format('woff2'),
       url('fonts/hff-ultrasound.ttf') format('truetype');
}
@font-face {
  font-family: 'gasca';
  src: url('fonts/gasca.woff') format('woff'),
       url('fonts/gasca.woff2') format('woff2'),
       url('fonts/gasca.ttf') format('truetype');
}
@font-face {
  font-family: 'square';
  src: url('fonts/square.woff') format('woff'),
       url('fonts/square.woff2') format('woff2'),
       url('fonts/square.ttf') format('truetype');
}
.font-bebas-neue-regular { font-family: "Bebas Neue", sans-serif; font-weight: 400; }
.font-gasca { font-family: "gasca", sans-serif; font-weight: 400; }
.rubik-font { font-family: "Rubik", sans-serif; font-optical-sizing: auto; font-weight: 400; }

/*======================================================================
   GENERAL STYLES
======================================================================*/
html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    font-size: 62.5%;
}
body {
    font-family: "Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Noto Sans JP,sans-serif;
    line-height: 1.5;
    color: #5c6b80;
    margin: 0;
    -webkit-font-smoothing: antialiased;
}
#header, #container, #footer { padding: 0; }
#header { background: unset; }
p { margin: 0; padding: 0; font-size: 1.65rem; line-height: 1.8; }
strong { font-size: 1.4rem; }
ol, ul { box-sizing: border-box; list-style: none; }
h1, h2, h3, h4, h5, h6 {
    margin: 0 0 15px 0;
    font-family: "Helvetica Neue", 'Noto Sans JP', Helvetica, Arial, sans-serif;
    font-weight: normal;
    color: #444;
}
audio, canvas, img, svg, video { width: 100%; height: auto; box-sizing: border-box; }

/*======================================================================
   LINK STYLES
======================================================================*/
a:hover, a:focus, a:visited:hover { color: #dddddd; }
a:link { -webkit-tap-highlight-color: rgba(0,0,0,0.3); text-decoration: none; color: #212121; }
a:visited { color: #212121; }
.footer a:visited { color: #e9e9e9; }
h1 a, h2 a, h3 a, h4 a, h5 a { color: #212121; text-decoration: none; }
h1, .h1 { font-size: 2.5em; line-height: 1.3; }
h2, .h2 { font-size: 1.75em; line-height: 1.4em; margin-bottom: 0.375em; }
h3, .h3 { font-size: 1.125em; }
h4, .h4 { font-size: 1.1em; font-weight: 700; }
h5, .h5 { font-size: 0.846em; line-height: 2.09em; text-transform: uppercase; letter-spacing: 2px; }
#content { margin-top: 0; display: inline-block; width: 100%; padding: 100px 0; }
.post-template-default #content { padding: 0; background: #eeeeee; }
.post-template-default .entry-content { padding: 20px; min-height: 700px; }
.post-template-default .entry-content .inbox { background: #fff; border-radius: 15px; padding: 35px 25px; min-height: 600px; }

/*======================================================================
   SINGLE
======================================================================*/
.entry-content { max-width: 1000px; }
.entry-content, .entry-page {
    background: #fff;
    padding: 3px;
    margin-bottom: 25px;
    margin: 0 auto 60px;
    position: relative;
    z-index: 3;
}
.single-post h2 { font-size: 2.3rem; padding: 6px 10px !important; background: #f1eaea; border-radius: 3px; }
.single-post h3 { font-size: 1.6rem; color: #5a5555; background: #eee; border-radius: 3px; padding: 6px 8px !important; margin: 5px 0 3px 0 !important; }
.single-post h4 { font-size: 2rem; padding: 5px !important; }
.single-post h5 { font-size: 1.8rem; padding: 5px !important; }
.single-post h6 { font-size: 1.7rem !important; padding: 4px 5px !important; }

.single-post p { font-size: 1.6rem; line-height: 1.9; margin: 0; padding: 15px; color: #4b4b4b; }
.post .entry-meta { font-size: 16px; color: #040404; margin: 0; padding: 2px 1px; text-align: right; }
.entry-content .inbox { padding: 30px 30px 40px; min-height: 700px; height: auto; }
.type-post footer { max-width: 1000px; margin: 20px auto; text-align: right; }
.entry-title { font-size: 2.4rem; font-weight: 500; line-height: 1.3; }
.singular-article { padding: 30px 35px; }
.singular-header__meta { font-size: 1.5rem; }
.post-navigation { max-width: 1050px; margin: 0 auto; display: flex; padding: 25px; }
.nav-links { margin-top: 30px; display: inline-block; width: 100%; }
.nav-previous, .nav-next { width: 100%; display: inline-block; }
.genre { }
.info { background: #ef0e0e; }
.blog { background: #009688; }
.event { background: #1383dc; }
.size-medium { width: 32.7%; padding: 1px; margin: 0; }
@media only screen and (max-width: 860px) { .size-medium { width: 48.5%; } }
@media only screen and (max-width: 440px) { .size-medium { width: 100%; } }
@media only screen and (max-width: 860px) {
  .entry-content .inbox { padding: 20px 18px 30px; }
  .entry-title { font-size: 2.4rem; }
  #content p { font-size: 1.5rem; }
}
@media only screen and (max-width: 580px) {
  .entry-title { font-size: 2rem; }
  .page #content p, .single-post #content p { font-size: 1.4rem !important; }
}

/*======================================================================
   COMMON HELPERS
======================================================================*/
.width1400 { width: 100%; max-width: 1400px; margin: 0 auto; padding: 15px; }
.width1300 { width: 100%; max-width: 1300px; margin: 0 auto; padding: 15px; }
.color232323 { color: #232323; }
.colore24822 { color: #e24822; }
.borderradius10 { border-radius: 10px; }
.sv_effect { opacity: 0; visibility: hidden; transform: translateY(40px); transition: all 1s; }
.is-show { opacity: 1; visibility: visible; transform: translateY(0px); }
.boxshadow01 { box-shadow: 0 3px 5px rgba(0,0,0,.30); }
.paddingtop20px { padding-top: 30px; }
.padding10px { padding: 10px; }
.under-header-space { padding: 160px 0 0 0; background: #fbfbfb; }
.sm-ec { display: none; }
.pc-ec { display: block; }
@media only screen and (max-width:768px) { .sm-ec { display: block; } .pc-ec { display: none; } }

/*  {^ */
.btn02 {
    width: 200px; text-align: center; display: inline-block; padding: 0.3em 1em;
    color: #ffffff !important; background: #781616; border: solid 3px #781616;
    border-radius: 32px; transition: .4s; font-size: 1.6rem; font-weight: 500;
    box-shadow: 0 3px 5px rgba(0,0,0,.30);
}
.btn02:hover { background: #ffffff; color: #d40077 !important; border: solid 3px #d40077; }
@media (max-width: 768px) { .btn02 { width: 125px; font-size: 1.3rem; } }

/* PAGE TOP */
.icon_page_top { max-width: 60px !important; height: auto; }
#page_top { position: fixed; bottom: 10px; right: 20px; z-index: 7000; }
#page_top a { text-align: center; text-decoration: none; padding: 0; font-size: 0; }
#page_top a:hover { background-color: #555; }

/*======================================================================
   TABLE
======================================================================*/
.table02 { border-collapse: separate; border-spacing: 2px; float: left; width: 100%; padding: 8px; }
.table02 th { font-size: 1.6rem; font-weight: 500; padding: 10px 25px; text-align: left; background: #750303; width: 20%; color: #fff; border-radius: 3px; }
.table02 td { color: #2f2d2d; font-size: 1.6rem; font-weight: 500; background: #f5f5f5; border-radius: 3px; }
@media screen and (max-width:680px) {
  .table02 th, .table02 td { padding: 10px !important; display: block; width: 100%; font-size: 1.4rem; }
}



/*======================================================================
   PAGE COMMON
======================================================================*/
.index-section01 { text-align: center; margin: 0 auto; padding: 30px 10px 10px; }
.index-section01 h3 { font-size: 10vw; text-align: left; font-weight: 200; line-height: 0.85; padding: 0; border-bottom: 3px solid; margin: 0; font-family: "Bebas Neue", sans-serif; }
.index-section01 h3 span { font-size: 3rem; letter-spacing: 1px; padding: 0 15px; font-weight: 300; }
.index-section02 { padding: 30px 10px 10px; margin: 0 auto; }
.index-section02 h3 { font-size: 5.5vw; display: flex; font-weight: 200; line-height: 0.8; padding: 0; border-bottom: 3px solid; margin: 0; font-family: "Bebas Neue", sans-serif; flex-direction: row; align-items: baseline; }
.index-section02 h3 span { font-size: 30%; letter-spacing: 1px; padding: 0 15px; font-weight: 400; }
.index-section05 { padding: 30px 10px 10px; margin: 0 auto; }
.index-section05 h3 { font-size: 6.5vw; display: flex; font-weight: 200; line-height: 0.8; padding: 0; border-bottom: 3px solid; margin: 0; font-family: "Bebas Neue", sans-serif; flex-direction: row-reverse; align-items: baseline; }
.index-section05 h3 span { font-size: 3rem; letter-spacing: 1px; padding: 0 15px; font-weight: 400; }
@media(max-width:768px) { .index-section01 { font-size: 2.5rem; } .index-section01 h3 { font-size: 7vw; } }

/*======================================================================
   ARCHIVE
======================================================================*/
.main-archive { padding: 0; width: 100%; min-height: 600px; max-width: 880px; margin: 0 auto; }
.block-three01 { margin: 0 auto; padding: 0; position: relative; width: 100%; font-size: 0; }
.block-three01 li { padding: 10px; width: 33.333%; position: relative; font-size: 0; display: inline-block; }
.block-three01 img { width: 100%; height: auto; padding: 0; border-radius: 5px; border: 2px solid #fff; }
.block-three01 h3 { font-family: 'Noto Sans JP', sans-serif; font-size: 1.7rem; min-height: 90px; font-weight: 600; line-height: 1.6em; padding: 5px 2px; }

/*======================================================================
   SINGLE POST
======================================================================*/
.section-entry-index .bg-image { background-size: cover; background-position: center; background-repeat: no-repeat; }
.section-entry-index .bg-image.master, .section-entry-index .bg-shader.master { height: 600px; position: absolute; z-index: 1; top: 0; right: 0; left: 0; }
/*======================================================================
   ABOUT PAGE
======================================================================*/
.section-page-about { padding: 20px; }
.section-profile01 { padding: 50px 0; display: table; }
.section-profile01 .left { width: 67%; padding: 0 10px 0 0; float: left; }
.section-profile01 .right { width: 33%; padding: 0 0 0 20px; float: right; }
.section-profile01 .right img { width: 100%; height: auto; border-radius: 6px; }
@media only screen and (max-width:780px) { .section-profile01 .left, .section-profile01 .right { width: 100%; padding: 0; } }


/*======================================================================
   404
======================================================================*/
.page-404 h1 { padding: 40px 0 0; font-size: 20vw; line-height: 17vw; text-align: center; color: #dd8080; }
.page-404 h2 { font-size: 6vw; text-align: center; color: #dd8080; }
.page-404 p { text-align: center; font-size: 2vw; }
.page-404 .back-to-top { text-align: center; width: 100%; margin: 10px auto 50px; display: inline-block; }
.page-404 .back-to-top h6 { text-align: center; background: #de8282; color: #fff; width: 200px; margin: 0 auto; padding: 8px; display: inline-block; border-radius: 22px; }


/*======================================================================
   BREADCRUMBS
======================================================================*/
.breadcrumbs__list { margin: 0; padding: 1.2rem 0; }
.breadcrumbs__item { display: inline; margin-left: .5em; font-size: 1.5rem; font-family: Noto Sans JP, 'Lato', sans-serif; }
.breadcrumbs__item:before { margin-right: .25em; content: ">"; }

/*======================================================================
   VIDEO BG
======================================================================*/
#video-header { position: relative; height: 100vh; }
#video-area { position: fixed; z-index: -1; top: 0; right: 0; left: 0; bottom: 0; overflow: hidden; }
#video { position: absolute; z-index: -1; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 177.77777778vh; height: 56.25vw; min-height: 100%; min-width: 100%; max-width: unset; }

/*======================================================================
   NEON EFFECTS
======================================================================*/
.neon3 {
    text-shadow: 0px 0px 1px #e5e5e5, 0px 0px 1px #b9b9b9, 0px 0px 3px #838383, 0px 0px 3px #676767, 0px 0px 4px #333333;
}





#works .works-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    list-style: none;
    margin: 0;
    padding: 0;
}

#works .works-item a {
  display: block;
  text-decoration: none;
  color: inherit;
}

#works .works-thumb {
    width: 100%;
    aspect-ratio: 3 / 3;
    background: #d9d9d9;
    border-radius: 0;
    overflow: hidden;
    border-radius: 10px;
}

#works .works-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

#works .works-item a:hover .works-thumb img {
  transform: scale(1.05);
}

#works .works-info {
  padding: 0;
}

#works .works-title {
  font-size: 1.4rem;
  color: #2e3747;
  line-height: 1.5;
}


@media (max-width: 1180px) {
#works .works-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 27px;
}
}

@media (max-width: 768px) {
  #works .works-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
  }
}

@media (max-width: 480px) {
#works .works-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
}
}
@media (max-width: 420px) {
#works .works-grid {
        grid-template-columns: repeat(1, 1fr);
        gap: 10px;
    }
}

/* =====================================================================
   Philosophy
====================================================================== */
section.u-section {
    background: #fff;
    padding: clamp(10px, 3vw, 35px) 0 clamp(10px, 3vw, 20px);
}

section.u-section .u-section__inner {
	max-width: calc(1300px - 30px);
	margin: 0 auto;
	padding: 0 15px;
	box-sizing: border-box;
}

section.u-section .u-section__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(24px, 3vw, 64px);
    align-items: start;
    margin-bottom: clamp(28px, 4vw, 48px);
}

section.u-section .u-section__title {
    margin: 0 0 18px;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", "Noto Sans JP", Meiryo, sans-serif;
    font-weight: 300;
    font-size: clamp(2.9rem, 4.8vw, 5.2rem);
    line-height: 1.5;
    color: #1a2744;
    padding: 0px 0 0 0;
    letter-spacing: 0.03em;
    text-align: right;
}
section.u-section .u-section__title-line {
	display: block;
}

section.u-section .u-section__lead {
    margin: 15px 0 0;
    font-size: clamp(1.6rem, 4vw, 1.9rem);
    CONTAIN-INTRINSIC-BLOCK-SIZE: AUTO 100PX;
    color: #4b5563;
    font-weight: 400;
}

@media (max-width: 900px) {
	section.u-section .u-section__grid {
		grid-template-columns: 1fr;
	}
}