@charset "utf-8";

header{
  box-sizing:border-box;
  width:100%; height:150px;
  min-width:1280px;
  padding:0 40px;
  border-bottom:5px solid #598814;
  background:#FFF;
  position:fixed; z-index:100;
  transition:0.5s ease;
}
header#program{
  height:145px;
  border-bottom:0;
}
header.scroll-header{
  height:70px !important;
  border-bottom:2px solid #598814 !important;
  transition:0.5s ease;
}
header #logo{
  padding-top:33px;
  margin-bottom:10px;
  transition:0.3s ease;
  width:600px;
}
header #logo a{
  display:flex;
  align-items:baseline;
  color:#333;
  text-decoration:none;
  position:relative;
  padding-left:85px;
  transition:0.3s ease;
}
header #logo a::before{
  content:"";
  width:68px; height:80px;
  background:url(../../img/common/shiawase-shinshu.png) no-repeat center top;
  background-size:68px auto;
  position:absolute;
  top:-15px; left:0;
  transition:0.3s ease;
}
header #logo img{
  width:280px; height:auto;
  transition:0.3s ease;
}
header #logo span{
  display:inline-block;
  font-size:15px; line-height:32px; font-weight:500;
  position:relative; bottom:4px;
  margin-left:15px;
  opacity:1;
  transition:0.3s ease;
}
header.scroll-header #logo{
  padding-top:18px;
  transition:0.3s ease;
}
header.scroll-header #logo img{
  width:210px; height:auto;
  transition:0.3s ease;
}
header.scroll-header #logo a{
  padding-left:0;
  transition:0.3s ease;
}
header.scroll-header #logo a::before{
  content:""; display:none;
  transition:0.3s ease;
}
header.scroll-header #logo span{
  opacity:0;
  transition:0.3s ease;
}
nav#global-nav{
  position:relative;
  position:absolute;
  top:85px; left:40px;
  opacity:1;
  transition:0.3s ease;
}
header.scroll-header nav#global-nav{
  opacity:0;
  display:none;
  transition:0.5s ease;
}
nav#global-nav ul{
  display:flex;
}
nav#global-nav ul li{
  margin-right:25px;
  position:relative;
}
nav#global-nav ul li a{
  display:block;
  text-decoration:none;
  font-size:16px; line-height:160%; font-weight:700;
  color:#333;
	position:relative;
}
nav#global-nav ul li a::before{
	content:"";
	position:absolute;
	bottom:-5px;
	width:0%; height:2px;
	background:#598814;
	transition:0.1s;
}
nav#global-nav ul li a::before{left:0%;}
nav#global-nav ul li a:hover::before{
	width:100%;
	transition:0.1s;
}
nav#global-nav ul li ul{
  display:block !important;
  position:absolute;
  top:28px; left:50%;
  transform:translateX(-50%);
  z-index:100;
  width:auto !important;
  height:auto !important;
  background:rgba(89,136,20,0.95);
  border-radius:5px;
  overflow:hidden;
}
nav#global-nav ul li ul li{
  display:block !important;
  width:auto !important;
	margin-right:0 !important;
}
nav#global-nav ul li ul li a{
  display:block;
  white-space:nowrap;
  font-size:14px !important;
  line-height:44px !important;
  color:#FFF;
  text-align:center;
  padding:0 40px;
  text-shadow:none;
}
nav#global-nav ul li ul li a:hover{
  color:#FFF !important;
  background:rgba(89,136,20,1);
}

nav#global-nav ul li#subsidy a:hover{
  color:#ff6666;
}
nav#global-nav ul li#subsidy a::before{
	background:#ff6666;
}
nav#global-nav ul li#subsidy ul{
  background:rgba(255,102,102,0.95);
}
nav#global-nav ul li#subsidy ul li a:hover{
  background:rgba(255,102,102,1);
}

nav#global-nav ul li#probono a:hover{
  color:#2dafe3;
}
nav#global-nav ul li#probono a::before{
	background:#2dafe3;
}

nav#global-nav ul li#about a:hover{
  color:#d67958;
}
nav#global-nav ul li#about a::before{
	background:#d67958;
}
nav#global-nav ul li#about ul{
  background:rgba(214,121,88,0.95);
}
nav#global-nav ul li#about ul li a:hover{
  background:rgba(214,121,88,1);
}

nav#global-nav ul li#npo a:hover{
  color:#402000;
}
nav#global-nav ul li#npo a::before{
	background:#402000;
}
nav#global-nav ul li#npo ul{
  background:rgba(64,32,0,0.95);
}
nav#global-nav ul li#npo ul li a:hover{
  background:rgba(64,32,0,1);
}

nav#global-nav ul li ul li a::before,
nav#global-nav ul li ul li a::after,
nav#global-nav ul li ul li a:hover::before,
nav#global-nav ul li ul li a:hover::after{
	content:""; display:none;
}

#fade-in li ul{
	visibility:hidden;
	opacity:0;
	transition:0.4s;
}
#fade-in li:hover ul{
	visibility:visible;
	opacity:1;
}
#fade-in li ul li a{
	visibility:hidden;
	opacity:0;
	transition:0.4s;
}
#fade-in li:hover ul li a{
	visibility:visible;
	opacity:1;
}

#change{
  width:100%;
  position:fixed;
  top:0; left:0;
  z-index:101;
  background:#CCC;
  display:none;
  transition:0.3s ease;
}
#change nav#global-nav{
  position:absolute;
  top:20px; left:280px;
  transition:0.3s ease;
}
#change nav#global-nav ul li a{
  font-size:15px;
}

#donation-total{
  height:104px;
  position:absolute;
  top:18px; right:30px;
  padding-right:80px;
  opacity:1;
  transition:0.5s ease;
}
header.scroll-header #donation-total{
  opacity:0;
  display:none;
  transition:0.3s ease;
}
#donation-total .copy{
  box-sizing:border-box;
  width:auto; height:24px;
  border-radius:12px;
  background:#dc9976;
  padding:6px 0 0 0;
  margin:24px auto 8px auto;
  overflow:hidden;
}
#donation-total .copy img{
  width:auto; height:12px;
  margin:0 auto;
}
#donation-total .total{
  font-size:14px; font-weight:500;
  position:relative;
  padding:0 10px;
}
#donation-total .total strong{
  font-size:22px; font-weight:700;
  margin-left:12px;
}
#donation-total .total .date{
  display:block;
  font-size:13px; font-weight:400;
  text-align:right;
}
#donation-total::after{
  content:"";
  width:72px; height:104px;
  position:absolute;
  top:0; right:0;
  background:url(../../img/svg/kiffy.svg) no-repeat center center;
  background-size:72px auto;
}

#container{
  padding-top:150px;
}

#index-billboard{
  width:100%;
  padding:30px 0 0 0;
  background-color:#f4f4ec;
}
#index-slider{
  margin-bottom:30px;
}
#index-slider ul li a{
  display:flex;
  text-decoration:none;
  width:860px;
  background:#FFF;
  font-size:14px; line-height:160%;
  color:#111;
  border-radius:5px;
  overflow:hidden;
}
#index-slider ul li a .thumbnail{
  width:400px;
}
#index-slider ul li a .text-box{
  box-sizing:border-box;
  width:460px;
  padding:20px 25px;
  text-align:left;
}
#index-slider ul li a h2{
  font-size:26px; line-height:160%;
  color:#5b82af;
  margin-bottom:5px;
}
#index-slider ul li a:hover h2{
  text-decoration:underline;
}
#index-slider ul li a .program{
  display:inline-block;
  width:auto; height:16px;
  font-size:10px; line-height:17px;
  color:#FFF;
  padding:0 20px;
  border-radius:8px;
}
#index-slider ul li a .program01{background:#6699cc;}
#index-slider ul li a .program02{background:#CB6699;}
#index-slider ul li a .program03{background:#ff6666;}
#index-slider ul li a .program04{background:#996666;}
#index-slider ul li a p{
  margin-bottom:10px;
}
#index-slider ul li a .meter-box{
  width:100%; height:54px;
  position:relative;
}
#index-slider ul li a .meter-box .meter{
  width:100%; height:20px;
  background:#ccc;
  border-radius:10px;
  overflow:hidden;
  position:absolute;
  top:17px; left:0;
}
#index-slider ul li a .meter-box .meter .bar{
  position:absolute;
  top:0; left:0;
  height:20px;
  background:#fac75a;
}
#index-slider ul li a .meter-box .percentage{
  width:54px; height:54px;
  background:#fac75a;
  border-radius:100%;
  color:#FFF;
  font-size:20px; line-height:54px; font-weight:700;
  text-align:center;
  position:absolute;
  top:0; left:0;
}
#index-slider ul li a .meter-box .percentage::after{
  content:"%";
  font-size:14px;
}
#index-slider ul li a .amount{
  display:flex;
  justify-content:flex-end;
  margin-top:-5px;
}
#index-slider ul li a .goal::after{
  content:"/";
  margin:0 5px;
}
#index-slider ul li a .schedule{
  text-align:right;
}
#index-slider ul li a .schedule::before{
  content:"";
  display:inline-block;
  width:18px; height:18px;
  background:url(../../img/svg/schedule.svg) no-repeat center center;
  background-size:18px auto;
  position:relative; top:4px;
  margin-right:5px;
}
#index-slider ul li a .schedule .num{
  font-size:18px; line-height:160%;
  font-weight:500;
}
#index-slider ul li a .schedule-end{
  text-align: center;
    font-weight: bold;
    color: #FF0000;
}
#index-slider .sp-button{
  border:none;
  background:#999;
}
#index-slider .sp-button.sp-selected-button{
  background:#333;
}

#index-banner{
  width:1200px;
  margin:0 auto;
  padding-bottom: 30px;
}
#index-banner ul{
  display:flex;
  justify-content:space-between;
  flex-wrap: wrap;
}
#index-banner ul li{
  width:290px; height:112px;
  margin-bottom:15px;
  max-height:180px;
  overflow:hidden;
  position:relative;
}
#index-banner ul li img{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  transform-origin:50% 50%;
  transition:0.3s;
}
section{
  width:100%;
  margin:0 auto 80px auto;
}
.index-contents section{
  width:1200px;
  margin:0 auto;
  padding:50px 0;
}

.button{
  box-sizing:border-box;
  font-size:16px; line-height:20px; font-weight:500;
  width:420px;
  overflow:hidden;
  margin:0 auto;
}
.button a{
  display:block;
  text-decoration:none;
  text-align:center;
  padding:18px 0;
  border-radius:7px;
  transition:0.3s;
}
.button a:hover{
  transition:0.3s;
}

#index-program01{
  width:100%;
  background:linear-gradient(
    #598814 65%, #f4f4ec 65%
    );
}
#index-program01 h2{
  display:inline-block;
  font-size:28px; line-height:160%; font-weight:700;
  color:#FFF;
  margin:0 auto 40px auto;
}
#index-program01 h2::after{
  display:block;
  content:"";
  width:auto; height:16px;
  background:url(../../img/svg/title_bar.svg) no-repeat left bottom;
  background-size:auto 16px;
}

ul.program-list{
  display:flex;
  justify-content:space-between;
  margin-bottom:40px;
}
ul.program-list li{
  width:270px;
  background:#FFF;
  text-align:left;
  border-radius:5px;
}
ul.program-list li a{
  font-size:12px; line-height:160%;
  color:#111;
  text-decoration:none;
  position:relative;
}
ul.program-list li a .thumbnail{
  width:100%; height:160px;
  border-radius:5px 5px 0 0;
  overflow:hidden;
  position:relative;
}
ul.program-list li a .thumbnail img{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  transform-origin:50% 50%;
  transition:0.3s;
}
ul.program-list li a:hover .thumbnail img{
  width:110%; height:auto;
  transform:translate(-50%,-50%) rotate(-1deg);
  transition:0.3s;
}
ul.program-list li .text-box{
  padding:15px 15px;
  position:relative;
}
ul.program-list li a h3{
  font-size:16px; line-height:160%;
  color:#5b82af;
  margin-bottom:5px;
  word-break: break-all;
}
ul.program-list li a:hover h3{
  text-decoration:underline;

}
ul.program-list li .text-box .tag{
  display:inline-block;
  width:auto; height:16px;
  font-size:10px; line-height:17px;
  color:#FFF;
  padding:0 12px;
  border-radius:8px;
  position:absolute;
  top:-8px; left:15px;
}
ul.program-list li .text-box .tag.program01{
  background:#6699cc;
}
ul.program-list li .text-box .tag.program02{
  background:#CB6699;
}
ul.program-list li .text-box .tag.program03{
  background:#ff6666;
}
ul.program-list li .text-box .tag.program04{
  background:#996666;
}
ul.program-list li a .meter-box{
  width:100%; height:36px;
  position:relative;
  margin-bottom:5px;
}
ul.program-list li a .meter-box .meter{
  width:100%; height:12px;
  background:#ccc;
  border-radius:10px;
  overflow:hidden;
  position:absolute;
  top:12px; left:0;
}
ul.program-list li a .meter-box .meter .bar{
  position:absolute;
  top:0; left:0;
  height:12px;
  background:#fac75a;
}
ul.program-list li a .meter-box .percentage{
  width:36px; height:36px;
  background:#fac75a;
  border-radius:100%;
  color:#FFF;
  font-size:15px; line-height:36px; font-weight:700;
  text-align:center;
  position:absolute;
  top:0; left:0;
}
ul.program-list li a .meter-box .percentage::after{
  content:"%";
  font-size:12px;
}
ul.program-list li a .amount{
  display:flex;
  justify-content:flex-end;
}
ul.program-list li a .goal::after{
  content:"/";
  margin:0 5px;
}
ul.program-list li a .schedule{
  text-align:right;
}
ul.program-list li a .schedule::before{
  content:"";
  display:inline-block;
  width:18px; height:18px;
  background:url(../../img/svg/schedule.svg) no-repeat center center;
  background-size:18px auto;
  position:relative; top:4px;
  margin-right:5px;
}
ul.program-list li a .schedule .num{
  font-size:15px; line-height:160%;
  font-weight:500;
}
ul.program-list li a .schedule-end{
  font-size:14px; line-height:160%; font-weight:700;
  color:#DD0000;
  text-align: center;
  margin:5px auto 0 auto;
}
ul.program-list li a .probono-name{
  font-weight:500;
}
ul.program-list li a .probono-area{
  position:relative;
  padding-left:5em;
}
ul.program-list li a .probono-area::before{
  content:"活動地域：";
  position:absolute;
  top:0; left:0;
}
ul.program-list li a .subsidy-status{
  position:absolute;
  top:-12px; left:-12px; z-index:10;
  box-sizing:border-box;
  width:58px; height:58px;
  border-radius:100%;
  background:#FFF;
  font-size:0.85vw !important; line-height:120%; font-weight:700;
  color:#ff6666; text-align:center;
  padding:14px 5px 0 5px;
  padding:0 5px;
  transform:rotate(-10deg);
}
ul.program-list li a .subsidy-status span{
  width:calc(100% - 10px);
  position:absolute;
  top:50%; left:5px;
  transform:translateY(-50%);
  font-size:90%;
  line-height:140%;
}

#index-program01 ul.program-list li{
}
#index-program01 .button a{
  background:#598814;
  color:#FFF;
}

#index-about{
  width:100%;
  background:#FFF;
  overflow:hidden;
}
#index-about h2{
  display:inline-block;
  font-size:28px; line-height:160%; font-weight:700;
  color:#c51c3b;
  margin:0 auto 40px auto;
  margin-top:20px;
  position:relative;
}
#index-about h2::before{
  content:"";
  width:80px; height:37px;
  background:url(../../img/svg/ribbon_red.svg) no-repeat center center;
  background-size:80px auto;
  transform:rotate(-15deg);
  position:absolute;
  top:-35px; left:-45px;
}
ul.index-about-list{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  margin-bottom:20px;
}
ul.index-about-list li{
  box-sizing:border-box;
  width:380px;
  padding:30px;
  margin-bottom:30px;
  background:#f7f4ee;
  border-radius:7px;
}
ul.index-about-list li a{
  display:block;
  text-decoration:none;
  font-size:15px; line-height:160%;
  color:#111;
}
ul.index-about-list li a h3{
  font-size:22px; line-height:160%;
  color:#402000;
  margin-bottom:10px;
}
ul.index-about-list li a p{
  font-size:15px; line-height:170%;
  margin-bottom:0;
}
ul.index-about-list li a:hover h3{
  text-decoration:underline;
}
ul.index-about-list li a::before{
  content:"";
  width:100px; height:100px;
  background-color:#FFF;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:54px auto;
  border-radius:100%;
  display:block;
  margin:0 auto 15px auto;
}
ul.index-about-list li.support01 a::before{
  background-image:url(../../img/svg/program.svg);
}
ul.index-about-list li.support02 a::before{
  background-image:url(../../img/svg/group.svg);
}
ul.index-about-list li.support03 a::before{
  background-image:url(../../img/svg/company.svg);
}
ul.index-about-list li.support04 a::before{
  background-image:url(../../img/svg/monthly.svg);
}
ul.index-about-list li.support05 a::before{
  background-image:url(../../img/svg/legacy.svg);
}
ul.index-about-list li.support06 a::before{
  background-image:url(../../img/svg/probono.svg);
}
.tax-incentives{
  display:inline-block;
  margin:0 auto;
  padding-left:220px;
  text-align:left;
  position:relative;
}
.tax-incentives::before{
  content:"";
  width:200px; height:200px;
  background:url(../../img/svg/kiffy.svg) no-repeat center top;
  background-size:200px auto;
  position:absolute;
  top:0; left:0;
}
.tax-incentives p{
  font-size:18px; line-height:160%; font-weight:500;
  margin-bottom:15px;
}
.tax-incentives .button{
  margin:0;
}
.tax-incentives .button a{
  border:2px solid #598814;
  color:#598814;
}
.tax-incentives .button a:hover{
  background:#598814;
  color:#fff;
}

#index-topics{
  padding:50px 0;
  background:#f6f6f6;
  display:flex;
  justify-content:center;
}
#index-topics .topics-box{
  width:730px;
  text-align:left;
  margin-right:50px;
}
#index-topics .topics-box h2{
  font-size:28px; line-height:160%;
  color:#402000;
  margin-bottom:15px;
}
#index-topics .facebook-box{
  width:420px;
}
#index-topics ul.topics-menu{
  display:flex;
  border-bottom:1px solid #999;
}
#index-topics ul.topics-menu li{
  display:inline-block;
  font-size:15px; line-height:37px; font-weight:500;
  color:#555;
  padding:0 2em;
  margin-right:5px;
  border:1px solid #999;
  cursor:pointer;
  position:relative; top:1px;
}
#index-topics ul.topics-menu li.active{
  font-weight:700;
  color:#402000;
  background:#FFF;
  border-bottom:1px solid #fff;
}
#index-topics .tab-contents{
  box-sizing:border-box;
  width:730px;
  padding:30px 40px;
  background:#FFF;
  display:none;
}
#index-topics .tab-contents.active{
  display:block;
}
ul.topics-list li{
  margin-bottom:25px;
}
ul.topics-list li a{
  display:block;
  color:#444;
  text-decoration:none;
  position:relative;
  padding-left:100px;
}
ul.topics-list li a .entry-date{
  position:absolute;
  top:0; left:0;
  font-size:14px;
  margin-right:30px;
}
ul.topics-list li a .title{
  color:#5b82af;
}
ul.topics-list li a:hover .title{
  text-decoration:underline;
}
.topics-box .button-more{
  text-align:center;
  margin:0 auto 5px auto;
}
.topics-box .button-more a{
  display:inline-block;
  text-decoration:none;
  font-size:14px; line-height:36px; font-weight:500;
  color:#402000;
  border:1px solid #402000;
  border-radius:18px;
  margin:0 auto;
  padding:0 2em;
  transition:0.3s;
}
.topics-box .button-more a:hover{
  background:#402000;
  color:#fff;
  transition:0.3s;
}

#index-program02{
  width:100%;
  background:linear-gradient(
    #2dafe3 65%, #f4f4ec 65%
    );
}
#index-program03{
  width:100%;
  background:linear-gradient(
    #ff6666 65%, #f4f4ec 65%
    );
}
#index-program02 h2,
#index-program03 h2{
  display:inline-block;
  font-size:28px; line-height:160%; font-weight:700;
  color:#FFF;
  margin:0 auto 30px auto;
}
#index-program02 h2::after,
#index-program03 h2::after{
  display:block;
  content:"";
  width:auto; height:16px;
  background:url(../../img/svg/title_bar.svg) no-repeat left bottom;
  background-size:auto 16px;
}
#index-program02 .probono-title,
#index-program03 .probono-title{
  width:300px;
  color:#FFF; text-align:left;
}
#index-program02 ul.program-list,
#index-program03 ul.program-list{
  width:850px;
  padding-top:90px;
}
#index-program02 p,
#index-program03 p{
	font-size:15px; line-height:170%;
  margin-bottom:0;
}
#index-program02 .button,
#index-program03 .button{
  width:100%;
  margin-top:30px;
}
#index-program02 .button a,
#index-program03 .button a{
  color:#FFF;
  border:1px solid #FFF;
}
#index-program02 .button a:hover{
  background:#fff;
  color:#2dafe3;
}
#index-program03 .button a:hover{
  background:#fff;
  color:#ff6666;
}

#newstopics-new-box{
  background:#FFFFFF;
  padding:18px 0;
}
.newstopics-new-box-inner{
  width: 1200px;
  margin: 0 auto;
  text-align: left;
  position: relative;
  height: 27px;
}
.newstopics-new-box-inner h2{
  font-size:21px;
  color: #402000;
  position: absolute;
  width: 185px;
  top:2px;
}
.newstopics-new-box-inner h2::after{
  content:"";
  display:block;
  border-right:4px solid #402000;
  position: absolute;
  top:3px;
  right: 15px;
  height:18px;
}
.newstopics-new-box-inner p.news-title{
  position: absolute;
  width: 915px;
  left: 185px;
  top:3px;
}
.newstopics-new-box-inner p.news-title span{
  margin-right:10px;
}

.newstopics-new-box-inner p.news-more{
  position: absolute;
  width: 100px;
  right:0;
  text-align: right;
}
.newstopics-new-box-inner p.news-more a{
  display: inline-block;
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  color: #402000;
  border: 1px solid #402000;
  border-radius: 18px;
  margin: 0 auto;
  padding: 0 15px;
  transition: 0.3s;
}
.newstopics-new-box-inner p.news-more a:hover{
  background:#402000;
  color:#fff;
  transition:0.3s;
}



footer{
  background:#4e5659;
  background:#52575a;
  color:#FFF;
}
footer section{
  width:1200px;
  margin:0 auto;
  padding:50px 0;
}
nav#footer-nav{
  display:flex;
  justify-content:space-between;
}
nav#footer-nav ul li{
  font-size:13px; line-height:180%;
  color:#FFF;
  text-align:left;
  margin:0;
  position:relative;
}
nav#footer-nav ul li a{
  text-decoration:none;
  color:#FFF;
}
nav#footer-nav ul li.sub{
  list-style:disc outside;
  margin-left:20px;
}
footer .credit{
  display:flex;
  justify-content:center;
  margin:50px auto;
  border-top:1px solid rgba(255,255,255,0.6);
  border-bottom:1px solid rgba(255,255,255,0.6);
}
.credit #footer-logo{
  width:180px;
  margin:50px 30px 50px 0;
}
.credit .credit-text{
  text-align:left;
  margin:50px 0;
}
.credit .credit-text p{
  font-size:14px; line-height:180%;
  margin:0;
}
.credit .credit-text p:last-of-type{
  margin-top:25px;
}
.credit .credit-text p a{
  color:#FFF;
}
footer .copyright{
  font-size:12px; line-height:180%;
}
.banner-box{
  margin:30px auto 10px;
}
.banner-box ul{
  display:flex;
  justify-content:space-between;
}
.banner-box ul li{
  width: 575px;
}

#billboard{
  width:100%;
  margin:0 auto 50px auto;
}
#billboard.business-program{
  background:#6699cc;
  background:rgba(102,153,204,1);
}
#billboard.group-program{
  background:#CB6699;
  //background:rgba(102,153,204,1);
}
#billboard.area-program{
  background:#996666;
  //background:rgba(102,153,204,1);
}
#billboard.crown-program{
  background:#ff6666;
  //background:rgba(102,153,204,1);
}
#billboard.crown-program-1058{
  background:#FCD669;
}
.billboard-inner{
  width:1200px;
  margin:0 auto;
  padding:50px 0 60px 0;
}
.billboard-inner h1{
  font-size:26px; line-height:160%;
  color:#FFF;
  margin:0 auto 15px auto;
}
#billboard h1::before{
  content:"";
  width:36px; height:36px;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:36px auto;
  display:block;
  margin:0 auto 15px auto;
}
#billboard.business-program h1::before,
#billboard.group-program h1::before,
#billboard.crown-program h1::before,
#billboard.area-program h1::before{
  background-image:url(../../img/svg/program_white.svg);
}

#billboard.crown-program-1058 h1::before{
  background-image:url(../../img/svg/program_white.svg);
}
.billboard-inner ul.category{
  font-size:13px; line-height:160%;
  display:flex;
  justify-content:center;
}
.billboard-inner ul.category li{
  margin-right:30px;
}
.billboard-inner ul.category li:last-child{
  margin-right:0px;
}
.billboard-inner ul.category li,
.billboard-inner ul.category li a{
  text-decoration:none;
  color:#FFF;
}
.billboard-inner ul.category li a:hover{
  text-decoration:underline;
}
.billboard-inner ul.category li span.label{
  display:inline-block;
  width:auto; height:18px;
  font-size:11px; line-height:17px;
  border:1px solid #FFF;
  padding:0 0.6em;
  margin-right:0.6em;
}

.billboard-inner p{
	margin-bottom: 15px;
    margin-top: -18px;

}
#billboard.crown-program-1058 .billboard-inner p{
	color:#FFFFFF;

}

.flex-container{
  width:1200px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
}
#main,
#side{
  text-align:left;
  padding-bottom:40px;
}
.regular-container #main{
  width:840px;
  padding-top:50px;
}
.regular-container #side{
  width:300px;
  padding-top:50px;
}
.program-container #main{
  width:760px;
}
.program-container #side{
  width:400px;
}

.regular-container section h1{
  font-size:30px; line-height:140%; font-weight:700;
  border-bottom:1px solid #333;
  margin-bottom:20px;
  padding-bottom:10px;
}
section h2{
  font-size:24px; line-height:180%;
  margin-bottom:20px;
}
section h2 span{
  display:inline-block;
}
section h2 span::after{
  content:"";
  display:block;
  width:100%;
  border-bottom:2px solid #333;
}
.business-program section h2,
.business-program-box section h2{
  color:#6699cc;
}
.business-program-box section h2{
  font-size:20px; line-height:180%;
}
.business-program section h2 span::after,
.business-program-box section h2 span::after{
  border-color:#6699cc;
}

.group-program section h2{
  color:#CB6699;
  font-size:20px; line-height:180%;
}
.group-program section h2 span::after{
  border-color:#CB6699;
}

.area-program-box section h2{
  color:#996666;
  font-size:20px; line-height:180%;
}
.area-program-box section h2 span::after{
  border-color:#996666;
}

.monthly-program section h2{
  color:#006cb6;
  font-size:20px; line-height:180%;
}
.monthly-program section h2 span::after{
  border-color:#006cb6;
}

.monthly-program .monthly-total-box{
	margin-bottom: 80px;
    padding: 20px 0;
    background: #006cb6;
    color: #FFFFFF;
    border-radius: 10px;
    text-align: center;
}
.monthly-program .monthly-total-box p.monthly-amount{
	font-size: 200%;
    font-weight: bold;
    margin-bottom: 0;
}
.monthly-program .monthly-total-box p.monthly-genle{
	font-size: 90%;
    margin-bottom: 10px;
}




.legacy section h2{
  color:#9b8f26;
  font-size:20px; line-height:180%;
}
.legacy section h2 span::after{
  border-color:#9b8f26;
}

.crown-program section h2{
  color:#ff6666;
}
.crown-program section h2 span::after{
  border-color:#ff6666;
}
.crown-program-1058 section h2{
  color:#FCD669;
}
.crown-program-1058 section h2 span::after{
  border-color:#FCD669;
}
.group-program section h2{
  color:#CB6699;
}
.group-program section h2 span::after{
  border-color:#CB6699;
}
.area-program section h2{
  color:#996666;
}
.area-program section h2 span::after{
  border-color:#996666;
}

.group-introduction section h2{
  font-size:20px; line-height:180%;
  color:#402000;
}
.group-introduction section h2 span::after{
  border-color:#402000;
}
.about section h2{
  font-size:20px; line-height:180%;
  color:#d67958;
}
.about section h2 span::after{
  border-color:#d67958;
}

section h3{
  font-size:17px; line-height:180%;
  margin-bottom:20px;
}

section p{
  font-size:16px; line-height:180%;
  margin-bottom:25px;
}
section .photo-right{
  max-width:300px; height:auto;
  float:right;
  margin:0 0 25px 25px;
}

section ul.disc-list,
section ol.decimal-list{
  margin-bottom:25px;
}
section ul.disc-list li,
section ol.decimal-list li{
  font-size:16px; line-height:180%;
  margin:0 0 5px 25px;
}
section ul.disc-list > li{
  list-style:disc outside;
}
section ol.decimal-list > li{
  list-style:decimal outside;
}

.business-program-box hr{
  border:none;
  border-top:1px dashed #999;
  margin:80px auto;
}

/* directory title */
#directory-title{
  display:inline-block;
  font-size:20px; line-height:32px; font-weight:700;
  margin-bottom:40px;
}
#directory-title::before{
  display:inline-block;
  content:"";
  width:32px; height:32px;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:32px auto;
  position:relative; top:6px;
  margin-right:10px;
}
#directory-title::after{
  display:block;
  content:"";
  width:auto; height:16px;
  background-repeat:no-repeat;
  background-position:left bottom;
  background-size:auto 12px;
}
#directory-title.title-npo{
  color:#402000;
}
#directory-title.title-npo::before{
  background-image:url(../../img/svg/group.svg);
}
#directory-title.title-npo::after{
  background-image:url(../../img/svg/title_bar_brown.svg);
}
#directory-title.title-news{
  color:#598814;
}
#directory-title.title-news::before{
  background-image:url(../../img/svg/news.svg);
}
#directory-title.title-news::after{
  background-image:url(../../img/svg/title_bar_green.svg);
}
#directory-title.title-about{
  color:#d67958;
}
#directory-title.title-about::before{
  background-image:url(../../img/svg/kiffy_icon.svg);
}
#directory-title.title-about::after{
  background-image:url(../../img/svg/title_bar_darkpink.svg);
}

section.group-box{
  margin-bottom:60px;
}
ul.group-category{
  font-size:14px; line-height:160%;
}
ul.group-category li{
  margin-bottom:5px;
}
ul.group-category li a:hover{
  text-decoration:underline;
}
ul.group-category li span.label{
  display:inline-block;
  width:5.2em;
}
ul.group-category li span.label::after{
  content:"：";
}

ul.group-program-list{
  display:flex;
  flex-wrap:wrap;
  margin-bottom:60px;
}
ul.group-program-list li{
  width:260px;
  background:#FFF;
  text-align:left;
  border-radius:5px;
  margin:0 30px 30px 0;
  box-shadow:2px 2px 4px #CCC;
}
ul.group-program-list li:nth-child(3n),
ul.group-program-list li:last-child{margin-right:0;}
ul.group-program-list li a{
  font-size:12px; line-height:160%;
  color:#111;
  text-decoration:none;
  position:relative;
}
ul.group-program-list li a .thumbnail{
  width:100%; height:150px;
  border-radius:5px 5px 0 0;
  overflow:hidden;
  position:relative;
}
ul.group-program-list li a .thumbnail img{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  transform-origin:50% 50%;
  transition:0.3s;
}
ul.group-program-list li a:hover .thumbnail img{
  width:110%; height:auto;
  transform:translate(-50%,-50%) rotate(-1deg);
  transition:0.3s;
}
ul.group-program-list li .text-box{
  padding:15px 15px;
  position:relative;
}
ul.group-program-list li a h3{
  font-size:16px; line-height:160%;
  color:#5b82af;
  margin-bottom:5px;
  word-break: break-all;
}
ul.group-program-list li a:hover h3{
  text-decoration:underline;
}
ul.group-program-list li .text-box .tag{
  display:inline-block;
  width:auto; height:16px;
  font-size:10px; line-height:17px;
  color:#FFF;
  padding:0 12px;
  border-radius:8px;
  position:absolute;
  top:-8px; left:15px;
}
ul.group-program-list li .text-box .tag.program01{
  background:#6699cc;
}
ul.group-program-list li .text-box .tag.program02{
  background:#CB6699;
}
ul.group-program-list li .text-box .tag.program03{
  background:#ff6666;
}
ul.group-program-list li .text-box .tag.program04{
  background:#996666;
}
ul.group-program-list li a .meter-box{
  width:100%; height:36px;
  position:relative;
  margin-bottom:5px;
}
ul.group-program-list li a .meter-box .meter{
  width:100%; height:12px;
  background:#ccc;
  border-radius:10px;
  overflow:hidden;
  position:absolute;
  top:12px; left:0;
}
ul.group-program-list li a .meter-box .meter .bar{
  position:absolute;
  top:0; left:0;
  height:12px;
  background:#fac75a;
}
ul.group-program-list li a .meter-box .percentage{
  width:36px; height:36px;
  background:#fac75a;
  border-radius:100%;
  color:#FFF;
  font-size:15px; line-height:36px; font-weight:700;
  text-align:center;
  position:absolute;
  top:0; left:0;
}
ul.group-program-list li a .meter-box .percentage::after{
  content:"%";
  font-size:12px;
}
ul.group-program-list li a .amount{
  display:flex;
  justify-content:flex-end;
}
ul.group-program-list li a .goal::after{
  content:"/";
  margin:0 5px;
}
ul.group-program-list li a .schedule{
  text-align:right;
}
ul.group-program-list li a .schedule::before{
  content:"";
  display:inline-block;
  width:18px; height:18px;
  background:url(../../img/svg/schedule.svg) no-repeat center center;
  background-size:18px auto;
  position:relative; top:4px;
  margin-right:5px;
}
ul.group-program-list li a .schedule .num{
  font-size:15px; line-height:160%;
  font-weight:500;
}
ul.group-program-list li a .probono-name{
  font-weight:500;
}

ul.group-program-list li a .schedule-end{
  font-size:14px; line-height:160%; font-weight:700;
  color:#DD0000;
  text-align: center;
  margin:5px auto 0 auto;
}



ul.group-program-list li a .probono-area{
  position:relative;
  padding-left:5em;
}
ul.group-program-list li a .probono-area::before{
  content:"活動地域：";
  position:absolute;
  top:0; left:0;
}
ul.group-program-list li a .subsidy-status{
  position:absolute;
  top:-12px; left:-12px;
  box-sizing:border-box;
  width:58px; height:58px;
  border-radius:100%;
  background:#FFF;
  font-size:13px; line-height:15px; font-weight:700;
  color:#ff6666; text-align:center;
  padding:14px 5px 0 5px;
  transform:rotate(-10deg);
}
table.group-table{
  width:100%;
  margin:0 auto 50px auto;
  border-collapse:collapse;
  border-bottom:1px solid #CCC;
}
table.group-table tr{
  border-top:1px solid #CCC;
}
table.group-table th,
table.group-table td{
  padding:20px 10px;
  font-weight:400;
}
table.group-table td span.zip{
  display:block;
}
.group-fb-box{
  text-align:center;
  margin:0 auto 60px auto;
}
.gmap-box{
  margin:0 auto 60px auto;
}
.gmap-box iframe{
  width:100%; height:420px;
}

#main .sns-button-box{
  text-align:center;
}

ul.group-area-menu{
  display:flex;
  flex-wrap:wrap;
}
ul.group-area-menu li{
  margin:0 10px 10px 0px;
}
ul.group-area-menu li a{
  display:block;
  text-decoration:none;
  font-size:14px; line-height:1;
  color:#444;
  padding:8px 26px;
  border:1px solid #CCC;
  border-radius:3px;
}
ul.group-area-menu li a:hover{
  background:rgba(91,130,175,0.3);
  background:rgba(89,136,20,0.2);
  border-color:rgba(89,136,20,0.6);
}

ul.group-list{
  display:flex;
  flex-wrap:wrap;
  margin:0 auto 50px auto;
}
ul.group-list li{
  width:256px;
  margin:0 36px 36px 0;
}
ul.group-list li:nth-child(3n),
ul.group-list li:last-child{margin-right:0;}
ul.group-list li .thumbnail{
  box-sizing:border-box;
  width:100%; height:140px;
  overflow:hidden;
  position:relative;
  margin:0 auto 10px auto;
}
ul.group-list li .thumbnail.dummy{
  border:1px solid #CCC;
}
ul.group-list li .thumbnail img{
  position:absolute;
  top:50%; left:0;
  transform:translateY(-50%);
}
ul.group-list li a{
  display:block;
  text-decoration:none;
  color:#555;
}
ul.group-list li a h2{
  font-size:16px; line-height:160%;
  color:#5b82af;
  margin-bottom:5px;
}
ul.group-list li a p{
  font-size:13px; line-height:160%;
  margin-bottom:0;
  padding-left:67px;
  position:relative;
}
ul.group-list li a p span.label{
  width:auto; height:18px;
  font-size:12px; line-height:17px;
  position:absolute;
  top:0; left:0;
}
ul.group-list li a p span.label::after{
  content:"：";
}

.pagenavi-box .wp-pagenavi{
  padding:0 !important;
}

/* news archive */
ul.topics-archive-list{
  margin:30px auto;
}
ul.topics-archive-list li{
  margin-bottom:25px;

}
ul.topics-archive-list li a{
  display:block;
  color:#444;
  text-decoration:none;
  position:relative;
  padding-left:100px;
}
ul.topics-archive-list li a .entry-date{
  position:absolute;
  top:0; left:0;
  font-size:14px;
  margin-right:30px;
}
ul.topics-archive-list li a .title{
  color:#5b82af;
}
ul.topics-archive-list li a:hover .title{
  text-decoration:underline;
}

/* news article */
.entry-title p.entry-date{
  font-size:14px; line-height:180%;
  color:#555;
  margin-bottom:0;
}
.entry-body{
  margin:40px auto;
  line-height:200%;
}
ul.entry-bottom{
  border-top:1px solid #CCC;
  margin:10px auto 0 auto;
  padding-top:40px;
  display:flex;
  justify-content:center;
}
ul.entry-bottom li{
  font-size:13px; line-height:160%;
}
ul.entry-bottom li::before{
  content:"｜";
  display:inline-block;
  margin:0 10px;
}
ul.entry-bottom li:first-child::before{
  content:""; display:none;
}

/* npo */
ul.npo-program-list{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  margin-bottom:20px;
}
ul.npo-program-list li{
  box-sizing:border-box;
  width:410px;
  padding:30px;
  margin-bottom:20px;
  background:#f7f4ee;
  border-radius:7px;
}
ul.npo-program-list li a{
  display:block;
  text-decoration:none;
  font-size:15px; line-height:160%;
  color:#111;
  text-align:center;
}
ul.npo-program-list li a h3{
  font-size:22px; line-height:160%;
  color:#402000;
  margin-bottom:10px;
}
ul.npo-program-list li a p{
  font-size:15px; line-height:170%;
  text-align:left;
}
ul.npo-program-list li a:hover h3{
  text-decoration:underline;
}
ul.npo-program-list li a::before{
  content:"";
  width:100px; height:100px;
  background-color:#FFF;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:54px auto;
  border-radius:100%;
  display:block;
  margin:0 auto 15px auto;
}
ul.npo-program-list li.support01 a::before{
  background-image:url(../../img/svg/program.svg);
}
ul.npo-program-list li.support02 a::before{
  background-image:url(../../img/svg/group.svg);
}
ul.npo-program-list li.support03 a::before{
  background-image:url(../../img/svg/company.svg);
}
ul.npo-program-list li.support04 a::before{
  background-image:url(../../img/svg/area.svg);
}
ul.npo-program-list li a .button{
  width:100%;
  font-size:15px; line-height:40px;
  border:1px solid #402000;
  background:rgba(255,255,255,0.8);
  border-radius:20px;
  transition:0.3s;
}
ul.npo-program-list li a:hover .button{
  background:#402000;
  color:#FFF;
  transition:0.3s;
}
table.program-summary-table{
  width:100%;
  margin:0 auto 25px auto;
  border-collapse:collapse;
  border-top:1px solid #CCC;
}
table.program-summary-table tr{
  border-bottom:1px solid #CCC;
}
table.program-summary-table th{
  width:30%;
}
table.program-summary-table th,
table.program-summary-table td{
  padding:20px 0;
  font-weight:normal;
  vertical-align:top;
}

/* about */
.about-image-box{
  width:670px; height:auto;
  margin:0 auto 25px auto;
}
table.history-table{
  width:100%;
  margin:0 auto 25px auto;
  border-collapse:collapse;
}
table.history-table tr{
  border-bottom:1px solid #CCC;
}
table.history-table tr:last-child{
  border-bottom:none;
}
table.history-table th,
table.history-table td{
  padding:20px 0;
  font-weight:normal;
  vertical-align:top;
}

ul.about-feature-list{
  margin:30px auto 30px auto;
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
}
ul.about-feature-list li{
  box-sizing:border-box;
  width:410px;
  background:rgba(214,121,88,0.04);
  border:1px solid rgba(214,121,88,0.8);
  border-radius:7px;
  padding:20px 25px;
  margin-bottom:20px;
}
ul.about-feature-list li h3{
  font-size:18px; line-height:160%;
  color:#CC0000;
  margin-bottom:5px;
}
ul.about-feature-list li p{
  font-size:15px; line-height:180%;
  margin-bottom:0;
}

strong.organization-lead{
  font-size:110%; line-height:180%;
  color:#CC0000;
}

table.about-table{
  width:100%;
  margin:0 auto 30px auto;
  border-collapse:collapse;
}
table.about-table th{
  border:1px solid #CCC;
  padding:20px;
  text-align:center; vertical-align:top;
  font-weight:400;
}
table.about-table td{
  border:1px solid #CCC;
  padding:20px;
  text-align:left; vertical-align:top;
  font-weight:400;
}
table.about-table td p:last-of-type{margin-bottom:0;}

.tax-box{
  margin:30px auto;
  display:flex;
  justify-content:space-between;
  border:1px solid #CCC;
  border-radius:7px;
  padding:25px 30px;
}
.tax-box h3{
  width:200px;
  white-space:nowrap;
}
.tax-box h3::before{
//  content:"・";
}
.tax-box .tax-contents{
  width:580px;
}
.tax-box .tax-contents p:last-of-type{margin-bottom:0;}

ul.tax-list li{
  font-size:16px; line-height:180%;
  margin-bottom:20px;
}
ul.tax-list li strong{
  display:block;
  font-size:105%; line-height:180%;
}
.tax-caution-box{
  margin:20px auto;
  padding:15px 20px;
  border:1px dashed #999;
  font-size:15px; line-height:160%;
}
table.tax-table{
  width:100%;
  border-collapse:collapse;
  margin:0 auto;
}
table.tax-table th{
  border:1px solid #d67958;
  padding:15px;
  font-weight:500;
  text-align:center; vertical-align:top;
  background:rgba(214,121,88,0.08);
}
table.tax-table td{
  border:1px solid #d67958;
  padding:15px;
  text-align:left; vertical-align:top;
}

ul.howto-flow-outline-list{
  display:flex;
  justify-content:space-between;
}
ul.howto-flow-outline-list li{
  box-sizing:border-box;
  width:180px;
  padding:20px;
  border:1px solid #598814;
  border-radius:5px;
  position:relative;
  font-size:15px; line-height:140%; font-weight:700;
  text-align:center;
  background:rgba(89,136,20,0.1);
}
ul.howto-flow-outline-list li .tag{
  position:absolute;
  top:-10px; left:-10px;
  box-sizing:border-box;
  width:42px; height:42px;
  background:#598814;
  border-radius:100%;
  font-size:16px; line-height:16px; font-weight:700;
  color:#FFF;
  padding-top:9px;
}
ul.howto-flow-outline-list li .tag::before{
  content:"STEP";
  display:block;
  font-size:10px; line-height:10px; font-weight:400;
  transform:scale(0.9,1);
}

ul.howto-flow-list{
  margin:30px auto;
}
ul.howto-flow-list > li{
  width:780px;
  margin:0 auto 40px auto;
  box-sizing:border-box;
  padding:30px 40px;
  border:2px solid #598814;
  border-radius:5px;
  position:relative;
}
ul.howto-flow-list > li::after{
  content:"";
  border-top:20px solid #598814;
  border-left:30px solid transparent;
  border-right:30px solid transparent;
  position:absolute;
  bottom:-20px; left:50%;
  margin-left:-30px;
}
ul.howto-flow-list > li:last-child::after{
  display:none;
}
ul.howto-flow-list li .tag{
  position:absolute;
  top:-15px; left:-27px;
  box-sizing:border-box;
  width:54px; height:54px;
  background:#598814;
  border-radius:100%;
  font-size:18px; line-height:1; font-weight:700;
  color:#FFF; text-align:center;
  padding-top:12px;
}
ul.howto-flow-list li .tag::before{
  content:"STEP";
  display:block;
  font-size:12px; line-height:1; font-weight:400;
}
ul.howto-flow-list li h3{
  font-size:22px; line-height:180%;
//  color:#598814;
  border-bottom:2px dashed #598814;
  padding-bottom:5px;
  margin-bottom:20px;
}
ul.howto-flow-list li p:last-of-type{
  margin-bottom:0;
}
ul.howto-flow-list ol{
  margin:15px auto 0 auto;
}
ul.howto-flow-list ol strong{
  display:block;
  font-size:17px; line-height:160%;
}

.payment-caution-box{
  margin:25px auto;
  padding:25px 30px;
  border:1px dashed #999;
}
.payment-caution-box h3{
  margin-bottom:10px;
}
.payment-caution-box h3::before{
  content:"◆";
  color:#598814;
  margin-right:2px;
}
.payment-caution-box p{
  font-size:15px; line-height:160%;
  margin-bottom:10px;
}
.payment-caution-box p:last-of-type{
  margin-bottom:0;
}

ul.faq-list li{
  box-sizing:border-box;
  border:1px solid #598814;
  border-radius:7px;
  padding:20px 25px;
  margin:0 auto 30px auto;
}
ul.faq-list li .question{
  font-size:18px; line-height:180%; font-weight:700;
  color:#444;
  padding-left:36px;
  margin-bottom:10px;
  position:relative;
}
ul.faq-list li .question::before{
  content:"Q";
  position:absolute;
  top:0; left:0;
  font-size:30px; font-weight:400;
  color:#598814;
}
ul.faq-list li .answer{
  font-size:16px; line-height:180%;
  color:#444;
  padding-left:36px;
  position:relative;
}
ul.faq-list li .answer::before{
  content:"A";
  position:absolute;
  top:0; left:0;
  font-size:30px; font-weight:400;
  color:#dd0000;
}

/* side */
#side .side-program-box{
  box-sizing:border-box;
  background:rgba(244,244,236,0.8);
  border-radius:3px;
  padding:20px 30px;
/*
  position:sticky;
  top:85px;
*/
}
.side-program-box h2.present-amount{
  font-size:25px; line-height:160%;
}
.side-program-box h2.present-amount span{
  font-size:15px; font-weight:400;
  margin-right:0.5em;
}
.side-program-box .meter-box{
  width:100%; height:54px;
  position:relative;
}
.side-program-box .meter-box .meter{
  width:100%; height:20px;
  background:#ccc;
  border-radius:10px;
  overflow:hidden;
  position:absolute;
  top:17px; left:0;
}
.side-program-box .meter-box .meter .bar{
  position:absolute;
  top:0; left:0;
  height:20px;
  background:#fac75a;
}
.side-program-box .meter-box .percentage{
  width:54px; height:54px;
  background:#fac75a;
  border-radius:100%;
  color:#FFF;
  font-size:20px; line-height:54px; font-weight:700;
  text-align:center;
  position:absolute;
  top:0; left:0;
}
.side-program-box .meter-box .percentage::after{
  content:"%";
  font-size:14px;
}
.side-program-box .amount{
  display:flex;
  justify-content:flex-end;
  margin-top:-10px;
}
.side-program-box .amount02{
  display:flex;
  justify-content:flex-end;
}
.side-program-box .schedule{
  text-align:right;
}
.side-program-box .schedule::before{
  content:"";
  display:inline-block;
  width:18px; height:18px;
  background:url(../../img/svg/schedule.svg) no-repeat center center;
  background-size:18px auto;
  position:relative; top:4px;
  margin-right:5px;
}
.side-program-box .schedule .num{
  font-size:20px; line-height:160%;
  font-weight:500;
}
.side-program-box .schedule-end{
  text-align: center;
    margin-top: 30px;
    font-weight: bold;
    color: #FF0000;
}
.side-donation-box{
  border-top:1px solid #ccc;
  border-bottom:1px solid #ccc;
  margin:20px auto;
  padding:20px 0;
}
.side-donation-box h3{
  font-size:17px; line-height:160%;
  color:#FF6600;
  margin-bottom:5px;
}
.side-donation-box p{
  margin-bottom:0;
}
.side-donation-next-box{
  border-top:1px solid #ccc;
  margin:20px auto;
  padding:20px 0;
}
.side-note-box{
  border-top:1px solid #ccc;
  margin:20px auto;
  padding:20px 0;
}
#side .side-button-next a{
 	display: block;
    text-decoration: none;
    font-size: 16px;
    line-height: 36px;
    font-weight: 500;
    color:#FFFFFF;
    border-radius: 8px;
    margin: 0 auto;
    padding: 10px 2em;
    //transition: 0.3s;
    text-align: center;
    background: #555555;
}
#side .side-button-next a:hover{
  background:#FF6600;
  color:#fff;
  //transition:0.3s:
}
#side .side-group-box{
  box-sizing:border-box;
  border:1px solid #CCC;
  border-radius:3px;
  padding:20px 30px;
  margin:30px auto 0 auto;
}
.side-group-box .box-title{
  font-size:14px; line-height:160%; font-weight:500;
  color:#444;
  margin-bottom:10px;
}
.side-group-box h2{
  font-size:20px; line-height:160%;
  margin-bottom:10px;
}
.side-group-box ul.category{
  font-size:13px; line-height:160%;
}
.side-group-box ul.category li{
  margin-right:30px;
}
.side-group-box ul.category li a:hover{
  text-decoration:underline;
}
.side-group-box ul.category li span.label{
  display:inline-block;
  width:5.2em; height:18px;
  font-size:12px; line-height:17px;
}
.side-group-box ul.category li span.label::after{
  content:"：";
}

.side-group-box .button-more{
  text-align:center;
  margin:20px auto 5px auto;
}
.side-group-box .button-more a{
  display:block;
  text-decoration:none;
  font-size:14px; line-height:36px; font-weight:500;
  color:#402000;
  border:1px solid #402000;
  border-radius:18px;
  margin:0 auto;
  padding:0 2em;
  transition:0.3s;
}
.side-group-box .button-more a:hover{
  background:#402000;
  color:#fff;
  transition:0.3s;
}

.side-menu-box{
  box-sizing:border-box;
  background:rgba(244,244,236,0.6);
  border-radius:3px;
  padding:20px 30px;
}
.side-menu-box h2{
  font-size:17px; line-height:180%;
  padding-bottom:2px;
  border-bottom:2px solid #333;
}
.side-menu-box h2 a{
  display:block;
  text-decoration:none;
}
.side-menu-box h2.group{
  border-color:#402000;
}
.side-menu-box h2.group a{
  color:#402000;
}
.side-menu-box h2.news{
  border-color:#598814;
}
.side-menu-box h2.news a{
  color:#598814;
}
.side-menu-box h2.about{
  border-color:#d67958;
}
.side-menu-box h2.about a{
  color:#d67958;
}
.side-menu-box h2.subsidy{
  border-color:#ff6666;
}
.side-menu-box h2.subsidy a{
  color:#ff6666;
}

.side-menu-box ul.side-menu-list li{
  font-size:14px; line-height:160%;
  border-bottom:1px solid rgba(0,0,0,0.2);
}
.side-menu-box ul.side-menu-list li:last-child{
  border:none;
}
.side-menu-box ul.side-menu-list li a{
  display:block;
  padding:15px 0 15px 20px;
  color:#222;
  position:relative;
}
.side-menu-box ul.side-menu-list li:last-child a{
  padding-bottom:5px;
}
.side-menu-box ul.side-menu-list li a::before{
  content:"・";
  position:absolute;
  top:15px; left:2px;
}
ul.side-menu-list li a .entry-date{
  font-size:12px; line-height:180%;
  display:block;
}

.side-menu-box .button{
  font-size:13px; line-height:35px; font-weight:500;
  width:100%;
  margin:15px auto 5px auto;
}
.side-menu-box .button a{
  padding:0;
  border-radius:20px;
  border:1px solid #777;
  color:#444;
}
.side-menu-box .button a:hover{
  background:#777;
  color:#fff;
}

.side-group-search{

}
.side-group-search .side-search{
	width: 100px;
    padding: 5px;
    margin: 10px auto;
    text-align: center;
    display: block;
    cursor: pointer;
}


.side-note-box ul{
	font-size: 95%;
    padding-left: 20px;
}
.side-note-box p.title-name{
	margin-top: 20px;
    margin-bottom: 10px;
}
.side-note-box ul li{
	list-style: disc;
     margin-bottom: 5px;
}
.side-note-box ul li:last-child{
    margin-bottom: 0;
}




.search-name01{
	margin-bottom:-20px;
}
.search-name02{
	margin-bottom:-20px;
}

.search-name03{
	margin:20px 0 5px;
}

.side-precautions-message{
	font-size:95%;
	margin-bottom:10px;
	font-weight:bold;
}

#floating-box{
  position:fixed;
  top:50%; right:-50px; z-index:300;
  opacity:0;
  transform:translateY(-50%);
  transition:0.3s ease;
  width:auto; height:260px;
}
#floating-box.in-view{
  right:0px;
  opacity:1;
  transition:0.3s ease;
}
#floating-box a{
  display:block;
  text-decoration:none;
  -webkit-writing-mode:vertical-rl;
  -ms-writing-mode:tb-rl;
  writing-mode:vertical-rl;
  font-size:14px; line-height:1; font-weight:700;
  color:#FFF;
//  letter-spacing:-0.3em;
  white-space:nowrap;
  background:#FF6600;
  padding:1.2em 1.5em;
  border-radius:5px 0 0 5px;
}
_:lang(x)::-internal-media-controls-overlay-cast-button, #floating-box a{ /* chrome */
  letter-spacing:-0.3em;
}
_:-ms-lang(x)::backdrop, #floating-box a{ /* Edge */
  letter-spacing:0;
}
_:-ms-lang(x)::-ms-backdrop, #floating-box a{ /* IE11 */
  letter-spacing:0;
}

/* 遺贈寄付*/
#directory-title.title-program-legacy{
  color:#9b8f26;
}
#directory-title.title-program-legacy::before{
  background-image:url(../../img/svg/legacy_darkyellow.svg);
}
#directory-title.title-program-legacy::after{
  background-image:url(../../img/svg/title_bar_darkyellow.svg);
}
.property-img-box{
	float:right;
  width:360px;
  margin:0 0 15px 25px;
}
.izoukifu-inquiry{
  text-align: center;
  border:1px solid #ccc;
  padding:20px;
  margin:0 auto;

}
.izoukifu-banner{
  width: 500px;
  margin:50px  auto;
}
.property-banner-box{
  margin-bottom:80px;
}
.property-banner-box ul{
  display:flex;
  justify-content:space-between;
}
.property-banner-box ul li{
  width:410px;
}


/* マンスリー寄付*/
#directory-title.title-program-monthly{
  color:#006cb6;
}
#directory-title.title-program-monthly::before{
  background-image:url(../../img/svg/monthly_blue.svg);
}
#directory-title.title-program-monthly::after{
  background-image:url(../../img/svg/title_bar_blue.svg);
}
.monthly-img-box{
    width: 600px;
    margin:0 auto 30px;
}
.monthly-img-box02{
    width: 100%;
    margin:30px auto;
}
.monthly-table caption{
  	text-align:left;
  	font-weight:bold;
  	//margin:10px 0;
  	font-size:16px; line-height:160%;
  margin-bottom:5px;
 }
.monthly-table{
	 width:100%;
	 margin:0px auto 50px auto;
	 border-collapse:collapse;
	 border-bottom:1px solid #CCC;
}
.monthly-table tr{
	 border-top:1px solid #CCC;
}
.monthly-table th,
.monthly-table td{
	padding:20px 10px;
	font-weight:400;
  vertical-align:top;
}
.monthly-table th{
	width:20%;
}
.monthly-table span{
	font-weight:bold;
}
.monthly-table p.box-bottom{
	margin-bottom:0;
}
.monthly-bonx-innner{
	margin-top:80px;

}
.monthly-bonx-innner .monthly-title{
	font-weight:bold;
	margin-bottom:5px;
}
.child-support-img{
	margin:30px 0 50px 0;
}
.child-support-box ul.program-list{
  display:flex;
  flex-wrap:wrap;
  margin-bottom:60px;
  justify-content: start;
}
.child-support-box ul.program-list li{
  width:260px;
  background:#FFF;
  text-align:left;
  border-radius:5px;
  margin:0 30px 30px 0;
  box-shadow:2px 2px 4px #CCC;
}
.child-support-box ul.program-list li:nth-child(3n),
.child-support-box ul.program-list li:last-child{margin-right:0;}
.child-support-box ul.program-list li a{
  font-size:12px; line-height:160%;
  color:#111;
  text-decoration:none;
  position:relative;
}
.child-support-box ul.program-list li a .thumbnail{
  width:100%; height:150px;
  border-radius:5px 5px 0 0;
  overflow:hidden;
  position:relative;
}
.child-support-box ul.program-list li a .thumbnail img{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  transform-origin:50% 50%;
  transition:0.3s;
}
.child-support-box ul.program-list li a:hover .thumbnail img{
  width:110%; height:auto;
  transform:translate(-50%,-50%) rotate(-1deg);
  transition:0.3s;
}
.child-support-box ul.program-list li .text-box{
  padding:15px 15px;
  position:relative;
}
.child-support-box ul.program-list li a h3{
  font-size:16px; line-height:160%;
  color:#5b82af;
  margin-bottom:5px;
}
.child-support-box ul.program-list li a:hover h3{
  text-decoration:underline;
}
.child-support-box ul.program-list li .text-box .tag{
  display:inline-block;
  width:auto; height:16px;
  font-size:10px; line-height:17px;
  color:#FFF;
  padding:0 12px;
  border-radius:8px;
  position:absolute;
  top:-8px; left:15px;
}
.child-support-box ul.program-list li .text-box .tag.program01{
  background:#6699cc;
}
.child-support-box ul.program-list li .text-box .tag.program02{
  background:#CB6699;
}
.child-support-box ul.program-list li .text-box .tag.program03{
  background:#ff6666;
}
.child-support-box ul.program-list li .text-box .tag.program04{
  background:#996666;
}
.child-support-box ul.program-list li a .meter-box{
  width:100%; height:36px;
  position:relative;
  margin-bottom:5px;
}
.child-support-box ul.program-list li a .meter-box .meter{
  width:100%; height:12px;
  background:#ccc;
  border-radius:10px;
  overflow:hidden;
  position:absolute;
  top:12px; left:0;
}
.child-support-box ul.program-list li a .meter-box .meter .bar{
  position:absolute;
  top:0; left:0;
  height:12px;
  background:#fac75a;
}
.child-support-box ul.program-list li a .meter-box .percentage{
  width:36px; height:36px;
  background:#fac75a;
  border-radius:100%;
  color:#FFF;
  font-size:15px; line-height:36px; font-weight:700;
  text-align:center;
  position:absolute;
  top:0; left:0;
}
.child-support-box ul.program-list li a .meter-box .percentage::after{
  content:"%";
  font-size:12px;
}
.child-support-box ul.program-list li a .amount{
  display:flex;
  justify-content:flex-end;
}
.child-support-box ul.program-list li a .goal::after{
  content:"/";
  margin:0 5px;
}
.child-support-box ul.program-list li a .schedule{
  text-align:right;
}
.child-support-box ul.program-list li a .schedule::before{
  content:"";
  display:inline-block;
  width:18px; height:18px;
  background:url(../../img/svg/schedule.svg) no-repeat center center;
  background-size:18px auto;
  position:relative; top:4px;
  margin-right:5px;
}
.child-support-box ul.program-list li a .schedule .num{
  font-size:15px; line-height:160%;
  font-weight:500;
}
.child-support-box table{
  width:100%;
  margin:0 auto 25px auto;
  border-collapse:collapse;
}
.child-support-box table tr{
  border-bottom:1px solid #CCC;
}
.child-support-box table tr:last-child{
  border-bottom:none;
}
.child-support-box table th,
.child-support-box table td{
  padding:20px 0;
  font-weight:normal;
  vertical-align:top;
}
.child-support-box table th{
	width:30%;
	//border-right:1px solid #CCC;
}

.child-support-box a .button {
    width: 50%;
    font-size: 15px;
    line-height: 40px;
    border: 1px solid #402000;
    background: rgba(255,255,255,0.8);
    border-radius: 20px;
    transition: 0.3s;
    margin:0 auto;
    text-align:center;
    color:#000;
    margin-bottom:50px;
}
.child-support-box a:hover{
  text-decoration:none !important;
}
.child-support-box a:hover .button{
  background:#402000;
  color:#FFF;
  transition:0.3s;

}
.child-support-box .child-list-box{

}
.child-support-box .child-list-box li{
	float: left; width: 265px;margin-bottom:10px;margin-right:20px;
}
.child-support-box .child-list-box li:nth-child(3),
.child-support-box .child-list-box li:nth-child(6){
	margin-right:0;
}
.child-support-box .child-list-box li p{
	margin-top:10px;
	margin-bottom:20px;
}
.child-support{
	margin-top:50px;
	text-align:center;
}

/* 地域指定プログラム*/
#directory-title.title-program-area{
  color:#996666;
}
#directory-title.title-program-area::before{
  background-image:url(../../img/svg/area_lightbrown.svg);
}
#directory-title.title-program-area::after{
  background-image:url(../../img/svg/title_bar_lightbrown.svg);
}
.area-program-box a .button {
    width: 50%;
    font-size: 15px;
    line-height: 40px;
    border: 1px solid #402000;
    background: rgba(255,255,255,0.8);
    border-radius: 20px;
    transition: 0.3s;
    margin:0 auto;
    text-align:center;
    color:#000;
}
.area-program-box a:hover{
  text-decoration:none !important;
}
.area-program-box a:hover .button{
  background:#402000;
  color:#FFF;
  transition:0.3s;

}
.area-program-img-box{
	width:360px;
}
.area-program-message{
	width:450px;
}

/* 団体指定プログラム*/
#directory-title.title-program-group{
  color:#CB6699;
}
#directory-title.title-program-group::before{
  background-image:url(../../img/svg/group_purple.svg);
}
#directory-title.title-program-group::after{
  background-image:url(../../img/svg/title_bar_purple.svg);
}
.group-program-box .button{
  box-sizing:border-box;
  font-size:16px; line-height:20px; font-weight:500;
  width:420px;
  overflow:hidden;
  margin:0 auto;
}
.group-program-box .button a{
  display:block;
  text-decoration:none;
  text-align:center;
  padding:18px 0;
  border-radius:7px;
  transition:0.3s;
  background:#598814;
  color:#FFF;
}
.group-program-box .button a:hover{
  transition:0.3s;
}

/* 事業指定プログラム */
#directory-title.title-program{
  color:#6699cc;
}
#directory-title.title-program::before{
  background-image:url(../../img/svg/program_skyblue.svg);
}
#directory-title.title-program::after{
  background-image:url(../../img/svg/title_bar_skyblue.svg);
}

.program-donation-box section h1{
  display:inline-block;
  font-size:24px; line-height:140%; font-weight:700;
  border-bottom:none;
  margin-bottom:15px;
  padding-bottom:0px;
}
.program-donation-box section h1::before{
  display:inline-block;
  content:"";
  width:32px; height:32px;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:32px auto;
  position:relative; top:6px;
  margin-right:12px;
}
.program-donation-box section h1::after{
  display:block;
  content:"";
  width:auto; height:20px;
  background-repeat:no-repeat;
  background-position:left bottom;
  background-size:auto 13px;
}
.program-donation-box h1.title-program{
  color:#6699cc;
}
.program-donation-box h1.title-program::before{
  background-image:url(../../img/svg/program_skyblue.svg);
}
.program-donation-box h1.title-program::after{
  background-image:url(../../img/svg/title_bar_skyblue.svg);
}

.program-donation-box h1.title-program-group{
  color:#CB6699;
}
.program-donation-box h1.title-program-group::before{
  background-image:url(../../img/svg/group_purple.svg);
}
.program-donation-box h1.title-program-group::after{
  background-image:url(../../img/svg/title_bar_purple.svg);
}

.program-donation-box h1.title-program-area{
  color:#996666;
}
.program-donation-box h1.title-program-area::before{
  background-image:url(../../img/svg/area_lightbrown.svg);
}
.program-donation-box h1.title-program-area::after{
  background-image:url(../../img/svg/title_bar_lightbrown.svg);
}

.program-donation-box h1.title-program-monthly{
  color:#006cb6;
}
.program-donation-box h1.title-program-monthly::before{
  background-image:url(../../img/svg/monthly_blue.svg);
}
.program-donation-box h1.title-program-monthly::after{
  background-image:url(../../img/svg/title_bar_blue.svg);
}

.program-donation-box h1.title-program-legacy{
  color:#9b8f26;
}
.program-donation-box h1.title-program-legacy::before{
  background-image:url(../../img/svg/legacy_darkyellow.svg);
}
.program-donation-box h1.title-program-legacy::after{
  background-image:url(../../img/svg/title_bar_darkyellow.svg);
}

.button a.business-program{
  border:2px solid #6699cc;
  color:#6699cc;
}
.button a.business-program:hover{
  background:#6699cc;
  color:#fff;
}

.button a.group-program{
  border:2px solid #CB6699;
  color:#CB6699;
}
.button a.group-program:hover{
  background:#CB6699;
  color:#fff;
}

.button a.area-program{
  border:2px solid #996666;
  color:#996666;
}
.button a.area-program:hover{
  background:#996666;
  color:#fff;
}

.button a.monthly-program{
  border:2px solid #006cb6;
  color:#006cb6;
}
.button a.monthly-program:hover{
  background:#006cb6;
  color:#fff;
}

.button a.legacy-program{
  border:2px solid #9b8f26;
  color:#9b8f26;
}
.button a.legacy-program:hover{
  background:#9b8f26;
  color:#fff;
}

.business-program-box ul.program-list{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  margin:0 auto 0px auto;
//  margin-bottom:60px;
}
.business-program-box ul.program-list li{
  width:31.6%;
  background:#FFF;
  text-align:left;
  border-radius:5px;
  margin:0 0 30px 0;
  box-shadow:2px 2px 4px #CCC;
}
.business-program-box ul.program-list li:nth-child(3n),
.business-program-box ul.program-list li:last-child{margin-right:0;}
.business-program-box ul.program-list li a{
  font-size:12px; line-height:160%;
  color:#111;
  text-decoration:none;
  position:relative;
}
.business-program-box ul.program-list li a .thumbnail{
  width:100%; height:150px;
  border-radius:5px 5px 0 0;
  overflow:hidden;
  position:relative;
}
.business-program-box ul.program-list li a .thumbnail img{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  transform-origin:50% 50%;
  transition:0.3s;
}
.business-program-box ul.program-list li a:hover .thumbnail img{
  width:110%; height:auto;
  transform:translate(-50%,-50%) rotate(-1deg);
  transition:0.3s;
}
.business-program-box ul.program-list li .text-box{
  padding:15px 15px;
  position:relative;
}
.business-program-box ul.program-list li a h3{
  font-size:16px; line-height:160%;
  color:#5b82af;
  margin-bottom:5px;
}
.business-program-box ul.program-list li a:hover h3{
  text-decoration:underline;
}
.business-program-box ul.program-list li .text-box .tag{
  display:inline-block;
  width:auto; height:16px;
  font-size:10px; line-height:17px;
  color:#FFF;
  padding:0 12px;
  border-radius:8px;
  position:absolute;
  top:-8px; left:15px;
}
.business-program-box ul.program-list li .text-box .tag.program01{
  background:#6699cc;
}
.business-program-box ul.program-list li .text-box .tag.program02{
  background:#CB6699;
}
.business-program-box ul.program-list li .text-box .tag.program03{
  background:#ff6666;
}
.business-program-box ul.program-list li .text-box .tag.program04{
  background:#996666;
}
.business-program-box ul.program-list li a .meter-box{
  width:100%; height:36px;
  position:relative;
  margin-bottom:5px;
}
.business-program-box ul.program-list li a .meter-box .meter{
  width:100%; height:12px;
  background:#ccc;
  border-radius:10px;
  overflow:hidden;
  position:absolute;
  top:12px; left:0;
}
.business-program-box ul.program-list li a .meter-box .meter .bar{
  position:absolute;
  top:0; left:0;
  height:12px;
  background:#fac75a;
}
.business-program-box ul.program-list li a .meter-box .percentage{
  width:36px; height:36px;
  background:#fac75a;
  border-radius:100%;
  color:#FFF;
  font-size:15px; line-height:36px; font-weight:700;
  text-align:center;
  position:absolute;
  top:0; left:0;
}
.business-program-box ul.program-list li a .meter-box .percentage::after{
  content:"%";
  font-size:12px;
}
.business-program-box ul.program-list li a .amount{
  display:flex;
  justify-content:flex-end;
}
.business-program-box ul.program-list li a .goal::after{
  content:"/";
  margin:0 5px;
}
.business-program-box ul.program-list li a .schedule{
  text-align:right;
}
.business-program-box ul.program-list li a .schedule::before{
  content:"";
  display:inline-block;
  width:18px; height:18px;
  background:url(../../img/svg/schedule.svg) no-repeat center center;
  background-size:18px auto;
  position:relative; top:4px;
  margin-right:5px;
}
.business-program-box ul.program-list li a .schedule .num{
  font-size:15px; line-height:160%;
  font-weight:500;
}


/* 助成金情報*/
#directory-title.title-subsidy{
  color:#ff6666;
}
#directory-title.title-subsidy::before{
  background-image:url(../../img/svg/company_pink.svg);
}
#directory-title.title-subsidy::after{
  background-image:url(../../img/svg/title_bar_pink.svg);
}
.crown-program-container{

}


.crown-program-container ul.program-list li a .subsidy-status {
    position: absolute;
    top: -12px;
    left: -12px;
    box-sizing: border-box;
    width: 58px;
    height: 58px;
    border-radius: 100%;
    background: #ff6666;
    font-size: 13px;
    line-height: 15px;
    font-weight: 700;
    color: #FFF;
    text-align: center;
    padding: 14px 5px 0 5px;
    transform: rotate(-10deg);
}

.crown-program-container ul.program-list{
  display:flex;
  flex-wrap:wrap;
  margin-bottom:60px;
}
.crown-program-container ul.program-list li{
  width:400px;
  background:#FFF;
  text-align:left;
  border-radius:5px;
  margin:0 30px 30px 0;
  box-shadow:2px 2px 4px #CCC;
}
.crown-program-container ul.program-list li:nth-child(2n),
.crown-program-container ul.program-list li:last-child{margin-right:0;}
.crown-program-container ul.program-list li a{
  font-size:14px; line-height:160%;
  color:#111;
  text-decoration:none;
  position:relative;
}
.crown-program-container ul.program-list li .desciption{
}
.subsidy-box section h2 {
    font-size: 20px;
    line-height: 180%;
    color: #ff6666;
}
.subsidy-box section h2 span::after {
    border-color: #ff6666;
}
.subsidy-box ul.subsidy-thinking{
	padding-left:30px;
}
.subsidy-box ul.subsidy-thinking li{
	list-style:disc;
}
.subsidy-box .subsidy-img-box01{
	width:670px;margin:30px auto;
}
.subsidy-box .subsidy-img-box02{
	float:right;
  width:280px;
  margin:0 0 10px 25px;
}
.subsidy-box ul.howto-flow-list{
  margin:30px auto;
}
.subsidy-box ul.howto-flow-list > li{
  width:780px;
  margin:0 auto 40px auto;
  box-sizing:border-box;
  padding:30px 40px;
  border:2px solid #ff6666;
  border-radius:5px;
  position:relative;
}
.subsidy-box ul.howto-flow-list > li::after{
  content:"";
  border-top:20px solid #ff6666;
  border-left:30px solid transparent;
  border-right:30px solid transparent;
  position:absolute;
  bottom:-20px; left:50%;
  margin-left:-30px;
}
.subsidy-box ul.howto-flow-list > li:last-child::after{
  display:none;
}
.subsidy-box ul.howto-flow-list li .tag{
  position:absolute;
  top:-15px; left:-27px;
  box-sizing:border-box;
  width:54px; height:54px;
  background:#ff6666;
  border-radius:100%;
  font-size:18px; line-height:1; font-weight:700;
  color:#FFF; text-align:center;
  padding-top:12px;
}
.subsidy-box ul.howto-flow-list li .tag::before{
  content:"STEP";
  display:block;
  font-size:12px; line-height:1; font-weight:400;
}
.subsidy-box ul.howto-flow-list li h3{
  font-size:22px; line-height:180%;
  border-bottom:2px dashed #ff6666;
  padding-bottom:5px;
  margin-bottom:20px;
}
.subsidy-box ul.howto-flow-list li p:last-of-type{
  margin-bottom:0;
}
.subsidy-box ul.howto-flow-list ol{
  margin:15px auto 0 auto;
}
.subsidy-box ul.howto-flow-list ol strong{
  display:block;
  font-size:17px; line-height:160%;
}

/* プライバシーポリシー */
.privacy-list li{
	margin-bottom:30px;
}
.privacy-list li h3{
	margin-top:40px;
	margin-bottom:5px;
}
.privacy-list li ol.privacy-item-list{
	padding-left:30px;
}
.privacy-list li ol.privacy-item-list li{
	list-style:disc;
	margin-bottom:10px;
}
/* 特定商取引に関する法律に基づく表記 */

table.law-table{
	  width:100%;
	  margin:0 auto 50px auto;
	  border-collapse:collapse;
	  border-bottom:1px solid #CCC;
}
table.law-table tr{
	  border-top:1px solid #CCC;
}
table.law-table th,
table.law-table td{
	 padding:20px 10px;
	 font-weight:400;
}
table.law-table th{
	width:30%;
}

/* お問い合わせ */

.contact-box{

}
.contact-tel{
	border:5px solid #ccc;
	text-align:center;
	padding:20px;
	font-size:150%;
}
.contact-box table{
  width:100%;
  margin:0 auto 25px auto;
  border-collapse:collapse;
}
.contact-box table tr{
  border-bottom:1px dotted #CCC;
}
.contact-box table tr:last-child{
  border-bottom:none;
}
.contact-box table th,
.contact-box table td{
  padding:20px 20px;
  font-weight:normal;
  vertical-align:top;
}
.contact-box table th{
	width:30%;
}
.contact-box table input[type="text"],
.contact-box table input[type="tel"],
.contact-box table input[type="email"]{
	width:100%;
	background:#FCFCFC;
	font-size:15px;
	text-indent:10px;
}

.contact-box table textarea{
	box-sizing:border-box;
	width:100%; height:200px;
	padding:10px;
	font-size:15px; line-height:160%;
	background:#FCFCFC;
}

.contact-box td.privacy{
	font-size:15px; line-height:160%;
	text-align:center;
}
.contact-box input[type="submit"]{
	width:400px; height:52px;
	margin:30px auto 0 auto;
	padding:0;
	font-size:16px; line-height:52px; font-weight:700;
  border-radius:3px;
  border:2px solid #68430b;
	background:#FFF;
  color:#68430b;
	outline:none;
	cursor:pointer;
	transition:0.3s;
}
.contact-box input[type="submit"]:hover{
	color:#FFF;
	background:#68430b;
	border-color:#68430b;
	transition:0.3s;
}
.contact-box input[type="submit"]:disabled{
  background:#F6F6F6;
	color:#999;
	border-color:#999;
}

.cartjs_box{
  padding:0 0 20px 0 !important;
}
.cartjs_product_table table{
  width:100% !important;
  margin:0 auto 5px auto !important;
}
.cartjs_product_table table tr th{
  width:20%;
  font-weight:500 !important;
  text-align:right;
  white-space:nowrap;
  color:transparent;
//  background:#000;
  position:relative;
}
.cartjs_product_table table tr:first-child th{
}
.cartjs_product_table table tr th::after{
  color:#111;
  position:absolute;
  top:4px; right:0;
}
.cartjs_product_table table tr:first-child th::after{
  content:"寄付数：";
}
.cartjs_product_table table tr:nth-child(2) th::after{
  content:"金額：";
}
.cartjs_product_table table tr td{
  width:75%;
  position:relative;
}
.cartjs_product_table table tr td input.cartjs_product_input_txt{
  width:100% !important;
  height:30px !important;
  padding:0 !important;
  text-indent:0.6em;
  outline:none;
	-webkit-appearance:none;
	-moz-appearance:none;
	appearance:none;
}
.cartjs_product_table table tr.cartjs_option td select{
  width:100% !important;
  height:36px !important;
  padding:0 !important;
  text-indent:0.6em !important;
  outline:none;
	-webkit-appearance:none;
	-moz-appearance:none;
	appearance:none;
}
.cartjs_product_table table tr.cartjs_option td::after{
  content:"▼";
  font-size:11px; line-height:1;
  color:#FF6600;
  position:absolute;
  top:50%; right:10px; z-index:0;
  transform:translateY(-90%) scale(1,0.6);
}
/*
.cartjs_product_table table tr{
  display:inline-block !important;
  width:50% !important;
}
.cartjs_product_table table tr th{
  width:50px;
  padding-right:5px !important;
  text-align:right;
}
.cartjs_product_table table tr td input.cartjs_product_input_txt{
  width:90px !important;
  height:30px !important;
  padding:0 !important;
  text-indent:0.5em;
}
*/
.cartjs_cart_in input[type="submit"]{
  width:100% !important;
//  background:#777 !important;
  font-weight:700 !important;
  letter-spacing:2px !important;
  margin:0 auto !important;
  outline:none;
	-webkit-appearance:none;
	-moz-appearance:none;
	appearance:none;
  text-indent:-9999px;
  background-image:url(../../img/program/button_donation_off.png);
  background-repeat:no-repeat;
  background-position:center center;
  background-size:cover;
}
.cartjs_cart_in input[type="submit"]:hover{
  background-image:url(../../img/program/button_donation_on.png);
}


/* precautions */
.precautions-box-inner{
	position:relative;
	font-size:90%;
	margin-bottom:50px;
}
.precautions-box img{
	border:1px solid #ccc;
	width:838px;
}
.precautions01{
	position: absolute;
    top: 230px;
    left: 170px;
    width: 300px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.precautions02{
	position: absolute;
    top: 1440px;
    left: 230px;
    width: 250px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.precautions03{
	position: absolute;
    top: 2000px;
    left: 540px;
    width: 250px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.precautions04{
	position: absolute;
    top: 270px;
    left: 620px;
    width: 200px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.precautions05{
	position: absolute;
    top: 2200px;
    left: 490px;
    width: 330px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.precautions06{
	position: absolute;
    top: 2280px;
    left: 490px;
    width: 330px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.precautions07{
	position: absolute;
    top: 38px;
    right: 10px;
    width: 250px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFF;
}
.precautions-list{
	//margin-left:30px;
}
.precautions-list li{
	padding:5px 20px 5px 50px;
	//list-style:decimal;
	margin-bottom:10px;
	border-bottom:1px dotted #ccc;
	position:relative;
}
.precautions-list li:nth-child(1){
	padding-top:10px;
	border-top:1px dotted #ccc;
}
.precautions-list li:nth-child(1)::before{
  content:"①";
  margin-right:10px;
  position:absolute;
  top:10px;
  left:20px;
}
.precautions-list li:nth-child(2)::before{
  content:"②";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.precautions-list li:nth-child(3)::before{
  content:"③";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.precautions-list li:nth-child(4)::before{
  content:"④";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.precautions-list li:nth-child(5)::before{
  content:"⑤";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.precautions-list li:nth-child(6)::before{
  content:"⑥";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.precautions-list li:nth-child(7)::before{
  content:"⑦";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}

/* precautions */
.program-container .precautions-box-inner{
	position:relative;
	font-size:90%;
	margin-bottom:50px;
}
.program-container .precautions-box img{
	border:1px solid #ccc;
	width:760px;
}
.program-container .precautions01{
	position: absolute;
    top: 220px;
    left: 150px;
    width: 300px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.program-container .precautions02{
	position: absolute;
    top: 1300px;
    left: 200px;
    width: 250px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.program-container .precautions03{
	position: absolute;
    top: 1810px;
    left: 480px;
    width: 250px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.program-container .precautions04{
	position: absolute;
    top: 240px;
    left: 550px;
    width: 200px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.program-container .precautions05{
	position: absolute;
    top: 1980px;
    left: 410px;
    width: 330px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.program-container .precautions06{
	position: absolute;
    top: 2070px;
    left: 410px;
    width: 330px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFFFFF;
}
.program-container .precautions07{
	position: absolute;
    top: 38px;
    right: 10px;
    width: 250px;
    background: rgba(0,0,0,0.8);
    padding: 5px;
    border-radius: 5px;
    color:#FFF;
}
.program-container .precautions-list{
	//margin-left:30px;
}
.program-container .precautions-list li{
	padding:5px 20px 5px 50px;
	//list-style:decimal;
	margin-bottom:10px;
	border-bottom:1px dotted #ccc;
	position:relative;
}
.program-container .precautions-list li:nth-child(1){
	padding-top:10px;
	border-top:1px dotted #ccc;
}
.program-container .precautions-list li:nth-child(1)::before{
  content:"①";
  margin-right:10px;
  position:absolute;
  top:10px;
  left:20px;
}
.program-container .precautions-list li:nth-child(2)::before{
  content:"②";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.program-container .precautions-list li:nth-child(3)::before{
  content:"③";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.program-container .precautions-list li:nth-child(4)::before{
  content:"④";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.precautions-list li:nth-child(5)::before{
  content:"⑤";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.program-container .precautions-list li:nth-child(6)::before{
  content:"⑥";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}
.program-container .precautions-list li:nth-child(7)::before{
  content:"⑦";
  margin-right:10px;
  position:absolute;
  top:5px;
  left:20px;
}

/*giving12 */
.giving12-box section h2{
  color:#ea5528;
  font-size:20px; line-height:180%;
}

.giving12-box section h2 span::after{
  border-color:#ea5528;
}
.giving12-logo{
  position: absolute;
  box-shadow: 0 10px 10px 0 rgba(0, 0, 0, .5);
}
.giving12-message{
  background: #f6f6f6;
  padding:50px 20px 30px 350px;
  line-height: 180%;
  margin-top:50px;
  margin-left:50px;
}
.giving12-message p:first-child{
  font-size: 150%;
}
#directory-title.title-giving12{
  color:#ea5528;
}
#directory-title.title-giving12::before{
  background-image:url(../../img/svg/12_orange.svg);
}
#directory-title.title-giving12::after{
  background-image:url(../../img/svg/title_bar_orange.svg);
}
.side-giving12-list li{
  margin-bottom:15px;
}
.side-giving12-list li:last-child{
  margin-bottom:0;
}
.giving-list{
  display:flex;
  flex-wrap: wrap;
  justify-content:space-between;
  margin-top:30px;
}
.giving-list li{
  width:360px;
  padding:30px 20px 20px 20px;
  color: #FFF;
  margin-bottom:40px;
}
.giving-list li span{
  display: block;
  font-size:50px;
  margin-bottom:10px;
}
.giving-list li:first-child{
  background: #295eac;
}
.giving-list li:nth-child(2){
  background: #1789a4;
}
.giving-list li:nth-child(3){
  background: #e9558f;
}
.giving-list li:last-child{
  background: #187839;
}
.giving-list li:first-child span::after{
  content:"人";
  font-size:20px;
}
.giving-list li:nth-child(2) span::after{
  content:"人";
  font-size:20px;
}
.giving-list li:nth-child(3) span::after{
  content:"箇所";
  font-size:20px;
}
.giving-list li:last-child span::after{
  content:"％";
  font-size:20px;
}
.giving-list dl dd{
  display: list-item;
  list-style: disc;
  margin-left:20px;
  //padding-left:10px;
}
.giving12-banner-box{
  border-top:1px dotted #ccc;
  padding-top:40px;
  text-align: center;
  line-height: 200%;
}
.giving12-banner-box .button{
  margin-top:50px;
}
.giving12-banner-box .button a{
  border:2px solid #ea5528;
  color:#ea5528;
}
.giving12-banner-box .button a:hover{
  background:#ea5528;
  color:#fff;
}
