@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;}
.sp700_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(2 88 17 / 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/campex_mainvisual_bg.png);
    height: 396px;
}
.mv_ttl img {
    margin-top: 54px;
}

/*** contentエリア ***/
.campex_content {
	padding: 0 0 50px 0;
    background: #FFF url(../images/campex_contentbg.png) repeat top left;
}
.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  ***/
.campex_prevbox {
	border: 7px solid #b3cfac;
    padding: 15px;
    text-align: center;
    background: rgb(220 229 217 / 40%);
}
p.prev_txt {
    margin: 0 0 1.0em 0;
}
p.prev_txt02 {
    margin: 0 0 20px 0;
    font-size: 1.1em;
    font-weight: bold;
  font-family: "Noto Sans JP", sans-serif;
}
ul.prevbox_company_ul {
    margin: 0 auto;
    text-align: center;
    display: flex;
    justify-content: center;
	align-items: center;
  font-family: "Noto Sans JP", 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 {
    background-color: rgb(2 88 17 / 70%);
    color: #ffffff;
    border-radius: 20px;
    margin: 0 0 20px 0 !important;
    font-size: 1.2em;
    font-weight: bold;
    display: inline-block;
    padding: 5px 20px 7px;
    letter-spacing: 0.08em;
  font-family: "Noto Sans JP", sans-serif;
}
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: "Noto Sans JP", sans-serif;
    font-size: 1.2em;
    letter-spacing: 0.1em;
    color: #025811;
    font-weight: 700;
    outline: 2px solid #025811;
    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;
}
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;
}
/*** 商品 紹介エリア ***/
.campex_h2 {
    font-family: 'Noto Sans JP', serif;
    color: #fff;
    font-size: 1.5em;
    font-weight: bold;
    letter-spacing: 0.2em;
    margin: 70px auto 30px;
    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;
}

ul.campex_products_ul {
    display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
    margin: 20px 0 0 0;
}
ul.campex_products_ul > li {
    width: 48%;
    background: rgb(255 255 255 / 70%);
    margin: 0 1% 30px 1%;
    color: #333333;
    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 {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}
.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.2em;
    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 0 0;
    line-height: 1.2em;
}
p.products_sizearea {
    margin: 0px 0 10px 0;
    line-height: 1.2em;
}
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: #da4308;
    text-align: center;
    line-height: 100px;
    color: #fff;
    position: relative;
}
p.percent_number {
    position: absolute;
    left: -18%;
    top: 47%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 100px;
    text-align: center;
    font-size: 2.0em;
    letter-spacing: -0.03em;
    font-weight: bold;
}
span.percent_txt {
	font-weight:normal;
    font-size: 0.6em;
    font-style: italic;
}
p.off_txt {
    font-style: italic;
}
p.campaign_price {
    color: #da4308;
    font-size: 2.0em;
    font-weight: bold;
    margin: 10px 0 0 0;
line-height: 60%;
}
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;
    /*vertical-align: top;*/
    margin: 0 5px 0 0;

}

.maker_btnarea {
    margin: 0 auto;
    text-align: center;
}
a.maker_btn {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    padding: .2em 1em;
    border: none;
    border-radius: 5px;
    background-color: #d4d4d4;
    color: #181818;
    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 #181818;
    border-right: 1px solid #181818;
    content: '';
    transition: .4s;
}
a.maker_btn:hover {
    background-color: #118b27;
    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;
}



