@charset "utf-8";

/* ===========================================
リセットcss
=========================================== */

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  background-color: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

input, select {
  vertical-align: middle;
}


/* ===========================================
初期設定
=========================================== */


/* ===========================================
【英数字の折り返し設定】
パンくず、大見出し、画像キャプション、a08_リンク、a05_ファイルダウンロード（PDF等）、ローカルナビは
word-break:break-all;を設定してるため、英単語が途中で折り返す
=========================================== */

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  width: 100%;
  height: auto;
  word-wrap: break-word;
  overflow-wrap: anywhere;
  /* IE11用 */
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 62.5%;
}

body {
  width: 100%;
  color: #000;
  background-color: #FFF;
  line-height: 1.75;
  font-size: 1.6rem;
  font-weight: 400;
  -webkit-text-size-adjust: 100%;
}


/* フォーム部分のフォント指定 */

button, input, select, textarea {
  font-family: inherit;
  color: #000;
}


/* フォント指定 */

body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", 'メイリオ', sans-serif;
}


/* ===========================================
CMSスタイル
=========================================== */


/* html5用 */

article, aside, footer, header, hgroup, main, nav, section {
  display: block;
}


/* スタイルリセット
============================== */


/* iOSでのデフォルトスタイルをリセット */

input[type="submit"], input[type="button"], input[type="reset"] {
  border-radius: 0;
  border: none;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  cursor: pointer;

}

input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration {
  display: none;
}

input[type="submit"]:focus, input[type="button"]:focus {
  outline-offset: -2px;
}

input.fedbt, input[type="button"], input[type="text"], input[type="submit"] {
  border-radius: 0;
}


/* プレースホルダー文字色 */

:-moz-placeholder-shown {
  color: #6F6F6F;
}

:-ms-input-placeholder {
  color: #6F6F6F;
}

:placeholder-shown {
  color: #6F6F6F;
}


/* Google Chrome, Safari, Opera 15+, Android, iOS */

::-webkit-input-placeholder {
  color: #6F6F6F;
}


/* Firefox 18- */

:-moz-placeholder {
  color: #6F6F6F;
  opacity: 1;
}


/* Firefox 19+ */

::-moz-placeholder {
  color: #6F6F6F;
  opacity: 1;
}


/* IE 10+ */

:-ms-input-placeholder {
  color: #6F6F6F;
}

a[href], label[for], input[type="button"], input[type="submit"], input[type="reset"], input[type="image"], input[type="radio"], input[type="checkbox"], select {
  cursor: pointer;
}

button {
  cursor: pointer;
  padding: 0;
  margin: 0;
  border: none;
  background: none;
}

fieldset {
  border: none;
}

address {
  font-style: normal;
}

a img {
  vertical-align: bottom;
}
p {
    /* padding-bottom: .85em; */
    padding-top: 0.85em;
    padding-right: .85em;
  }

/*  通常のリンク色  */

a:link {
  color: #1b2d6c;
  text-decoration: underline;
}

a:visited {
  color: #880088;
  text-decoration: underline;
}

a:active {
  color: #CC0000;
  background-color: transparent;
}

a:hover, a:focus {
  color: #0066CB;
  background-color: transparent;
  text-decoration: underline;
}


a:hover {
  text-decoration: underline;
}

/* 大見出し */
h1#header_logo::before,
h1.logo::before{
    content: none;
}
h1.logo{
    margin: 0;
    /* padding: 0; */
}
h1 {
    margin: 55px 0 26px 0;
    padding: 0 0 15px 0;
    font-size: 3.4rem;
    font-weight: bold;
    position: relative;
    line-height: 1.3;
    position: relative;
}

h1::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 4px;
    background-color: #43843f;
    position: absolute;
    top: 100%;
    left: 0;
}

h2 {
    font-size: 3.0rem;
    margin: 1.2em 0 0.8em 0;
    padding: 0;
    position: relative;
}
h2.contitle {
  position: relative;
}

h2::before {
  content: "";
  background: #CCD9D4;
  width: 100%;
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  position: absolute;
  top: 100%;
  left: 0;
}
h2::after {
  content: "";
  width: 160px;
  background: #43843f;
  display: block;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  }



/* テーブル */
table {
	padding: 0;
	border-collapse: collapse;
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
    background-color: #FFF;
    width: 100%;
    margin: 1.2em 0 0.8em 0;
}
table th {
    padding: 6px 4px;
    border-bottom: 1px solid #CCCCCC;
    /* background-color: #EEF8F7; */
    text-align: left;
    width: 10em;
}
table td {
    padding: 6px 4px;
    border-bottom: 1px solid #CCCCCC;
    background-color: #fff;
  }

/* 注釈 */
p.kome {
  position: relative;
  padding-left: 2em;
}
p.kome::before {
  content: "＊";
  font-size: 1.8em;
  color: #880011;
  position: absolute;
  top: 0.1em;
  left: 0;
}
/* ===============================================
topページ
================================================= */
p.main_img_wp {
  padding: 0;
}
img.main_img {
  display: block;
  /* width: 100% !important; */
  /* height: auto !important; */
  max-width: 100%;
  margin: 0 auto;
  width: 100%;
  height: 400px;
  object-fit: cover;
}
p.top_con02_text {
  font-size: 2.3rem;
  font-weight: bold;
}
p.top_con02_btn a {
  display: block;
  padding: 20px 25px 20px 30px;
  background-size: 50px;
  background-repeat: no-repeat;
  width: 250px;
  background-color: #274a27;
  font-size: 1.8rem;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  background-position: 5px 10px;
}
/* 矢印 */
.dli-arrow-right {
  display: inline-block;
  vertical-align: middle;
  color: #fff;
  line-height: 1;
  position: relative;
  width: 1em;
  height: 0.1em;
  background: currentColor;
}

.dli-arrow-right::before {
  content: '';
  width: 0.65em;
  height: 0.65em;
  border: 0.1em solid currentColor;
  border-left: 0;
  border-bottom: 0;
  transform: rotate(45deg);
  transform-origin: top right;
  position: absolute;
  top: 50%;
  right: -0.05em;
  box-sizing: border-box;
}

.kyousan_con li {
  background: none;
  /* margin: 0 27px 12px 0; */
  text-align: center;
  border: 1px solid #ccc;
  display: flex;
  align-items: center;
  width: calc(100% / 3 - 7px);
  justify-content: center;
}

.kyousan_con {
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  list-style: none;
  gap: 10px;
}
ul.kyousan_con img {
    max-width: 100%;
}
.kyousan_con li a {
  padding: 10px 20px;
}
/* 打ち消し線 */
.strikethrough {
  text-decoration: line-through;
  color: #a0a0a0;
}
/* ===============================================
プロフィールページ
================================================= */
.profile_con {
  margin: 55px 0 26px 0;
}
/* ===============================================
お問い合わせページ
================================================= */
span.tel_text {
  padding-left: 50px;
  font-size: 3.0rem;
  font-weight: bold;
}
p.line_link a {
  display: block;
  padding: 20px 25px 20px 55px;
  background-image: url(/images/LINE_Brand_icon.png);
  background-size: 50px;
  background-repeat: no-repeat;
  width: 250px;
  background-color: #07c856;
  font-size: 1.8rem;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  background-position: 5px 10px;
}

.map {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  /* 16:9のアスペクト比 */
  height: 0;
}

.map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.dli-mail {
  display: inline-block;
  vertical-align: middle;
  color: #333;
  line-height: 1;
  position: relative;
  width: 1.06667em;
  height: 0.8em;
  border: 0.1em solid currentColor;
  border-radius: 0.1em;
  box-sizing: content-box;
  overflow: hidden;
}

.dli-mail::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  width: 0.75425em;
  height: 0.75425em;
  border: 0.1em solid currentColor;
  border-top-color: transparent;
  border-right-color: transparent;
  border-radius: 0 0 0 0.1em;
  box-sizing: content-box;
  transform: translate(-50%, -50%) rotate(-45deg) skew(10deg, 10deg);
}
.mail_text{
  font-size: 3.0rem;
}
/* ===============================================
フッター
================================================= */
.footer_in {
  border-top: 1px solid #43843f;
  border-bottom: 1px solid #43843f;
}

.f0copy {
  background-color: #264b24;
  color: #fff;
  text-align: center;
  padding-bottom: .85em;
}
ul.fotter_li {
  padding-bottom: .85em;
  list-style-type: none;
  list-style-image: none;
}



ul.fotter_li a{
  position: relative;
  padding-left: 1.5em;
}
ul.fotter_li a::before {
  -webkit-transform: translateY(-50%) rotate(45deg);
  -ms-transform: translateY(-50%) rotate(45deg);
  transform: translateY(-50%) rotate(45deg);
  border-color: #264b24;
  border-style: solid;
  border-width: 2px 2px 0 0;
  content: "";
  display: block;
  height: 6px;
  position: absolute;
  left: 0;
  top: 50%;
  width: 6px;
  -webkit-transition: all .2s;
  -o-transition: all .2s;
  transition: all .2s;
}

ul.fotter_li a:hover::before {
  left: 3px;
}
/* ===============================================
Instagram埋め込み
================================================= */
.insta_list{
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 20px 0;
  list-style: none;
}

.insta_list li{
  position: relative;
  width: calc((100% - 40px)/3);
}

@media screen and (max-width: 750px){
  .insta_list li{
      width: calc((100% - 20px)/2);
  }
}

.insta_list li::before{
content: "";
display: block;
padding-top: 100%;
}

.insta_list a{
position: absolute;
top: 0;
width: 100%;
height: 100%;
}

.insta_list img{
width: 100%;
height: 100%;
object-fit: cover;
}

.insta_btn{
  background-color: #000;
  padding: .5em 1em;
  width: fit-content;
  margin: 0 auto;
  cursor: pointer;
  transition: .3s
}

.insta_btn a{
  color: #fff;
  text-decoration: none;
}

.insta_btn:hover{
  background-color: #999;
}