@charset "UTF-8";

/*--------------------------------------------------------------------
 *	共通の記述
 *--------------------------------------------------------------------*/
body {
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
}
body .ttl_en,
#home #area_01 .part_num span {
    font-family: Avenir, 'Helvetica neue', Helvetica, '游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
}
header {
  position: relative;
  width: 100%;
  z-index: 1000;
  font-weight: 550;
}
header .wrap,
footer .wrap {
	background-color: #006837;
	color: #fff;
}
main {
	color: #333;
}
.f_green {
    color: #006837;
}
.f_white {
	color: #fff;
}
a {
	text-decoration: none;
	color: #fff;
}
a:hover {
    opacity: 0.8;
}
li {
	list-style: none;
}
.rounded {
    border-radius: 20px;
}
.bg_gray {
    background-color: #e6e6e6;
}
.bg_white {
	background-color: #fff;
}
.f_bold {
	font-weight: bold;
}

/*--------------------------------------------------------------------
 *	768px未満用（SP用）の記述
 *--------------------------------------------------------------------*/
@media screen and (max-width: 768px) {

.visible_sp {
	display: block !important;
}
.visible_pc {
	display: none !important;
}

.tel a {
    pointer-events: auto;  /* クリック可能 */
    cursor: pointer;
}


/* ◆ Header */
header #hd_area #logo {
	margin: 2% auto 2% 3%;
	width: 100%;
}
header #hd_area .hd_link {
	display: none;
}
header #hd_area {
	display: flex;
}
header #hd_area .hd_contact {
	width: 35%;
	margin: 3.2% auto 0 10%;
	text-align: center;
	font-size: 2vw;
	line-height: 1.3;
}
/* ---------------------------ハンバーガーメニュー START ----------------------------*/
.hamburger-menu {
    position: relative;                 /* bar の親に指定 */
	width: 5vw;                        /* ボタンサイズ */
    height: 2vh;                       /* ボタンサイズ */
    border: none;
	margin: 55% 2vw 0 0;
	padding: 0;
    background: transparent;
	cursor: pointer;
}
.hamburger-menu__bar {                  /* span */
	display: inline-block;
	position: absolute;
	width: 5vw;                        /* bar の長さ */
    height: 1.5px;                      /* bar の太さ */
    left: 50%;
	background-color: #fff;
    transform: translateX(-50%);
    transition: .5s;                    /* 三 → × に変わるスピード */
}
.hamburger-menu__bar:first-child {      /* bar の位置 */
    top: 0;
}
.hamburger-menu__bar:nth-child(2) {
    top: 10px;
}
.hamburger-menu__bar:last-child {
    top: 20px;
}
.hamburger-menu::after{                 /* bar 下部に文字入れ 開く前はMENU */
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    content: '';
    color: #fff;
}
.hamburger-menu--open .hamburger-menu__bar {                    /* button のbar用span */
    top: 55%;                                                   /* ×の上からの位置 */
}
.hamburger-menu--open .hamburger-menu__bar:first-child {        /* bar 1本目を×の要素に */
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
}
.hamburger-menu--open .hamburger-menu__bar:last-child {         /* bar 3本目を×の要素に */
    transform: translateX(-50%) translateY(-50%) rotate(-45deg);
}
.hamburger-menu--open .hamburger-menu__bar:nth-child(2) {       /* bar 2本目を非表示に */
    display: none;
}
.hamburger-menu--open::after{                     /* bar 下部に文字入れ 開いたときはCLOSE */
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    content: '';
    text-align: center;
    color: #fff;
}
header #hd_area .navigation  {                   /* 開いたハンバーガーの中身 */
    display: none;
    position: absolute;
	background-color: #e6e6e6;
    width: 100%;
    height: 48vw;                              /* 画面いっぱいにハンバーガーメニュー背景広げる */
	max-height: 270px;
	left: 0;
    z-index: 9999;
}
.navigation__list {
    text-align: center;
    list-style: none;
    padding: 2% 10%;
    margin: 0;
}
.navigation__list-item {
    border-bottom: solid 1px #006837;                   /* 開いたハンバーガーの中身 区切線*/
}
.navigation__link {                                       /* 開いたハンバーガーの中身 装飾 */
    text-decoration: none;
    display: block;
    padding: 10px 0;
    transition: .5s;
	color: #006837;
	font-size: 2.4vw;
	line-height: 1.5;
}
/* ---------------------------- ハンバーガーメニュー END -----------------------------*/


/* ◆ Footer */
footer .ft_contents {
	width: 80%;
	margin: 0 auto;
	padding: 10% 0 5%;
	font-size: 2.7vw;
	text-align: right;
	letter-spacing: 0.1vw;
}
footer .ft_contents img {
	width: 69.5%;
}
footer #copyright {
	margin-top: 2%;
}


/* 768px未満用（SP用）の記述 end -------------------------------------*/
}


/*--------------------------------------------------------------------
 *	768px以上用（PC用）の記述
 *--------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {

.visible_pc {
	display: block !important;
}
.visible_sp {
	display: none !important;
}

.tel a {
    pointer-events: none;  /* クリックできなくする */
    cursor: default;       /* カーソルも通常に */
    color: inherit;        /* 見た目はそのまま */
    text-decoration: none; /* 下線も消すなら */
}



header,
footer {
	width: 100%;
}
header #hd_area,
footer #ft_area {
	width: 100%;
	max-width: 1400px;
	min-width: 1200px;
	margin: 0 auto;
}
main {
	width: 100%;
    max-width: 1400px;
    min-width: 1200px;
	margin: 0 auto;
}


/* ◆ Header */
header .ham_menu {
	display: none;
}
header #hd_area {
	display: flex;
}
header #logo {
	margin: 1.5% 0 1.5% 1.5%;
}
header #logo img {
	width: 412px;
}
header #hd_area ul {
	display: flex;
	width: 48%;
	margin: 1.6% 6% 0 auto;
}
header #hd_area li {
	width: 25%;
	text-align: center;
	font-size: 18px;
	line-height: 1.3;
}
header #hd_area li small {
	font-size: 14px;
}

/* ◆ Footer */
footer #ft_area {
	display: flex;
}
footer .ft_link {
	width: 70%;
	padding-top: 3%;
	padding-left: 7.14%;
	font-size: 20px;
}
footer .ft_link ul {
	display: flex;
	margin: 0 auto 2% 0;
}
footer .ft_link li {
	width: 33%;
}
footer .ft_link .link_up li:first-child {
	width: 25%;
}
footer .ft_link .link_btm {
	padding-left: 25%;
}
footer .ft_link .link_btm li {
	width: 44%;
}
footer .ft_contents {
	width: 86%;
	margin: 0 auto;
	padding: 2.57% 7.14% 0 0;
	font-size: 18px;
	text-align: right;
}
footer .ft_contents img {
	width: 419px;
}


/* 768px以上用（PC用）の記述 end -------------------------------------*/
}

/* 1399px以下用（PC用）のフォントサイズ記述 ------------------------------------------- */
@media screen and (min-width:768px) and (max-width:1399px) {

/* ◆ Header */
header #hd_area li {
	font-size: 1.285714286vw;
}
header #hd_area li small {
	font-size: 1vw;
}
header #logo img {
	width: 29.42857143vw;
}

/* ◆ Footer */
footer .ft_link {
	font-size: 1.428571429vw;
}
footer .ft_contents {
	font-size: 1.285714286vw;
}
footer .ft_contents img {
	width: 29.92857143vw;
}

    
/* 1399px以下用（PC用）のフォントサイズ記述 end --------------------------------------- */
}


/* 1199px以下用（PC用）のフォントサイズ記述 ------------------------------------------- */
@media screen and (min-width:768px) and ( max-width:1199px) {

/* ◆ Header */
header #hd_area li {
	font-size: 15.42857143px;
}
header #hd_area li small {
	font-size: 12px;
}
header #logo img {
	width: 353.1428571px;
}

/* ◆ Footer */
footer .ft_link {
	font-size: 17.14285714px;
}
footer .ft_contents {
	font-size: 15.42857143px;
}
footer .ft_contents img {
	width: 359.1428571px;
}

/* 1199px以下用（PC用）のフォントサイズ記述 end--------------------------------------- */
}
