/*
Theme Name: yoneya
*/


*{
  box-sizing: border-box;
  line-height: normal;
  margin: 0;
  padding: 0;
}

html{
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body{
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5em;
}

ul,
ol{
  list-style: none;
}

li{
  list-style-type: none;
  position: relative;
}

a{
  color: #0d67d6;
  display: inline-block;
  position: relative;
  text-decoration: none;
  transition: 0.2s;
}

a:hover{
  opacity: 0.7;
}

img{
  display: block;
  height: auto;
  max-width: 100%;
  transition: 0.4s;
}

::before,
::after{
  background-repeat: no-repeat;
  background-position: center;
  transition: 0.2s;
}

table{
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
}

.inner{
  margin-left: auto;
  margin-right: auto;
  max-width: 1000px;
  width: 95%;
}

.flex_box{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.flex_box.center{
  justify-content: center;
}

.center{
  text-align: center;
}
img.center{
  margin-left: auto;
  margin-right: auto;
}

.right{
  text-align: right;
}

.bold{
  font-weight: 700;
}

span.red{
  color: #cf2e2e;
}

.sp{
  display: none;
}

.shiny{
  overflow: hidden;
  position: relative;
}

.shiny::before{
  position: absolute;
  content: '';
  display: inline-block;
  top: -180px;
  left: 0;
  width: 30px;
  height: 100%;
  background-color: #fff;
  transition: 500ms;
  animation: shinyshiny 2.5s ease-in-out infinite;
}

@-webkit-keyframes shinyshiny {
    0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
    80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
    81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
    100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}

main{
  display: flex;
  justify-content: space-between;
  max-width: 1000px;
  margin-top: 30px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 10rem;
  width: 100%;
}

main #sidebar{
  width: 220px;
}

main #main_contents{
  width: calc(100% - 250px);
}

main:not(#top) #main_contents a:hover{
  text-decoration: underline;
}

.mb-10{
  margin-bottom: 10px;
}
.mb-20{
  margin-bottom: 20px;
}
.mb-30{
  margin-bottom: 30px;
}
.mb-40{
  margin-bottom: 4rem;
}
.mb-50{
  margin-bottom: 5rem;
}

.youtube_wrap,
.wp-video,
.wp-block-embed__wrapper{
  height: 0;
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}

.youtube_wrap iframe,
.wp-video video,
.wp-block-embed__wrapper iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.staff-movie iframe{
  aspect-ratio: 16 / 9;
  height: 100%;
  margin-top: 20px;
  width: 100%;
}

.shortcut_wrap{
  margin: 30px 0;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  html{
    font-size: 50%;
  }
  
  .sp{
    display: block;
  }
  .pc{
    display: none !important;
  }
  
  main #main_contents{
    margin-left: auto;
    margin-right: auto;
    width: 95%;
  }
}



/*=============================

header

==============================*/
header .site_title{
  font-size: 14px;
  font-weight: 400;
  margin-top: 10px;
  margin-bottom: 10px;
  text-align: right;
}

header .header_inner,
header .header_inner .contact_box{
  align-items: center;
  display: flex;
  justify-content: space-between;
}

header .header_inner .contact_box a{
  margin-left: 10px;
}

nav.pc_nav{
  background: linear-gradient(to bottom, rgba(255, 124, 0, 1) 0%, rgba(255, 124, 0, 1) 46%, rgba(211, 80, 4, 1) 52%, rgba(211, 80, 4, 1) 100%, rgba(211, 80, 4, 1) 100%);
}

nav.pc_nav ul#pc_menu{
  display: flex;
  margin-top: 10px;
  margin-left: auto;
  margin-right: auto;
  max-width: 1060px;
  width: 100%;
}

nav.pc_nav ul#pc_menu > li{
  border-left: 1px solid #cccccc;
  width: 15%;
}

nav.pc_nav ul#pc_menu > li.showroomicn{
  background-image: url("img/common/navshowroom.png");
  background-repeat: no-repeat;
  background-position: center;
  width: 180px;
}

nav.pc_nav ul#pc_menu > li.showroomicn a{
  text-indent: -9999px;
}

nav.pc_nav ul#pc_menu > li.home{
  width: 10%;
}

nav.pc_nav ul#pc_menu > li.home a{
  font-size: 0 !important;
}

nav.pc_nav ul#pc_menu > li.home a::before{
  background-image: url("img/common/icon_home.svg");
  content: "";
  height: 25px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 28px;
}

nav.pc_nav ul#pc_menu > li > a{
  align-content: center;
  color: #fff;
  display: block;
  font-size: 18px;
  font-weight: 700;
  height: 100%;
  padding: 10px 12px;
  text-shadow:1px 1px 0 #E73827, -1px -1px 0 #E73827,
              -1px 1px 0 #E73827, 1px -1px 0 #E73827,
              0px 1px 0 #E73827,  0-1px 0 #E73827,
              -1px 0 0 #E73827, 1px 0 0 #E73827;
  text-align: center;
  width: 100%;
}

nav.pc_nav ul#pc_menu > li > a:hover{
  background-color: #C11F22;
}

nav.pc_nav ul#pc_menu > li.menu-item-has-children > a::after{
  content: '';
  width: 6px;
  height: 6px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: rotate(45deg) translateY(-50%);
}

nav.pc_nav ul.sub-menu{
  display: none;
}

nav.pc_nav ul#pc_menu > li:hover ul.sub-menu{
  display: block;
  position: absolute;
  z-index: 100;
}

nav.pc_nav ul.sub-menu li a{
  background-color: rgba(0, 0, 0, 0.7);
  border-bottom: 1px solid #fff;
  color: #fff;
  display: block;
  font-size: 14px;
  padding: 15px 10px;
  width: 200px;
}

nav.pc_nav ul.sub-menu li a:hover{
  background-color: rgba(0, 0, 0,1);
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  header .tel_btn.sp{
    margin-left: 10px;
    max-width: 120px;
  }
  
  header .site_title{
    font-size: 12px;
    text-align: left;
    margin: 0 0 5px 0;
  }
  
  header .hamburger_btn{
    background-color: #FC4600;
    cursor: pointer;
    height: 54px;
    margin-top: 16px;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 9999;
    width: 54px;
  }
  
  header .hamburger_btn::after{
    color: #fff;
    content: "\30E1\30CB\30E5\30FC";
    font-size: 8px;
    font-weight: 500;
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    width: 100%;
  }
  
  header .hamburger_btn.open::after{
    content: "\9589\3058\308B";
  }
  
  header .hamburger_btn span{
    background-color: #fff;
    border-radius: 2px;
    height: 4px;
    position: absolute;
    left: 50%;
    text-align: center;
    transform: translateX(-50%);
    transition: 0.2s;
    width: 30px; 
  }
  
  header .hamburger_btn span:nth-child(1){
    top: 10px;
  }
  header .hamburger_btn span:nth-child(2){
    top: 20px;
  }
  header .hamburger_btn span:nth-child(3){
    top: 30px;
  }
  
  header .hamburger_btn.open span:nth-child(1){
    transform: translateX(-50%) rotate(-45deg);
    top: 20px;
  }
  header .hamburger_btn.open span:nth-child(2){
    opacity: 0;
  }
  header .hamburger_btn.open span:nth-child(3){
    transform: translateX(-50%) rotate(45deg);
    top: 20px;
  }
  
  header .hamburger_menu{
    background-color: rgba(0, 0, 0, 0.6);
    height: 100%;
    opacity: 0;
    overflow: auto;
    padding-top: 70px;
    pointer-events: none;
    position: fixed;
    top: 0;
    left: 0;
    transition: 0.2s;
    width: 100%;
    z-index: 1000;
  }
  
  header .hamburger_menu.open{
    pointer-events: auto;
    opacity: 1;
  }
  
  header .hamburger_menu .hamburger_inner{
    background-color: #FF6700;
    padding: 20px 5px;
  }
  
  header .hamburger_menu #hamburger-menu-sp1,
  header .hamburger_menu #hamburger-menu-sp2{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  
  header .hamburger_menu #hamburger-menu-sp1{
    padding: 0 15px;
  }
  
  header .hamburger_menu #hamburger-menu-sp1 li{
    width: 33%;
  }
  
  header .hamburger_menu #hamburger-menu-sp1 li a{
    border: 4px solid #F75400;
    background-color: #fff;
    border-radius: 50px;
    color: #F75400;
    font-size: 12px;
    font-weight: 600;
    height: 100px;
    line-height: 1.3em;
    padding: 10px 5px;
    text-align: center;
    width: 100%;
  }
  
  header .hamburger_menu #hamburger-menu-sp1 li a::before{
    background-size: contain;
    content: "";
    display: block;
    height: 25px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 5px;
  }
  
  header .hamburger_menu #hamburger-menu-sp1 li.money a::before{
    background-image: url("img/common/icon_money-green.png");
    width: 33px;
  }
  header .hamburger_menu #hamburger-menu-sp1 li.building a::before{
    background-image: url("img/common/icon_building-green.png");
    width: 25px;
  }
  header .hamburger_menu #hamburger-menu-sp1 li.store a::before{
    background-image: url("img/common/icon_store-green.png");
    width: 31px;
  }
  header .hamburger_menu #hamburger-menu-sp1 li.book a::before{
    background-image: url("img/common/icon_book-green.png");
    width: 33px;
  }
  header .hamburger_menu #hamburger-menu-sp1 li.mail a::before{
    background-image: url("img/common/icon_mail-green.png");
    width: 33px;
  }
  header .hamburger_menu #hamburger-menu-sp1 li.tel a::before{
    background-image: url("img/common/icon_tel-green.png");
    width: 33px;
  }
  
  header .hamburger_menu .case_btn{
    padding: 0 15px;
  }
  
  header .hamburger_menu .case_btn a{
    background: linear-gradient(0deg, #3fa164 50%, #75ce95 100%);
    color: #FFF857;
    display: block;
    font-size: 15px;
    font-weight: 600;
    margin: 10px auto;
    padding: 12px 25px 12px 50px;
    text-align: center;
    width: calc(100% - 10px);
  }
  
  header .hamburger_menu .case_btn a span{
    font-size: 135%;
  }
  
  header .hamburger_menu .case_btn a::before{
    background-image: url("img/common/icon_roller-white.png");
    background-size: contain;
    content: "";
    height: 45px;
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 45px;
  }
  
  header .hamburger_menu .case_btn a::after{
    content: '';
    width: 10px;
    height: 10px;
    border-top: solid 2px #FFF857;
    border-right: solid 2px #FFF857;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: rotate(45deg) translateY(-50%);
  }
  
  
  header .hamburger_menu #hamburger-menu-sp2 li{
    width: 50%;
  }
  
  header .hamburger_menu #hamburger-menu-sp2 li a{
    align-content: center;
    background: linear-gradient(to bottom, #ffffff 0%, #f2f2f2 100%);
    border: 4px solid #F75400;
    border-radius: 7px;
    color: #F75400;
    display: block;
    font-size: 12px;
    font-weight: bold;
    height: 100%;
    line-height: 1.5em;
    padding: 12px 18px 12px 6px;
  }
  
  header .hamburger_menu #hamburger-menu-sp2 li a::before{
    content: '';
    width: 8px;
    height: 8px;
    border-top: solid 2px #F75400;
    border-right: solid 2px #F75400;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: rotate(45deg) translateY(-50%);
  }
  
}


/*=============================

footer

==============================*/
footer{
  background-color: #ebecec;
  padding: 30px 0;
  padding-bottom: 190px;
}

footer .logo a{
  display: block;
  padding-left: 40px;
}

footer .logo a::before {
  background-color: #fff;
  border: 2px solid #2f99b3;
  border-radius: 999px;
  content: "";
  height: 35px;
  position: absolute;
  left: 0;
  top: 12px;
  width: 35px;
}

footer .logo a::after{
  content: "";
  position: absolute;
  top: 25px;
  left: 9.5px;
  margin-top: -10px;
  border: 10px solid transparent;
  border-bottom: 10px solid #2f99b3;
}

footer .footer_nav,
footer .footer_info{
  display: flex;
  justify-content: space-between;
}

footer .footer_info.sp{
  display: none;
}

footer .footer_nav .area{
  background-color: #fff;
  margin-bottom: 30px;
  padding: 15px 20px 30px;
  width: 32%;
}

footer .footer_nav div:not(.area){
  margin-bottom: 30px;
  width: 32%;
}

footer .footer_nav .area .title span{
  background-color: #06acb6;
  border-radius: 999px;
  color: #fff;
  display: inline-block;
  font-weight: 700;
  margin-bottom: 20px;
  padding: 5px 10px;
}

footer .footer_nav .area p span.red{
  display: block;
  font-size: 18px;
  margin-bottom: 1em;
}

footer .footer_nav ul li{
  padding-left: 1.2em;
}

footer .footer_nav ul li::before{
  background-color: #666666;
  content: ">";
  color: #fff;
  font-size: 12px;
  height: 14px;
  line-height: 12.5px;
  text-align: center;
  position: absolute;
  top: 0.5em;
  left: 0;
  width: 14px;
}

footer .footer_nav ul li a{
  font-size: 14px;
}

footer .footer_nav ul li a.level_01{
  color: #000;
}

footer .footer_nav .sub-menu{
  margin-top: 5px;
}

footer .footer_nav .sub-menu li::before{
  content: "";
  height: 1px;
  top: 13px;
  width: 10px;
}

footer .footer_info .flex{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 4rem;
}

footer .footer_info p.address{
  padding-left: 20px;
}

footer .footer_info .site_btn a{
  background: linear-gradient(to bottom, #f1e767 0%, #feb645 100%);
  color: #000;
  font-weight: bold;
  padding: 10px 20px;
}

footer .footer_info .site_btn a:hover{
  background: linear-gradient(to top, #f1e767 0%, #feb645 100%);
  text-decoration: underline;
}

footer .footer_info .site_btn a::before{
    content: '';
    width: 5px;
    height: 5px;
    border-top: solid 2px #000;
    border-right: solid 2px #000;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: rotate(45deg) translateY(-50%);
}

footer .copy_right{
  color: #663300;
  font-size: 12px;
  text-align: center;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  footer .footer_nav{
    flex-wrap: wrap;
  }
  
  footer .footer_nav .area{
    width: 100%;
  }
  
  footer .footer_nav div:not(.area){
    width: 48%;
  }
  
  footer .footer_info.sp{
    display: block;
  }
  
  footer .footer_info.sp .left_box{
    width: 57%;
  }
  
  footer .footer_info .site_btn a{
    font-size: 14px;
  }
  
  footer .footer_info.sp .left_box .tel_box{
    margin-top: 10px;
  }
  
  footer .footer_info.sp .left_box .tel_box a::before{
    background-image: url("img/common/icon_freedial.png");
    content: "";
    display: inline-block;
    height: 1em;
    vertical-align: middle;
    width: 2em;
  }
  
  footer .footer_info.sp .left_box .tel_box a img{
    display: inline-block;
    vertical-align: middle;
  }
  
  footer .footer_info.sp .text_box{
    width: 40%;
  }
  
  footer .footer_info.sp .text_box .shop{
    font-size: 12px;
    line-height: 1.4em;
    margin-top: 10px;
  }
  
  footer .footer_info.sp #bnr_box{
    margin: 25px 0;
  }
  
  footer .footer_info.sp #sns_box a,
  footer .footer_info.sp #bnr_box a{
    margin: 0 8px;
  }
  
  footer .footer_info.sp #bnr_box a{
    height: 70px;
  }
  
  footer .footer_info.sp #bnr_box a img{
    height: 100%;
  }
  
}

/*=============================

フッター固定

==============================*/
.toTop {
  background: rgba(0,0,0,0.8);
  height: 185px;
  position: fixed;
  right: 0;
  bottom: 0;
  width: 100%;
  padding: 8px 85px;
  z-index: 1000;
}

.toTop #fc_box{
  margin-left: auto;
  margin-right: auto;
  max-width: 1000px;
  width: 100%;
}

.toTop #fc_box .bnr{
  margin: 0;
}

.toTop .box1{
  align-items: center;
  background-color: #fff;
  display: flex;
  justify-content: space-around;
}

#toTop {
  position: fixed;
  right: 25px;
  bottom: 25px;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .toTop{
    height: auto;
    padding: 4px 0;
  }
  
  .toTop .box2 a.yoyaku,
  .toTop .box2 a.contact{
    align-content: center;
    color: #fff;
    font-size: 14px;
    height: 45px;
  }
  
  .toTop .box2 a {
    display: block;
    background: #3e6aa2;
    float: left;
    width: 28%;
    margin: 0 0.4%;
    text-align: center;
    color: #FFFFFF;
    border-radius: 6px;
    border-bottom: 2px solid #1c406d;
    border-top: 2px solid #6197da;
  }
  
  .toTop .box2 a::before{
    background-image: url("img/common/icon_sp_yoyaku.png");
    background-position: center;
    content: "";
    display: inline-block;
    height: 16px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    top: 2px;
    width: 16px;
  }
  
  .toTop .box2 a.contact {
    background: #f56e00;
    border-bottom: 2px solid #9d4600;
    border-top: 2px solid #fea35a;
  }
  .toTop .box2 a.contact::before{
    background-image: url("img/common/icon_sp_contact.png");
  }
  
  .toTop .box2 a.line{
    font-size: 14px;
    width: 14%;
    line-height: 1.2em;
    height: 45px;
    background: #00BA01;
    border-bottom: 2px solid #007C00;
    border-top: 2px solid #AAD3AA;
  }
  .toTop .box2 a.line::before{
    background-image: url("img/common/icon_sp_line.png");
  }
  
  .toTop .box2 a.tel {
    font-size: 14px;
    width: 14%;
    line-height: 1.2em;
    height: 45px;
    background: #dc0000;
    border-bottom: 2px solid #9a0000;
    border-top: 2px solid #f86666;
  }
  .toTop .box2 a.tel::before{
    background-image: url("img/common/icon_sp_tel.png");
  }

  #toTop {
    right: 0px;
    bottom: 5px;
  }
}

/*=============================

共通パーツ

==============================*/
.post_case .article a:hover,
.post_voice a:hover,
.post_paint a:hover,
.staff-archive ul.staff-list li a:hover,
.staff-single .post_voice a{
  text-decoration: none !important;
}


/*---------------
見出し
----------------*/
.staff-single-about dt,
h3.style_blue,
.main_heading_2 h3{
  background-color: #4cb7d1;
  border-radius: 4px;
  color: #fff;
  font-size: clamp(18px,1.95vw,20px) !important;
  font-weight: 600;
  margin-top: 4rem;
  margin-bottom: 30px;
  padding: 8px 16px 8px 28px;
  position: relative;
}
.staff-single-about dt::before,
h3.style_blue::before,
.main_heading_2 h3::before{
  background-color: #0083a4;
  content: "";
  display: block;
  height: 9px;
  position: absolute;
  top: 50%;
  left: 1px;
  transform: translateY(-50%);
  width: 16px;
}

.style_gray,
h3#a2,
h3#a3{
  background: linear-gradient(to bottom, #fff 0%, #EDEDED 90%, #EDEDED 100%);
  border: 1px solid #ccc;
  font-weight: 600;
  font-size: 20px;
  line-height: 1.2em;
  margin-bottom: 28px;
  padding: 15px 16px;
}


/*---------------
ボタン
----------------*/
.link_btn{
  margin-top: 4rem;
  text-align: center;
}

.link_btn.left{
  text-align: left;
}

.link_btn.right{
  text-align: right;
}

.link_btn a,
.monthly-next a,
.link_btn p{
  background: linear-gradient(to bottom, rgba(32, 124, 202, 1) 0%, rgba(26, 110, 165, 1) 47%, rgba(30, 87, 153, 1) 53%, rgba(30, 87, 153, 1) 100%);
  border-radius: 10px;
  color: #fff;
  display: inline-block;
  text-align: center;
  text-decoration: none !important;
  padding-top: 8px;
  padding-left: 15px;
  padding-bottom: 8px;
  padding-right: 30px;
  position: relative;
}
.link_btn a::before,
.monthly-next a::before,
.link_btn p::before{
  content: '';
  width: 7px;
  height: 7px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  margin-top: -2px;
  position: absolute;
  right: 17px;
  top: 50%;
  transform: rotate(45deg) translateY(-50%);
}


/**----------
施工事例一覧
-----------**/
.post_case .category,
#single #case_article table td .case-works-list{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 30px;
}

.post_case .category li a,
#single #case_article table td .case-works-list li a{
  background: #003466;
  border-radius: 5px;
  color: #fff;
  font-size: clamp(13px,1.56vw,16px);
  font-weight: 600;
  padding: 5px 8px;
  text-align: center;
}

.post_case .article{
  display: grid;
  grid-template-columns: repeat(3,auto);
  gap: 30px 12px;
}

#top .post_case .article{
  grid-template-columns: repeat(4,auto);
}

.post_case .article a{
  display: flex;
  flex-flow: column;
}

.post_case .article .img_box{
  overflow: hidden;
  position: relative;
}

.post_case .article .img_box img{
  aspect-ratio: 3/2;
  height: 100%;
  object-fit: cover;
  object-position: center;
  width: 100%;
}

.post_case .article a:hover .title{
  text-decoration: underline;
}

.post_case .article .date{
  color: #000;
  font-size: 14px;
  margin: 5px 0 10px;
}

.post_case .article .cat_box{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 10px 0;
}

.post_case .article .cat_box .cat{
  background-color: #2f99b3;
  border-radius: 3px;
  color: #fff;
  font-size: 11px;
  padding: 1px 2px;
}

.post_case .article .btn{
  background-color: #f85032;
  border-radius: 999px;
  color: #fff;
  font-size: 12px;
  margin: auto auto 0;
  padding: 5px;
  text-align: center;
  width: 80%;
}


.post_case.blog_box .article{
  grid-template-columns: repeat(3,auto);
}

.post_case.blog_box .blog-cat{
  background-color: #d30003;
  color: #fff;
  font-size: 14px;
  padding: 0 4px;
  position: absolute;
  top: 0;
  left: 0;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .post_case .article,
  .post_case.blog_box .article,
  #top .post_case .article{
    grid-template-columns: repeat(2, auto);
  }
}


/**----------
施工事例 地域ボタン
-----------**/
.area_btn_box{
  margin: 30px 0;
}

.area_btn_box .shop{
  font-weight: 600;
  margin-top: 20px;
}

.area_btn_box ul.area_btn{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.area_btn_box ul.area_btn li{
  width: 19%;
}

.area_btn_box ul.area_btn li a{
  align-content: center;
  background: linear-gradient(0deg, rgba(0, 117, 38, 1) 0%, rgba(38, 166, 79, 1) 100%);
  border-radius: 5px;
  color: #fff;
  font-weight: bold;
  font-size: 15px;
  display: block;
  height: 100%;
  padding: 5px;
  padding-right: 20px;
  text-align: center;
}

.area_btn_box ul.area_btn li a::before{
  content: '';
  width: 7px;
  height: 7px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  right: 15px;
  top: 50%;
  transform: rotate(45deg) translateY(-50%);
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .area_btn_box ul.area_btn li{
    width: 48%;
  }
}


/**----------
施工事例一覧
-----------**/
.post_voice{
  display: grid;
  grid-template-columns: repeat(3,auto);
  gap: 30px 12px;
  margin: 30px 0;
}

#top .post_voice{
  grid-template-columns: repeat(4,auto);
}

.post_voice a{
  display: flex;
  flex-flow: column;
}

.post_voice a .manzoku,
#voice_article .manzoku{
  align-content: center;
  background: #fe0000;
  border-radius: 999px;
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  height: 55px;
  line-height: 1.2em;
  position: absolute;
  top: -10px;
  left: -10px;
  text-align: center;
  width: 55px;
}

.post_voice a .manzoku span,
#voice_article .manzoku span{
  display: none;
}

.post_voice a .img_box{
  position: relative;
}

.post_voice a .img_box p{
  background-color: rgba(0,0,0,0.5);
  color: #fff;
  font-size: 11px;
  line-height: 1.3em;
  padding: 5px;
  position: absolute;
  bottom: 0;
  width: 100%;
}

.post_voice a .img_box img{
  aspect-ratio: 3/2;
  height: 100%;
  object-fit: cover;
  object-position: center;
  width: 100%;
}

.post_voice a:hover .title{
  text-decoration: underline;
}

.post_voice a .date{
  color: #000;
  font-size: 14px;
  margin: 5px 0 10px;
}

.post_voice a .btn{
  background-color: #f85032;
  border-radius: 999px;
  color: #fff;
  font-size: 12px;
  margin: auto auto 0;
  padding: 5px;
  text-align: center;
  width: 80%;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .post_voice{
    grid-template-columns: repeat(2,auto);
  }
}


/**----------
塗料一覧
-----------**/
.post_paint{
  display: flex;
  flex-wrap: wrap;
  gap: 20px 0;
  margin-top: 30px;
  justify-content: space-between;
}

.post_paint a{
  background-color: #ffffcc;
  border: 2px solid #707070;
  color: #000;
  display: block;
  width: 49%;
}

.post_paint a p.price-catch{
  background-color: #D80003;
  color: #fff;
  font-weight: 700;
  padding: 5px;
  width: 100%;
}

.post_paint a .left_box{
  padding: 7px;
  width: 55%;
}

.post_paint a .left_box .price-name{
  color: #0C1A5C;
  font-size: 26px;
  margin-bottom: 10px;
  text-shadow:
    2px 2px 0 #fff,
    -2px 2px 0 #fff,
    -2px -2px 0 #fff,
    2px -2px 0 #fff;
}

.post_paint a .left_box .price-name span{
  display: block;
  font-size: 20px;
}

.post_paint a .left_box .info p{
  background-color: #fff;
  border: 1px solid #ccc;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 3px;
  padding: 5px;
  text-align: center;
}

.post_paint a .left_box .price-read{
  font-size: 13px;
  margin-top: 10px;
}

.post_paint a .right_box{
  padding: 7px;
  width: 45%;
}

.post_paint a .right_box .price-txt{
  color: #C90003;
  font-weight: 700;
  letter-spacing: -1px;
  paint-order: stroke;
  text-align: right;
  -webkit-text-stroke: 8px #fff;
  text-stroke: 8px #fff;
}

.post_paint a .right_box .price-txt .p1{
  font-size: 375%;
}

.post_paint a .right_box .price-txt .p2{
  font-size: 200%;
}


.post_paint a .bottom_box{
  padding: 7px;
  width: 100%;
}

.post_paint a .bottom_box .price-area{
  background-color: #000;
  color: #fff;
  font-size: 14px;
  display: inline-block;
  padding: 2px 7px;
}

.post_paint a .bottom_box .price-details tr{
  display: flex;
}

.post_paint a .bottom_box .price-details th{
  background-color: #ccc;
  display: block;
  flex-shrink: 0;
  font-size: 14px;
  font-weight: 600;
  line-height: 1em;
  padding: 5px;
  width: 40px;
}

.post_paint a .bottom_box .price-details td{
  background-color: #fff;
  border: 1px solid #ccc;
  display: block;
  font-size: 14px;
  padding: 5px;
  text-align: center;
  width: calc(100% - 40px);
}

.post_paint a .bottom_box .price-note{
  font-size: 12px;
  margin: 5px 0;
  text-align: right;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .post_paint a{
    width: 100%;
  }
  
  .post_paint a .right_box .price-txt .p1{
    font-size: 350%;
  }
  
  .yane.post_paint a:nth-of-type(2),
  .yane.post_paint a:nth-of-type(5),
  .gaiheki.post_paint a:nth-of-type(2),
  .gaiheki.post_paint a:nth-of-type(5){
    display: none;
  }
}


/**----------
雨漏り一覧
-----------**/
.post_amamori{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.post_amamori a{
  display: flex;
  flex-flow: column;
  width: 24%;
}

.post_amamori a .title{
  margin: 15px 0;
}

.post_amamori a .btn{
  background-color: #f85032;
  border-radius: 999px;
  color: #fff;
  font-size: 12px;
  margin-top: auto;
  margin-left: auto;
  margin-right: auto;
  padding: 5px;
  text-align: center;
  width: 80%;
}

/**----------
Before・After
-----------**/
.be-af_box{
  display: flex;
  justify-content: space-between;
  margin:20px 0;
}

.be-af_box .before,
.be-af_box .after{
  position: relative;
}

.be-af_box .before::before,
.be-af_box .after::before{
  color: #fff;
  font-size: 18px;
  padding: 0 10px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

.be-af_box .before{
  width: 30%;
}
.be-af_box .before::before{
  background-color: #0010dd;
  content: "Before";
}

.be-af_box .after{
  width: 69%;
}
.be-af_box .after::before{
  background-color: #fe0000;
  content: "After";
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .be-af_box .before::before,
  .be-af_box .after::before{
    font-size: 14px;
  }
}

/**----------
お問い合せ
-----------**/
#contact_table tr{
  display: flex;
}

#contact_table th, 
#contact_table td{
  border: 1px solid #ccc;
  display: block;
  padding: 10px;
}

#contact_table th{
  background-color: #DFE0D6;
  font-weight: 500;
  text-align: left;
  width: 33%;
}

#contact_table td{
  width: 67%;
}

#contact_table tr td:first-child {
  width: 100%;
}

.form_text_s input,
.form_text_s select,
.form_text_l input,
#contact_table td input,
#contact_table td select{
  background-color: #ffffcc;
  border: 1px solid #ccc;
  font-size: 16px;
  padding:5px 15px;
  width: 100%;
}

.form_text_s select,
#contact_table td select{
  width: auto;
}

.required{
  background: #eb1d1d;
  border-radius: 4px;
  color: #fff;
  font-size: 10px;
  vertical-align: 2px;
  padding: 2px 4px;
}

.optional{
  background: #2f99b3;
  border-radius: 4px;
  color: #fff;
  font-size: 10px;
  padding: 2px 4px;
  vertical-align: 2px;
}

.submit-btn{
  margin: 15px 0;
  text-align: center;
}

.submit-btn input[type="submit"], 
#action-button button {
  background-color: #2b8b27;
  border-top: 2px solid #35ad31;
  border-bottom: 3px solid #184f16;
  border-radius: 6px;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  height: 60px;
  line-height: 50px;
  outline: none;
  text-align: center;
  text-decoration: none;
  transition: .3s ease-in-out;
  width: 240px;
}

.submit-btn input[type="submit"]:hover, 
#action-button button:hover{
  background-color: #216b1e;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #contact_table tr{
    flex-wrap: wrap;
  }
  
  #contact_table th,
  #contact_table td{
    width: 100%;
  }
}

/**----------
ページネーション
-----------**/
.wp-pagenavi{
  display: flex;
  flex-wrap: wrap;
  margin-top: 5rem;
  margin-bottom: 30px;
}

.wp-pagenavi a,
.wp-pagenavi span{
  background-color: #4cb7d1;
  border: 1px solid #ccc;
  display: block;
  color: #fff;
  margin: 2px;
  padding: 3px 6px;
  transition: 0.3s;
}
.wp-pagenavi span.current{
    background-color: #fff;
    font-weight: bold;
    color: #333;
}

.wp-pagenavi span.pages::before{
  content: "\30DA\30FC\30B8\6570\FF1A";
}

/*=============================

sidebar

==============================*/
#sidebar .side_item{
  margin-bottom: 25px;
}

/*-- ご挨拶 ------*/
#sidebar #greeting{
  border: 1px solid #ccc;
}

#sidebar #greeting .heading{
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(235, 235, 235, 1));
  border: 1px solid #ccc;
  font-size: 20px;
  font-weight: 700;
  padding: 10px;
  text-align: center;
}

#sidebar #greeting img{
  margin-left: auto;
  margin-right: auto;
}

#sidebar #greeting p{
  font-size: 14px;
  padding: 10px 10px 0 10px;
}

#sidebar #greeting a{
  font-size: 14px;
  padding: 0 10px 25px;
}


/*-- お知らせ＆ブログ ------*/
#sidebar #news{
  border: solid 5px #4cb7d1;
  border-top: none;
  padding: 80px 5px 5px 5px;
  position: relative;
}

#sidebar #news img{
  position: absolute;
  top: -14px;
  left: 0;
}

#sidebar #news .news_box .post1{
  border-bottom: dotted 1px #999;
  margin-bottom: 7px;
  padding-bottom: 5px;
}


#sidebar #news .news_box .post1 .day{
  color: #073B6C;
  display: inline-block;
  font-size: 13px;
}

#sidebar #news .news_box .post1 .category{
  background: #2f99b3;
  border-radius: 3px;
  color: #fff;
  display: inline-block;
  font-size: 12.5px;
  margin-left: 5px;
  padding: 1px 2px;
}

#sidebar #news .news_box .post1 .pick{
  background: #d67033;
  border-radius: 3px;
  color: #fff;
  font-size: 14px;
  padding: 1px 2px;
  position: relative;
}

#sidebar #news .news_box .post1 .pick::after{
  content: "";
  position: absolute;
  top: 100%;
  left: 20px;
  margin-left: -5px;
  border: 5px solid transparent;
  border-top: 5px solid #d67033;
}

#sidebar #news .news_box a{
  color: #333;;
}
#sidebar #news .news_box a:hover{
  text-decoration: underline;
}

#sidebar #news a.list_btn{
  background: linear-gradient(to bottom, rgba(32, 124, 202, 1) 0%, rgba(26, 110, 165, 1) 47%, rgba(30, 87, 153, 1) 53%, rgba(30, 87, 153, 1) 100%);
  border-radius: 4px;
  color: #fff;
  font-size: 12.5px;
  padding: 4px 10px;
  padding-right: 20px;
}

#sidebar #news a.list_btn::after{
  content: '';
  position: absolute;
    top: 50%;
    right: 10px;
  transform: rotate(45deg) translateY(-50%);
  padding: 0;
  width: 6px;
  height: 6px;
  border-top: solid 2px #FFFFFF;
  border-right: solid 2px #FFFFFF;
}

/*-- リンク集 ------*/
#sidebar ul{
  border-top: 6px solid;
}

#sidebar ul li a{
  border-bottom: 1px solid #ccc;
  color: #000;
  display: block;
  font-size: 15px;
  font-weight: 700;
  padding: 12px 20px 12px 12px;
}
#sidebar ul li a::before{
  background-size: contain;
  content: "";
  height: 12px;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  width: 12px;
}


#sidebar ul.emerald{
  border-color: #06acb6;
}
#sidebar ul.emerald li a{
  background-image: linear-gradient(180deg, #C1E2E4, #CDEEF0);
}
#sidebar ul.emerald li a::before{
  background-image: url("img/common/icon-arrow_emerald.svg");
}

#sidebar ul.yellow{
  border-color: #FFCC00;
}
#sidebar ul.yellow li a{
  background-image: linear-gradient(180deg, #F1E7BE, #FFF5CC);
}
#sidebar ul.yellow li a::before{
  background-image: url("img/common/icon-arrow_yellow.svg");
}

#sidebar ul.blue{
  border-color: #3562AC;
}
#sidebar ul.blue li a{
  background-image: linear-gradient(180deg, #CDDAE7, #DBE8F6);
}
#sidebar ul.blue li a::before{
  background-image: url("img/common/icon-arrow_blue.svg");
}

#sidebar p.lime{
  background-color: #8ed14d;
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  padding: 10px;
  text-align: center;
}
#sidebar ul.lime{
  border: none;
}
#sidebar ul.lime li a{
  background-image: linear-gradient(180deg, #DCE9CF, #E8F6DB);
}
#sidebar ul.lime li a::before{
  background-image: url("img/common/icon-arrow_lime.svg");
}


/*-- お問い合せ・店舗情報 ------*/
#sidebar #contact_box{
  border: 1px solid #ccc;
  padding: 55px 10px 20px;
  position: relative;
}

#sidebar #contact_box .heading{
  background-color: #38A6C2;
  border-bottom: 5px solid #0083A4;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  padding: 10px;
  position: absolute;
  top: 0;
  left: 0;
  text-align: center;
  width: 100%;
}

#sidebar #contact_box .heading span{
  color: #E3F013;
}

#sidebar #contact_box .contact > p{
  background-color: #EBECEC;
  font-size: 14px;
  font-weight: 600;
  padding: 2px 5px;
}

#sidebar #contact_box .contact > p span{
  background-color: #376D24;
  border-radius: 5px;
  color: #fff;
  font-size: 11px;
  margin-right: 5px;
  padding: 0 8px;
}

#sidebar #contact_box .contact a.btn{
  border: 2px solid #FD3300;
  background-image: linear-gradient(180deg, #FD3300, #CC3300);
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: 13px;
  font-weight: 600;
  margin: 10px 0;
  padding: 10px;
  text-align: center;
}

#sidebar #contact_box .shop_list > p.bold{
  font-size: 14px;
  margin: 10px 0;
}

#sidebar #contact_box .shop_list .shop{
  margin-bottom: 15px;
}

#sidebar #contact_box .shop_list .shop a{
  font-weight: bold;
}

#sidebar #contact_box .shop_list .area p:not(.bold){
  font-size: 14px;
}

#sidebar #sns_box{
  display: flex;
  column-gap: 10px;
  justify-content: center;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #sidebar{
    display: none;
  }
}


/*=============================

TOP（front-page）

==============================*/
/**----------
メインビジュアル
-----------**/
#mainvisual{
  background-color: #F0E8D8;
  padding-top: 15px;
}

#mainvisual .mv_slide img.sp{
  display: none;
}


#mainvisual .mv_slide a img{
  width: 100%;
}

#mainvisual .mv_slide ul.slick-dots{
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
}

#mainvisual .mv_slide .slick-dots li button{
  background-color: #a9a8a8;
  border: none;
  border-radius: 999px;
  font-size: 0;
  height: 8px;
  margin: 0 4px;
  width: 8px;
}

#mainvisual .mv_slide .slick-dots li.slick-active button{
  background-color: #000;
}

#mainvisual .mv_slide .slick-arrow{
  background-color: #007aff;
  border-radius: 999px;
  border: 4px solid #fff;
  cursor: pointer;
  font-size: 0;
  height: 70px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 100;
  width: 70px;
}

#mainvisual .mv_slide .slick-arrow:active{
  top: calc(50% + 3px);
}

#mainvisual .mv_slide .slick-arrow.slick-prev{
  left: 5%;
}

#mainvisual .mv_slide .slick-arrow.slick-next{
  right: 5%;
}

#mainvisual .mv_slide .slick-arrow.slick-prev::before,
#mainvisual .mv_slide .slick-arrow.slick-next::before{
  content: '';
  width: 12px;
  height: 12px;
  border-top: solid 3px #fff;
  border-right: solid 3px #fff;
  position: absolute;
  top: 50%;
}

#mainvisual .mv_slide .slick-arrow.slick-prev::before{
  margin-top: -12px;
  left: 30px;
  transform: rotate(-135deg) translateY(-50%);
}
#mainvisual .mv_slide .slick-arrow.slick-next::before{
  margin-top: -2px;
  right: 30px;
  transform: rotate(45deg) translateY(-50%);
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #mainvisual{
    padding-top: 0;
  }
  
  #mainvisual .mv_slide .slick-arrow{
    height: 35px;
    width: 35px;
  }
  
  #mainvisual .mv_slide .slick-arrow{
    border: 2px solid #fff;
  }
  
  #mainvisual .mv_slide .slick-arrow.slick-prev{
    left: 0px;
  }

  #mainvisual .mv_slide .slick-arrow.slick-next{
    right: 0px;
  }
  
  #mainvisual .mv_slide .slick-arrow.slick-prev::before,
  #mainvisual .mv_slide .slick-arrow.slick-next::before{
    height: 7px;
    width: 7px;
  }
  
  #mainvisual .mv_slide .slick-arrow.slick-prev::before{
    left: 16px;
    margin-top: -9px;
  }
  #mainvisual .mv_slide .slick-arrow.slick-next::before{
    right: 16px;
  }
}


#mainvisual #mv_bottom{
  background-color: #d78659;
  display: flex;
  margin-top: 15px;
  padding: 20px 0;
}

#mainvisual .tab_box{
  position: relative;
  width: 49%;
}

#mainvisual .tab_btn{
  display: flex;
}

#mainvisual .tab_btn li{
  background: #012b7f;
  border-radius: 5px 5px 0 0;
  color: #FFFFFF;
  cursor: pointer;
  font-size: 12px;
  margin-right: 2px;
  padding: 10px;
  text-align: center;
}

#mainvisual .tab_btn li.active{
  background: linear-gradient(to bottom, rgba(99, 118, 170, 1) 0%, rgba(17, 61, 147, 1) 49%, rgba(1, 43, 127, 1) 53%, rgba(1, 43, 127, 1) 100%);
}

#mainvisual .tab_box .tab_area{
  background-color: #fff;
  border-top: 4px solid #012b7f;
  display: none;
  padding: 0 10px 30px;
}

#mainvisual .tab_box .tab_area.show{
  display: block;
}

#mainvisual .tab_box .tab_area a{
  border-bottom: 1px solid #A4A4A4;
  display: flex;
  padding: 20px 0;
  width: 100%;
}

#mainvisual .tab_box .tab_area li:last-child a{
  border-bottom: none;
}

#mainvisual .tab_box .tab_area a .img_box{
  aspect-ratio: 3 / 2;
  flex-shrink: 0;
  overflow: hidden;
  width: 140px;
}

#mainvisual .tab_box .tab_area a .img_box img{
  height: 100%;
  object-fit: cover;
  width: 100%;
}

#mainvisual .tab_box .tab_area a:hover img{
  transform: scale(1.15);
}

#mainvisual .tab_box .tab_area a .text_box{
  margin-left: 20px;
}

#mainvisual .tab_box .tab_area a span.cat{
  background: #D30003;
  color: #FFFFFF;
  display: inline-block;
  font-size: 10px;
  padding: 0 5px;
}

#mainvisual .tab_box .tab_area a .text{
  color: #0d67d6;
  font-size: 16.5px;
  font-weight: bold;
  transition: 0.2s;
}

#mainvisual .tab_box .tab_area a:hover .text{
  opacity: 0.7;
  text-decoration: underline;
}

#mainvisual .tab_box .tab_area a .day{
  color: #000;
}

#mainvisual .tab_box a.list_btn{
  background: linear-gradient(to bottom, rgba(99, 118, 170, 1) 0%, rgba(17, 61, 147, 1) 49%, rgba(1, 43, 127, 1) 53%, rgba(1, 43, 127, 1) 100%);
  border-radius: 5px;
  color: #fff;
  padding: 5px;
  padding-right: 30px;
  position: absolute;
  bottom: 10px;
  right: 10px;
}

#mainvisual .tab_box a.list_btn::before{
  content: '';
  width: 5px;
  height: 5px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: rotate(45deg) translateY(-50%);
}


#mainvisual .contact_box{
  width: 49%;
}

#mainvisual .contact_box .contact_text{
  background-color: #163a81;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  padding: 5px;
}

#mainvisual .contact_box .contact{
  background-color: #fff;
  margin-bottom: 20px;
  padding: 5px 10px 10px;
}

#mainvisual .contact_box .contact p.text{
  font-size: clamp(14px,1.56vw,16px);
  font-weight: 600;
  margin-bottom: 5px;
}

#mainvisual .contact_box .contact .tel{
  border: 5px solid #0fa32b;
  margin-bottom: 10px;
  position: relative;
  overflow: hidden;
}

#mainvisual .contact_box .contact .tel .tel_text{
  background: #0fa32b;
  color: #FFFFFF;
  font-size: 14px;
  padding-bottom: 5px;
}

#mainvisual .contact_box .contact .tel .notes{
  font-size: 12px;
  padding: 0 5px 5px 5px;
}

#mainvisual .contact_box .contact .mail a{
  background: linear-gradient(to bottom, #f85032 0%, #f16f5c 50%, #f6290c 51%, #f02f17 71%, #e73827 100%);
  border: 3px solid #8A282A;
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: clamp(14px,1.56vw,16px);
  padding: 1.5rem;
  text-align: center;
  transition: 0s;
  width: 100%;
}

#mainvisual .contact_box .contact .mail a:hover{
  background: #9E2611;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #mainvisual #mv_bottom .inner{
    flex-wrap: wrap-reverse;
  }
  
  #mainvisual .tab_box,
  #mainvisual .contact_box{
    width: 100%;
  }
  
  #mainvisual .tab_box{
    margin-top: 15px;
  }
  
  #mainvisual .mv_slide img.pc{
    display: none;
  }
  #mainvisual .mv_slide img.sp{
    display: block;
  }

}

/**----------
奈良の外壁塗装・屋根塗装の施工実績
-----------**/
#top section,
.bnr{
  margin-top: 5rem;
  position: relative;
}

#top section .head h2{
  border: 1px solid #ccc;
  border-bottom: 4px solid #FF2F00;
  font-size: 2.8rem;
  line-height: 1.3em;
  margin-bottom: 20px;
  position: relative;
  padding: 12px 17px;
  paint-order: stroke;
  -webkit-text-stroke: 2px #fff;
  text-stroke: 2px #fff;
}

#top section .head h2::before{
  background-image: url("img/top/top_ttl_gaiheki.png");
  background-size: contain;
  content: "";
  height: 70px;
  position: absolute;
  top: 0;
  left: 0;
  width: 70px;
  z-index: -1;
}

#top section .head h2::after{
  background-image: url("img/top/top_ttl_yonekichi.png");
  background-size: contain;
  content: "";
  height: 60px;
  position: absolute;
  right: 0;
  bottom: 0;
  width: 60px;
  z-index: -1;
}

#top section .head .comment{
  background-color: #FF2F00;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  color: #fff;
  font-weight: 700;
  padding: 5px 10px;
  position: absolute;
  top: -33px;
  z-index: -1;
  right: 0;
}

#top section#top_case .area_overview{
  border: 2px solid #004D8C;
  margin-bottom: 20px;
  padding: 10px;
}

#top section#top_case .area_overview h3{
  background-color: #004D8C;
  color: #fff;
  display: inline-block;
  font-size: 16px;
  margin-bottom: 10px;
  padding: 0.3rem 1rem;
}

#top section#top_case .area_overview h4{
  display: inline-block;
  margin: 10px 0;
  padding: 0 1.5em;
  position: relative;
}

#top section#top_case .area_overview h4::before,
#top section#top_case .area_overview h4::after {
    position: absolute;
    color: #eb6100;
}

#top section#top_case .area_overview h4::before {
    left: 0;
    content: '>>';
}
#top section#top_case .area_overview h4::after{
    right: 0;
    content: '<<';
}

#top section#top_case .area_overview p{
  font-size: 14px;
}

#top section#top_case .area h3{
  background: #0d89aa;
  color: #fff;
  font-size: 2.4rem;
  font-weight: 600;
  padding: 10px 5px;
  text-align: center;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #top section .head h2{
    padding-bottom: 20px;
  }
  #top section .head h2::after{
    height: 40px;
    width: 40px;
  }
}


/**----------
奈良にお住いの方から頂いたお客様の声
-----------**/
#top #top_voice .head h2{
  border-bottom-color:#e3309b;
}

#top #top_voice .head h2::before{
  background-image: url("img/top/top_ttl_voice.png");
}
  
#top_voice #tv{
  margin-top: 4rem;
}

#top_voice #tv h3{
  font-size: 19px;
  margin-bottom: 10px;
  padding-left: 1.2em;
  position: relative;
}

#top_voice #tv h3::before{
  background-image: url("img/common/icon_comment.svg");
  content: "";
  position: absolute;
  top: 0.2em;
  left: 0;
  height: 1em;
  width: 1em;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #top_voice .sp h3.style_gray{
    margin-top: 10px;
  }
  
  #top_voice .sp .img_box{
    margin-bottom: 20px;
    position: relative;
  }
  
  #top_voice .sp .img_box img{
    box-shadow: 0px 0px 10px -5px rgba(0, 0, 0, 0.8);
  }
  
  #top_voice .sp .img_box .manzoku{
    align-content: center;
    background-color: #fe0000;
    border-radius: 999px;
    color: #fff;
    font-size: 30px;
    font-weight: 600;
    line-height: 1.2em;
    height: 100px;
    position: absolute;
    top: -10px;
    left: 0;
    text-align: center;
    width: 100px;
  }
  
  #top_voice h3.style_blue::after{
    background-image: url(img/top/top_ttl_yonekichi.png);
    background-size: contain;
    content: "";
    height: 60px;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 60px;
    z-index: 1;
  }
  
  #top_voice .be-af_box .before{
    width: 40%;
    }

  #top_voice .be-af_box .after{
    width: 60%;
  }
  
}


/**----------
ヨネヤがお客様から選ばれる10の理由
-----------**/
#top_reason h2{
  font-size: 2.8rem;
  line-height: 1.5em;
  margin-bottom: 20px;
  text-align: center;
}

#top_reason h2 span{
  background: linear-gradient(transparent 70%, #FFFF00 0%);
  color: #e3b31c;
  font-size: 140%;
  padding: 0 12px;
  paint-order: stroke;
  -webkit-text-stroke: 6px #000;
  text-stroke: 6px #000;
}

#top_reason .reason_box.btn{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 30px;
}

#top_reason .reason_box.btn li{
  width: 19%;
}

#top_reason .reason_box.btn a{
  background-image: url("img/common/reason_frame.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  color: #000;
  display: flex;
  flex-flow: column;
  font-weight: 700;
  height: 100%;
  text-align: center;
}

#top_reason .reason_box.btn a .reason{
  font-size: 12px;
  color: #C74400;
}

#top_reason .reason_box.btn a .reason span{
  font-size: 18px;
}

#top_reason .reason_box.btn a .text{
  margin-bottom: 10px;
  paint-order: stroke;
  -webkit-text-stroke: 3px #fff;
  text-stroke: 3px #fff;
}

#top_reason .reason_box.btn a .btn{
  background: linear-gradient(to bottom, rgba(248, 80, 50, 1) 0%, rgba(241, 111, 92, 1) 50%, rgba(246, 41, 12, 1) 51%, rgba(240, 47, 23, 1) 71%, rgba(231, 56, 39, 1) 100%);
  border-radius: 5px;
  color: #fff;
  font-size: 14px;
  margin-top: auto;
  margin-left: auto;
  margin-right: auto;
  padding: 5px;
  text-align: center;
  width: 90%;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #top_reason .reason_box.btn li {
    width: 48%;
  }
  
  #top_reason .post_paint a:nth-child(even){
    display: none;
  }
}


/**----------
ヨネヤの雨漏り施工実績
-----------**/
#top #top_amamori .head h2{
  border-bottom-color:#25a4d9;
}
#top #top_amamori .head h2::before{
  background-image: url("img/top/top_ttl_amamori.png");
}

#top_amamori .cat_list{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 30px 0;
} 

#top_amamori .cat_list li a{
  background-color: #f4b81a;
  color: #fff;
  font-weight: 700;
  padding: 5px 15px;
}

#top_amamori .amamori_reason h3{
  background-color: #0407A7;
  color: #fff;
  font-size: 24px;
  margin-top: 5rem;
  padding: 7px;
  text-align: center;
}

#top_amamori .amamori_reason h3 small{
  font-size: 16px;
  margin: 0 3px;
}

#top_amamori .amamori_reason h3 .yellow{
  color: #FFE958;
}

#top_amamori .amamori_reason .flex_box{
  border: 1px solid #ccc;
  gap: 10px;
}

#top_amamori .amamori_reason .flex_box .item{
  padding: 10px;
  width: 49%;
}

#top_amamori .amamori_reason .flex_box .item h4{
  background-color: #EBEFFF;
  font-size: 18px;
  margin-bottom: 8px;
  padding: 5px;
  padding-left: 30px;
  position: relative;
}

#top_amamori .amamori_reason .flex_box .item h4 span{
  align-content: center;
  background-color: #0C2978;
  color: #FFFFFF;
  position: absolute;
  height: 100%;
  top: 0;
  left: 0;
  text-align: center;
  width: 25px;
}

#top_amamori .amamori_reason .flex_box .item img{
  float: right;
}

#top_amamori .amamori_reason .flex_box .item p{
  font-size: 14px;
}


/**----------
地域の方へのあいさつ
-----------**/
#top_greeting h2{
  color: #D85F0E;
  margin-bottom: 1em;
}

.profile_box{
  margin: 30px 0;
}

.profile_box .img_box{
  width: 27%;
}

.profile_box .text_box{
  font-size: 16px;
  width: 70%;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .profile_box .img_box,
  .profile_box .text_box{
    width: 100%;
  }
  
  .profile_box .img_box{
    margin-bottom: 20px;
  }
}


/**----------
ここ〇年の外壁塗装・屋根塗装実績ー奈良 実績No1
-----------**/
#case-number .flex_box{
  margin-top: 30px;
}

#case-number .flex_box h4{
  border-bottom: 2px solid #663300;
  color: #663300;
  font-size: 18px;
  padding: 2px 8px 5px 18px;
  margin-bottom: 1em;
}

#case-number .flex_box .text_box{
  width: 68%;
}

#case-number .flex_box .img_box{
  width: 30%;
}

#case-number .flex_box ul{
  display: flex;
  flex-wrap: wrap;
}

#case-number .flex_box ul li{
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 1em;
  width: 33.3%;
}

#case-number .flex_box ul li .city{
  background-color: #f4b91a;
  color: #fff;
  margin: 0 8px 0 14px;
  padding: 2px 4px 1px;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #case-number .flex_box .text_box,
  #case-number .flex_box .img_box{
    width: 100%;
  }
  
  #case-number .flex_box ul li{
    width: 48%;
  }
  
  #case-number .flex_box .img_box img{
    margin-left: auto;
    margin-right: auto;
  }
  
  #case-number .sp h3.style_gray{
    margin-top: 30px;
    margin-bottom: 0;
  }
  
  #case-number .news_box .post1{
    border-bottom: 1px dotted #ccc;
    padding: 10px 0;
  }
  
  #case-number .news_box .post1 .day{
    color: #4cb7d1;
    display: inline-block;
    font-size: 14px;
  }
  
  #case-number .news_box .post1 .pick {
    background: #d67033;
    border-radius: 3px;
    color: #fff;
    font-size: 14px;
    padding: 1px 2px;
    position: relative;
  }
  
  #case-number .news_box .post1 .pick::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 20px;
    margin-left: -5px;
    border: 5px solid transparent;
    border-top: 5px solid #d67033;
}
  
  #case-number .news_box .post1 .category {
    background: #2f99b3;
    border-radius: 3px;
    color: #fff;
    display: inline-block;
    font-size: 12.5px;
    margin-left: 5px;
    padding: 1px 2px;
  }
  
  #case-number .news_box .post1 .text1 a{
    color: #000;
  }
}




/*=============================

下層ページ

==============================*/
.top_bnr{
  margin: 10px 0 20px;
}

#page_title{
  align-content: center;
  background-image: url("img/common/bg_page-title.jpg");
  background-position: right;
  background-size: cover;
  font-size: 2.2rem;
  height: 140px;
  margin-bottom: 20px;
  position: relative;
}

#page_title .title{
  color: #fff;
  font-size: 3.2rem;
  padding-left: 20px;
  text-shadow: 0px 0px 8px #333;
}

.breadcrumbs{
  font-size: 14px;
  margin-bottom: 20px;
  text-align: right;
}

.breadcrumbs span{
  margin-left: 5px;
}

.breadcrumbs span a{
  color: #4cb7d1;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #page_title{
    height: auto;
    padding: 15px;
  }
  
  #page_title .title{
    font-size: 22px;
    padding-left: 0;
  }
  
  .breadcrumbs{
    text-align: left;
  }
}

/*=============================

固定ページ

==============================*/

#page:not(.price-page):not(.seminar-page) #main_contents p,
#single #main_contents article p{
  padding-bottom: 1.25em;
}

#page .main_heading_1 h2{
  background: linear-gradient(to bottom, #fff 0%, #EDEDED 90%, #EDEDED 100%);
  border: 1px solid #ccc;
  font-weight: 600;
  font-size: 2.4rem;
  line-height: 1.2em;
  margin-bottom: 30px;
  padding: 15px 16px;
}

#page .main_heading_1:not(:first-child) h2{
  margin-top: 30px;
}

#page h3.wp-block-heading,
#page h3.downicn{
  font-size: 22px;
  margin: 5rem 0 30px;
}

#page h3.has-background{
  padding: 10px;
}

#page h3.wp-block-heading.style_blue{
  padding: 10px 10px 10px 25px !important;
}

#page h4.wp-block-heading{
  font-size: 2.2rem;
  font-weight: 600;
  margin: 20px 0;
}

.wp-block-columns,
.wp-block-image,
.wp-block-gallery{
  margin: 15px 0;
}

.wp-block-button{
  margin: 15px 0 !important;
}


.wp-block-column .wp-block-image{
  margin: 0;
}

.wp-block-table tr th{
  background-color: #f0f0e5;
  font-weight: 500;
  text-align: left; 
}

.info_table th{
  background: #f0f0e5;
  border: 1px solid #ccc;
  color: #333;
  font-weight: 500;
  padding: 10px;
  text-align: left;
  width: 30%;
}

.info_table td{
  border: 1px solid #cccccc;
  padding: 5px 10px;
}

.textlist li {
  line-height: 2.0;
  padding-left: 18px;
}

.textlist ul li::before{
  content: "■";
  color: #4cb7d1;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}

ul.btn-box{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

ul.btn-box li{
  margin-bottom: 0.5%;
  width: 49.5%;
}

ul.btn-box li a{
  background-color: #0E226F;
  border-radius: 6px;
  color: #fff;
  display: block;
  font-size: 2rem;
  text-align: center;
  text-decoration: none;
  padding: 20px 0;
}


/*=============================

お問い合わせ

==============================*/
.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption):before{
  display: none;
}

.wp-block-gallery.has-nested-images figure.wp-block-image figcaption{
  background: linear-gradient(0deg, #000000b3, #0000004d 70%, #0000);
  bottom: 0;
  box-sizing: border-box;
  color: #fff;
  font-size: 13px;
  left: 0;
  margin-bottom: 0;
  max-height: 60%;
  overflow: auto;
  padding: 0 8px 8px;
  position: absolute;
  scrollbar-color: #0000 #0000;
  scrollbar-gutter: stable both-edges;
  scrollbar-width: thin;
  text-align: center;
  width: 100%;
  will-change: transform;
}

.block-contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  width: 100%;
}

.block-item {
  width: calc(100% / 4 - 30px);
  text-align: center;
}

.btnbox .wp-block-button, 
.btnbox .wp-block-button a {
  width: 100%;
}

/*- under 640px -----------------------------*/
@media screen and (max-width: 640px){
  .block-item {
    font-size: 14px;
    width: calc(100% / 2 - 20px);
  }
}

/*=============================

スタッフ一覧

==============================*/
.staff-archive ul.staff-list{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.staff-archive ul.staff-list::before,
.staff-archive ul.staff-list::after{
  content: "";
  display: block;
  order: 1;
  width: 23%;
}

.staff-archive ul.staff-list li{
  margin-bottom: 6rem;
  width: 23%;
}


.staff-archive ul.staff-list li a{
  display: flex;
  flex-flow: column;
  height: 100%;
}

.staff-archive ul.staff-list li .img_box{
  aspect-ratio: 5 / 6;
  margin-bottom: 10px;
  overflow: hidden;
}

.staff-archive ul.staff-list li .img_box img{
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.staff-archive ul.staff-list li a p.cat,
.staff-single .staff-single-txt p.cat{
  line-height: 1em;
  margin-bottom: 3px;
  text-align: center;
}

.staff-single .staff-single-txt p.cat{
  display: inline-block;
}

.staff-archive ul.staff-list li a p.cat span,
.staff-single .staff-single-txt p.cat span{
  background-color: #0082a4;
  border-radius: 5px;
  color: #fff;
  font-size: 10px;
  padding: 2px 5px;
  text-align: center;
}

.staff-single .staff-single-txt p.cat span{
  font-size: 12px;
  margin-right: 5px;
}

.staff-archive ul.staff-list li a h2{
  font-size: 20px;
  margin-top: 10px;
}

.staff-archive ul.staff-list li a .en_name{
  font-size: 10px;
  margin-bottom: 20px;
}

.staff-archive ul.staff-list li a:hover h2,
.staff-archive ul.staff-list li a:hover .en_name{
  text-decoration: underline;
}

.staff-archive ul.staff-list li a .more_btn{
  background-color: #ff6600;
  border-radius: 999px;
  color: #fff;
  font-size: 12px;
  margin-top: auto;
  margin-left: auto;
  margin-right: auto;
  max-width: 120px;
  width: 100%;
}

.staff-archive ul.sikaku{
  border: 2px solid #ffb03f;
  margin-bottom: 30px;
  padding: 0.5em;
  position: relative;
}

.staff-archive ul.sikaku li{
  border-bottom: 1px dashed silver;
  list-style-type: circle;
  margin-left: 1.4em;
  padding: 4px 0;
}

.staff-single .staff-single-ph.img_box{
  width: 40%;
}

.staff-single .staff-single-txt.text_box{
  width: 58%;
}

.staff-single .staff-single-txt .name{
  font-size: 24px;
  margin-top: 20px;
}

.staff-single .staff-single-txt .en_name{
  color: #0082a4;
  font-weight: 500;
  font-size: 14px;
  margin-bottom: 30px;
}

.staff-single .staff-movie p{
  margin: 30px 0;
  text-align: center;
}

.staff-single .post_case .article,
.staff-single .post_voice{
  grid-template-columns: repeat(3, auto);
}

.staff-single .post_voice .img_box img.anq{
  position: absolute;
  right: 0;
  bottom: 0;
  width: 58%;
}
.staff-single .post_voice .comment{
  color: #000;
  font-weight: 600;
  margin-top: 10px;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .staff-archive ul.staff-list::before,
  .staff-archive ul.staff-list::after{
    display: none;
  }
  
  .staff-archive ul.staff-list li{
    width: 49%;
  }
  
  .staff-single .post_case .article,
  .staff-single .post_voice{
    grid-template-columns: repeat(2, auto);
  }
}

/*=============================

雨漏り

==============================*/
.wp-block-group.mokuji{
  border: 1px solid #999;
  margin-bottom: 40px;
  padding: 20px;
}

.amamori-cause{
  border: 2px solid #3f87ce;
  border-bottom: 6px solid #3f87ce;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.25);
  border-radius: 9px;
  margin-bottom: 6rem;
  padding: 15px;
  position: relative;
}

.amamori-cause::before{
  border: 50px solid transparent;
  border-top: 18px solid #3f87ce;
  content: '';
  height: 0;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
}

.amamori-cause h3{
  margin-top: 0 !important;
}

h4.wp-block-heading.amamoricasettl{
  border-top: 3px solid #000;
  border-radius: 12px 0 0 0;
  font-size: 2.5rem; 
  font-weight: 600;
  margin-bottom: 20px;
  padding: 10px 2rem 10px 110px;
  position: relative;
  word-break: break-all;
}

h4.wp-block-heading.amamoricasettl em{
  background: #000;
  border-radius: 10px 0 20px 10px;
  color: #fff;
  display: block;
  font-size: 16px;
  font-style: normal;
  padding: 8px 20px;
  position: absolute;
  top: 0;
  left: 0;
  text-shadow: initial;
}

h4.causettl,
h4.decidettl{
  background-color: #E10003;
  border-radius: 20px;
  color: #fff;
  display: inline-block;
  font-size: 2.2rem;
  margin-bottom: 20px;
  padding: 5px 20px;
}

h4.decidettl{
  background-color: #0039A7;
}

h3.honkaku{
  background-color: #FFF500;
  color: #ff0000;
  display: inline-block;
  font-size: 2.5rem !important;
  padding: 10px 15px;
  position: relative;
  bottom: -10px;
  transform: rotate(-4deg);
}

/*=============================

3D工法

==============================*/
.method-qa dt {
  margin-bottom: 10px;
}
.method-qa dd {
    margin-bottom: 20px;
}

.method-qa span {
    border: solid 2px #336699;
    border-radius: 1em;
    padding: 0px 2px;
}

.method-qa th, 
.method-qa td {
  display: block;
  font-weight: normal;
  text-align: left;
  vertical-align: top;
  width: 100%;
}

.method-qa ul{
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-bottom: 1em;
}


/*=============================

選ばれる理由

==============================*/
h2.paint_head{
  align-items: center;
  display: flex;
  font-size: clamp(20px,2.34vw,24px);
  margin-bottom: 30px;
}

h2.paint_head span{
  background-image: url("img/reason/main_heading_point_bg.png");
  background-repeat: no-repeat;
  background-size: contain;
  color: #ff6600;
  display: inline-block;
  flex-shrink: 0;
  font-size: 22px;
  height: 56px;
  margin-right: 10px;
  padding-top: 22px;
  text-align: center;
  width: 78px;
}

.point_page_nav{
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  display: flex;
  justify-content: space-between;
  margin: 2rem 0;
  width: 100%;
}

ul li.list_cross,
ul li.list_triangle,
ul li.list_circle{
  margin-top: 20px;
  padding-left: 6rem;
}

ul li.list_cross::before,
ul li.list_triangle::before,
ul li.list_circle::before{
  background-size: contain;
  content: "";
  height: 37px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 37px;
}

ul li.list_cross::before{
  background-image: url("img/reason/list_cross.jpg");
}
ul li.list_triangle::before{
  background-image: url("img/reason/list_triangle.jpg");
}
ul li.list_circle::before{
  background-image: url("img/reason/list_circle.jpg");
}


.point_page_nav .left,
.point_page_nav .right{
  padding: 20px 30px;
  width: 50%;
}

.point_page_nav .left{
  border-right: 1px solid #ccc;
}

.point-table{
  border: 1px solid #cccccc;
  margin-bottom: 30px;
}

.point-table th,
.point-table td{
  border: 1px solid #ccc;
  padding: 10px;
}

.point-table th{
  background-color: #f0f0e5;
  font-weight: 400;
  text-align: left;
}

.point-nisshi{
  border: 3px solid #ccc;
  margin-bottom: 2em;
  padding: 20px;
}

.point-nisshi p{
  line-height: 1.6em;
  padding-bottom: 0 !important;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .wp-block-columns.reverse{
    flex-wrap: wrap-reverse !important;
  } 
}

/*=============================

ショールーム

==============================*/
.anchor_link_btn.showroom a{
  background-image: linear-gradient(180deg, #FF7C02 , #D35005);
  border-radius: 10px;
  color: #fff;
  font-size: 2.4rem;
  font-weight: 700;
  min-height: 65px;
  padding-bottom: 25px;
  text-align: center;
  width: 32%;
}

.anchor_link_btn.showroom a::before{
  content: "";
  position: absolute;
  bottom: 5px;
  left: 50%;
  margin-left: -15px;
  margin-bottom: -15px;
  border: 15px solid transparent;
  border-top: 15px solid #fff;
}



/*=============================

料金ページ

==============================*/
.price-page .anchor li{
  width: 50%;
}
.price-page .anchor li:last-child{
  width: 100%;
}

.price-page .anchor a{
  background-color: #1e5799;
  border: 1px solid #FFFFFF;
  border-radius: 6px;
  color: #fff;
  display: block;
  font-size: 2.4rem;
  font-weight: 700;
  padding: 12px 0 20px;
  text-align: center;
}

.price-page .anchor a::before{
  border: 10px solid transparent;
  border-top: 10px solid #fff;
  content: "";
  margin-bottom: -10px;
  position: absolute;
  bottom: 5px;
  left: 50%;
  transform: translateX(-50%);
}

.price-page .anchor a:hover{
  text-decoration: none !important;
}

.price-detail .price-title{
  background-size: cover;
  background-repeat: no-repeat;
  margin-bottom: 5px;
  height: 440px;
  padding: 8px;
  position: relative;
}

.price-detail .price-title h2.price{
  color: #0C1A5C;
  font-size: clamp(35px,6.84vw,7rem);
  line-height: 1em;
  margin-bottom: 15px;
  paint-order: stroke;
  -webkit-text-stroke: 6px #fff;
  text-stroke: 6px #fff;
}

.price-detail .price-title h2.price span{
  font-size: 86%;
  letter-spacing: -0.1em;
}


.price-detail .price-title .lable{
  position: absolute;
  top: 0;
  right: 0;
  width: 30%;
}

.price-detail .price-title .lable img{
  margin-left: auto;
  margin-right: 0;
}

.price-detail .price-title .price-txt{
  color: #C90003;
  font-size: clamp(35px,6.84vw,7rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  paint-order: stroke;
  padding-bottom: 0 !important;
  position: absolute;
  right: 8px;
  bottom: 50px;
  -webkit-text-stroke: 6px #fff;
  text-stroke: 6px #fff;
}

.price-detail .price-title .price-txt .p1{
  font-size: 200%;
}

.price-detail .price-title .price-txt .p2{
  font-size: 140%;
}

.price-detail .price-title .price-details{
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 16px);
}

.price-detail .be-af_box .link_btn p{
  padding-bottom: 8px !important;
}

.price-detail .price-title .sp-security{
  background-color: #fff;
  border: 1px solid #000000;
  display: inline-block;
  font-size: 2rem;
  font-weight: 700;
  padding: 2px 10px !important;
}

.price-detail .price-title .price-area{
  background-color: #000;
  display: inline-block;
  color: #fff;
  font-size: 12px;
  padding: 1px 10px !important;
}

.price-detail .sp-year{
  border: 1px solid #000000;
  font-size: 14px;
  font-weight: bold;
  display: inline-block;
  margin-top: 15px;
  margin-right: 10px;
  margin-bottom: 15px;
  padding: 0;
  text-align: center;
  width: 200px;
}

.price-detail .sp-year h4{
  background: #58ba00;
  color: #FFFFFF;
  font-size: 16px;
  padding: 5px 0;
}

.price-detail .sp-year p{
  font-size: 2.2rem;
  padding: 10px 0 !important;
}


.price-detail .about_box{
  flex-flow: row-reverse;
  margin-bottom: 30px;
}

.price-detail .about_box .img_box{
  width: 27%;
}

.price-detail .about_box .text_box{
  width: 70%;
}

.price-detail .about_box .text_box .link_btn{
  text-align: left;
}

.price-detail .checklist{
  border: 1px solid #868686;
  margin-bottom: 20px;
  padding: 15px;
}

.price-detail .checklist li{
  font-size: 2rem;
  padding-left: 3.5rem;
  position: relative;
}

.price-detail .checklist li::before{
  border-right: 2px solid #8b6b4e;
  border-bottom: 2px solid #8b6b4e;
  content: "";
  height: 14px;
  transform: rotate(50deg);
  position: absolute;
  top: 5px;
  left: 9px;
  width: 6px;
}

.price-detail .checklist li::after{
  border: 2px solid #8b6b4e;
  border-radius: 2px;
  content: "";
  height: 2.2rem;
  position: absolute;
  top: 3px;
  left: 0;
  width: 2.2rem;
}


.price-detail .price-details tr{
  display: flex;
}

.price-detail .price-details th{
  align-content: center;
  background-color: #ccc;
  display: block;
  flex-shrink: 0;
  font-size: 14px;
  font-weight: 600;
  line-height: 1em;
  padding: 5px;
  width: 40px;
}

.price-detail .price-details td{
  align-content: center;
  background-color: #fff;
  border: 1px solid #ccc;
  display: block;
  font-size: 14px;
  padding: 5px;
  text-align: center;
  width: 100%;
}

.price-detail .price-details td:first-child{
  width: 30%;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .price-detail .about_box{
    display: block;
  }
  
  .price-detail .about_box .img_box,
  .price-detail .about_box .text_box{
    width: 100%;
  }
  
  .price-detail .price-title{
    height: 285px;
  }
}

/*=============================

シミュレーション

==============================*/
#simulation_box{
	border: 3px solid #048D98;
	border-radius: 10px;
	margin-top: 50px;
  margin-bottom: 50px;
	padding: 30px;
}

#simulation_box .flow{
	background-color: #F3F3F3;
	border-radius: 10px;
	justify-content: center;
	padding: 25px;
	position: relative;
}

#simulation_box .flow .step_img{
	position: absolute;
}
.step.step_img:nth-of-type(1) {
  top: 0;
  width: 126px !important;
  height: 146px;
  left: -26px;
}

.step.step_img:last-of-type {
  top: auto;
  bottom: 0;
  width: 137px !important;
  height: 154px;
  right: -30px;
}

#simulation_box .flow .step{
	align-content: center;
	text-align: center;
}

#simulation_box .flow .step:nth-child(2){
	border-bottom: 1px solid #CCCCCC;
  margin-bottom: 20px;
  padding-bottom: 20px;
}



#simulation_box .flow .step p span{
	color: #048D98;
	font-weight: bold;
}

#simulation_box .flow .step .input_wrap {
    align-items: flex-end;
    display: flex;
    justify-content: center;
}

#simulation_box .flow .step input{
	background-color: #ffffff;
	outline: 1px solid #7d7d7d; 
	font-size: 16px;
	margin-right: 10px;
	padding: 5px;
	text-align: right;
}
#simulation_box .flow .step input:focus{
	outline: 2px solid #000; 
}

#simulation_box .flow .step button#start_btn{
	background-color: #048D98;
	box-shadow: 0 8px 0 #004348;
	border-radius: 28px;
	color: #ffffff;
	cursor: pointer;
	font-size:20px;
	font-weight: bold;
	max-width: 245px;
	padding: 12px;
	text-align: center;
	transition: 0.2s;
	width: 100%;
}

#simulation_box .flow .step button#start_btn::before{
	background-image: url("img/common/icon_calculator.png") ;
	background-repeat:no-repeat;
	background-size: contain;
	content: "";
	display: inline-block;
	height:1.2em;
	margin-right: 3px;
	position: relative;
		top: 0.2em;
	width: 1em;
}

#simulation_box .flow .step button#start_btn:hover{
	box-shadow: 0 4px 0 #004348;
    transform: translateY(4px);
}

#simulation_box table{
	border: 1px solid #CCCCCC;
	margin: 30px 0;
	width: 100%;
}

#simulation_box table.sp{
	display: none;
}

#simulation_box table thead tr th{
	background-color: #D7F7F9;
	border: 1px solid #CCCCCC;
	font-size: 18px;
	font-weight: bold;
	padding: 8px;
	text-align: center;
}

#simulation_box table tbody td{
	border-right: 1px solid #CCCCCC;
	text-align: right;
	padding: 10px;
}
#simulation_box table tbody tr:last-child td{
	border: 1px solid #CCCCCC;
	font-size:18px;
}
#simulation_box table tbody tr:last-child td:not(:first-child){
	font-weight: bold;
}


#simulation_box table tbody td.first{
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
#simulation_box table tbody td.first span{
	font-size: 125%;
}

#simulation_box table#result_table th{
  background-color: #048D98;
  color: #fff;
}


#simulation_box .fukidashi p{
	background-color: #FFED95;
	border-radius: 10px;
	font-size: 25px;
	font-weight: bold;
	margin-bottom: 0;
	padding: 22px;
	padding-right: 100px;
	text-align: center;
	position: relative;
}
#simulation_box .fukidashi p::after{
	background-image: url("img/common/icon_wallet.png");
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	height: 90px;
	position: absolute;
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
	width: 90px;
}

#simulation_box .fukidashi p span#result_07{
	border-bottom: 3px solid #BE0505;
	color: #BE0505;
  margin: 0 5px;
}

#simulation_box .fukidashi p span#result_07 strong{
	font-size: 180%;
	vertical-align: bottom;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #simulation_box{
		padding: 15px;
	}
	
	#simulation_box .flow{
    display: flex;
		flex-wrap: wrap;
		padding: 10px 5px;
	}
	
	#simulation_box .flow .step{
		border-right: none !important;
		box-sizing: border-box;
		font-size: 14px;
		margin-bottom: 20px;
		padding: 0 5px;
		text-align: left;
		width: 60%;
	}
	#simulation_box .flow .step_img{
		height: auto;
		position: static;
		width: 40% !important;
	}
	
	#simulation_box .flow .step:last-child{
		margin-bottom: 8px;
	}
	
	#simulation_box .flow .step input{
		width: 75%;
	}
	
	#simulation_box .flow .step button#start_btn{
		font-size: 16px;
		max-width: 100%;
	}
	
	#simulation_box table.sp tbody,
	#simulation_box table.sp tr,
	#simulation_box table.sp th,
	#simulation_box table.sp td{
		box-sizing: border-box;
		display: block;
		width: 100%;
	}
	
	#simulation_box table.sp th{
		background-color: #048D98;
		color: #ffffff;
		font-size: 18px;
		padding: 10px;
	}
	
	#simulation_box table.sp td{
		font-size: 16px;
	}
	
	#simulation_box table thead tr th,
	#simulation_box table tbody td,
	#simulation_box table tbody tr:last-child td{
		font-size:14px;
	}
	
	#simulation_box table tbody td{
		padding: 10px 5px;
	}
	
	#simulation_box .fukidashi{
		padding-right: 0;
	}
	
	#simulation_box .fukidashi::after{
		top: auto;
		right: auto;
		bottom: 0;
		left: 50%;
		transform: translatex(-50%);
	}
	
	#simulation_box .fukidashi p{
		font-size: 18px;
		padding: 15px;
	}
	
	#simulation_box .fukidashi p::after{
		top: 13px;
		right: 0;
		height:68px;
		width: 68px;
	}
	
	#simulation_box .fukidashi p span#result_07{
		display: block;
		margin-bottom: 5px;
	}
}

/*=============================

詳細ページ

==============================*/
.liquid-speech-balloon-text p:last-of-type{
  padding-bottom: 0 !important;
}

#single #ez-toc-container{
  background-color: #f1fafc;
  border: 2px solid #4cb7d1;
  margin: 40px auto !important;
  width: 100%;
}

#single div#ez-toc-container .ez-toc-title{
  font-weight: 700;
}

#single div#ez-toc-container .ez-toc-heading-level-2{
  border-bottom: 1px dashed #ccc;
  padding: 7px;
}

#single #main_contents article a{
  text-decoration: underline;
}

#single h2.wp-block-heading{
  background-color: #D2EBF1;
  border-left: 7px solid #4cb7d1;
  padding: 15px 10px;
  margin: 4rem 0;
}

#single .bottomblog #link_box{
  border-top: 1px solid #ccc;
  padding-top: 30px;
}

#single .bottomblog #link_box a{
  font-weight: 700;
  padding-left: 1.2em;
}

#single .bottomblog #link_box a::before{
  background-color: #18B800;
  border-radius: 999px;
  content: "";
  height: 1em;
  position: absolute;
  top: 0.3em;
  left: 0;
  width: 1em;
}

#single .bottomblog #link_box a::after{
  content: '';
  width: 5px;
  height: 5px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  left: 3px;
  top: 0.6em;
  transform: rotate(45deg);
}


#single .bottomblog #shop_box > p{
  width: 100%;
}

#single .bottomblog #shop_box .shop{
  width: 24%;
}

#single .bottomblog #shop_box .shop p{
  font-size: 15px;
  font-weight: 400;
  padding-bottom: 0;
}

#single .bottomblog #cat_box{
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  margin-top: 30px;
  padding-top: 20px;
}

.tobloglist{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px 0 4rem;
}

.tobloglist .item{
  width: 30%;
}

.tobloglist .item{
  text-align: center;
}
.tobloglist .item:first-child{
  text-align: left;
}
.tobloglist .item:last-child{
 text-align: right;
}

.tobloglist .item a{
  background-color: #4cb7d1;
  color: #fff;
  margin-bottom: 10px;
  text-align: center;
  padding: 12px 15px;
}

.monthly-calendar table{
  margin: 20px 0;
}

.monthly-calendar table caption{
  font-size: 18px;
  font-weight: bold;
  padding: 10px 0 0 0;
}

.monthly-calendar table th, .monthly-calendar table td {
  border: 1px solid #fff;
  padding: 8px 0;
  font-size: 15px;
  line-height: 1.7;
  vertical-align: middle;
  background: #f5f5f5;
  position: relative;
  text-align: center;
}

.monthly-calendar table th{
  background: #f6e8e8;
  padding: 7px 0;
  text-align: center;
}

.day-box.no-day{
  background-color: #ccc !important;
}

.monthly-prev{
  display: none;
}


.single-default #main_contents article#default{
  border: 1px solid #ccc;
  border-top: 4px solid #4cb7d1;
  box-shadow: 0px 4px 4px rgba(153, 153, 153, 0.75);
  margin-bottom: 5rem;
  padding: 15px;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #single .bottomblog #shop_box .shop{
    margin-top: 10px;
    width: 45%;
  }
  
  .tobloglist .item,
  .tobloglist .item:first-child,
  .tobloglist .item:last-child,
  .tobloglist .item a{
    text-align: center;
    width: 100%;
  }
}


/*---------------
お客様の声
----------------*/
.character::after{
  background-image: url("img/top/top_ttl_yonekichi.png");
  background-size: contain;
  content: "";
  height: 60px;
  position: absolute;
  right: 0;
  bottom: 0;
  width: 60px;
}

#single #voice_article .link_btn a,
#single #case_article .link_btn a{
  padding: 20px 30px 20px 60px;
}

#single #voice_article .link_btn a img{
  position: absolute;
  top: 50%;
  left: -40px;
  transform: translateY(-50%) rotate(-3deg);
  width: 90px;
}

#single #voice_article .manzoku{
  font-size: 3rem;
  height: 10rem;
  left: 0;
  width: 10rem;
}

#single #voice_article .customer_comment{
  background-color: #EDF9FC;
  border-radius: 10px;
  margin: 30px 0;
  padding: 20px 15px;
}

#single #voice_article .customer_comment p:last-child{
  padding-bottom: 0;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #single #voice_article .link_btn{
        padding-left: 60px;
  }
}


/*---------------
施工事例
----------------*/
#single #case_article table{
  margin-bottom: 30px;
}

#single #case_article table th,
#single #case_article table td{
  border: 1px solid #B4B4B4;
  padding: 5px 0;
}

#single #case_article table th{
  background-color: #FFF6B1;
}

#single #case_article table td{
  padding: 5px;
}

#single #case_article table td p{
  padding-bottom: 0;
}

#single #case_article table td .case-works-list{
  margin-bottom: 0;
}

#single #case_article table td .case-works-list li a{
  background-color: #003466;;
  text-decoration: none;
}

#single #case_article .construction_list::after{
  content: "";
  display: block;
  width: 32%;
}

#single #case_article .construction_list .item{
  margin-bottom: 20px;
  width: 32%;
}

#single #case_article .construction_list .item .construction_list_ttl{
  color: #006067;
  font-size: 18px;
  font-weight: bold;
  margin-top: 5px;
  padding-bottom: 5px;
}

#single #case_article .staff_comment{
  border: 2px solid #0A0E57;
  border-radius: 6px;
  margin-bottom: 15px;
  margin-top: 35px;
  padding: 25px 10px 10px 10px;
  position: relative;
}

#single #case_article .staff_comment h2{
  background-color: #121C49;
  border-radius: 4px 4px 4px 0;
  color: #fff;
  display: inline-block;
  font-size: 22px;
  position: absolute;
  top: -15px;
  left: -2px;
  text-align: center;
  width: 225px;
}

#single #case_article .staff_comment .staff-photo{
  flex-shrink: 0;
  width: 15rem;
}

#single #case_article .staff_comment .staff-photo p{
  text-align: center;
  font-weight: 700;
  margin-top: 5px;
}

#single #case_article .staff_comment .staff-photo p a{
  text-decoration: none;
}

#single #case_article .staff_comment .staff-txt{
  width: calc(100% - 15rem - 1%);
}

#single #case_article .staff_comment h3{
  margin-top: 0;
  margin-bottom: 15px;
}

#single #case_article .link_btn{
  position: relative;
}

#single #case_article .link_btn a{
  width: 100%;
}

#single #case_article .link_btn::after{
  background-image: url("img/common/icon_questionnaire.png");
  background-size: contain;
  content: "";
  height: 88px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%) rotate(-3deg);
  width: 90px;
}

#single .post_case.related .article{
  grid-template-columns: repeat(4, auto);
}

#single .post_case.related .article .title{
  margin: 10px 0;
}

/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  #single #case_article .construction_list::after{
    display: none;
  }

  #single #case_article .construction_list .item{
    width: 49%;
  }
  
  #single #case_article .staff_comment .staff-photo{
    width: 100px;
  }
  
  #single #case_article .staff_comment .staff-txt{
    width: calc(100% - 100px - 1%);
  }
  
  #single #case_article .link_btn::after{
    width: 60px;
  }
  
  #single .post_case.related .article{
    grid-template-columns: repeat(2, auto);
  }
}


/*=============================

塗装市民講座（セミナー）

==============================*/
.seminar-page section{
  margin-bottom: 30px;
}

.seminar-page .seminar-info{
  background-color: #ffcc00;
  margin: -10px 0 30px;
  padding: 10px 45px 20px;
}

.seminar-page .seminar-info dl{
  align-items: center;
  display: flex;
  flex-wrap: wrap;
}

.seminar-page .seminar-info dl dt{
  align-content: center;
  background-color: #3b7f08;
  border-radius: 7px 0 0 7px;
  color: #fff;
  margin: 0 0 14px;
  height: 100px;
  text-align: center;
  width: 140px;
}

.seminar-page .seminar-info dl dd{
  align-content: center;
  background-color: #fff;
  border-radius: 0 7px 7px 0;
  height: 100px;
  margin-bottom: 14px;
  padding: 0 40px;
  width: calc(100% - 140px);
}

.seminar-page .seminar-contact{
  border: 1px solid #ccc;
  background: url(img/seminar/bg_contact.png) center center;
  margin-bottom: 30px;
  padding: 30px;
  text-align: center;
}

.seminar-page .seminar-contact img{
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 10px;
}

.seminar-page .seminar-point-inr{
  background-color: #4cb7d1;
  padding: 0 20px 20px;
}

.seminar-page .seminar-point-list{
  background-color: #fff;
  margin-bottom: 20px;
  padding: 30px 45px;
}
.seminar-point-list:last-of-type {
  margin-bottom: 0;
}

.seminar-page .seminar-point-list h4{
  border-left: 5px solid #003366;
  color: #003366;
  font-size: 20px;
  margin-bottom: 20px;
  padding-left: 15px;
}

.seminar-page .seminar-point-list li{
  background: url(img/seminar/icon_check.png) no-repeat left center;
  font-size: 20px;
  line-height: 1.5em;
  margin-bottom: 10px;
  padding-left: 30px;
}

.seminar-page .seminar-point-list li span{
  background: #ffcf5c;
}

.seminar-page .seminar-guide .seminar-guide-inr{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 20px;
}

.seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-ph{
  max-width: 285px;
  width: 37.5%;
}

.seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt{
  border: 2px solid #003d75;
  max-width: 440px;
  width: 57.89%;
}

.seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt h3{
  background-color: #003d75;
  color: #fff;
  font-size: 2.4rem;
  padding: 10px 20px;
  position: relative;
  text-align: center;
}
.seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt h3:before {
    display: block;
    content: "";
    position: absolute;
    top: 90%;
    left: 50%;
    transform: translateX(-50%);
    width: 52px;
    height: 29px;
    background: url(img/seminar/icon_arw_guide.png) no-repeat;
    background-size: contain;
}

.seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt ul{
  background-color: #f8f8f8;;
  padding: 25px 40px;
}

.seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt ul li{
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 10px;
}

.seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt ul li:before{
  content: "Q. ";
  color: #cc0000;
}

.seminar-page .seminar-guide h4{
  font-size: 3.6rem;
  font-weight: 700;
  text-align: center;
}

.seminar-page .seminar-guide h4 .bold{
  color: #cc0000;
  display: block;
}

.seminar-page .seminar-flyer{
  border: 3px solid #333;
}

.seminar-page .seminar-flyer h3{
  background-color: #333;
  color: #fff;
  font-size: 2.6rem;
  padding: 10px 20px;
  text-align: center;
}

.seminar-page .seminar-flyer h4{
  background-color: #ffcc00;
  color: #cc0000;
  font-size: 2rem;
  padding: 10px;
  text-align: center;
}

.seminar-page .seminar-flyer .seminar-flyer-inr{
  padding: 25px 25px 15px;
  text-align: center;
}

.seminar-page .seminar-flyer .seminar-flyer-inr figure{
  font-size: 3.6rem;
  margin-bottom: 20px;
  text-align: center;
}

.seminar-page .seminar-voice .flex-nml{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.seminar-page .seminar-voice .flex-nml li{
  background-color: #bae7f2;
  margin-top: 4%;
  padding: 25px;
  position: relative;
  width: 48%;
}

.seminar-page .seminar-voice .flex-nml li:after {
  background: url(img/seminar/icon_flag.png) no-repeat;
  background-size: contain;
  content: "";
  display: block;
  position: absolute;
    top: -5px;
    left: 15px;
  width: 33px;
  height: 32px;
}

.seminar-page .seminar-voice .flex-nml li figure img{
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 20px;
}

.seminar-page .seminar-faq .seminar-faq-inr{
  background: url(img/seminar/bg_faq.png) no-repeat left top;
  border: 1px solid #ccc;
  border-top: none;
  padding: 60px 35px 10px;
  position: relative;
}

.seminar-page .seminar-faq .seminar-faq-inr::before{
  background: url(img/seminar/icon_arw_faq.png) no-repeat;
  background-size: 100% auto;
  content: "";
  display: block;
  height: 37px;
  position: absolute;
    top: -5px;
    left: 50%;
  transform: translateX(-50%);
  width: 100%;
}


.seminar-page .seminar-faq dt{
  color: #cc0000;
  font-size: 2.4rem;
  font-weight: 700;
  margin-bottom: 10px;
}

.seminar-page .seminar-faq dt:before {
  color: #cc0000;
  content: "Q. ";
}

.seminar-page .seminar-faq dd{
  font-size: 2.4rem;
  font-weight: 700;
  margin-bottom: 4rem;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .seminar-page .seminar-info{
    margin: -10px 0 20px;
    padding: 10px 25px 20px;
  }
  
  .seminar-page .seminar-info dl dt{
    border-radius: 0;
    height: 30px;
    margin: 0;
    width: 100%;
  }
  
  .seminar-page .seminar-info dl dd{
    border-radius: 0;
    margin: 0 0 14px;
    padding: 10px 20px;
    width: 100%;
  }
  
  .seminar-page .seminar-contact{
    padding: 20px 15px;
  }
  
  .seminar-page .seminar-point-list{
    padding: 20px 15px;
  }
  
  .seminar-page .seminar-point-list li{
    font-size: 14px;
  }
  
  .seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-ph{
    max-width: 100%;
    width: 100%;
  }
  
  .seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-ph img{
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
  }
  
  .seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt{
    width: 100%;
  }
  
  .seminar-page .seminar-guide .seminar-guide-inr .seminar-guide-txt ul{
    padding: 25px 15px;
  }
  
  .seminar-page .seminar-guide h4{
    font-size: 20px;
    margin-bottom: 20px;
  }
  
  .seminar-page .seminar-flyer h3{
    font-size: 18px;
  }
  
  .seminar-page .seminar-voice .flex-nml li{
    font-size: 13px;
    padding: 15px;
  }
  
  .seminar-page .seminar-faq .seminar-faq-inr{
    padding: 40px 15px 10px;
  }
  
  .seminar-page .seminar-faq .seminar-faq-inr::before{
    display: none;
  }
  
  .seminar-page .seminar-faq dt{
    font-size: 16px;
  }
  
  .seminar-page .seminar-faq dd{
    font-size: 14px;
  }
}


/*=============================

火災保険

==============================*/
 .insurance-trouble-point{
  background: url(img/insurance/img_trouble.png) no-repeat right bottom;
  margin-bottom:  35px;
}

 .insurance-trouble-point ul{
  margin-top: 30px;
}

 .insurance-trouble-point li{
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 5px;
  padding-left: 35px;
}

 .insurance-trouble-point li::before{
    display: block;
    content: "";
    position: absolute;
    top: 4px;
    left: 0;
    width: 26px;
    height: 24px;
    background: url(img/insurance/icon_check01.png) no-repeat center center;
    background-size: contain;
}

 .insurance-trouble-case ul{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

 .insurance-trouble-case ul li{
  font-size: 2rem;
  margin-bottom: 2.5rem;
  text-align: center;
  width: 32%;
}

 .insurance-trouble-case ul li figure{
  margin-bottom: 6.25%;
}

 .insurance-trouble-caution{
  margin-bottom: 40px;
}

 .insurance-trouble-caution-inr{
  background: url(img/insurance/img_caution.png) no-repeat right 35px bottom;
  border: 4px solid #003366;
  padding: 30px 60px 20px;
}

  .insurance-trouble-caution-txt{
  max-width: 455px;
  width: 75%;
}

 .insurance-trouble-caution-inr h4{
  font-size: 2rem;
  margin-bottom: 5px;
}

 .insurance-compatible h3{
  margin-bottom: 30px;
}

 .insurance-compatible-list ul{
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

 .insurance-compatible-list ul li{
  margin-bottom: 35px;
  padding: 0 10px;
  text-align: center;
  width: 20%;
}

 .insurance-compatible-list ul li img{
  margin: auto auto;
}

 h3.insurance_point{
  color: #663300;
  font-size: 2rem !important;
  padding-left:123px;
  position: relative;
  margin: 0 0 20px;
}

h3.insurance_point::before{
  background-size: contain;
  content: "";
  height: 38px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 113px;
}

h3.insurance_point:first-of-type::before{
  background: url(img/insurance/icon_ttl_point01.png) no-repeat;
}
h3.insurance_point:nth-of-type(2)::before{
  background: url(img/insurance/icon_ttl_point02.png) no-repeat;
}

.insurance-flow-inr{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.insurance-flow-inr ul{
  margin-bottom: 32px;
  width: 49%;
}

.insurance-flow ul li{
  border: 3px solid #003366;
  margin-bottom: 32px;
}
.insurance-flow ul li:before{
  background: url(img/insurance/icon_arw02.png) no-repeat;
  background-size: contain;
  display: block;
  content: "";
  position: absolute;
  top: calc(100% + 3px);
  left: 50%;
  transform: translateX(-50%);
  width: 121px;
  height: 32px;
}

.insurance-flow ul:not(:first-of-type) li:last-child::before{
  display: none;
}

.insurance-flow ul li h3{
  background-color: #003366;
  color: #fff;
  font-size: 2rem;
  padding: 3px 25px;
}
.insurance-flow ul li p{
  padding: 15px 22px;
}


/*- under 767px -----------------------------*/
@media screen and (max-width:767px){
  .insurance-trouble-point{
    background: none;
  }
  
  .insurance-trouble-case ul li{
    font-size: 13px;
  }
  
  .insurance-trouble-caution-inr{
    background: none;
    padding: 15px;
  }
  
  .insurance-trouble-caution-txt{
    max-width: 100%;
    width: 100%;
  }
  
  .insurance-compatible-list ul li{
    width: 33.3%;
  }
  
  .insurance-flow-inr ul{
    margin-bottom: 0;
    width: 100%;
  }
}


/*----------------------
 * 予約ページ
 * --------------------*/
#contact-present{
	border: 2px solid #2f99b3;
	border-radius:15px;
	margin-bottom: 30px;
	padding: 15px;
}

#contact-present h2{
	background-color:#2f99b3;
	color: #fff;
	margin-bottom: 1.2rem;
	padding: 5px;
	text-align: center;
}

#contact-present p span.bold{
	color: red;
	font-size: 120%;
	font-weight: bold;
}

#contact-present p span.marker{
	background: linear-gradient(transparent 70%, #FFF500 70%);
}

#contact-present ul.notes{
	border-top: 1px solid #ccc;
	padding-top: 10px;
}

#contact-present ul.notes li{
	font-size:80%;
}