@charset "UTF-8";
/*!
Theme Name: campaign_exterior  main.css
Version:20251120
*/


html {
    /* ルートのフォントサイズを10pxに設定しておく */
	font-size: 62.5%;
	/*scroll-behavior: smooth;*/
}
body{
	font-size:14px;
	color:#333;
	width:100%;
	text-align:center;
    line-height: 1.6em;
/*font-family: "Helvetica Neue",
    Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    Meiryo,
	  sans-serif;*/
	    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.clearfix::after {
   content: "";
   display: block;
   clear: both;
}
img {
  vertical-align: bottom;
}
a{
    color: #025811;
    text-decoration: underline;
}
a:hover{
	color:#7fb345;
	text-decoration:none;
}

ul {
    list-style: none;
    list-style-position: outside;
    padding: 0px;
    margin: 0px;
	text-align: left;
}
dl {
    list-style: none;
    list-style-position: outside;
    padding: 0px;
    margin: 0px;
}
a.ft_telno_link {
    text-decoration: none;
	color: #333!important;
}
.txt_bold{
	font-weight:700;
}
.txt_attention_bold{
	font-weight:500;
	color:#ed5d20;
}
.text_attention {
    color: #ed5d20;
}
.text_underline{
	text-decoration:underline;
}
.btm20{
	margin-bottom:20px;
}
.yellowline_span {
    font-weight: bold;
    background: linear-gradient(transparent 50%, rgb(255 255 102 / 70%) 0%);
    transition: 2s;
}
* {
    overflow-wrap: break-word;
    word-wrap: break-word;
}
.row {
    display: flex;
    flex-direction: row;
}
.row>* {
    min-width: 0;
}
.col {
    display: flex;
    flex-direction: column;
}
.col>* {
    max-width: 100%;    
}
/*** tel番号　768px以上で電話不可 ***/
@media screen and (min-width: 768px){
  a[href^="tel:"]{
    pointer-events: none;
  }
}
/******************************/
.pc_mode{display:block;}
.sp_mode{display:none;}
.spmenu_mode{display:none;}
.sp600_mode{display:none;}
.sp400_mode{display:none;}
/************************/
.mvpc_mode{display:block;}
.mvpc1920_mode{display:none;}
.mvpc1480_mode{display:none;}
.mvsp_mode{display:none;}	
.mvsp500_mode{display:none;}	

a:focus, *:focus { outline:none; }

#page-top {
    display: none;
}
#pageTop {
  position: fixed;
  bottom: 40px;
  right: 40px;
    z-index: 999;
}
#pageTop i {
  padding-top: 17px;
	font-size:15px;	
}
#pageTop a {
	display: block;
 	z-index: 99;
 	padding: 0px;
 	width: 50px;
 	height: 50px;
	background-color: rgb(61 165 24 / 80%);
	color: #fff;
 	font-weight: bold;
  	text-decoration: none;
 	text-align: center;
    font-size: 25px;
    border-radius: 30px;
	-webkit-transition:all 0.3s ;
	-moz-transition:all 0.3s ;
	transition:all 0.3s ;
}
#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}
/*************************/

#header_wrap, #header #gnavi, #parents, #footer_wrapinner, #footer_bottom, .centering {
    width: 1000px;
    margin: 0 auto;
}
.clearfix {
    zoom: 1;
}
#header {
    width: 100%;
    height: 120px;
    background: #FFF url(../images/header_bg.jpg) repeat-x top left;
    border-top: 5px solid #7fb345;
}
#header #header_wrap {
    height: 115px;
    padding-top: 18px;
    position: relative;
    background: url(../images/header_logobg.jpg) no-repeat top center;
}
.logo img {
    margin: 18px auto 0;
}
.sub_h1 {
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    margin: 0;
}

/*** mainvisualエリア ***/
.mv_area {
    background-image: url(../images/campaignex_mv01.png);
	height: 371px;/*396*/
	background-position: center;
}
.mv_ttl img {
    margin-top: 30px;
}

/*** contentエリア ***/
.campex_content {
	padding: 0 0 50px 0;
    background: #FFF url(../images/campex_contentbg.png) repeat top left;
}
/*.campex_content_bg01 {
    background: rgb(255 255 255 / 50%);
    padding: 30px 0 60px;
}
.campex_content_bg02 {
    padding: 30px 0 60px;
}*/
.campex_content_bg01 {
    background: rgb(249 214 218 / 20%);
    padding: 30px 0 60px;
}
.campex_content_bg02 {
    background: rgb(200 224 229 / 30%);
    padding: 30px 0 60px;
}
.campex_content_bg03 {
    background: rgb(191 239 221 / 30%);
    padding: 30px 0 60px;
}
.campex_content_bg04 {
    background: rgb(191 235 176 / 30%);
    padding: 30px 0 60px;
}
.campex_content_bg05 {
    background: rgb(246 243 188 / 20%);
    padding: 30px 0 60px;
}
.campex_content_bg06 {
    background: rgb(244 222 183 / 30%);
    padding: 30px 0 60px;
}
.campex_content_bg07 {
    background: rgb(245 213 202 / 30%);
    padding: 30px 0 60px;
}
.campex_contentinner {
    width: 1000px;
    margin: 0 auto;
    text-align: left;
	line-height: 1.7em;
}

/*** breadcrumbsエリア ***/
#breadlist {
    padding: 20px 0px 0px;
    font-size: 13px;
	margin: 0 0 1.5em 0;
}
#breadlist span img {
    margin: 0 10px;
    vertical-align: middle;
}

/*** prevbox  ***/
p.btm_contact {
    margin: 50px 0 20px 0;
    text-align: center;
    font-size: 2.0em;
    font-weight: bold;
	font-family: "Kosugi Maru", sans-serif;
}
.campex_prevbox {
	/* border: 7px solid #b3cfac;*/
    padding: 15px;
    text-align: center;
   /* background: rgb(220 229 217 / 40%);
	border: 7px solid rgb(156 226 138 / 50%);
	background: rgb(247 253 223 / 40%);*/
	background: rgb(255 255 255 / 40%);
	border-radius: 10px;
}
p.prev_txt {
    font-family: "Kosugi Maru", sans-serif;
    margin: 0 0 1.0em 0;
    font-size: 1.3em;
    line-height: 175%;
}
p.prev_txt02 {
    margin: 0 0 20px 0;
    font-size: 1.6em;
    font-weight: bold;
font-family: "Kosugi Maru", sans-serif;
}
ul.prevbox_company_ul {
    margin: 0 auto;
    text-align: center;
    display: flex;
    justify-content: center;
	align-items: center;
font-family: "Kosugi Maru", sans-serif;
}
p.prevbox_company_name {
    margin: 0 30px 0 0 !important;
    font-size: 1.5em;
    font-weight: bold;
}
img.prevbox_freedialicon {
    vertical-align: text-bottom;
}
span.tel_no.tel-link {
    margin: 0 0 0 10px;
    font-size: 2.3em;
    font-weight: bold;
	font-weight: 600;
    font-family: "Jost", sans-serif;
}
span.tel_no.tel-link::before {
	content: "";
	display: inline-block;
	width: 50px;
	height: 32px;
	background-image: url(../images/free_dial_icon.png);
	background-size: contain;
	vertical-align: middle;
    margin: 0 10px 0 0;
}
span.tel_no.tel-link a {
    text-decoration: none;
    color: #000;
}
/*** category_menu  ***/
.category_menu_area {
    margin: 60px auto 60px;
    text-align: center;
    /* background: rgb(241 241 241 / 50%); */
    /* padding: 30px 0 20px 0; */
    /* border: 2px solid rgb(46 139 24 / 30%); */
    /* box-shadow: 0 0 0 10px rgb(46 139 24 / 10%); */
    /* width: calc(100% - 20px); */
}
p.category_menu_ttl {
    color: /*#32763e*/#000000;
    border-radius: 20px;
    margin: 0 auto 40px !important;
    font-size: 1.8em;
    font-family: "Lato", sans-serif;
    font-weight: 700;
    font-style: italic;
    padding: 0 3em;
    width: fit-content;
    text-align: center;
    position: relative;
}
p.category_menu_ttl::before, p.category_menu_ttl::after {
    content: '';
    background: /*#32763e*/#000000;
    width: 2em;
    height: 2px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
p.category_menu_ttl::before {
    left: 0;
}
p.category_menu_ttl::after {
    right: 0;
}
ul.category_menu_ul {
    margin: 0 0 0px;
    list-style-type: none;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
ul.category_menu_ul > li:not(:last-child){
	margin:0 30px 20px 0;
	
}
a.btn_categorymenu {
  font-family: "Kosugi Maru", sans-serif;
    font-size: 1.2em;
    letter-spacing: 0.1em;
    color: /*#025811*/#000;
    font-weight: 700;
    outline: 2px solid /*#025811*/#000;
    display: block;
    position: relative;
    box-sizing: border-box;
    max-width: 300px;
    text-align: center;
    padding: 16px 0px;
    margin-inline: auto;
    text-decoration: none;
    z-index: 998;
    transition: all 0.3s;
    border-radius: 5px;
    width: 190px;
	text-shadow: 1px 1px 0 #ffffff, -1px 1px 0 #ffffff, 1px -1px 0 #ffffff, -1px -1px 0 #ffffff;
}
a.btn_categorymenu:before {
    content: "";
    position: absolute;
    top: 6px;
    left: 6px;
    width: 100%;
    height: 100%;
	background: rgb(201 222 208 / 40%);
    background: repeating-linear-gradient(-45deg, rgb(184 223 197 / 40%), rgb(184 223 197 / 40%) 4px, rgb(219 229 149 / 40%) 3px, rgb(219 229 149 / 40%) 8px);
    z-index: -999;
    transition: all 0.3s ease;
    border-radius: 5px;
}
a.btn_categorymenu:hover:before{
  top: 0;
  left: 0;
  transition: all 0.3s;
}
a.btn_categorymenu.cat_01:before {
    background: #fbaacf;
	background: repeating-linear-gradient(-45deg, rgb(251 170 207 / 60%), rgb(251 170 207 / 60%) 4px, rgb(251 199 223 / 60%) 3px, rgb(247 205 224 / 60%) 8px);
}
a.btn_categorymenu.cat_02:before {
    background: #a3cef5;
	background: repeating-linear-gradient(-45deg, rgb(163 206 245 / 60%), rgb(163 206 245 / 60%) 4px, rgb(204 226 247 / 60%) 3px, rgb(204 226 247 / 60%) 8px);
}
a.btn_categorymenu.cat_03:before {
    background: #a3f5df;
	background: repeating-linear-gradient(-45deg, rgb(163 245 223 / 80%), rgb(163 245 223 / 80%) 4px, rgb(223 245 236 / 80%) 3px, rgb(223 245 236 / 80%) 8px);
}
a.btn_categorymenu.cat_04:before {
    background: #aff5a3;
	background: repeating-linear-gradient(-45deg, rgb(175 245 163 / 80%), rgb(175 245 163 / 80%) 4px, rgb(214 247 208 / 80%) 3px, rgb(214 247 208 / 80%) 8px);
}
a.btn_categorymenu.cat_05:before {
    background: #eff5a3;
	background: repeating-linear-gradient(-45deg, rgb(230 242 110), rgb(230 242 109) 4px, rgb(241 243 214 / 60%) 3px, rgb(241 243 214 / 60%) 8px);}
a.btn_categorymenu.cat_06:before {
    background: #f5d1a3;
	background: repeating-linear-gradient(-45deg, rgb(245 209 163), rgb(245 209 163) 4px, rgb(251 232 208 / 70%) 3px, rgb(251 232 208 / 70%) 8px);
}
a.btn_categorymenu.cat_07:before {
    background: #f5a3a3;
	background: repeating-linear-gradient(-45deg, rgb(245 133 133 / 60%), rgb(245 133 133 / 60%) 4px, rgb(249 230 230 / 60%) 3px, rgb(249 230 230 / 60%) 8px);
}
/*** 商品 紹介エリア ***/
.pre_h2area {
    display: block;
    text-align: center;
}
p.pre_h2 {
    font-family: "Kosugi Maru", sans-serif;
    text-align: center;
    margin: 0 0 0px 0 !important;
    border-top: 3px dotted #555;
    border-bottom: 3px dotted #555;
    padding: 5px;
    display: inline-block;
    position: relative;
}
p.pre_h2:before {
    content: '';
    display: block;
    position: absolute;
    bottom: -9px;
    left: 0;
    right: 0;
    margin: auto;
    width: 0;
    height: 0;
    border-right: 10px solid transparent;
    border-left: 10px solid transparent;
    border-top: 9px solid #000;
}
p.pre_h2:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 3px;
    /* background: #000; */
    z-index: 1;
}
.campex_h2 {
    font-family: "Kosugi Maru", sans-serif;
    font-size: 2.3em;
    font-weight: bold;
    margin: 10px auto 30px;
    padding: 0 0 20px 0;
    text-align: center;
}
h2.h2_gate,h2.h2_fence,h2.h2_carport,h2.h2_deck,h2.h2_sunroom,h2.h2_terrace,h2.h2_other {
    position: relative;
}
h2.h2_gate{
	    letter-spacing: 0.3em;
	background-position: top center;
	background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_gate.png);
    background-repeat: no-repeat;
	background-size:120px;
    height: 100px;
    padding: 16px 0 0 0;
    text-shadow: 3px 3px 0 rgb(249 249 243 / 60%), -3px 3px 0 rgb(250 250 244 / 60%), 3px -3px 0 rgb(245 245 233 / 60%), -3px -3px 0 rgb(248 248 240 / 60%);
}
h2.h2_fence {
    letter-spacing: 0.1em;
    background-position: top center;
	    background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_fence.png);
    background-repeat: no-repeat;
	background-size:140px;
    height: 98px;
    padding: 16px 0 0 0;
	text-shadow: 3px 3px 0 rgb(233 233 209 / 60%), -3px 3px 0 rgb(248 248 239 / 60%), 3px -3px 0 rgb(249 249 241 / 60%), -3px -3px 0 rgb(244 244 232 / 60%);
}
h2.h2_carport {
    letter-spacing: 0.1em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_carport.png);
    background-repeat: no-repeat;
	background-size: 170px;
    height: 98px;
    padding: 16px 0 0 0;
    text-shadow: 3px 3px 0 rgb(249 249 243 / 60%), -3px 3px 0 rgb(250 250 244 / 60%), 3px -3px 0 rgb(245 245 233 / 60%), -3px -3px 0 rgb(248 248 240 / 60%);
}
h2.h2_deck {
    letter-spacing: 0.3em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_deck.png);
    background-repeat: no-repeat;
    background-size: 120px;
    height: 94px;
    padding: 16px 0 0 0;
	text-shadow: 3px 3px 0 rgb(233 233 209 / 60%), -3px 3px 0 rgb(248 248 239 / 60%), 3px -3px 0 rgb(249 249 241 / 60%), -3px -3px 0 rgb(244 244 232 / 60%);
}
h2.h2_sunroom {
    letter-spacing: 0.1em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_sunroom.png);
    background-repeat: no-repeat;
    background-size: 180px;
    height: 94px;
    padding: 16px 0 0 0;
    text-shadow: 3px 3px 0 rgb(249 249 243 / 60%), -3px 3px 0 rgb(250 250 244 / 60%), 3px -3px 0 rgb(245 245 233 / 60%), -3px -3px 0 rgb(248 248 240 / 60%);
}
h2.h2_terrace {
    letter-spacing: 0.1em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_terrace.png);
    background-repeat: no-repeat;
	background-size: 170px;
    height: 93px;
    padding: 16px 0 0 0;
	text-shadow: 3px 3px 0 rgb(233 233 209 / 60%), -3px 3px 0 rgb(248 248 239 / 60%), 3px -3px 0 rgb(249 249 241 / 60%), -3px -3px 0 rgb(244 244 232 / 60%);
}
h2.h2_other {
    letter-spacing: 0.3em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_other.png);
    background-repeat: no-repeat;
    background-size: 135px;
    height: 93px;
    padding: 16px 0 0 0;
    text-shadow: 3px 3px 0 rgb(249 249 243 / 60%), -3px 3px 0 rgb(250 250 244 / 60%), 3px -3px 0 rgb(245 245 233 / 60%), -3px -3px 0 rgb(248 248 240 / 60%);
}
h2.h2_gate:after,h2.h2_fence:after,h2.h2_carport:after,h2.h2_deck:after,h2.h2_sunroom:after,h2.h2_terrace:after,h2.h2_other:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 100%;
    height: 12px;
    border-radius: 5px;
}
h2.h2_gate:after {
    background: -webkit-repeating-linear-gradient(-45deg, rgb(249 123 150), rgb(249 123 150) 2px, #f0e9da 4px, #f7f0e8 6px);
	background: repeating-linear-gradient(314deg, rgb(249 123 150), rgb(249 123 150) 2px, #f0e9da 4px, #f7f0e8 6px);
}
h2.h2_fence:after {
    background: -webkit-repeating-linear-gradient(-45deg, #76bceb, #76bceb 2px, #e6eee8 4px, #e6eee5 6px);
    background: repeating-linear-gradient(314deg, #76bceb, #76bceb 2px, #e6eee8 4px, #e6eee5 6px);
}
h2.h2_carport:after {
    background: -webkit-repeating-linear-gradient(-45deg, #8eefd2, #8ce7ca 2px, #e6f4e9 4px, #e2f0df 6px);
    background: repeating-linear-gradient(314deg, #8eefd2, #8ce7ca 2px, #e6f4e9 4px, #e2f0df 6px);
}
h2.h2_deck:after {
    background: -webkit-repeating-linear-gradient(-45deg, rgb(82 205 49), rgb(82 205 49) 2px, #e0edcf 4px, #ddeac7 6px);
    background: repeating-linear-gradient(314deg, rgb(82 205 49), rgb(82 205 49) 2px, #e0edcf 4px, #ddeac7 6px);
}
h2.h2_sunroom:after {
    background: -webkit-repeating-linear-gradient(-45deg, rgb(237 221 0 / 70%), rgb(237 221 0 / 70%) 2px, #ebebcd 4px, #f3f3de 6px);
	background: repeating-linear-gradient(314deg, rgb(237 221 0 / 70%), rgb(237 221 0 / 70%) 2px, #ebebcd 4px, #f3f3de 6px);
}
h2.h2_terrace:after {
    background: -webkit-repeating-linear-gradient(-45deg, #ff9c1f, #ff9c1f 2px, #f1ead1 4px, #f5eeda 6px);
	background: repeating-linear-gradient(314deg, #ff9c1f, #ff9c1f 2px, #f1ead1 4px, #f5eeda 6px);
}
h2.h2_other:after {
    background: -webkit-repeating-linear-gradient(-45deg, #ef5646, rgb(239 86 70 / 60%) 2px, #f6ece2 4px, #f4eade 6px);
    background: repeating-linear-gradient(314deg, #ef5646, rgb(239 86 70 / 60%) 2px, #f6ece2 4px, #f4eade 6px);
}

    padding: 16px 0 0 0;
    text-shadow: 3px 3px 0 rgb(249 249 243 / 60%), -3px 3px 0 rgb(250 250 244 / 60%), 3px -3px 0 rgb(245 245 233 / 60%), -3px -3px 0 rgb(248 248 240 / 60%);
}
h2#deck {
    letter-spacing: 0.3em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_deck.png);
    background-repeat: no-repeat;
    background-size: 120px;
    height: 94px;
    padding: 16px 0 0 0;
	text-shadow: 3px 3px 0 rgb(233 233 209 / 60%), -3px 3px 0 rgb(248 248 239 / 60%), 3px -3px 0 rgb(249 249 241 / 60%), -3px -3px 0 rgb(244 244 232 / 60%);
}
h2#sunroom {
    letter-spacing: 0.1em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_sunroom.png);
    background-repeat: no-repeat;
    background-size: 180px;
    height: 94px;
    padding: 16px 0 0 0;
    text-shadow: 3px 3px 0 rgb(249 249 243 / 60%), -3px 3px 0 rgb(250 250 244 / 60%), 3px -3px 0 rgb(245 245 233 / 60%), -3px -3px 0 rgb(248 248 240 / 60%);
}
h2#terrace {
    letter-spacing: 0.1em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_terrace.png);
    background-repeat: no-repeat;
	background-size: 170px;
    height: 93px;
    padding: 16px 0 0 0;
	text-shadow: 3px 3px 0 rgb(233 233 209 / 60%), -3px 3px 0 rgb(248 248 239 / 60%), 3px -3px 0 rgb(249 249 241 / 60%), -3px -3px 0 rgb(244 244 232 / 60%);
}
h2#other {
    letter-spacing: 0.3em;
    background-position: top center;
		background-position: 50% 50px;
    background-image: url(../images/campaignex_sub_h2_other.png);
    background-repeat: no-repeat;
    background-size: 135px;
    height: 93px;
    padding: 16px 0 0 0;
    text-shadow: 3px 3px 0 rgb(249 249 243 / 60%), -3px 3px 0 rgb(250 250 244 / 60%), 3px -3px 0 rgb(245 245 233 / 60%), -3px -3px 0 rgb(248 248 240 / 60%);
}
h2#gate:after,h2#fence:after,h2#carport:after,h2#deck:after,h2#sunroom:after,h2#terrace:after,h2#other:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 100%;
    height: 12px;
    border-radius: 5px;
}
h2#gate:after {
    background: -webkit-repeating-linear-gradient(-45deg, rgb(249 123 150), rgb(249 123 150) 2px, #f9f9f3 4px, #f9f9f1 6px);
	background: repeating-linear-gradient(314deg, rgb(249 123 150), rgb(249 123 150) 2px, #f9f9f3 4px, #f9f9f1 6px);
}
h2#fence:after {
    background: -webkit-repeating-linear-gradient(-45deg, #76bceb, #76bceb 2px, #f1f1e2 4px, #e9e9d1 6px);
    background: repeating-linear-gradient(314deg, #76bceb, #76bceb 2px, #f1f1e2 4px, #e9e9d1 6px);
}
h2#carport:after {
    background: -webkit-repeating-linear-gradient(-45deg, #8eefd2, #8ce7ca 2px, #f9f9f3 4px, #f9f9f1 6px);
    background: repeating-linear-gradient(314deg, #8eefd2, #8ce7ca 2px, #f9f9f3 4px, #f9f9f1 6px);
}
h2#deck:after {
    background: -webkit-repeating-linear-gradient(-45deg, rgb(82 205 49), rgb(82 205 49) 2px, #fbfbf5 4px, #f4f4e8 6px);
    background: repeating-linear-gradient(314deg, rgb(82 205 49), rgb(82 205 49) 2px, #fbfbf5 4px, #f4f4e8 6px);
}
h2#sunroom:after {
    background: -webkit-repeating-linear-gradient(-45deg, #e6f26e, #e6f26d 2px, #fbfbf5 4px, #f4f4e8 6px);
    background: repeating-linear-gradient(314deg, rgb(237 221 0 / 70%), rgb(237 221 0 / 70%) 2px, #fbfbf5 4px, #f4f4e8 6px);
}
h2#terrace:after {
    background: -webkit-repeating-linear-gradient(-45deg, #ff9c1f, #ff9c1f 2px, #f1f1e2 4px, #e9e9d1 6px);
	background: repeating-linear-gradient(314deg, #ff9c1f, #ff9c1f 2px, #f1f1e2 4px, #e9e9d1 6px);
}
h2#other:after {
    background: -webkit-repeating-linear-gradient(-45deg, #ef5646, rgb(239 86 70 / 60%) 2px, #f9f9f3 4px, #f9f9f1 6px);
    background: repeating-linear-gradient(314deg, #ef5646, rgb(239 86 70 / 60%) 2px, #f9f9f3 4px, #f9f9f1 6px);
}




ul.campex_products_ul {
    display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
    margin: 20px 0 0 0;
}
ul.campex_products_ul > li {
	display: flex;
    flex-direction: column;
    width: 48%;
    background: rgb(255 255 255 / 70%);
    margin: 0 1% 30px 1%;
    color: #333333;
	/*align-self: flex-start;*/
    border-radius: 3px;
    box-shadow: -3px 0px 5px 0px rgba(160, 160, 160, 0.15), 3px 0px 5px 0px rgba(160, 160, 160, 0.15), 0px -3px 5px 0px rgba(160, 160, 160, 0.15), 0px 3px 5px 0px rgba(160, 160, 160, 0.15);
    /* box-shadow: 0px 3px 5px 0px rgba(0, 0, 0, 0.15); */
}
ul.campex_products_ul > li a img:hover {
    opacity: 0.7;
}
ul.campex_products_ul > li a img {
/*aspect-ratio: 16 / 9;
    width: 100%;*/
	width: 100%;
	/*aspect-ratio: 16 / 9;
	object-fit: cover;*/
	aspect-ratio: 4 / 3;
	object-fit:contain;
}
.campex_products_txtarea {
    padding: 10px;
}
.products_name a {
    text-decoration: none;
    color: #000;
	transition:.4s;
}
.products_name a:hover {
    color: #1f7b0e;
	text-decoration:underline;
}
span.products_makername {
    font-size: 1.2em;
    font-weight: bold;
}
span.products_name {
    font-size: 1.4em;
    font-weight: bold;
}
.catch_area {
    overflow: hidden;
    width: 100%;
    max-height: 42px;
    min-height: 42px;
}
p.products_catchphrase {
    color: #118b27;
    line-height: 1.3em;
    margin: 5px 0 5px 0;
    font-weight: bold;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    padding: 0;
    margin: 5px 0;
    line-height: 1.3em;
}
p.products_specification {
    margin: 10px 0 5px 0;
    line-height: 1.0em;
}
p.products_sizearea {
    margin: 0px 0 10px 0;
    line-height: 1.0em;
}
ul.product_price_ul {
    display: flex;
    margin: 0 0 10px 0;
    justify-content: center;
}
ul.product_price_ul >li.product_price_li {
    margin: 0 20px 0 0;
}
.percentarea {
    width: 70px;
    height: 70px;
    border-radius: 50%;
    background: #f34e46;
    text-align: center;
    line-height: 100px;
    color: #fff;
    position: relative;
}
p.percent_number {
    position: absolute;
	left: -5%;
    top: 48%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 100px;
    text-align: center;
    font-size: 1.8em;
    letter-spacing: -0.03em;
    font-weight: bold;
	/*font-style: italic;*/
}
.balloon-right {
	position: relative;
    display: inline-block;
    /* margin: 1.5em 15px 1.5em 0; */
    padding: 0 5px;
    width: 90px;
    height: 90px;
    line-height: 90px;
    text-align: center;
    color: #FFF;
    font-size: 20px;
    font-weight: bold;
    border-radius: 50%;
    box-sizing: border-box;
}
.bal_gate{
    background: #f97b96;	
}
.bal_fence{
    background:#76bceb;
}
.bal_carport{
    background:#38c39a;
}
.bal_deck{
    background:#52cd31;
}
.bal_sunroom{
    background:#eddd00;
}
.bal_terrace{
    background:#ff9c1f;
}
.bal_other{
    background:#ef5646;
}
.balloon-right:before {
  content: "";
  position: absolute;
  top: 50%;
    right: -19px;
    margin-top: -10px;
    border: 9px solid transparent;
  z-index: 0;
}
.bal_gate:before {
  border-left: 15px solid #f97b96;
}
.bal_fence:before {
  border-left: 15px solid #76bceb;
}
.bal_carport:before {
  border-left: 15px solid #38c39a;
}
.bal_deck:before {
  border-left: 15px solid #52cd31;
}
.bal_sunroom:before {
  border-left: 15px solid #eddd00;
}
.bal_terrace:before {
  border-left: 15px solid #ff9c1f;
}
.bal_other:before {
  border-left: 15px solid #ef5646;
}
span.percent_txt {
	font-weight:normal;
    font-size: 0.4em;
    font-style: italic;
}
p.off_txt {
    font-style: italic;
    position: absolute;
    left: 32%;
    top: 25%;
    font-weight: normal;
    font-size: 0.8em;
}
p.teika {
    margin: 15px 0 10px 0;
}
p.campaign_price {
    font-size: 2.5em;
    font-weight: bold;
    margin: 10px 0 0 0;
    line-height: 60%;
}
/*.price_gate{
    color: #f97b96;	
}
.price_fence{
    color:#76bceb;
}
.price_carport{
    color:#38c39a;
}
.price_deck{
    color:#52cd31;
}
.price_sunroom{
    color:#eddd00;
}
.price_terrace{
    color:#ff9c1f;
}
.price_other{
    color:#ef5646;
}*/
.price_gate,.price_fence,.price_carport,.price_deck,.price_sunroom,.price_terrace,.price_other{
    /*color: #ef5646;	
    color: #555;*/
	color: #ff0000;
}

span.en {
    font-size: 0.7em;
}
span.zeikomi {
    font-size: 0.5em;
    color: #000;
    font-weight: normal;
}
/*p.campaign_price:before{
	content: "";
	display: inline-block;
	width: 27px;
	height: 19px;
	background-image: url(../images/campex_price_arrow.png);
	background-size: contain;
    margin: 0 5px 0 0;
}*/

.maker_btnarea {
    margin: auto auto 20px;
    text-align: center;
    width: 90%;
}
a.maker_btn {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    padding: .2em 1em;
    border: none;
    border-radius: 5px;
    background-color: #b3b3b3;
    color: #fff;
    font-size: 1em;
    text-decoration: none;
    transition: .4s;
	line-height:175%;
}
a.maker_btn:after {
    transform: rotate(45deg);
    width: 5px;
    height: 5px;
    margin-left: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    content: '';
    transition: .4s;
}
a.maker_btn:hover {
    background-color: #34783e;
    color: #fff;
}
a.maker_btn:hover:after {
    border-top: 1px solid #ffffff;
    border-right: 1px solid #ffffff;
}


/*** Footer ***/
.f_left {
    float: left;
}
.f_right {
    float: right;
}
.footer_comparea {
    text-align: left;
}
#footer_wrap {
    padding: 30px 0px;
    background: url(../images/footer_bg.png) repeat center left;
	text-align: left;
}
#footer_wrap a{
	color:#3c1c12;
}
#footer_wrap a:hover{
	color:#7fb345;
}
#footer_wrapinner div.tel{
	display: inline;
	margin-left: 10px;
}
#footer_wrapinner dl.address{
	margin-top: 10px;
	font-size: 13px;
}
#footer_wrapinner dl.address dt{
	padding-left: 15px;
	background: url(../images/circle_brown.png) no-repeat center left;
}
#footer_wrapinner dl.address dd{
	margin-left: 15px;
	margin-bottom: 10px;
}
#footer_wrapinner div.f_left{
	padding-right: 30px;
	border-right: 1px solid #dbb69b;
}
ul.f_navi{
	float: left;
	margin-right: 20px
}
ul.f_navi li{
	margin-bottom: 10px;
	font-size: 12px;
}
ul.f_navi li a{
	padding-left: 20px;
	background: url(../images/point_cross_brown.png) no-repeat center left;
}
ul.f_navi li ul{
	margin-top: 5px;
	margin-left: 20px;
}
ul.f_navi li ul li a{
	padding-left: 10px;
	background: url(../images/arrow_brown_s.png) no-repeat center left;
}

#footer_bottom_wrap{
	padding: 10px 0px;
	color:#FFF;
	background: url(../images/header_bg.jpg) repeat center left;
}
#footer_bottom ul li{
	float: left;
	margin-right: 20px;
}
#footer_bottom ul li a{
	color: #FFF;
	font-size: 11px;
	padding-left: 15px;
	background: url(../images/arrow_green.png) no-repeat center left;
}
#footer_bottom p#copy{
	font-size: 10px;
}
#footer_bottom p#copy a{
	color: #FFF;
}

/*** 404 ***/
.sec_post_ttl {
    padding: 50px 0 30px 0px;
}
h2.top_h2_02 {
    font-family: 'Noto Sans JP', serif;
    color: #fff;
    font-size: 1.5em;
    font-weight: bold;
    letter-spacing: 0.2em;
    margin: 0px auto 0px;
    padding: 20px;
    background: rgb(31 123 14 / 80%);
    background: -webkit-repeating-linear-gradient(-45deg, rgb(31 123 14 / 80%), rgb(31 123 14 / 80%) 4px, rgb(46 139 24 / 80%) 3px, rgb(46 139 24 / 80%) 8px);
    background: repeating-linear-gradient(-45deg, rgb(31 123 14 / 80%), rgb(31 123 14 / 80%) 4px, rgb(46 139 24 / 80%) 3px, rgb(46 139 24 / 80%) 8px);
    border-radius: 5px;
}






