﻿.top_cms_box.cms1 .sub_title{
  color: rgb(253 186 170 / 70%);
    letter-spacing:5px;
}
.button_container{
    opacity:1;
}
.button_container span{
    height:2px;
}
.marker {
    background: linear-gradient(transparent 60%, #fdfdb0 60%);
}
.hvr_txt_color1:hover {
    color: #b3c677;
}
header.clone-nav{
    z-index:10;
}
.main_img_wrap {
    height: auto;
    min-height: 0;
    margin-bottom: 100px;
}
#page_title .title:before {
    width: 100%;
    height: 150px;
    content: "";
    position: absolute;
    background: url(Dup/img/title_img.png) no-repeat;
    background-size: contain;
    left: 0;
    background-position: center;
    top: -150px;
    z-index: -1;
}
#page_title {
    background-image: url(Dup/img/page_title.jpg) !important;
    background-size: cover !important;
background-attachment: unset;
}

#page_title:before {
    width: 50%;
    height: 100%;
    background: url(Dup/img/page_title1.png) no-repeat;
    content: "";
    position: absolute;
    background-size: contain;
}
#page_title:after {
    width: 50%;
    height: 100%;
    background: url(Dup/img/page_title2.png) no-repeat;
    content: "";
    position: absolute;
    right: 0;
    background-position: right;
    background-size: contain;
}
#tel_contact .box_wrap .box {
    padding: 20px;
    box-sizing: border-box;
}
#tel_contact .box_wrap {
    display: flex;
    justify-content: center;
    max-width: 800px;
    margin: auto;
}
#cms_2-b .cate_title {
    border-color: #ffeeea;
}
#cms_3-c .box_txt1 {
    background: whitesmoke;
    padding: 10px !important;
    box-sizing: border-box;
    border-radius: 5px;
}
.cms_link div a {
    background: #b3c677;
    color: white;
}
.cms_link div a:hover{
    color:white;
}
a.linkStyle {
    color: #a7c93d;
    text-decoration: underline;
}
#page_title {
    margin-top: 70px; 
}
.border_color3 {
    border-color: #b3c677;
}
.bg_color2 {
    background-color: #fcf9f1;
}
.hvr_txt_color3:hover {
    color: #5a3216;
}
.hvr_bg_color1:hover {
    background-color: #b3c677;
}
.bg_color3 {
    background-color: #b3c677;
}
#contents .con1 .fig_wrap:before {
    width: 220px;
    height: 200px;
    content: "";
    position: absolute;
    background: url(Dup/img/con_img2.png) no-repeat;
    right: -80px;
    z-index: 2;
    background-size: contain;
    bottom: -50px;
}
#contents .con2 .fig_wrap:before {
    width: 180px;
    height: 200px;
    content: "";
    position: absolute;
    background: url(Dup/img/con_img3.png) no-repeat;
    left: -60px;
    z-index: 2;
    background-size: contain;
    bottom: -50px;
}
#contents .con3 .fig_wrap:before {
    width: 200px;
    height: 140px;
    content: "";
    position: absolute;
    background: url(Dup/img/con_img4.png) no-repeat;
    right: -60px;
    z-index: 2;
    background-size: contain;
    bottom: -50px;
}
#contents .box .fig_wrap {
    position: relative;
}
#contents .box:nth-child(even) .fig_wrap{
    margin-left: 40%;
}
#contents .box:nth-child(even) figure {
    margin-left:0%;
}
.fig_wrap figure {
    width: 100%;
}
#contents h2:before {
    width: 100%;
    height: 110px;
    content: "";
    position: absolute;
    background: url(Dup/img/con_img1.png) no-repeat;
    background-size: contain;
    left: 0;
    background-position: center;
    top: -115px;
}
#contents h2 {
    position: relative;
}
#contents h2 {
    font-size: 40px;
}
#question .txt {
    padding-left: 50px;
    box-sizing: border-box;
    margin-bottom: 20px;
    padding-bottom: 5px;
}
#question .txt .check {
    position: absolute;
    left: 0;
}
header li a {
    color: #5a3312;
}
#contents .box .box_item {
    background-color: #ffeeea; 
}
#contents .box .box_item:before{
    display:none;
}
#contents .box .box_item{
    border-radius:10px;
}
section#contents{
    background:white;
}
#question .txt:before {
    background-color: rgb(243 243 243) !important;
}
.txt_color3 {
    color: #fdbaaa;
}
.bg_color1 {
    background-color: #F7E1E5;
}
header {
    transform: translateY(0) !important;
}
header.clone-nav {
    background: #fdcabe;
    padding: 15px 0;
}
header .logo {
    max-width: 300px;
}
.main_img {
    position: static!important;
    margin-top: 70px;
}
.bg_color4 {
    background-color: #fcf9f1;
}
.bg_color1 {
    background-color: #fbcabf;
}
.txt_color1 {
    color: #abbd70;
}
.border_color1 {
    border-color: #abbd71;
}
#intro .box_wrap .box_txt {
    width: 45%;
}

#intro .box_wrap .box_img {
    width: 55%;
    position: relative;
    left: 20px;
}
#intro .box_wrap {
    display: flex;
    justify-content: center;
}
section#intro h2 span:first-of-type {
    font-size: 24px;
    background: #b3c677;
    position: relative;
    color: white;
    padding: 5px 30px;
    display: inline-block;
    border-radius: 45px;
    font-weight: normal;
    margin-bottom: 10px;
}
section#intro h2 {
    text-align: center;
    font-size: 40px;
    font-weight: bold;
    margin-bottom:80px;
    font-family: 'M PLUS Rounded 1c', sans-serif;
    
}

body, .txt_color_nomal {
    color: #5b3312;
}
#intro .box_wrap .box_txt {
    padding: 5%;
    box-sizing: border-box;
    background: #ffeeea;
    border-radius: 10px;
}
#intro .box_wrap {
    display: flex;
    justify-content: center;
    max-width: 1280px;
    margin: auto;
}
section#intro h2 span:last-of-type{
    position:relative;
}
section#intro h2 span:last-of-type:before {
    content: "";
    position: absolute;
    width: 3px;
    height: 55px;
    border-radius: 5px;
    background: #5b3312;
    transform: rotate(-45deg);
    left: -35px;
    bottom: -5px;
}
section#intro h2 span:last-of-type:after {
    content: "";
    position: absolute;
    width: 3px;
    height: 55px;
    border-radius: 5px;
    background: #5b3312;
    transform: rotate(45deg);
    right: -35px;
    bottom: -5px;
}
section#intro {
    padding: 0 5%;
    margin-bottom: 100px;
}
#intro .box_wrap2 ul li {
    width: 23%;
    text-align: center;
    background: #bdd388;
    color: white;
    padding: 10px;
    box-sizing: border-box;
    border-radius: 5px;
}
#intro .box_wrap2 ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}
#intro .box_wrap2 {
    max-width: 1180px;
    margin: auto;
    margin-top: 80px;
}

/*-------------------------タブレット-------------------------------*/
@media screen and (max-width:768px){
    header .logo img {
    height: 40px!important;
    width: auto!important;
}
header.clone-nav {
    background: #fdcabe;
    padding: 20px 0;
}
.main_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.main_img {
    position: static!important;
    margin-top: 70px;
}
.main_img {
    height: 35vh;
    width: 100%;
}

section#intro h2 {
    text-align: center;
    font-size: 28px; 
}
section#intro h2 span:first-of-type {
    font-size: 18px; 
}
.t_banner_box .banner {
    width: 40%; 
}
section#intro h2 span:last-of-type:after,section#intro h2 span:last-of-type:before{
        height: 50px;
}
#intro .box_wrap {
    flex-direction: column;
}
#intro .box_wrap .box_img {
    width: 80%;
    position: relative;
    left: 20px;
    margin: auto;
}
#intro .box_wrap .box_txt {
    width: 80%;
    margin: auto;
    margin-top: -20px;
}
#intro .box_wrap2 ul{
    justify-content: flex-start;
}
#intro .box_wrap2 ul li {
    width: calc(33% - 5px); 
}
#intro .box_wrap2 {
    margin: auto;
    margin-top: 50px;
    width: 80%;
}
#question .txt{
    width:100%;
    margin-bottom:30px;
        padding-bottom: 10px;
    font-size: 20px;
}
#contents .box:nth-child(even) .fig_wrap {
    margin-left: 0;
}
#contents .fig_wrap:before{
    display:none;
}
#page_title:before {
    width: 30%;
    height: 100%;
    background: url(Dup/img/page_title1.png) no-repeat;
    content: "";
    position: absolute;
    background-size: cover;
}
#page_title:after {
    width: 30%;
    height: 100%;
    background: url(Dup/img/page_title2.png) no-repeat;
    content: "";
    position: absolute;
    right: 0;
    background-position: right;
    background-size: cover;
    z-index: -1;
}
#page_title {
    margin-top: 80px;
    z-index:2;
}
#tel_contact .box_wrap {
    display: flex;
    justify-content: center;
    max-width: 400px;
    margin: auto;
    flex-wrap: wrap;
    margin-bottom: 50px;
}
#tel_contact .box_wrap .box div {
    margin-bottom: 0;
}
}

/*-------------------------スマホ-------------------------------*/
@media screen and (max-width:667px){
    .main_img {
    height: auto;
    width: 100%
    }
    header.clone-nav {
    background: #fdcabe;
    padding: 10px 0;
}
.t_banner_box .banner {
    width: 80%;
}
.main_img_wrap {
    margin-bottom: 50px;
}
header.clone-nav {
    padding: 20px 0;
}
header .logo img {
    height: auto !important;
    width: 100% !important;
}
header .logo {
    max-width: 180px !important;
    height: auto !important;
}
section#intro h2 {
    text-align: center;
    font-size: 24px;
    margin-bottom: 30px;
    
}
section#intro h2 span:last-of-type:after, section#intro h2 span:last-of-type:before {
    height: 35px;
}
section#intro h2 span:last-of-type:after{
    right:-20px;
}
section#intro h2 span:last-of-type:before{
    left:-20px;
}
section#intro h2 span:first-of-type {
    font-size: 16px;
}
#intro .box_wrap .box_img {
    width: 100%;
    position: relative;
    left: 0;
    margin: auto;
}
#intro .box_wrap .box_txt {
    width: 100%;
    margin: auto;
    margin-top: 10px;
}
#intro .box_wrap2 ul li {
    width: 100%;
}
#intro .box_wrap2 {
    margin: auto;
    margin-top: 40px;
    width: 90%;
}
#question .txt {
    font-size: 18px;
}
#contents h2 {
    font-size: 24px;
}
#contents h2:before {
    width: 100%;
    height: 80px; 
    top: -85px;
}
.top_cms_wrap {
    padding-top: 0px;
}
#page_title .title:before {
    width: 100%;
    height: 110px;
    top: -110px;
    z-index: -1;
}
.all_page header .logo img {
    height: auto !important;
}
#page_title {
    margin-top: 65px; 
}
#page_title:after,#page_title:before{
    display:none;
}
#cms_3-c .box_txt1{
    margin-top:10px;
}
#tel_contact .box_wrap .box {
    padding: 10px 0;
    box-sizing: border-box;
}
#tel_contact .box_wrap .box h3 {
    margin-bottom: 5px;
}
section#intro h2 span:last-of-type:after,section#intro h2 span:last-of-type:before{
    display:none;
}
.main_img {
    position: static!important;
    margin-top: 65px;
}
#question h2 {
    white-space: nowrap;
}

}


/*2025-11-11*/
.t_banner_box .banner:hover{
    transform: translateY(-5px);
    margin-top: 0;
}