/*
Theme Name: satooya
Template: businesspress
Theme URI: 
Author: satooya
Author URI: 
Description: satooya kumamoto
*/

@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic&display=swap');


:root {
  --theme-color: #f87489 ;/*ピンク*/
  --color-grn:#83c944;    /* 緑 */
}

body:lang(ja){
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height:1.65;
}

h1, h2, h3, h4, h5, h6, .site-title{
	color: unset;
}
.h1 {
	font-size: 2.5rem;
}
.h2 {
	font-size: 1.75rem;
}
.h3 {
	font-size: 1.5rem;
}
.h4 {
	font-size: 1.25rem;
}
.h5 {
	font-size: 1.125rem;
}
.h6 {
	font-size: 1rem;
}
h1, h2, h3, h4, h5, h6, .site-title {
    line-height: 1.3;
}


/*------------------------------------------*/
/*===========Margin And Paddings============*/
/*------------------------------------------*/
.mt-0 {
    margin-top: 0 !important;
}
.mt-5 {
    margin-top: 5px !important;
}
.mt-10 {
    margin-top: 10px !important;
}
.mt-15 {
    margin-top: 15px !important;
}
.mt-20 {
    margin-top: 20px !important;
}
.mt-25 {
    margin-top: 25px !important;
}
.mt-30 {
    margin-top: 30px !important;
}
.mt-35 {
    margin-top: 35px !important;
}
.mt-40 {
    margin-top: 40px !important;
}
.mt-45 {
    margin-top: 45px !important;
}
.mt-50 {
    margin-top: 50px !important;
}
.mt-55 {
    margin-top: 55px !important;
}
.mt-60 {
    margin-top: 60px !important;
}
.mt-62 {
    margin-top: 62px !important;
}
.mt-65 {
    margin-top: 65px !important;
}
.mt-70 {
    margin-top: 70px !important;
}
.mt-75 {
    margin-top: 75px !important;
}
.mt-80 {
    margin-top: 80px !important;
}
.mt-85 {
    margin-top: 85px !important;
}
.mt-90 {
    margin-top: 90px !important;
}
.mt-95 {
    margin-top: 95px !important;
}
.mt-100 {
    margin-top: 100px !important;
}
/* Custom Margin Bottom */
.mb-0 {
    margin-bottom: 0 !important;
}
.mb-5 {
    margin-bottom: 5px !important;
}
.mb-10 {
    margin-bottom: 10px !important;
}
.mb-15 {
    margin-bottom: 15px !important;
}
.mb-20 {
    margin-bottom: 20px !important;
}
.mb-25 {
    margin-bottom: 25px !important;
}
.mb-30 {
    margin-bottom: 30px !important;
}
.mb-35 {
    margin-bottom: 35px !important;
}
.mb-40 {
    margin-bottom: 40px !important;
}
.mb-45 {
    margin-bottom: 45px !important;
}
.mb-50 {
    margin-bottom: 50px !important;
}
.mb-55 {
    margin-bottom: 55px !important;
}
.mb-60 {
    margin-bottom: 60px !important;
}
.mb-62 {
    margin-bottom: 62px !important;
}
.mb-65 {
    margin-bottom: 65px !important;
}
.mb-70 {
    margin-bottom: 70px !important;
}
.mb-75 {
    margin-bottom: 75px !important;
}
.mb-80 {
    margin-bottom: 80px !important;
}
.mb-85 {
    margin-bottom: 85px !important;
}
.mb-90 {
    margin-bottom: 90px !important;
}
.mb-95 {
    margin-bottom: 95px !important;
}
.mb-100 {
    margin-bottom: 100px !important;
}
.m-0 {
    margin: 0px !important;
}
.m-15{margin:5px 15px !important}


/* Custom Padding top */
.pt-0 {
    padding-top: 0 !important;
}
.pt-5 {
    padding-top: 5px !important;
}
.pt-10 {
    padding-top: 10px !important;
}
.pt-15 {
    padding-top: 15px !important;
}
.pt-20 {
    padding-top: 20px !important;
}
.pt-25 {
    padding-top: 25px !important;
}
.pt-30 {
    padding-top: 30px !important;
}
.pt-35 {
    padding-top: 35px !important;
}
.pt-40 {
    padding-top: 40px !important;
}
.pt-45 {
    padding-top: 45px !important;
}
.pt-50 {
    padding-top: 50px !important;
}
.pt-55 {
    padding-top: 55px !important;
}
.pt-60 {
    padding-top: 60px !important;
}
.pt-65 {
    padding-top: 65px !important;
}
.pt-70 {
    padding-top: 70px !important;
}
.pt-75 {
    padding-top: 75px !important;
}
.pt-80 {
    padding-top: 80px !important;
}
.pt-85 {
    padding-top: 85px !important;
}
.pt-90 {
    padding-top: 90px !important;
}
.pt-95 {
    padding-top: 95px !important;
}
.pt-100 {
    padding-top: 100px !important;
}
/* Custom Padding top */
.pb-0 {
    padding-bottom: 0 !important;
}
.pb-5 {
    padding-bottom: 5px !important;
}
.pb-10 {
    padding-bottom: 10px !important;
}
.pb-15 {
    padding-bottom: 15px !important;
}
.pb-20 {
    padding-bottom: 20px !important;
}
.pb-25 {
    padding-bottom: 25px !important;
}
.pb-30 {
    padding-bottom: 30px !important;
}
.pb-35 {
    padding-bottom: 35px !important;
}
.pb-40 {
    padding-bottom: 40px !important;
}
.pb-45 {
    padding-bottom: 45px !important;
}
.pb-50 {
    padding-bottom: 50px !important;
}
.pb-55 {
    padding-bottom: 55px !important;
}
.pb-60 {
    padding-bottom: 60px !important;
}
.pb-65 {
    padding-bottom: 65px !important;
}
.pb-70 {
    padding-bottom: 70px !important;
}
.pb-75 {
    padding-bottom: 75px !important;
}
.pb-80 {
    padding-bottom: 80px !important;
}
.pb-85 {
    padding-bottom: 85px !important;
}
.pb-90 {
    padding-bottom: 90px !important;
}
.pb-95 {
    padding-bottom: 95px !important;
}
.pb-100 {
    padding-bottom: 100px !important;
}
.p-0 {
    padding: 0 !important;
}

.font-bold{
    font-weight: 700;
}
.font-normal{
    font-weight: 400;
}

b, strong {
    font-weight: 900;
}

img{max-width: 100%;}

.text-center{
	text-align:center;
}
.text-white{
	color:#FFF;
}
.text-pink{
	color:var(--theme-color);
}

/*------------------------------------------*/
/*===Common==Margin And Paddings============*/
/*------------------------------------------*/
.main-navigation .nav_kifu a{
    background: var(--theme-color);
    border-radius: 50px;
    color: #FFF;
    min-width: 82px;
    text-align: center;
}
.main-navigation .nav_member a{
    background: var(--color-grn);
    border-radius: 50px;
    color: #FFF;
    min-width: 82px;
    text-align: center;
}

.drawer-navigation {
    background: #fff5d5;
    border-radius: 45px 0 0 45px;
}

.drawer-navigation ul li:nth-child(-n+3) a {
    border-bottom: 4px dotted #b0a377;
    padding-bottom: 2px;
}


/* Drawer Button */
.drawer-hamburger {
	width: 30px;
	min-width: 30px;
}
.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
	background-color: #9dcc67;
	height: 3px;
	border-radius: 5px;
}

.drawer-navigation a {
    display: block;
}

.jumbotron {
    background-color: var(--color-grn);
}

.home-header-overlay,
.jumbotron-overlay {
    background-color: rgba(0, 0, 0, 0);
}

.main-header {
    padding-bottom: 5px;
    padding-top: 5px;
}

.home-header-content {
    padding-bottom: 30px;
    padding-top: 30px;
    text-align: left;
}

.flexbox {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}


/*topnews*/
.news_top{
	padding:3em 0;
	background-image:url("img/info-haikei.jpg");
	background-size:cover;
	background-repeat:none;
	margin:0 15px 0;
}


.news_top ul{
    margin: 0 20px;
    background: #FFF;
    padding: 1em 20px;
    border-radius: 1em;
}
.news_top ul li {
    display: flex;
    letter-spacing: .16em;
    padding: 1.3em 20px 1.3em 0;
    border-bottom: 1px solid #999393;
    overflow: hidden;
    line-height: 1.5;
}
.news_top ul li:nth-child(1) {
    padding-top: 0;
}
.news_top ul li time {
    margin-right: 4%;
}
.news_top ul li p {
    margin: 0;
}
/*topnews end*/


/*見出し*/

/*midashi 01*/
.heading-kids {
  display: inline-block;
  padding: 0.6em 1.6em 0.6em 1.2em;
  border-radius: 999px;
  background: linear-gradient(90deg, #ffe4f2, #fff7d6);
  color: #555;
  font-weight: 700;
  position: relative;
  box-shadow: 0 3px 0 #f5c7d8;
}

/* 左のアイコン丸 */
.heading-kids::before {
  content: "★";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.6em;
  height: 1.6em;
  margin-right: 0.4em;
  border-radius: 50%;
  background: #ffb6c9;
  color: #fff;
  font-size: 1em;
  box-shadow: 0 2px 0 rgba(0,0,0,0.05);
}

/* 下にちょこんと影（ふきだし風） */
.heading-kids::after {
  content: "";
  position: absolute;
  left: 20%;
  bottom: -8px;
  width: 40%;
  height: 8px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.08);
  filter: blur(2px);
}


.cat-links a {
    background: #e77400;
    border-radius: 1em;
    padding: 1px .8em 2px;
    color: #FFF;
    font-size: .9rem;
    font-weight: 600;
    letter-spacing: .02rem;
}

.widget {
    color: unset;
}

.widget-title {
    color: #6d5353;/*文字色*/
    font-size: 1.5rem;/*文字サイズ*/
    padding: 5px 10px;/*文字回りの余白（上下 左右）*/
    display: block;
    position: relative;
    border-left: 8px solid #9ad5e3;/*左線上側（太さ 実線 色）*/
}
.widget-title:before {
    position: absolute;
    content: '';
    left: -8px;
    bottom: 0;
    width: 8px;/*左線下側の太さ（幅）*/
    height: 50%;/*左線下側の高さ*/
    background-color: #dea3c1;/*左線下側の色*/
}



.footer-widget-area {
    border-top: solid 1px #eee;
    padding-bottom: 3rem;
    padding-top: 3rem;
    background:#fb9aad;
    color:#FFF;
}



/*midashi 02*/
.heading-note {
  position: relative;
  display: inline-block;
  padding: 0.4em 1.2em;
  margin: 1.5em 0 0.8em;
  background: #fffaf0;
  border-radius: 8px;
  border: 2px dashed #ffc86f;
  color: #555;
  font-weight: 700;
}

/* 上部のテープ */
.heading-note::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%) rotate(-3deg);
  width: 60%;
  height: 12px;
  background: repeating-linear-gradient(
    135deg,
    #ffe0e0,
    #ffe0e0 4px,
    #fff 4px,
    #fff 8px
  );
  opacity: 0.9;
  border-radius: 3px;
}

/* 左に小さなクマさんマーク（絵文字で簡易表現） */
.heading-note span.icon {
  margin-right: 0.3em;
}

/*midashi 03*/
.heading-block {
  display: flex;
  align-items: center;
  gap: 0.4em;
  color: #555;
  font-weight: 700;
}

/* 左の積み木3つ */
.heading-block::before {
  content: "";
  display: inline-block;
  width: 1.2em;
  height: 1.2em;
  border-radius: 4px;
  background:
    linear-gradient(#ffb6c1, #ffa4b3);
  box-shadow:
    1.1em 0.3em 0 -0.1em #ffe694,
    2.2em 0.6em 0 -0.2em #a0ddff;
  margin-right: 0.4em;
}


.heading-line {
    padding: 1.2rem 18px .6rem;/*文字回りの余白（上 左右 下）*/
    display: block;
    position: relative;
}
.heading-line:before {
    content: '';
    background: #a2ddeb;/*背景色*/
    width: calc(100% + 3px);
    height: calc(100% + 3px);
    position: absolute;
    top: 0px;
    left: 6px;
    z-index: -1;
    transform: rotate(1.5deg);/*背景影部の回転*/
}
.heading-line:after {
    content: '';
    background: #fff;/*背景色（白）*/
    border: 3px solid #a2ddeb;/*背景白部の囲み線（太さ 実線 色*/
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0px;
    left: -5px;
    z-index: -1;
    transform: rotate(-.5deg);/*背景白部の回転*/
}

.post-navigation a {
    color: var(--theme-color);
    font-size: 1.1rem;
}


/*button*/
.btn-kids {
  display: inline-block;
  padding: 0.8em 1.6em;
  background: linear-gradient(90deg, #ffdce6, #ffeecf);
  border-radius: 50px;
  color: #555;
  font-weight: bold;
  text-decoration: none;
  box-shadow: 0 4px 0 #f6bfcf, 0 6px 12px rgba(0,0,0,0.1);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

/* ホバー時 */
.btn-kids:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 0 #f6bfcf, 0 10px 14px rgba(0,0,0,0.15);
}

/* 押された時 */
.btn-kids:active {
  transform: translateY(2px);
  box-shadow: 0 2px 0 #f6bfcf, 0 4px 8px rgba(0,0,0,0.1);
}


@media screen and (min-width: 640px) {
    .post-navigation .nav-previous,
    .post-navigation .nav-next {
        line-height: 1;
    }
}



@media screen and (min-width: 782px) {
    .main-header {
        padding-bottom: 10px;
        padding-top: 10px;
    }
    .home-header-content {
        padding-bottom: 40px;
        padding-top: 40px;
    }
    .flexrev{
        flex-direction: row-reverse;
    }

}
@media screen and (min-width: 980px) {
    .home-header-content {
        padding-bottom: 80px;
        padding-top: 80px;
    }
    .main-navigation {
        line-height: 2.5em;
    }

    .main-navigation a {
        padding-left: 14px;
        padding-right: 14px;
    }
    .main-navigation div.menu > ul > li:last-child > a, .main-navigation ul.menu > li:last-child > a {
        padding-right: 14px;
    }
	.main-navigation .nav_kifu{
	    margin-right:14px;
	}
}

@media screen and (max-width: 679px) {
 .niji-width{
	width:66%
 }
}



input[type="text"], input[type="email"], input[type="url"], input[type="password"], input[type="search"], input[type="tel"],textarea {
    border: solid 1px #e6e6e6;
    color: #777;
    margin-top: 0em;
    padding: 0.2em;
    borde-radius:3px;
}

.back-to-top {
    border-radius: 50%;
}
.back-to-top:before {
    color: #FFF;
}
.back-to-top:hover {
    background-color: var(--color-grn);
}

/* ========================================================== 
  Animation
============================================================*/
/* ========================================================== 
  Animation
============================================================*/
.fadeInUp {
  animation-fill-mode: both;
  animation-duration : 1.5s;
  animation-name     : fadeInUp;
  visibility         : visible !important;
}

@keyframes fadeInUp {
  0% {
    opacity  : 0;
    transform: translateY(40px);
  }

  100% {
    opacity  : 1;
    transform: translateY(0);
  }
}
.order-fade {
  opacity: 0;
  transform: translateY(60px);
  transition: all 1.5s;
}
.order-scroll {
  opacity: 1;
  transform: translateY(0);
}
.order-fade:nth-of-type(1) {
  transition-delay: 300ms;
}
.order-fade:nth-of-type(2) {
  transition-delay: 500ms;
}

.slidein_L {
  opacity: 0.1;
  transform: translateX(-80px);
  transition: all 2s;
}
.slidein_L.scrollin {
  opacity: 1;
  transform: translate(0);
}
.slidein_R {
  opacity: 0.1;
  transform: translateX(80px);
  transition: all 2s;
}
.slidein_R.scrollin {
  opacity: 1;
  transform: translate(0);
}



