﻿/*--------------------------------------------
 色 ・　文字
----------------------------------------------*/
:root{
    --color1: #222;
    --color2: #f9f9f9;
    --color3: #104E32;
    --color4: #104E32;
	--text: #111111;
    --base: #ffffff;
    
    --font1: 16px;
    --fontB1: 32px;
    --font-jp: 'Noto Sans JP', "游ゴシック Medium", sans-serif;
}
/* スマホ */
@media screen and (max-width: 667px){
    :root{
        --fontB1: 22px;
    }
}


/* --------------------------------------------
 リンクボタン 
---------------------------------------------*/
.linkStyle,a{
	color: var(--color1);
	text-decoration: underline;
	transition: all 0.5s;
}
a{
    text-decoration: none;
}
.linkStyle:hover,a:hover{
	opacity: 0.7;
	text-decoration: none;
}
/*
.cate_list li a,#page10 ul li a,.more a{
    background-color: var(--color1);
    color: var(--base);
    font-weight: bold;
    padding: 10px 20px;
    transition: all 0.8s;
}
#page10 ul li a{
    padding-top: 15px;
    padding-bottom: 15px;
}
.cate_list li a:hover,#page10 ul li a:hover,.more a:hover{
    background-color:var(--color3);
    opacity: 0.7;
}*/


/*--------------------------------------------
 色 ・　文字
----------------------------------------------*/
html,body,.font_10,.font_11,.font_12,.font_13,.font_14,.font_15{font-size: var(--font1);}
.font_2up{font-size: max(calc(var(--font1) + 2px), calc(1rem  + 2px));}
.font_4up{font-size: max(calc(var(--font1) + 4px), calc(1rem  + 4px));}
.font_2dw{font-size: max(calc(var(--font1) - 2px), calc(1rem  - 2px));}
.font_4dw{font-size: max(calc(var(--font1) - 4px), calc(1rem  - 4px));}
.font_6dw{font-size: max(calc(var(--font1) - 6px), calc(1rem  - 6px));}




/* color */
body, .txt_color_nomal, .hvr_txt_color_nomal:hover{color: var(--text);}
.linkStyle{transition: 0.5s;color: var(--text)}
.linkStyle:hover{opacity: 0.7}

.txt_white, .hvr_txt_white:hover{color: white;}
.txt_red, .hvr_txt_red:hover{color: var(--red);}
.txt_color1, .hvr_txt_color1:hover{color: var(--color1)} /* メインカラー */
.txt_color2, .hvr_txt_color2:hover{color: var(--color2)} /* サブカラー */
.txt_color3, .hvr_txt_color3:hover{color: var(--color3)} /* アクセントカラー1 */
.txt_color4, .hvr_txt_color4:hover{color: var(--color4)} /* アクセントカラー2 */

/* background-color */
.bg_white, .hvr_bg_white:hover{background-color: white} /* 白背景 */
.bg_black, .hvr_bg_black:hover{background-color: var(--black)} /* 黒背景 */
.bg_color1, .hvr_bg_color1:hover{background-color: var(--color1)} /* メインカラー */
.bg_color2, .hvr_bg_color2:hover{background-color: var(--color2)} /* サブカラー */
.bg_color3, .hvr_bg_color3:hover{background-color: var(--color3)} /* アクセントカラー1 */
.bg_color4, .hvr_bg_color4:hover{background-color: var(--color4)} /* アクセントカラー2 */
.bg_color_clear, .hvr_bg_color_clear:hover{background-color: transparent!important}


/* border-color ※!important */
.border_white, .hvr_border_white:hover{border-color: white}
.border_black, .hvr_border_black:hover{border-color: var(--black)}
.border_color1, .hvr_border_color1:hover{border-color: var(--color1)}
.border_color2, .hvr_border_color2:hover{border-color: var(--color2)}
.border_color3, .hvr_border_color3:hover{border-color: var(--color3)}
.border_color4, .hvr_border_color4:hover{border-color: var(--color4)}

/*****************************************************/
.intro_title .txt_vertical {
    -webkit-writing-mode: unset;
    -ms-writing-mode: tb-rl;
    writing-mode: unset;
}
.top_header .sns_links ul li a {
    background-color: #000;
}
.logo .width_300-max {
    width: 100%;
    max-width: 150px;
}
.catch2 {
    font-size: 20px;
}
/*************************************************/
#top_gallery .cate_box:nth-of-type(1) {
    grid-area: 1 / 1 / 2 / 2;
    position: relative;
    overflow: hidden;
}
#top_gallery .cate_box:nth-of-type(1):after {
    content: "";
  display: block;
  width: 30px;
  height: 100%;
  position: absolute;
  top: -180px;
  left: 0;
  background-color: #FFF;
  opacity: 0;
  transform: rotate(45deg);
  animation: reflect 4s ease-in-out infinite;
  -webkit-transform: rotate(45deg);
  -webkit-animation: reflect 4s ease-in-out infinite;
}
@keyframes reflect {
  0% { transform: scale(0) rotate(45deg); opacity: 0; }
  80% { transform: scale(0) rotate(45deg); opacity: 0.5; }
  81% { transform: scale(4) rotate(45deg); opacity: 1; }
  100% { transform: scale(50) rotate(45deg); opacity: 0; }
}
@-webkit-keyframes reflect {
  0% { transform: scale(0) rotate(45deg); opacity: 0; }
  80% { transform: scale(0) rotate(45deg); opacity: 0.5; }
  81% { transform: scale(4) rotate(45deg); opacity: 1; }
  100% { transform: scale(50) rotate(45deg); opacity: 0; }
}
/******************************************************/

.heading02 {
	position: relative;
	border-bottom: 3px solid #f9f9f9;
}

.heading02::after {
	content: '';
	position: absolute;
	bottom: -3px;
	left: 50%;
	transform: translateX(-50%);
	width: 70px;
	height: 3px;
	background-color: #104e32;
}

#top_contents .con_no {
  position: relative;
}
#top_contents .con_no:after {
  content: "";
  position: absolute;
  border: 1px solid #104e32;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  top: 50%;
  /* border: dashed 1px white; */
  left: -15px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  z-index: 0;
}
.bg_color1, .hvr_bg_color1:hover {
    background-color: var(--color3);
}
.linkStyle {
    color: #03a55c;
}
#header {
    /*background-color: var(--color1);*/
    padding: 30px;
}
#header .width_200-max {
    max-width: 150px;
}
#top_cms .more_h::before {
    mix-blend-mode: unset;
}
.line_box .line {
    width: 500px;
}
/* タブレット */
@media screen and (max-width: 768px){
#page10 .grid_4 .title2 {
    font-size: 12px;
}
#top_contents .letter_5 {
    letter-spacing: 4px;
}
#menu_wrap .sns_links {
    background-color: #c3c3c3;
}
#menu_wrap ul li {
        margin-bottom: 15px;
        margin-top: 15px;
    }
    main {
    border-bottom: 1px solid #f9f9f9;
}
}
/* スマホ */
@media screen and (max-width: 667px){
#header .width_200-max {
    max-width: 90px;
}
.fv_box .catch {
    font-size: 16px;
}
.catch2 {
    font-size: 15px;
}
#top_contents .con_no:after {
    display: none;
}
    #top_contents .con_title {
        font-size: -webkit-calc(1rem + 3px);
        font-size: calc(1rem + 3px);
    }
    #top_gallery .cate_box:nth-of-type(1) {
    grid-area: 1 / 1 / 2 / 3;
}
#loader .logo {
    max-width: 150px;
}
.pager li {
    margin-right: 0px !important;
}
#cms_2-a .cate_title {
    padding: 0 2%;
}
.line_box .line {
    width: 300px;
}
}


