﻿
/* ---------- 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_mon_l{
    font-family: var(--font-jp);
}
.font_en, a[href^="tel:"]{
    font-family: var(--font-en);
}

/* ---------- color ---------- */
a {
    text-decoration: none;
    color: #333;
}
.linkStyle{color: #1a2f5c;transition: opacity .3s;text-decoration: underline;}
.linkStyle:hover{opacity: 0.7}

:root {
    --normal_color: #333333;
    --color1: #1a2f5c; /* メインカラー */
    --color2: #ddf0fc; /* サブカラー */
    --color3: #49c9d8; /* アクセントカラー1*/
    --color4: #f3f3f3; /* アクセントカラー2*/
    --color6: #fff105;
}
.txt_color6{color: var(--color6);}
.bg_color5 {
    background-color: var(--color1);
}
.txt{
	color: var(--normal_color);
}
#header_sns{
    background-color: transparent!important;
}


/* ---------- all ---------- */
.time {display: none;}
.marker{
    background: -webkit-linear-gradient(transparent 60%, #ff6 60%);
    background: -o-linear-gradient(transparent 60%, #ff6 60%);
    background: linear-gradient(transparent 60%, #ff6 60%);
}

.logo_wrap, header::before {
    width: 150px;
}
#header.active .logo_wrap {
    width: 136px;
}

#footer_info{
    position: relative;
}
#footer_info:before {
    content: "";
    display: block;
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    z-index: 1;
}
#footer_info:before {
    background-image: url(../img/item04.png);
    background-size: 100%;
    width: 242px;
    height: 295px;
    bottom: -74px;
    right: 23px;
    opacity: 0.6;
}
footer.bg_color5{
    position: relative;
    z-index: 2;
}
#footer_info .info_txt_wrap .f_mail a {
    background-color: #fff;
    padding: 10px 10px 0px;
    margin-left: 13px;
    width: min(94%, 474px);
    box-sizing: border-box;
}
#footer_info .f_mail a {
    padding-left: 0;
    padding-right: 0;
    max-width: 100%;
    font-size: 21px;
}

#pc_nav ul li:last-of-type a{
    background-color: var(--color1);
    border-radius: 0;
    color: #fff;
}



/* ---------- top ---------- */
header.top{padding: 0;}
.header_tel {display: none!important;}

.catch_wrap {
    top: 47%;
    width: 80%;
    max-width: 1000px;
    z-index: 2;
}

#main_img {
    background: url( "../img//fv01.jpg" ) center / cover no-repeat;
    z-index: 1;
}

#con_nav {
    padding-bottom: 20px;
}
#con_nav ul {
    margin-top: -79px;
    z-index: 3;
    width: 90%;
    max-width: 1280px;
}
#con_nav ul li a{
    padding: 30px 0;
}
.top_txt01_wrap {
    padding: 23px 5% 153px;
    background-color: var(--color2);
    text-align: center;
}

.top_txt01{
    margin: auto;
    width: min(90%, 1200px);
}

#top_contents1 .info_title {
    font-size: clamp(40px, 6.5vw, 59px);
}
#top_contents3 .con3_bg {
    background-image: url(../img/bg1.jpg);
    background-position: bottom;
    background-size: cover;
}
#top_contents3 .con3_no {
    color: var(--color2);
}
.con1_img {z-index: 1;}
.con3_img {
    margin-bottom: 0;
}
.con3_txt_wrap {
    padding: 50px;
    background-color: #fff;
    box-shadow:1px 1px 33px rgba(0,0,0,0.1);
}
.con2_txt_wrap {
    position: relative;
    width: 80%;
    max-width: 100%;
    padding-top: 183px;
    padding-bottom: 158px;
}
.con2_txt_wrap:before,.con2_txt_wrap:after {
    content: "";
    display: block;
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    z-index: 0;
}
.con2_txt_wrap:before {
    background-image: url(../img/item01.png);
    background-size: 100%;
    width: clamp(104px, 7vw, 300px);
    height: 500px;
    bottom: 4%;
    left: -3%;
    transform: rotate(-13deg);
}
.con2_txt_wrap:after {
    background-image: url(../img/item02.png);
    background-size: 100%;
    width: clamp(194px, 14vw, 400px);
    height: 295px;
    top: 50%;
    right: -14%;
    transform: rotate(-13deg);
}

#top_contents2 .con_title{
    display: inline-block;
    z-index: 1;
}
#top_contents2 .con_title:before {
    content: "";
    display: block;
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
}
#top_contents2 .con_title:before {
    background-image: url(../img/item03.png);
    background-size: 100%;
    width: 238px;
    height: 89px;
    top: -38px;
    left: -122px;
    transform: rotate(-13deg);
    z-index: -1;
}

/* contents */
.con_wrap {
    gap: 20px 2%;
}
.con2_item2 .con_box {
    width: 22%;
    box-sizing: border-box;
}
.con2_item2 .con_box:last-of-type {
    margin-right: 0;
}
.con2_item2 .con_img {
    border-radius: 30px;
}
.con2_item2 .con_title h3:before {
    content: "";
    display: block;
    width: 70px;
    height: 2px;
    position: absolute;
    bottom: -25px;
	left: 50%;
    -webkit-transform: translate(-50%,0);
    transform: translate(-50%,0);
	background-color: #3e3e3e;
}
.con2_item2 .con_txt{
	font-size: 13px;
}
@media screen and (max-width: 768px){
.con2_item2 .con_box {
    width: calc(33% - 12px);
}
}
@media screen and (max-width: 667px){
.con2_item2 .con_box {
    width: 80%;
    margin-right: 0;
    margin-bottom: 30px;
}
.con2_item2 .con_title h3:before {
    bottom: -15px;
}
}

/* nami */
#con_nav,#top_contents2{position: relative;}
#con_nav:before,#top_contents2:before,#top_contents2:after {
    content: "";
    width: 100%;
    height: 100px;
    position: absolute;
    left: 0;
    background-repeat: repeat-x;
    background-size: 110px;
    background-position: center top;
    z-index: 1;
}
#con_nav:before{
    top: 52px;
    background-image: url(../img/nami02.png);
}
#top_contents2:before{
    bottom: -78px;
    background-image: url(../img/nami01.png);
}
#top_contents2:after {
    top: -80px;
    left: 0;
    background-image: url(../img/nami01.png);
    transform: scale(1, -1);
}



/* ---------- under ---------- */
#page_title .title_img {
    height: 350px;
}
#page_title {
    margin-bottom: 189px;
}
#page_title .title_wrap {
    margin-top: -223px;
}
#page_title .sub_title{
    color:#fff!important;
    margin-bottom:0;
}
#page_title h2{
    color:#fff!important;
    font-weight:normal;
}
#page_title .title_before{
    display: none;
}
#page_title .sub_title:first-letter{
    color: var(--color6);
}
.btn_container {
    width: min(95%, 600px);
}
.line_bnr{
    width: min(100%, 500px);
}
#contact_mail a{
    padding-left: 0;
    padding-right: 0;
    max-width: 100%;
    font-size: 21px;
}


/* ---------- pc size ---------- */
@media screen and (max-width: 1230px){
#pc_nav ul li a{
    padding-left: 15px;
    padding-right: 15px;
    font-size: 15px;
}
}
@media screen and (max-width: 1123px){
.logo_wrap, header::before {
    width: 127px;
}
#pc_nav ul li a {
    font-size: 14px;
}
}
@media screen and (max-width: 1060px){
#header {
    padding: 20px;
}
header::before{
    left: 17px;
}
header.d_flex{
    padding: 10px 0;
}
#header.active .logo_wrap {
    width: 123px;
}
#pc_nav ul li a {
    padding-left: 10px;
    padding-right: 10px;
}
}

/* ---------- tablet ---------- */
@media screen and (max-width: 768px){
header.txt_color1{
    padding: 10px 0;
}
#header{
    padding-top: 15px;
}
#main_img {
        height: 80vw;
    }
.catch_wrap {
    top: 43%;
    width: 90%;
}
header::before {
    width: calc(100% - 40px);
}

#pc_nav ul li:last-of-type a {
    border-radius: 0 0 5px 5px;
    position: fixed;
    width: 106px;
    right: 45px;
    top: 0;
    padding: 13px 15px;
    text-align: center;
}

#con_nav:before, #top_contents2:before, #top_contents2:after{
    background-size: 70px;
}
#con_nav:before {
    top: 35px;
}
#con_nav ul{
    width: 95%;
}
.top_txt01_wrap {
    padding: 23px 2% 214px;
}
#top_contents1 .info_title {
    top: calc(-60vw - 56px);
}
#top_contents2:after {
    top: -82px;
}
#top_contents2:before {
    bottom: -82px;
}

#top_contents2 .con_title:before{
    top: -53px;
}
.con2_txt_wrap {
    width: 90%;
}
.con2_txt_wrap:before {
    width: clamp(89px, 7vw, 300px);
    height: 214px;
    bottom: 6%;
    left: -8%;
}
.con2_txt_wrap:after {
    width: clamp(197px, 14vw, 400px);
    height: 102px;
    top: 9%;
    right: -14%;
}
#footer_info .info_title {
    position: initial;
    margin-bottom: 20px;
}
#footer_info .info_txt_wrap .f_mail a {
    margin: auto;
    margin-bottom: 20px;
}
#footer_info .line_bnr{
    margin: auto;
}
}

/* ---------- mobile ---------- */
@media screen and (max-width: 667px){
#main_img {
    background: url(../img//fv01_sp.jpg) center / cover no-repeat;
}
#main_img {
    height: calc(100vw + 150px);
}
.catch_wrap {
    top: 43%;
    left: 52%;
    width: 100%;
}
.logo_wrap{
    width: 95px!important;
}
header.txt_color1 {
        padding: 0;
    }
header::before {
    width: calc(100% - 40px)!important;
}
#header.active .logo_wrap {
    width: 84px;
}
#header {
    padding-top: 16px;
        padding-bottom: 16px;
}
#con_nav ul {
    margin-top: -50px;
    width: 100%;
}
.top_txt01_wrap{
    padding: 23px 2% 216px;
}
.top_txt01{
    width: min(99%, 1200px);
}
#top_contents1 .info_title {
    top: calc(-44vw - 148px);
}

.con2_txt_wrap{
    padding-top: 130px;
    padding-bottom: 78px;
}
#top_contents2 .con_title:before{
    width: 150px;
    height: 89px;
    top: -53px;
    left: -16px;
}
.con2_txt_wrap:after {
    width: clamp(181px, 14vw, 400px);
    top: -2%;
    right: -14%;
}
.con2_txt_wrap:before {
    width: clamp(74px, 7vw, 300px);
    height: 176px;
    bottom: -1%;
    left: -8%;
    display: none;
}
.con2_txt_wrap {
    width: 100%;
}
.con3_txt_wrap{
    padding: 50px 20px 40px;
}
#page_title .title_wrap {
    margin-top: -130px;
}
#page_title .title_img {
    height: 190px;
}
#page_title {
    margin-bottom: 104px;
}
.cate_list {
    margin-bottom: 50px;
}
#footer_info:before {
    width: 175px;
    height: 217px;
    bottom: -56px;
    right: -5px;
}
#contact_mail a {
    font-size: 16px;
}
.f_conbox .f_mail p{
    font-size: 16px;
    letter-spacing: 0;
}
#contact_mail .fas, .f_conbox .f_mail .fas {font-size: 21px;}
}







