@charset "utf-8";

/* root/ikebukuro/maturity/
------------------------------------------ */

/* ヘッダー内 サブメニュー　PC only
------------------------------------------ */
header dl.submenu{
	width: 100%;
	max-width: 960px;
	margin: 2% auto 0;
	display: table;
}

header dl.submenu dt{
	display: table-cell;
	width: 14em;
	background-color: #368b38;
	color: #ffffff;
	padding: 2px 2px;
	border-radius: 5px;
	text-align: center;
	vertical-align: middle;
	white-space: nowrap;
}

header dl.submenu dd{
	display: table-cell;
	vertical-align: middle;
	padding-top: 2px;
}

header dl.submenu dd ul{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-wrap: wrap;
	margin-left: 1em;
	padding-top: 1px;
}

header dl.submenu dd ul li{
	margin-right: 1em;
	background:url(/ikebukuro/img/icon_link.png) no-repeat left 0px;
	background-size: 12px;
	padding: 0 0 0 14px;
	margin-bottom: 2px;
}


header dl.submenu dd ul li:nth-of-type(1){
	background:url(/ikebukuro/img/icon_anchor.png) no-repeat left 0px;
	background-size: 13px;
}


header dl.submenu a{
	color: #368138;
	text-decoration: none;
}

header dl.submenu a:hover{
	color: #ff8138;
}

@media screen and (max-width:768px) {
	header dl.submenu{
		display: none;
	}
}


/* メインコンテンツ article
------------------------------------------ */
article{
	width: 93.48%;
	max-width: 718px;
	padding:2% 3.26% 0;
}

article h1{
	box-sizing: border-box;
	width: 100%;
	border: #368d38 solid 1px;
	padding:0% 2% 1%;
}

article h1 img{
	width: 75.5%;
}

article p.remarks{
	text-size-adjust: 80%;
	width: 90%;
	padding: 1.5% 5% 0;
	line-height: 1.4em;
	font-size: 1.1rem;
}

article p.remarks span{
	color: #d80e19;
	font-size: 1.2em;
	font-weight: bold;
}

article p.s1_remarks{
	text-size-adjust: 80%;
	width: 90%;
	padding: 1.5% 5% 3%;
	line-height: 1.4em;
	font-size: 1rem;
}

.bold{
	font-weight: bold;
}

.detail{
	width: 96%;
	margin: 0 2%;
}

.link{
	padding-top: 0.5%;
	text-align: right;
}

.link a{
	background:url(/ikebukuro/img/icon_link.png) no-repeat right 2px;
	background-size: 12px;
	padding: 0px 16px 0 0;
	text-decoration: none;
	color: #ff8138;
}

.link a:hover{
	opacity:0.8;
	filter:alpha(opacity=80);
}


@media screen and (min-width:769px) {
	article{
		max-width: 960px;
		margin: 0 auto;
	}
	
	article h1{
		padding:1% 2%;
	}
	article h1 img{
		width: 38.43%;
	}
	
	article p.s1_remarks{
		padding: 1.5% 5% 0%;
	}
}


/* #s1
------------------------------------------ */
#s1 {
	width: 96%;
	margin: 0 2%;
}

#s1 h2{
	margin-top: 3%;
	padding: 1% 0;
	text-align: center;
	font-size: 1.4em;
	line-height: 1.5em;
	font-weight: bold;
	background-color: #368b38;
	color: #ffffff;
}

#s1 h2:last-of-type{
	margin-top: 10%;
	padding: 1% 0;
	text-align: center;
	font-size: 1.4em;
	line-height: 1.5em;
	font-weight: bold;
	background-color: #368b38;
	color: #ffffff;
}

/*#s1 h3{
	margin-top: 1.5%;
	font-size: 1.4em;
	display: -webkit-box;
	display: flex;
	align-items: center;
	color: #1d2088;
}
#s1 h3:before,
#s1 h3:after {
	border-top: 1px solid #1d2088;
	content: "";
	flex-grow: 1;
}
#s1 h3:before {
	margin-right: 0.5rem;
}
#s1 h3:after {
	margin-left: 0.5rem;
}*/

#s1 h4{
	margin-top: 7%;
}

#s1 h4 span:first-of-type{
	display: block;
	width: 12em;
	padding: 0.3em 0;
	margin: 0 0.5em 0.3em 0;
	text-align: center;
/*	background-color: #6db76d;	*/
	background-color: #458A27;
	color: #ffffff;
	font-size: 0.8em;
	border-radius: 5px;
}

#s1 h4 span:nth-of-type(2){
	font-size: 1.1em;
	color: #458a27 !important;
}

#s1 h4:nth-of-type(2){
	margin-top: 5%;
}

#s1 h4:nth-of-type(2) span:first-of-type{
/*	background-color: #e7849a;*/
	background-color: #DB4767;
	
}

#s1 h4:nth-of-type(2) span:nth-of-type(2){
	color: #db4767 !important;
}

#s1 h4:nth-of-type(2) div{
	margin-top: 0.5%;
	text-align: right;
	font-size: 0.8em;
	color: #db4767;
}

#s1 dl.subject{
	box-sizing: border-box;
	width: 100%;
	display: -webkit-box;
	display: flex;
	align-items: center;
	border: solid 1px #6db76d;
	border-radius: 5px;
	/*margin-top: 1%;*/
	margin-top: 3%;
	padding: 1%;
}

#s1 dl.subject dt{
	width: 20%;
	color: #6db76d;
	line-height: 1.4em;
	letter-spacing: 0.3em;
	white-space: nowrap;
	text-align: center;
	font-weight: bold;
}

#s1 dl.subject dd{
	width: 80%;
}

#s1 dl.subject dd li{
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.4em;
}

#s1 dl.subject dd span{
	color: #6db76d;
}

/*#s1 dl.subject:nth-of-type(3){
	border: solid 1px #e7849a;
}

#s1 dl.subject:nth-of-type(3) dt{
	color: #e7849a;
}

#s1 dl.subject:nth-of-type(3) dd span{
	color: #e7849a;
}*/

#s1 dl.flow{
	width: 100%;
	margin-top: 3%;
}

#s1 dl.flow dt{
	color: #1d2088;
	font-size: 1.1em;
	font-weight:bold;
}

#s1 dl.flow ul{
	width: 96%;
	margin: 0 2%;
}

#s1 dl.flow ul li{
	padding: 1% 0;
}

#s1 dl.flow ul li:nth-child(even){
	width: 6%;
	padding: 1% 47%;
	transform: rotate(90deg);
}

/* --- 追加：ボタンと注記のスタイル --- */
.procedure-action-area {
  	margin: 25px 0;
  	text-align: center;
}

/* 枠線あり・白背景・角丸ボタン */
.btn-outline-manual {
  	display: flex;
  	align-items: center;
  	justify-content: center;
  	position: relative;
  	width: 100%;
  	max-width: 450px;
  	margin: 0 auto 12px;
  	padding: 16px 42.5px 16px 12.5px; /* 右側の余白を少し調整 */
  	background-color: #ffffff;
  	border: 2px solid #368b38;
  	border-radius: 20px;
  	color: #368b38;
  	font-weight: bold; /* さらに太くして視認性をアップ */
  	text-decoration: none;
  	font-size: 1rem;
  	line-height: 1.2;
  	transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); /* 動きを滑らかに */
  	box-sizing: border-box;
  	box-shadow: 0 2px 4px rgba(0,0,0,0.05); /* 普段から少しだけ影を */
}

/* 右端の「＞」マーク */
.btn-outline-manual::after {
  	content: "";
 	position: absolute;
  	right: 20px;
  	top: 50%;
  	width: 8px;
  	height: 8px;
  	border-top: 2px solid #368b38;
  	border-right: 2px solid #368b38;
  	transform: translateY(-50%) rotate(45deg);
  	transition: all 0.3s ease;
}

/* --- 【強化】ホバー時の演出 --- */
@media (hover: hover) { /* マウス操作が可能なデバイスのみ適用 */
  	.btn-outline-manual:hover {
    	background-color: #368b38; /* 背景を緑に反転 */
    	color: #ffffff;            /* 文字を白に反転 */
    	transform: translateY(-3px); /* わずかに上に浮き上がる */
    	box-shadow: 0 6px 15px rgba(54, 139, 56, 0.3); /* 影を強くして浮遊感を出す */
  	}

  	.btn-outline-manual:hover::after {
    	border-color: #ffffff;      /* 矢印も白に反転 */
    	right: 15px;                /* 矢印が少し右にスライドする動き */
  	}
}

/* クリックした瞬間の沈み込み */
.btn-outline-manual:active {
  	transform: translateY(-1px);
  	box-shadow: 0 2px 5px rgba(54, 139, 56, 0.2);
}

/* 注記テキスト */
.procedure-note {
  	margin-top: 3%;
  	line-height: 1.5;
  	text-align: left;
  	display: inline-block;
  	max-width: 100%;
  	padding-left: 1em;
  	text-indent: -1em;
}

#s1 dl.bring{
	width: 100%;
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
	margin-top: 2%;
}

#s1 dl.bring dt,#s1 dl.bring dd{
	width: 49.5%;
	padding-top: 1%;
}

#s1 dl.bring dt{
	-webkit-text-size-adjust: 100%;
	box-sizing: border-box;
	padding-left: 0.5em;
	line-height: 1.2em;
	font-size: 1.2em;
	color: #DB4767;
}

#s1 .notice,
#s1 .important_notice{
	margin-top: 2%;
	padding: 2%;
	/*line-height: 1.4em;*/
	background-color: #eaeff9;
	border-radius: 5px;
}

#s1 .notice p{
	line-height: 1.4em;
}

.important_notice{
	text-align: center;
}

.important_notice dt{
	font-weight: bold;
	line-height: 1.4;
	font-size: 1.1em;
	text-decoration: underline;
}

.important_notice dd{
	margin-top: 0.5em;
	line-height: 1.4;
}



/*---2307/7/13---*/
.subject_raiten{
	box-sizing: border-box;
	width: 100%;
	align-items: center;
	border: solid 1px #e7849a;
	border-radius: 5px;
	margin-top: 3%;
	padding: 1%;
}

.subject_raiten dt{
	margin: 2% 0%;
	color: #e7849a;
	line-height: 1.4em;
	text-align: center;
	font-weight: bold;
}

.subject_raiten dd{
	width: 95%;
	margin: 0 2.5%;
}

.subject_raiten dd li{
	line-height: 1.6em;
}

.subject_raiten dd span{
	color: #e7849a;
	margin-right: 1%;
}

.procedure_notice{
	margin-top: 5%;
}


@media screen and (min-width:769px) {
	#s1 h2:last-of-type{
		margin-top: 5%;
	}
	
	#s1 h4{
		display: -webkit-box;
		display: flex;
		font-size: 1.2em;
		margin-top: 5%;
	}
	
	#s1 h4 div{
		padding-left: 0.5em;
	}
	
	#s1 dl.subject{
		margin-top: 1%
	}
	
	#s1 dl.subject dt{
		width: 6em;
	}

	#s1 dl.subject dd{
		width: inherit;
	}

	#s1 dl.subject dd ul{
		overflow: hidden;
	}
	
	#s1 dl.subject dd ul li{
		float: left;
		margin-right: 1em;
	}
	
	#s1 dl.flow ul{
		display: -webkit-box;
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin: 1% 2% 0;
	}
	
	#s1 dl.flow ul li{
		width: 32%;
		padding: 0;
	}
	
	#s1 dl.flow ul li:nth-child(even){
		width: 2%;
		padding: 1% 0;
		transform: rotate(0deg);
	}
	
	/* ---スマートフォン満期ボタンエリア--- */
	.procedure-action-area {
    	margin: 30px 0;
  	}
  
  	.btn-outline-manual {
    	font-size: 1.35rem;
    	padding: 15px 60px 15px 35px;
    	max-width: 500px;
    	border-radius: 50px;
  	}

  	.btn-outline-manual::after {
    	width: 12px;
    	height: 12px;
    	border-top: 3px solid #368b38;
    	border-right: 3px solid #368b38;
    	right: 25px;
  	}

  	/* PCホバー時の矢印移動距離を調整 */
  	.btn-outline-manual:hover::after {
    	right: 20px;
  	}
  
  	.procedure-note {
    	margin-top: 1%;
  	}
	/* ---ここまで--- */
	
	#s1 dl.bring dt,#s1 dl.bring dd{
		width: 24.75%;
		padding-top: 1%;
		font-size: 1.3em;
	}
	
	.subject_raiten{
		display: -webkit-box;
		display: flex;
		border: solid 1px #e7849a;
		border-radius: 5px;
		margin-top: 1%;
		padding: 1%;
	}
	
	.subject_raiten dt{
		width: 15%;
		line-height: 1.4em;
		letter-spacing: 0.3em;
	}
	
	.subject_raiten dd{
		width: 37.5%;
		margin: 0 2.5%;
	}
	
	.procedure_notice{
		margin-top: 3%;
	}
}



/* div.presec section
------------------------------------------ */
div.presec section {
	width: 96%;
	margin: 3% 2% 0;
}

div.presec section h2{
	margin-top: 5%;
	padding-bottom: 1px;
	font-size: 1.2em;
	font-weight: bold;
	color: #00828c;
	border-bottom: #40bfb6 1px solid;
}

div.presec section ul{
	margin-top: 1.5%;
}

div.presec section ul li{
	line-height: 1.4em;
	padding-left: 1em;
	text-indent: -1em;
}

.procedure_notice dl.notice_box,
div.presec section dl.notice{
	box-sizing: border-box;
	width: 100%;
	margin-top: 2%;
	/*border: #ff4628 solid 1px;*/
	border: #cc0000 solid 1px;
}

.procedure_notice dl.notice_box dt,
div.presec section dl.notice dt{
	width: 4em;
	padding: 1%;
	font-weight: bold;
	text-align: center;
	/*background-color: #ff4628;*/
	background-color: #cc0000;
	color: #ffffff;
}

.procedure_notice dl.notice_box dd,
div.presec section dl.notice dd{
	padding: 1% 2% 2%;
}

.procedure_notice dl.notice_box dd li,
div.presec section dl.notice dd li{
	line-height: 1.4em;
	padding-left: 1em;
	text-indent: -1em;
}

div.presec section  p{
	margin-top: 1.5%;
	line-height: 1.4em;
}

div.presec section p span{
	color: #d80e19;
}

.poa p img{
	margin-top: 5%!important;
	width: 70%;
	margin: 0 15%;
}

.info{
	margin-top: 3%!important;
	padding-left: 1em;
	text-indent: -1em;
	color: #cc0000;
	text-align: center;
}



div.presec section p.banner{
	width: 100%;
	margin-top: 5%;
}

div.presec section dl.attn{
	width: 100%;
	margin-top:4%;
}

div.presec section dl.attn dt{
	padding: 5px 0 5px 5px;
	/*background-color:#ff4628;*/
	background-color:#cc0000;
	color:#ffffff;
	font-size:1.1em;
}

div.presec section dl.attn dd{
	/*border:#ff4628 solid 1px;*/
	border:#cc0000 solid 1px;
	padding:5px;
}

div.presec section dl.attn ul li{
	padding-left:1em;
	text-indent:-1em;
	line-height:1.4em;
}

@media screen and (min-width:769px) {
	div.presec section div.wrap{
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;	
		align-items: center;
	}
	
	div.presec section div.wrap > div{
		width: 49%;
	}
	
	.poa p img{
		width: 68%;
	}
	
	div.presec section p.banner{
		margin: 5% auto 0;
		max-width: 700px;
	}
	
	div.presec section dl.attn{
		margin: 4% auto 0;
		max-width: 700px;		
	}
}



/* 
------------------------------------------ */
p.totop{
	text-align: right;
	color: #ff4628;
	margin-top: 1.5%;
	padding-right: 2.5%;
	font-size: 0.9em;
}

p.totop a{
	color: #368d38;
	text-decoration: none;
}

p.totop a:hover{
	color: #ff4628;
}


@media screen and (min-width:769px) {
	p.totop{
		max-width: 960px;
		margin: 22px auto 0;
	}
}


/* アコーディオン
------------------------------------------ */
/* --- アコーディオン全体 --- */
.accordion-item {
  border: 1px solid #d0d0d0;
  border-radius: 4px;
  /*margin-bottom: 15px;*/
	margin: 5% 0 0;
  background-color: #ffffff;
  overflow: hidden;
}

/* --- タイトル部分（ボタン） --- */
.accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 16px 20px;
  background-color: #f8f8f8; /* わずかにグレーにしてクリック領域を明示 */
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background-color 0.3s;
}

.accordion-header:hover {
  background-color: #f0f0f0;
}

/* タイトル文字（ロゴカラーの紺） */
.accordion-title-text {
  color: #1d2088;
  font-weight: bold;
  font-size: 1rem;
  line-height: 1.4;
  padding-right: 10px;
}

/* --- アイコン（＋・ー） --- */
.accordion-icon-mark {
  position: relative;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}

/* ＋とーを構成する棒（ロゴカラーの緑） */
.accordion-icon-mark::before,
.accordion-icon-mark::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 14px;
  height: 2px;
  background-color: #368b38;
  transform: translate(-50%, -50%);
  transition: transform 0.3s ease;
}

/* 縦棒を回転させて「＋」を作る */
.accordion-icon-mark::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

/* 開いた状態（is-open）のとき：縦棒を横棒に重ねて「ー」にする */
.accordion-header.is-open .accordion-icon-mark::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

/* --- コンテンツ開閉アニメーション --- */
.accordion-content {
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: all 0.3s ease-out; /* ここでフワッと感を調整 */
}

.accordion-content-inner {
  /*padding: 20px;*/
	padding: 10px;
  border-top: 1px solid #eeeeee;
}

/* --- ブレイクポイント（769px以上） --- */
@media screen and (min-width: 769px) {
  .accordion-header {
    padding: 20px 30px;
  }
  .accordion-title-text {
    font-size: 1.1rem;
  }
  .accordion-content-inner {
    padding: 30px;
  }
}

/* 
------------------------------------------ */


.just{
	text-align:justify;
}

.mgt10{
	margin-top: 10px;
}

.mgt20{
	margin-top: 20px;
}

.hgt-ind{
	padding-left:1em;
	text-indent:-1em;
	line-height: 1.4;
}

.ind{
	padding-left:1em;
	text-indent:-1em;
}

.red{
	color: #cc0000;
}