﻿@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@500;700&display=swap');
.font1,
#body{
    font-family: 'Zen Maru Gothic', "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}


.linkStyle{
    color: #F18A1A;
}
.linkStyle:hover{
    transition:all 0.3s;
    opacity:0.7;
    text-decoration:underline;
}

.font_15 {
    font-size: 18px;
}

/*
#pagetop{
    position:absolute;
}
*/

/*--all page---------------------------
-------------------------------------*/
body{
    letter-spacing:0;
    overflow:hidden;
}
#fakeloader .fl{
    max-width:350px;
}
.header-in {
    height: 80px;
    box-shadow: none;
}
.menu_btn {
    border: 0;
    box-shadow: none;
}
.logo1 {
    max-width: 150px;
    margin-right: 20px;
}
footer p{
    text-align:center;
}
.f_contact_img{
    position:relative;
}
.f_contact_img::before{
    content:'';
    position:absolute;
    display:block;
    width:100%;
    height:100%;
    background-color:rgba(0,0,0,0.3);
    top:0;
    left:0;
    z-index:1;
}
.f_contact_box{
    z-index:2;
    bottom: -150px;
}
.f_contact_box h4{
    line-height:1.2;
}
.f_contact_box .tel{
    line-height:1.5;
}
.pagetop{
    z-index: 3;
}

/*--top page---------------------------
-------------------------------------*/
.pc_nav .vma,
.pc_nav .hd_contact{
    padding-top:0!important;
}
.pc_nav .vma a,
.pc_nav .hd_contact a{
    border-radius:50px;
}
#main_img{
    position:relative;
}
#main_img::before{
    content:'';
    position:absolute;
    display:block;
    width:30vw;
    height:65vh;
    background-image:url(./Dup/img/catch.png);
    background-repeat:no-repeat;
    background-size:contain;
    top:28%;
    left:0;
    right:0;
    margin:auto;
    z-index:1;
}
#con1 {
    background-image: url(./Dup/img/machi.png);
    background-repeat: repeat-x;
    background-position: bottom;
    background-size: 100% auto;
    background-color: #F3F2EE;
    padding-bottom: 200px;
}
#con1 .ie1{
    width:120px;
    margin:auto;
}
#con1 h2{
    font-size:35px;
    font-weight:700;
}
.con1_squ{
    display:none;
}
#con2 .hand{
    width:100px;
    top: -80px;
    right: -50px;
    z-index:1;
    
}
#con2 .img_wrap{
    position:relative;
}
#con2 .img_wrap::before{
    content:'';
    position:absolute;
    display:block;
    width:60%;
    height:45%;
    background-size: auto auto;
    background-color: rgba(255, 255, 255, 1);
    background-image: repeating-linear-gradient(135deg, transparent, transparent 7px, rgba(251, 157, 55, 1) 7px, rgba(251, 157, 55, 1) 12px );
    bottom: 12%;
    left: 31%;
    z-index:-1;
    border-radius: 20px;
}
.con2_title{
    font-size:27px;
}
#con3 .men{
    width:70px;
    margin:auto;
}
.cmstitle .en{
    color: #F18A1A;
}
#con4 .bnr a{
    border-radius: 50px;
}
#con4 .men2{
    width: 120px;
    bottom: 15%;
    right: 8%;
}
.con4_list {
    max-width: 1450px;
}
.con4_list li{
    font-size:18px;
}
.cms_5-c .box_txt1::before,
#cms_5-c .box_txt1::before{
    top:2px;
}

/*---------top animation-------------*/
/*scroll underline*/
.Text-Span {
  position: relative;
  z-index: 1;
}
.Text-Span:after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 0%;
  height: 17px;
  background: #F7CC38;
  z-index: -1;
  transition: all 0.8s;
}
.Text-Span.isActive:after {
  width: 100%;
}


/* 拡大 */
.zoomIn{
  animation-name:zoomInAnime;
  animation-duration:0.5s;
  animation-fill-mode:forwards;
}

@keyframes zoomInAnime{
  from {
  transform: scale(0.6);
  opacity: 0;
  }

  to {
    transform: scale(1);
  opacity: 1;
  }
}
.zoomInTrigger{
    opacity:0;
}
/*--under page---------------------------
-------------------------------------*/
.pagetitle{
    background-color:transparent!important;
}
.pagetitle_img{
    opacity: 0.4;
    background-size: 100% auto;
}
.cate_list li a:hover{
    background-color:#F18A1A;
    color:white;
    border-color:#F18A1A;
}
#page4 .content{
    width:95%!important;
}
#page10 .sitemap li a:hover{
    background-color: #F18A1A;
}

/* ---------- responshive ---------- */

@media screen and (max-width: 1175px){
#con2 .d_flex > div{
    width:100%!important;
}
#con2 .con2_title{
    text-align:center;
}
#con2 .hand{
    left: 19%;
}
#con2 .img_wrap{
    margin-top:30px;
}
#con4 .pd_l-r5per{
    padding:0 2%;
}
.con4_list li {
    font-size: 16px;
    padding:20px;
}  
#con4 .men2{
    width:100px;
    right:1%;
    z-index:2;
}
}

@media screen and (max-width: 887px){
.header-in{
    width:99%;
}
.header-in .font_15{
    font-size:15px;
}
.logo1{
    max-width:110px;
    margin-right:0;
}
#main_img::before{
    width:35vw;
    height:30vh;
}
#con4 .men2{
    bottom:-2%;
}
}


/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
.logo1{
    max-width:200px;
}
#main_img::before {
    width: 38vw;
    left: auto;
    right: 25%;
}
#con2 .hand{
    left:0;
    right:0;
    margin:auto;
    top: -100px;
}
.con4_list li{
    width:80%;
    margin:auto;
    margin-bottom: 10px;
}
.con4_list li:nth-of-type(odd){
    margin:auto;
    margin-bottom: 10px;
}
.f_contact_box h4{
    font-size:40px;
}
.cms_5-c .box_txt1::before,
#cms_5-c .box_txt1::before {
    top: 6px;
}
}

/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
.font_15 {
    font-size: 15px;
}
.logo1{
    max-width: 150px;
    padding-left: 0;
}
#main_img::before{
    width:50vw;
    right:19%;
    top:42%;
}
#con1{
    background-size: 250%;
    margin-bottom: 50px;
    padding-bottom: 100px;
}
#con1 h2{
    font-size:24px;
    margin-top:0;
}
#con1 .ie1 {
    width: 80px;
    margin-top: 30px;
}
.con2_title {
    font-size: 22px;
}
#con2 .hand{
    width: 70px;
    top: -70px;
}
#con3 .men {
    width: 50px;
}
.con4_list li{
    font-size: 14px;
    padding:10px;
    width: 100%;
}
#con4 .men2{
    width: 70px;
}
.footer .width_1280-max{
    width:95%!important;
}
.f_contact_box h4 {
    font-size: 30px;
}
.cms_5-c .box_txt1::before,
#cms_5-c .box_txt1::before {
    top: 8px;
}
#page6 .content{
    padding-top: 50px;
}
#page6 .cate_box{
    padding: 30px;
}
}

/* ---------- IEの処理 ---------- */
@media all and (-ms-high-contrast: none){
#page8 .contact_tel a{
    padding:13px 40px 14px;
}
}


