﻿
/* ---------- font ---------- */

@import url('https://fonts.googleapis.com/css2?family=Jost:wght@500&family=Zen+Kaku+Gothic+New:wght@500;900&display=swap');

:root{
    --font-jp: 'Zen Kaku Gothic New', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
    --font-en: 'Jost', 'Zen Kaku Gothic New', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	/*font-family: "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";*/
}
body, .font_sans-serif, .font_serif, .font_shippori{
    font-family: var(--font-jp)!important;
}
.font_en, a[href^="tel:"]{
    font-family: var(--font-en);
}



/* ---------- color ---------- */
.bg_container .font_49 {
    color: #000;
}
#footer{
    background-color: #fff;
}
#top_cms1 .border_color2 {
    border-color: #141414;
}
#cms_3-c .border_color3 {
    border-color: #d7d7d7;
}
#tab_buttons .stepber ul li span.active.before{
    background-color: #f95a02;
}
.bg_line_color{
    background-color: #06c052;
}



/* ---------- all ---------- */
.fa-angle-up:before {
    content: "" !important;
    background-image: url(../img/pagetop.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    transform: translate(-50%, -50%);
}
html {
    font-size: 16px;
}
.font_14 {
    font-size: 16px;
}
::selection {
  background: #1ecee5;
  color: #000;
}
::-moz-selection {
  background: #1ecee5;
  color: #000;
}
.shop_link {
    display: none;
}
#logo img{
    max-width: 170px;
}
#header.active #logo img {
    max-width: 150px!important;
}
.button_container, .shop_link {
    height: 110px;
    width: 110px;
    border-radius: 50%;
    top: 19px;
    right: 19px;
    top: -7px;
    right: 19px;
    background-color: #3b3b3b00;
}
.button_container span{
    background: var(--normal);
}
#pc_nav {
    bottom: auto;
    top: -5px;
    right: 111px;
    background-color: transparent;
    backdrop-filter: none;
}
#logo2{
    max-width: 140px;
}
footer .f_btn_box p.line_bt{
    order: 2;
}
footer .f_btn_box p.contact_bt{
    order: 1;
}
footer .f_btn_box p.contact_bt a{
    background-color: #F95A04;
}
.overlay .tel_bt{
    display: none;
}
.overlay .sns_links:before {
    content: '';
    display: inline-block;
    width: 141px;
    height: 20px;
    background-image: url(../img/tel_img.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    left: 0;
    top: -32px;
    pointer-events: none;
}
.overlay .sns_links{
    position: relative;
    padding-top: 25px;
}



/* ---------- stroke ---------- */
#stroke {
    top: 176px;
    left: 67%;
    width: min(35%, 880px) !important;
    height: 90%;
    z-index: 2;
}
.stroke-path, .stroke-path2, .stroke-path3 {
    stroke:#00b6d9!important;
}
.stroke-path {
	fill: none;
	stroke: #111;
	stroke-dasharray: 1900;
	stroke-dashoffset: 1900;
	stroke-miterlimit: 10;
	stroke-width: 20px;
	stroke-linecap: round;
}
#stroke.active .stroke-path{
	animation: stroke-written 2.5s ease forwards;
}
@keyframes stroke-written {
	to {
		stroke-dashoffset: 0;
	}
}

#stroke2 {
    width: 100% !important;
    z-index: -1;
    position: absolute;
    top: -100px;
}
.stroke-path2 {
    fill: none;
    stroke: #111;
    stroke-dasharray: 1500;
    stroke-dashoffset: 1500;
    stroke-miterlimit: 10;
    stroke-width: 10px;
    stroke-linecap: round;
}
#stroke2.start .stroke-path2{
	animation: stroke-written2 2.5s ease forwards;
}
@keyframes stroke-written2 {
	50% {
		stroke-dashoffset: 0;
	}
	100% {
		stroke-dashoffset: 0;
	}
}

#stroke3 {
    width: 43% !important;
    z-index: 2;
    margin-top: 10px;
    position: relative;
    left: -25px;
}
.stroke-path3 {
    fill: none;
    stroke: #111;
    stroke-dasharray: 414px;
    stroke-dashoffset: 414px;
    stroke-miterlimit: 2;
    stroke-width: 7px;
     stroke-linecap: round; 
}
#stroke3.start .stroke-path3{
	animation: stroke-written 2s ease forwards;
}


/* ---------- anim ---------- */
.anim_box .item {
    transition: 1s;
    filter: blur(5px);
    transform: translateY(10px);
    opacity: 0;
    transition-property: opacity, transform, filter;
}
.anim_box .item.start {
    transform: none;
    filter: none;
    opacity: 1;
}


/* ---------- top ---------- */
video{
        min-height: 100%;
}
.con_img{
    width: 45% !important;
    margin-top: 50px;
    padding-right: 0px;
}
.con_video{
    overflow: hidden;
    height: 23vw;
    position: relative;
}
.con_video video{
    width: auto !important;
    height: 100%!important;
}
#main_img{
    height: 100%!important;
}
.fv_wrap {
    margin-top: 138px;
    margin-bottom: 8vw;
    position: relative;
}
#video {
    position: relative;
    max-width: 887px;
    overflow: hidden;
    width: 67vw !important;
    height: 33vw;
    max-height: 450px;
    margin: 0 auto;
}
.fv_p{
    /*font-size: clamp(20px, 2vw, 25px);*/
    font-size: clamp(22px, 2.2vw, 28px);
    padding-bottom: 1.3vw;
    letter-spacing: 0.45vw;
}
.fv_p2{
    /*font-size: clamp(16px, 1.3vw, 18px);*/
    font-size: clamp(16px, 1.5vw, 20px);
    padding-top: 1.5vw;
    padding-bottom: 2.5vw;
    letter-spacing: 0.45vw;
}
.fv_p3{
    letter-spacing: 0.2vw;
    font-size: clamp(12px, 1.3vw, 14px);
}


#wrap, #intro{
    overflow: visible;
}
#intro span.bg_box{
    opacity: 0;
}
#intro {
    align-items: flex-start;
    align-items: baseline;
    padding-top: 0;
    margin-top: -9vh;
        padding-bottom: 150px;
}
#intro .left {
    min-height: 100vh;
    width: 45% !important;
}
#intro .txt_wrap {
    padding: 107px 80px 0 14%;
    padding: 0 80px 150px 18%;
}
.intro_txt {
    font-size: clamp(16px, 1vw, 19px);
    line-height: 2.5;
    width: 100%;
    padding-top: 118px;
    padding-bottom: 113px;
}
/*#intro .right {
    position: sticky;
    top: 0;
    left: 0;
    width: 55% !important;
}
#intro .intro_img {
    height: 100vh !important;
}*/
#intro .right {
    position: sticky;
    top: 20%;
    top: 5%;
    left: 0;
    width: 52% !important;
    padding-right: 10%;
    margin-bottom: 12%;
}
.intro_title{
    font-size: clamp(26px, 2vw, 32px);
    font-size: clamp(26px, 2.3vw, 35px);
}
.intro_img2 {
    padding-right: 10%;
    margin-right: 67px;
    width: 100%;
    margin-top: 0;
    text-align: right;
    
    img{
        width: 350px;
    }
}
.intro_img6 {
    max-width: 1600px;
    margin: auto;
    margin-bottom: 50px;
}
.intro_img_box {
    padding: 0 10% 100px;
    margin: -7vw auto 34px;
    justify-content: space-between;
    
    .item{
        width: 26.33333%;
    }
}

.font_anim {
    position: relative;
    white-space: nowrap;
    will-change: transform;
    transition: transform .1s ease-out;
    font-size: 80px;
    color: #111;
    line-height: 1.2;
    font-weight: 200;
}
.font_anim_wrap::before {
    content: "";
    width: 100%;
    height: 17%;
    background-color:#00b6d9;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
    transform: translateX(-120%);
    opacity: 1;
}
.font_anim_wrap.start::before {
    animation: slideFade .8s ease-out forwards;
}

@keyframes slideFade {
    0% {
        transform: translateX(-120%);
        opacity: 1;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
.font_anim {
    position: relative;
    white-space: nowrap;
    will-change: transform;
    transition: transform .1s 
ease-out;
    font-size: 80px;
    color: #111;
    line-height: 1.2;
    font-weight: 200;
}

#contents_wrap .bg_container {
    background-color: transparent;
}
#contents_wrap .con_txt {
    line-height: 2.3;
}
#contents_wrap .title {
    text-align: left;
    padding-left: 20px;
}
.k_img_box {
    width: 100%;
    margin: auto;
    height: 53vh;
    background-attachment: fixed;
    margin-bottom: 50px;
    margin-top: 100px;
}
#contents_wrap .con_txt div.txt{
    line-height: 1.8;
}

#contents_wrap .con_item {
    min-width: 131px;
    width: 131px;
    top: -1%;
    display: none;
}

#top_cms1{
    padding-left: 8%;
    padding-right: 8%;
    padding-bottom: 0;
}
#top_cms1 .top_cms_title p, #top_cms2 .top_cms_title p {
    font-size: 62px;
    opacity: 1;
    bottom: 50px;
    left: -7px;
    transform: none;
    z-index: 1;
    letter-spacing: 6px;
    color: var(--normal);
    text-align: left;
}
#top_cms1 .top_cms_title h3, #top_cms2 .top_cms_title h3 {
    font-size: 19px;
    color: var(--normal);
}
.top_cms_box {
    padding-bottom: 10%;
}
#top_cms1 .top_cms_box {
    padding-bottom: 0;
}
.top_cms_title {
    text-align: left;
    margin-bottom: 0;
}
.more_bt {
    margin-top: 0;
}
footer .more_bt {
    margin-top: 25px;
}


/* ---------- under ---------- */
.cms_2-g{
    margin-bottom: 20px;
}
.btn_container a{padding: 8px 30px;}

#page_title{
        background: url(../img/page_bg1.jpg) center / cover no-repeat!important;
}
#page_title h2 span.font_anim {
    height: 95px;
}
#page_title::before{
    background: rgb(255 255 255 / 85%);
}
#cms_2-f .cate{
    border-color: #111;
}



/* ---------- tablet ---------- */
@media screen and (max-width: 768px){
.con_img {
    padding-bottom: 0;
    width: 100% !important;
    margin-top: 0;
    padding-right: 0px;
}
.con_video {
    overflow: hidden;
    height: 43vw;
    position: relative;
}
.title_wrap {
    padding-top: 0;
}
.fv_wrap{
    margin-top: 183px;
}
.fv_p2 {
    padding-top: 9.5vw;
}
#video {
    max-width: 850px;
    width: 69vw !important;
    height: 48vw;
}
.intro_title {
    font-size: clamp(23px, 2vw, 32px);
}
#intro {
    margin-top: 111px;
    padding-bottom: 105px
}
#intro .left {
    min-height: 100%;
    width: 100% !important;
}
#intro .txt_wrap {
    padding: 0 80px 0px 18%;
}
.intro_txt{
    padding-top: 65px;
    font-size: 17px;
    line-height: 2.5;
}
.stroke-path3 {
    stroke-width: 7px;
}
#intro .right {
    position: static;
    top: 20%;
    top: 5%;
    left: 0;
    width: 69% !important;
    padding-right: 0;
    margin-bottom: 0;
}
#intro .intro_img {
    height: 460px !important;
}
.intro_img2 {
    padding-right: 10%;
    margin-right: 67px;
    width: 100%;
    margin-top: 27px;
    text-align: right;
    
    img {
        width: 47%;
    }
}
.k_img_box {
    height: 229px;
}
.font_anim {
    font-size: 45px;
    transform: none !important;
    text-align: center;
}
.intro_img_box {
    padding: 0 10% 100px;
    margin: -13vw auto -74px;
    
    .item {
        width: 29.33333%;
    }
}
#contents_wrap .title {
    padding-left: 0;
}
#top_cms1 {
    padding-left: 0;
    padding-right: 0;
}
#top_cms1 .pd_l-r10per {
    padding: 0 5%;
}
#top_cms1 .top_cms_title p, #top_cms2 .top_cms_title p{
    font-size: 51px;
}
.top_cms_box {
    padding-bottom: 26%;
}
#page_title h2 span.font_anim {
    height: 45px;
}
}

/* ---------- mobile ---------- */
@media screen and (max-width: 667px){
.load_logo {
    width: 149px;
}
.con_video {
    height: 55vw;
}
.overlay .menu_box{
    background-color: rgba(255, 255, 255, 0.9);
}
#wrap, #intro {
    overflow: hidden;
}
.button_container, .shop_link {
    height: 81px;
    width: 63px;
}
#logo img {
    max-width: 107px;
}
#header.active #logo img {
    max-width: 107px!important;
}
.fv_p {
    font-size: 20px;
    padding-bottom: 4vw;
    letter-spacing: 0.2vw;
}
#main_img {
    margin-top: 0;
}
.fv_wrap {
    margin-top: 131px;
}
#video {
    width: 76vw !important;
    }
#stroke {
    top: 154px;
    left: 71%;
    width: 34%!important;
}
.stroke-path {
    stroke-width: 26px;
}
.fv_p2 {
    padding-top: 17.5vw;
}
#intro .txt_wrap {
    padding: 0 10% 0px 10%;
}
.intro_title {
    font-size: 20px;
}
.intro_txt {
    padding-top: 44px;
    font-size: 14px;
    line-height: 2;
    width: 100%;
    padding-bottom: 30px;
}
#intro .right{
    width: 75% !important;
}
#intro .intro_img {
    height: 260px !important;
}
.intro_img2 {
    padding-right: 12%;
    margin-right: 0;
    margin-top: 9px;
}
.font_anim {
    font-size: 24px;
    padding-left: 9px;
    letter-spacing: 0px;
}
.k_img_box {
    height: 233px;
    margin-top: 68px;
    background-attachment: scroll;
}
.intro_img_box {
    padding: 0 4% 0px;
    margin: -31vw auto 0px;
}
.intro_img_box .item {
    width:43.33333% !important;
    margin: auto;
    padding-bottom: 22px;
}

#contents_wrap h2 {
    padding-bottom: 4px;
}
#contents_wrap .title_wrap {
    padding-top: 0;
}
#contents_wrap .title {
    line-height: 1.5;
}
.font_13_sp {
    font-size: 14px;
}
#contents_wrap .con_txt div.txt {
    line-height: 1.9;
    line-height: 2;
}
#top_cms1 .top_cms_title p, #top_cms2 .top_cms_title p {
    font-size: 38px;
    bottom: 42px;
    left: -1px;
}
#top_cms1 .top_cms_title h3, #top_cms2 .top_cms_title h3 {
    font-size: 16px;
    letter-spacing: 1px;
}
.top_cms_title {
    margin-bottom: 18px;
}
.cms_2-g .box_wrap {
    box-shadow: rgb(0 0 0 / 0%) 0px 5px 15px 0px;
}
.cms_2-g .box_wrap .box_item .box_item_txt {
    padding-left: 0;
    padding-right: 0;
}
.more_bt {
    margin-top: 25px;
}
.top_cms_box {
    padding-bottom: 46%;
}
#gmap {
    height: 337px;
}
#logo2{
    max-width: 118px;
    margin-left: 0;
}
footer .bg_box {
    height: 241px;
}
#top_cms2 {
    padding-bottom: 70px;
}
#page_title h2 span.font_anim{
    font-size: 35px;
    padding-left: 0;
    letter-spacing: 3px;
    height: 37px;
}
#cms_2-g .cate_title {
    font-size: 23px;
    line-height: 1.4;
    letter-spacing: 1px;
}
.overlay .sns_links:before {
    top: -22px;
}
}




/* fix_bnr ---------------------------------------------------------------------------------------------*/
#fix_bnr, #fix_bnr2 {
    top: 38px;
    right: 158px;
    z-index: 10;
    width: 70%;
    max-width: 130px;
    transition: 0.5s;
    opacity: 0;
    pointer-events: none;
    z-index: 10;
}
#fix_bnr2{
    top: auto;
    bottom: 11px;
    right: 102px;
    max-width: 231px;
}
#fix_bnr.scroll,#fix_bnr2.scroll{
    opacity: 1;
pointer-events: auto;
}
#fix_bnr2.close{
    opacity: 0;
    z-index: -1;
}
@media screen and (max-width: 768px){
#fix_bnr{
    opacity: 1;
    pointer-events: auto;
}
#fix_bnr2.close{
    
}
}
@media screen and (max-width: 667px){
#fix_bnr{
    top: 1px;
    right: 89px;
    width: 18%;
    max-width: 62px;
    z-index: 1000
}
#fix_bnr2 {
    width: 53% !important;
    right: 0;
    left: 0;
    margin: auto;
    bottom: 7px;
    top: auto;
    display: block;
    max-width: 100%;
    opacity: 0;
    pointer-events: none;
}
#fix_bnr.scroll, #fix_bnr2.scroll{
    opacity: 1;
pointer-events: auto;
}
#fix_bnr a,#fix_bnr2 a {
    display: block;
    padding: 10px;
    text-align: center;
}
#fix_bnr img{
    max-width: 125px;
}
}
/* fix_bnr end ---------------------------------------------------------------------------------------------*/


/* 2025-12-23 */
.intro_img2_wrap{
    padding: 0 10% 100px;
    margin: -14vw auto 34px;
    justify-content: space-between;
}
.intro_img2_wrap .img{
    width: 26.33333%!important;
}

@media screen and (max-width: 768px){
.intro_img2_wrap{
    padding: 0 10% 100px;
    margin: -8vw auto -34px;
}
.intro_img2_wrap .img{
    width: 29.33333%;
    padding: 0;
}
}
@media screen and (max-width: 667px){
.intro_img2_wrap{
    padding: 0 4% 0px;
    margin: -24vw auto 27px;
}
.intro_img2_wrap .img {
    width: 43.33333% !important;
    margin: auto;
    padding-bottom: 22px;
}
}
