@charset "UTF-8";

/*
  ¤¯¤¹¤Î¤­»á¥Û©`¥à¥Ú©`¥¸
  
  -since 2025.04.01
  -author ŽÚˆóßBÐ¯ÊÒ
---------------------------------------------- */
html,
body {
  color: #333;
}

* {
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}

a {
  text-decoration: none;
}

.txt {
  font-size: 15px !important;
}

header {
  height: 60px;
}

#wrapper {
  padding: 0;
}

/*-------- .contents --------*/
.contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  width: 100%;
  margin: 0 auto;
  padding-top: 0;
}

/*---- .inner ----*/
.inner {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
}

#wrapper.narrow .inner {
  padding: 0 0 20px;
}

.inner section {
  width: 100%;
  margin: 0 auto 50px 0;
  padding: 10px 20px;
  border-bottom: 0;
}

#wrapper.narrow .inner section {
  width: 100%;
  padding: 20px 10px 50px 50px;
}

section:hover {
  background-color: transparent;
}

/* ÒŠ³ö¤· */
.inner section .sst01 {
  margin-left: -8px;
  padding: .5em 0 .5em .8em;
}



/*--- main_img ---*/
.main_img {
  position: relative;
  width: 100%;
  height: 300px;
  background-image: url('/kusunoki/img/main_img.jpg');
  background-position: center bottom;
  background-size: cover;
  background-repeat: no-repeat;
}

.main_img img {
  width: 100%;
}

.main_img h1 {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 49%;
  font-size: 3rem;
  text-align: center;
  transform: translate(-50%, -50%);
  text-shadow: 3px 3px 2px #FFF, -3px 3px 2px #FFF, -3px -3px 2px #fff, 3px -3px 2px #fff;
}

.main_img h1 span {
  display: block;
  margin-top: 20px;
  font-size: 20px;
  text-indent: 1em;
  text-shadow: 2px 2px 1px #FFF, -2px 2px 1px #FFF, -2px -2px 1px #fff, 2px -2px 1px #fff;
}

/* ----------- .nav_box_sp ----------- */
.nav_box {
  display: none;
}
.nav_box_sp {
  position: fixed;
  display: block;
  top: auto;
  left: 0px;
  bottom: 0;
  width: 100%;
  min-width: none;
  height: 36px;
  padding: 0;
  z-index: 100;
  background: #c1b091;
}

.nav_box_sp button{
  position: relative;
  width: 100%;
  height: 100%;
  padding: 8px 0;
  color: #716246;
  font-size: 14px;
  font-weight: bold;
  border: 0;
  background: transparent;
  cursor: pointer;
  z-index: 199;
}

#wrapper.narrow .nav_box_sp {
  z-index: 1;
}

.nav_box_sp .kusunoki_nav {
  position: absolute;
  display: none;
  transition: .5s all;
}

.nav_box_sp .kusunoki_nav.open_menu {
  position: absolute;
  display: block;
  width: 100%;
  height: auto;
  padding: 16px 0;
  bottom: 36px;
  background: #716246;
}

.nav_box_sp .kusunoki_nav.open_menu li{
  padding: 2px 0;
}

.nav_box_sp .kusunoki_nav li a{
  display: block;
  padding: 3px;
  color: #FFF;
  text-align: center;
}




/* ¤ªÖª¤é¤»
---------------------------------- */
#kusunoki_news dl {
  max-height: 200px;
  margin-top: 30px;
  border: 4px #efefef solid;
}

#kusunoki_news dl dd {
  display: block;
  width: 100%;
  padding: 5px 8px;
  text-align: left;
}



#kusunoki_news dl dt {
  display: block;
  width: 100%;
  padding: 5px 8px 16px;
}

/* Ï×Ìå¤È¤Ï
---------------------------------- */
.kaibou {
  margin: 20px 8px 30px;
  counter-reset: list-counter;
  list-style: none;
}

.kaibou li {
  position: relative;
  margin: 1em 0;
  padding-left: 1.2em;
  color: #555;
  font-size: 1.2em;
  text-indent: -1.7em;
  font-weight: bold;
  line-height: 1.5em;
}

.kaibou li::before {
  content: counter(list-counter);
  counter-increment: list-counter;
  color: #666;
  font-size: 1.5em;
  font-family: arial;
  font-weight: normal;
  margin-right: .6em;
  line-height: 1.1em;
}




/* ÑØ¸ï
---------------------------------- */
.enkaku_title {
  color: #804040;
}

.enkaku {
  display: block;
  margin-bottom: 30px;
  list-style-type: none;
}

.enkaku dd {
  width: 100%;
  margin-bottom: 0;
  padding: 8px 0 5px 10px;
  color: #804040;
  font-size: .9em;
  background-color: #f2f0ec;
  border-left: 3px solid #804040;
}
.enkaku dt {
  width: 100%;
  margin-bottom: 5px;
  padding: 0 0 8px 10px;
  background-color: #f2f0ec;
  border-left: 3px solid #804040;
}


/* Èë»á¤Ë¤Ä¤¤¤Æ
---------------------------------- */
.list_1 {
  list-style-type: none;
  padding: 1em;
  border: 1px solid #CCC;
}

.list_1 li {
  position: relative;
  display: block;
  align-items: center;
  gap: 0 5px;
  padding: .5em 0 .5em 1.5em;
}

.list_1 li::before {
  position: absolute;
  display: block;
  width: 10px;
  height: 5px;
  left: .35em;
  top: 12px;
  border-bottom: 2px solid #c5932a;
  border-left: 2px solid #c5932a;
  transform: rotate(-45deg);
  content: '';
}
.list-2 {
  border: 2px solid #2589d0;
}

.list-2 div {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 10px 0;
  background-color: #2589d0;
  color: #fff;
  font-weight: 600;
}

.list-2 ul {
  list-style-type: disc;
  margin: 0;
  padding: 1em 1em 1em 2.5em;
}

.list-2 li {
  list-style: disc;
  padding: .3em .3em .3em 0;
}

.list-2 li::before {
  display: none;
}

.list-2 li::marker {
  color: #2589d0;
  font-size: 1.1em;
}


.list_3 li {
  position: relative;
  display: block;
  align-items: center;
  gap: 0 5px;
  padding: .5em 0 .5em 1.5em;
}

.list_3 li::before {
  position: absolute;
  display: block;
  width: 10px;
  height: 5px;
  left: .35em;
  top: 4px;
  border-bottom: 2px solid #c5932a;
  border-left: 2px solid #c5932a;
  transform: rotate(-45deg);
  content: '';
}




.dList04 dd,
.dList04 dd:last-child {
  position: relative;
  display: block;
  padding: 15px 0 15px 70px;
  width: 100%;
}



ol.list01>li {
  margin: 0 0 .8em;
  padding-top: 1em;
  border-top: 1px #ccc dashed;
}

#Feature {
  display: none;
}

/*---- Á÷¤ì‡í ----*/
.nagare li span.stepNO {
  margin-right: .5em;
  color: #baa885;
  font-size: 2em;
  font-family: arial;
}

.nagare>li {
  position: relative;
  margin: 1.5em 0 2em;
  padding: 2em 2em 2em 3em;
  color: #555;
  font-size: 15px;
  line-height: 1.4em;
  text-indent: -2em;
  border: 3px #e6dbc5 solid;
  border-radius: 10px;
}

.nagare>li * {
  text-indent: 0;
}



.nagare>li::after {
  position: absolute;
  left: 50%;
  bottom: -28px;
  transform: translateX(-50%);
  background: #e6dbc5;
  height: calc(tan(60deg) * 30px / 2);
  width: 60px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  display: block;
}

.nagare>li:last-of-type:after {
  display: none;
}


.nagare>li.long_time {
  margin-top: 56px;
}

.nagare>li.long_time::before {
  position: absolute;
  display: block;
  top: -30px;
  left: 50%;
  bottom: auto;
  transform: translateX(-50%);
  background: #e6dbc5;
  height: calc(tan(60deg) * 30px / 2);
  width: 60px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  display: block;
}


.nagare>li .list05>li {
  position: relative;
  padding: 5px 0 5px 20px;
  text-indent: 0;
}

.nagare>li .flow {
  color: #555;
  font-weight: bold;
  font-size: 17px;
}

/* ¤·¤ª¤ê¤ò¤´ÓE¤¯¤À¤µ¤¤
---------------------------------- */
.exlink a {
  position: relative;
  display: inline-block;
  width: auto;
  margin: 0 auto;
  padding: .7em 4em .7em 2em;
  border: 0;
  border-radius: 5px;
  background-color: #808040;
  color: #FFF;
  font-size: 1em;
}

.exlink a::after {
  position: absolute;
  width: 2em;
  height: .5em;
  top: 46%;
  right: 1.5em;
  background-color: #FFF;
  clip-path: polygon(0 100%, 100% 100%, 70% 40%, 70% 90%, 0% 90%);
  transform: translateY(-50%);
  transform-origin: left;
  content: '';
  transition: transform .3s;
}

.exlink a:hover::after {
  transform: translateY(-50%) scaleX(1.2);
}



/* ¤ª†–ºÏ¤ï¤»¤Ë¤Ä¤¤¤Æ
---------------------------------- */
.accessmap {
  padding: 10px;
  border: 2px #ccc solid;
}

.accessmap a {
  display: block;
  border: 1px #fff solid;
  transition: .5s all;
}

.accessmap a:hover {
  border: 1px #cabca0 solid;
}

.accessmap img {
  width: 100%;
}

ol.list01 > li {
  border-bottom: 0;
  /* text-indent: 0; */
}

.dList04 dd, .dList04 dd:last-child {
  padding: 5px 0 15px 0;
}