﻿@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400&display=swap');

/*コード集サイト■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
.txt_anim6 .txt_anim span{
	display: inline-block;
	-webkit-transform: translateY(20px);
	transform: translateY(20px);
	-webkit-animation: .35s cubic-bezier(.175,.885,.32,1.275) both;
	animation: .35s cubic-bezier(.175,.885,.32,1.275) both;
	opacity: 0;
}
.txt_anim6 .txt_anim span.start{
	-webkit-animation-name: slide-bs;
	animation-name: slide-bs;
	opacity: 1;
}
@keyframes slide-bs{
	0%{-webkit-transform: translateY(20px);transform: translateY(20px);}
	100%{-webkit-transform: translateY(0);transform: translateY(0);}
}

/*----------------------------------------------------------------------------------------*/
.flow_type2 .cate_title {
    border-bottom: solid 3px #fff6eb;
    position: relative;
}
.flow_type2 .cate_title::after {
    content: '';
    display: block;
    background: #fe9c05;
    width: 30%;
    height: 3px;
    position: absolute;
    left: 0;
    bottom: -3px;
}
.flow_type2 .box_wrap {
	border: 3px solid #ff9000;
    border-radius: 5px;	
}
.flow_type2 .cate_box {
	padding: 30px;
	width: 100%!important;
}
.flow_type2 .box_txt1 {
    background-color: #fffef2;
    color: #ff9000;
    text-align: center;
    border-radius: 5px;
}
.flow_type2 .cate_box:not(:last-child) {
	border-bottom: 3px solid #ff9000;
	position: relative;
}
.flow_type2 .cate_box:not(:last-child)::before,
.flow_type2 .cate_box:not(:last-child)::after {
	content: "";
	border: solid transparent;
	position: absolute;
	top: 100%;
	left: 17%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}
.flow_type2 .cate_box:not(:last-child)::before {
	border-width: 22px;
	border-top-color: #ff9000;
}
.flow_type2 .cate_box:not(:last-child)::after {
	border-width: 18px;
	border-top-color: #fff;
}

.flow_type2{counter-reset: number 0;}

.flow_type2 .box_txt1::before {
    counter-increment: number 1;
    content: "step." counter(number);
    background-color: #ff9000;
    padding: 5px 10px;
    font-weight: 700;
    color: #ffffff;
    display: block;
    margin: 0px auto 10px;
    width: 50%;
    border-radius: 5px;
}
/*-------- スマートフォン --------*/
@media screen and (max-width: 667px){
.flow_type2 .cate_box:first-child {
    padding: 20px 10px 30px 10px;
}
.flow_type2 .cate_box:not(:first-child) {
    padding: 40px 10px 20px 10px;
}


#page5 .flow_type2 .cate_box:first-child {
    padding: 20px 20px 30px 20px;
}
#page5 .flow_type2 .cate_box:not(:first-child) {
    padding: 40px 20px 20px 20px;
}

.flow_type2 .cate_box:not(:last-child)::before, .flow_type2 .cate_box:not(:last-child)::after {
    left: 50%;
}
.flow_type2 .cate_box:not(:last-child)::after {
    border-top-color: #ffffff;
}
}
/*-------- FireFox --------*/
@-moz-document url-prefix() {
.flow_type2 .cate_box:not(:last-child)::before, .flow_type2 .cate_box:not(:last-child)::after {top: 98% !important;}
}

/*コード集サイト■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*【控え目】5～10px*/
/*border-radius-------------------------------------------------------------------------*/
.con_img, .cate_img1, .box_img1, .box_img2, .box_img3, .box_img4, #cms_3-c .cate_box .box_title3 span,#contents3 .con_box,#intro_wrap,#page_title .page_title_box,.pd_l-r10per.pd_t-5per.pd_b-5per.pd_5per_tb.pd_t-50px_sp .con_box,.box_img1 img{border-radius: 5px;}
.nav_menu_more a,.cate_list li a,.pager li a{border-radius: 5px;}
#cms_2-b h3.cate_title {border-radius: 5px;}
/*border-radius-------------------------------------------------------------------------*/

/*毎回いる*/

.swiper-button-next, .swiper-button-prev { z-index: 2 !important;}
#top_cms.back1:before {z-index: -1;}
.nav_menu_more a span::before {
    display: none !important;}
.nav_menu_more.mg_t-10px a span::before {
    display: block !important;}
div#contents2_wrap {margin-top: 50px;}

/*タブレット*/
@media screen and (max-width: 768px){
#cms_1-a .pager li {margin-right: 0px;}
}

@media screen and (max-width: 667px){
#contents1 .line:before, #contents2 .line:before {
    left: 50%;
    -ms-transform: translate(-50%,0);
    -webkit-transform: translate(-50%,0);
    transform: translate(-50%,0);}
}

/* color　---------------------------------------------------------------------------------------------*/
body{overflow:hidden;}

#wrap {
    position: relative;
    background-color: #ffcc8a !important;
    background-image: url(dup/img/bg_img.png);
    background-size: 100%;
    /* background-attachment: fixed; */
    background-position: top 19% center;
}

div#main_img {background: #f8f6cb !important;
    padding-top: 50px;
}

main {
    background: url(dup/img/bg_img.png);
    background-size: 100%;}
    
body,.txt_color_nomal,.hvr_txt_color_nomal:hover{color: #0e3838;}
.txt_color1,.hvr_txt_color1:hover{color: #ff9000} /* メインカラー */
.txt_color2,.hvr_txt_color2:hover{color: #42b6bc} /* サブカラー */
.txt_color3,.hvr_txt_color3:hover{color: #6ea53d} /* アクセントカラー1 */
.txt_color4,.hvr_txt_color4:hover{color:#fff8a8} /* アクセントカラー2 */
/* background-color */
.bg_black,.hvr_bg_black:hover{background-color: #0e3838} /* 黒背景 */
/*.bg_white,.hvr_bg_white:hover{background-color: #FFFAFA;}*/
.bg_color1,.hvr_bg_color1:hover{background-color: #ff9000} /* メインカラー */
.bg_color2,.hvr_bg_color2:hover{background-color: #42b6bc} /* サブカラー */
.bg_color3,.hvr_bg_color3:hover{background-color: #6ea53d} /* アクセントカラー1 */
.bg_color4,.hvr_bg_color4:hover{background-color: #fff8a8} /* アクセントカラー2 */
/* border-color ※!important */
.border_color1,.hvr_border_color1:hover{border-color: #ff9000 !important}
.border_color2,.hvr_border_color2:hover{border-color: #42b6bc !important}
.border_color3,.hvr_border_color3:hover{border-color: #6ea53d !important}
.border_color4,.hvr_border_color4:hover{border-color: #fff8a8 !important}

#main_img:before {background-color: rgb(149 127 111 / 0.3) !important;}
#info_contact .con_img:before,.title_img:before,#contents3_wrap:after,#page_title:before{background-color: rgb(215 191 159 / 50%) !important;}
.overlay { background: linear-gradient(135deg, rgb(230 133 7 / 0.9) , rgb(255 144 0 / 0.9) ) !important;}
.nav_menu_more a:hover {color: #ffffff !important;}

header {background-color: rgb(243 182 104 / 85%) !important;}
#footer {background-color: rgb(255 255 255 / 80%);}
.back1:before,.back2:before {background-color: rgb(205 202 194 / 0%) !important;}
/*linkStyle*/
a.linkStyle {
    color: #6ea53d !important;
    border-bottom:solid 1px;
    opacity: 0.9 !important;
}
a.linkStyle:hover {color: #6ea53d!important;
                   opacity: 0.9 !important;}
                   
.opacity07,.opacity08{opacity:0.9;}

.nav_menu_more .bg_color1 {background: #6ea53d;}
/* color　---------------------------------------------------------------------------------------------*/



/*font-------------------------------------------------------------------------*/

.cms_title p,.page_title_box p,.con_title .pop400,.con_box h2,a.more_btn,.pop400,.hannari,.cate_title,.box_title1,.box_title2, h3.box_title{font-family: 'Zen Kaku Gothic New',"游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif !important;}
    
a{font-family: 'Zen Kaku Gothic New',"游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif !important;}

body {font-family: 'Zen Kaku Gothic New',"游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif !important;}
/*font-------------------------------------------------------------------------*/


/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ top ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*header-------------------------------------------------------------------------*/
header.scr_header #logo {max-width: 90px;}
.top header{z-index:5 !important;}
.opacity_0{opacity:1 !important;}
.menu { display: none;}
#main_img:before {background-color: rgb(149 127 111 / 0%) !important;}
/*header-------------------------------------------------------------------------*/


.menu {top: 41% !important;}
img.catch {
    width: 40%;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, -50%);}


.num{display:none;}

#contents1 .con_img, #contents2 .con_img {
    z-index: 1;
    border-radius: 5px;}

#contents1 .con_box, #contents2 .con_box,#intro,#contents3 .con_box {position: relative;}

#contents1 .con_box::before {
    width: 115%;
    height: 135%;
    left: -5%;
    top: -15%;}
    
#contents2 .con_box::before {
    width: 115%;
    height: 130%;
    right: -5%;
    top: -15%;}

#contents1 .con_box::before, #contents2 .con_box::before {
    content: '';
    position: absolute;
    display: block;
    background-color: #ffffff;
    border-radius: 5px;
    z-index: 0;}


#contents1 {
    margin-bottom: 200px;
    margin-top: 150px;}
#contents2 {margin-bottom: 100px;}

#contents3 .con_box{
    border-radius:5px 0 0 5px;
    margin: 0 0 0 50%;
    background:#ffffff;
}

#contents3_wrap:after{background-color: rgb(215 191 159 / 0%) !important;}

#contents1 .con_box {margin-top: 10%;}
#contents2 .con_box {margin-top: 10%;}

.item {z-index: 1;}


.item01 {
    width: 19vw;
    bottom: -66px;
    left: -1px;}
.item02 {
    top: -50px;
    right: -76px;
    width: 15vw;
}
.item03 {
    width: 17vw;
    top: -10px;
    right: 1px;
}
.item04 {
    width: 15vw;
    top: -100px;
    left: 1px;}
.item05 {
    width: 17vw;
    top: -168px;
    right: -2%;
}
 
 
/* 拡大 */
.zoomIn{
  animation-name:zoomInAnime;
  animation-duration:0.7s;
  animation-fill-mode:forwards;
}

@keyframes zoomInAnime{
  from {
  transform: scale(0.6);
  opacity: 0;
  }

  to {
    transform: scale(1);
  opacity: 1;
  }
} 
    
#contents3_wrap:before, #contents3_wrap:after {width: 66%;
                                           border-radius: 0 0 5px 0;}
                                           
                                        
.top_cms_box:first-of-type {padding-top: 150px;}

.cms_wrap,.flow_type2 {
    background: #ffffff;
    border-radius: 5px;
    padding: 30px 30px;}


#intro p, #contents1 p, #contents2 p, #contents3 p {
    font-size: 16px;
    z-index: 3;
    position: relative;}
    

.cms_title p {
    color: #42b6bc;
    font-size: 15px;
    font-weight: 600;
    padding-bottom: 4px;
}

.cms_title p:before {
    background-color: #42b6bc;
    top: 10px;
}
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ top ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/


/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ sub ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
div#page_title {height: 350px;
                background: #f8f6cb;}
#page_title:before {background-color: rgb(215 191 159 / 0%) !important;}



#cms_2-b .cate_box {
    border: solid 0px !important;
    border-radius: 5px;
    background: rgba(255,247,234,0.9) !important;
    margin-bottom: 15px;

}    
#cms_2-b img{box-shadow: 0 2px 4px rgba(0,0,0,0);}

#cms_2-c .cate_box {
    border: solid 0px !important;
    border-radius: 10px;
    background: rgb(255 248 168 / 0.25) !important;
    margin-bottom: 20px;
    padding-bottom: 10px;
}   

#cms_3-b .cate_box {
    border: solid 0px !important;
    border-radius: 10px;
    background: rgb(255 248 168 / 0.25) !important;
    margin-bottom: 20px;    
}   

section#cms_3-b .cate_title{border-radius:5px;}

.page_title_box {transform: translate(-50%,10%);}

main {
    background: url(dup/img/bg_img.png);
    background-size: 100%;
    background-position: top 500px center;
}


section#cms_3-b h3.pd_b-50px {
    display: none;
}

section#cms_3-b h3.pd_b-50px:first-of-type {
    display: block;
    background: rgb(248 246 203 / 30%);
    padding: 8px;
    margin-bottom: 50px;
    border-radius: 5px;
    font-size: 25px;
    text-align: center;
}

#cms_5-a .cate .cate_title {border-radius: 5px;}
#cms_5-a .box_wrap{border-radius:0 0 5px 5px;}

#cms_5-a h4.box_title1 {color: #ff9000;}
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ sub ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ all ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/
#logo {max-width: 120px !important;}
#pc_nav li, #top_pc_nav li, #footer_nav li {max-width: 228px;}
section#footer_nav {
    margin-bottom: 0;
    padding-bottom: 50px;
}
/*■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ all ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■*/

/*タブレット*/
@media screen and (max-width: 768px){
.button_container {   top: 59%;}    
main {
    background: url(dup/img/bg_img.png);
    background-size: 100%;
    background-position: top 250px center !important;}
div#left {height: 100vh;}  
div#main_img {
    background: #f8f6cb !important;
    padding-top: 0px;}
#logo {max-width: 90px !important;}    
body {overflow: hidden !important;}

.head_banner {
    top: 33px;
    right: 118px;
}
a.res,a.res_sp{
    border-radius: 5px;
    background: #d4e4bc;
  transition:0.7s;
}
a.res:hover,a.res_sp:hover{
  background: rgba(212,228,188,0.7);
  transition:0.7s;
}
a.res::after,a.res_sp::after{
display:none;}

a.res_sp {padding: 10px;}
a.res_sp{opacity:0;}
.scr_header a.res_sp{opacity:1;}


.flex_order1_tb {
    order: initial;
}
.page_title_box {letter-spacing: 2px;}
#cms_1-a .pager li {margin-right: 0px;}
#fakeloader .fl { max-width: 200px;}
img.catch {
    width: 60%;
    position: absolute;
    top: 120%;
    left: 50%;
    transform: translate(-50%, -50%);}
#intro p, #contents1 p, #contents2 p, #contents3 p {font-size: 15px;}
#contents1 .con_box::before, #contents2 .con_box::before {
    content: '';
    position: absolute;
    display: block;;
    z-index: 0;
}
#contents1 .con_img, #contents2 .con_img {
    width: 70%!important;
    margin: 0px auto -50px;}
#contents1 .con_box, #contents2 .con_box {
    width: 100%!important;
    padding: 0 50px;
    margin-top: 12%;}
#contents1 .con_box::before, #contents2 .con_box::before {
    width: 100%;
    left: 0;
    top: -22%;
    right: 0;
    margin: auto;}
#contents1 .con_box::before {height: 130%;}

#intro h3, #contents1 h3, #contents2 h3, #contents3 h3 {
    text-align: center !important;
    display: block;}

#contents1 {
    margin-bottom: 20px;
    margin-top: 90px;}
    
#contents3 .con_box {
    border-radius: 5px 0 0 5px;
    margin: 0 0 0 36%;}
    
#contents3_wrap:before, #contents3_wrap:after {
    width: 50%;
    border-radius: 0 0 5px 0;}

.item01 {
    width: 18vw;
    bottom: -63px;
    left: 5px;}
.item02 {
    top: -31px;
    right: -38px;
    width: 17vw;}
.item03 {
    width: 20vw;
    top: 184px;
    right: 14px;
    z-index: 3;}
.item04 {
    width: 20vw;
    top: 300px;
    left: 0px;
    z-index: 3;}
.item05 {
    width: 19vw;
    top: -68px;
    right: -2%;}
.topcms_about_type1 .cate_box .box_title1 {
    font-size: 16px;
    line-height: 1.5;
    z-index: 1;
    letter-spacing: 0;}
.topcms_about_type1 .cate_box {
    margin: 0 auto 80px;
    width: 31.333333%!important;}
.topcms_about_type1 .cate_box {
    width: 31%!important;
    padding: 50px 15px 20px;}
.topcms_about_type1 .box_txt1{padding-top: 15px;}
#wrap {background-size: 120%;}
p#logo2 a {max-width: 180px;}

#contents1 .line:before, #contents2 .line:before {
    left: 50%;
    -ms-transform: translate(-50%,0);
    -webkit-transform: translate(-50%,0);
    transform: translate(-50%,0);}
.cms_title h3 {font-size: 26px !important;}

section#info_contact {
    margin-bottom: 0;
    padding-bottom: 50px;}
    
div#footer_con h2 {font-size: 21px;}
.page_title_box {width: 52%;}


    #cms_2-c .box_item {
    word-break: break-all;
    padding: 0px 20px 20px;}
    /*#cms_2-c .cate_box:first-of-type{padding-top: 0px;}*/
    #cms_2-c .cate_box {
    border-bottom: solid 1px rgb(4 160 232 / 50%);
    padding-top: 15px;}

}



/*スマホ*/
@media screen and (max-width: 667px){

#logo {max-width: 60px !important;}    
div#left {height: 75vh;}
div#main_img {
    background: #f8f6cb !important;
    padding-top: 70px;}

#intro_wrap {padding: 6% 3% 8% 3%;}



#cms_2-b .cate_box { padding: 10px;}    
#cms_2-b {padding: 0px 0px !important;}
.cms_wrap {padding: 0px 0px !important;}
img.catch {width: 90%;} 
#logo {max-width: 70px;}
header.scr_header #logo {max-width: 60px;}
#intro h3, #contents1 h3, #contents2 h3, #contents3 h3 {font-size: 17px;
        letter-spacing: 0.5px;}

#intro p, #contents1 p, #contents2 p, #contents3 p {
    font-size: 14px;
    letter-spacing: 1px;}

#contents1 .con_img, #contents2 .con_img {
    width: 70%!important;
    margin: 0px auto -25px;}
#contents1 .con_box, #contents2 .con_box {
    width: 100%!important;
    padding: 0 10px;
    margin-top: 14%;}
div#contents2_wrap {margin-top: 0px;}
.item04 {
    width: 20vw;
    top: 100px;
    left: -2px;}
#contents1 .con_box::before, #contents2 .con_box::before {
    width: 104%;
    left: -2%;
    top: -26%;}
#contents3 .con_box {
    border-radius: 5px;
    margin: 0 3%;}
#contents3_wrap:before, #contents3_wrap:after {
    width: 100%;
    border-radius: 0 0 0px 0;}
#contents2 {margin-bottom: 50px;}
.topcms_about_type1 .cate_box {
    width: 100%!important;
    padding: 50px 15px 20px;}
p#logo2 a {max-width: 150px;}
#fakeloader .fl {max-width: 140px;}
#wrap {background-size: 160%;}
.page_title_box {width: 71%;}
#page6 .cate_box {padding: 20px;}
.page_title_box h2 {
    font-size: 20px;
    letter-spacing: 1px;}

#page9 p {
    font-size: 13px;
    padding-left: 15px;
    letter-spacing: 2px;
}

.head_banner {
    top: 15px;
    right: 87px;
}

main {
    background: url(dup/img/bg_img.png);
    background-size: 110%;
    background-position: top 145px center !important;    
}

div#footer_con h2 {font-size: 20px;}
.cate_box .cms_wrap{
    margin: 0;
    width: 100% !important;}
.cms_wrap {padding: 20px !important;}

.item01 {
    width: 29vw;
    bottom: -64px;
    left: -8px;}
.item02 {
    top: -23px;
    right: -20px;
    width: 22vw;}    
.item03 {
    width: 29vw;
    top: 75px;
    right: -5px;}
.item04 {
    width: 25vw;
    top: 100px;
    left: -2px;}
.item05 {
    width: 33vw;
    top: -55px;
    right: -6%;}
    
.cms_wrap,.flow_type2 {
    background: #ffffff;
    border-radius: 5px;
    padding: 20px;}
    
.cms_1-a .cate_box {
    margin: 0;
    width: 100% !important;}
    
.cms_2-c .box_description2 {padding: 10px 10px 0;}
div#page_title {
    height: 200px;
    background: #f8f6cb;}
section#cms_2-c .box_item.box_description1 {padding: 10px 20px 0;}

section#cms_3-b h3.pd_b-50px:first-of-type {
    margin-bottom: 20px;
    font-size: 15px;}
    
section#cms_3-b h3.cate_title {font-size: 19px;}
#cms_3-b .cate_box {
    border: solid 0px !important;
    border-radius: 10px;
    background: rgb(255 248 168 / 0.25) !important;
    padding: 15px 15px 1px;
    margin-bottom: 15px;    
}

#cms_5-a .box_wrap {
    border-radius: 0 0 5px 5px;
    padding: 10px 0px 10px 17px;}
    
#page6 .cate_box {padding: 10px;}

.page_title_box {transform: translate(-50%,0%);}
#cms_2-c .box_item {
    word-break: break-all;
    padding: 20px;}
}


/*お問い合わせバナー*/
#h1txt{padding-bottom: 100px;}
#fix_banner{
width: 300px;
position: fixed;
bottom: 0;
right: 80px;
z-index: 4;
}

/*タブレット*/
@media screen and (max-width: 768px){
    #fix_banner {
        width: 250px;
        position: fixed;
        bottom: 0;
        right: 50px;
        z-index: 2;}
p#copyright {
    font-size: 12px;
    padding: 2px;}
}

@media screen and (max-width: 667px){
    #fix_banner {
    width: 200px;}
    #h1txt{padding-bottom: 80px;}
    p#copyright {padding: 2px 0;}}
    
    


/*20220810*/
#fix_banner {
    width: 200px;
        z-index: 4;
}
.cms_bnr{background:rgba(255,248,168,0.5);
}


/*タブレット*/
@media screen and (max-width: 768px){
    #h1txt {padding-bottom: 130px;}
}

/*スマホ*/
@media screen and (max-width: 667px){
#fix_banner {
    width: 151px;

}}