

@charset "UTF-8";

/*

    Aflac CSS
    定期保険Lightフィットプラン - 保険料シミュレーション

*/

/*コンテンツ部分*/
body.lightFit .whiteBox {
    padding-top: 24px
}
@media only screen and (max-width: 767px) {     /* SP */
   body.lightFit .whiteBox {
	    padding-top: 0px
	}
}

/* .bloSimulation
----------------------------------------------- */
.bloSimulation {
    display: block;
    background: #ffffff;
}
.bloSimulation * {
	font-family: 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', Verdana, Osaka, sans-serif;
}
@media only screen and (max-width: 767px) {     /* SP */
    .bloSimulation {
        padding: 16px 12px;
        margin: 0 -10px;
    }
    .bloSimulation * {
        font-family: sans-serif, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3";
    }
}
.bloSimulation .inputRadio,
.bloSimulation .inputCheckbox {
    display: none;
}


/* .bloCommonRadio 共通ラジオボタン設定
----------------------------------------------- */
.bloCommonRadio {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid #b2b2b2;
    background: #ffffff;
    cursor: pointer;
}
.bloCommonRadio::before {
    content: "";
    position: absolute;
    box-sizing: border-box;
    top: calc(50% - var(--radio-outer-radius) /2);
    left: var(--radio-outer-offset);
    width: var(--radio-outer-radius);
    height: var(--radio-outer-radius);
    border : 2px solid #b2b2b2;
    border-radius: 50%;
    background: #ffffff;
}
/* ハイライト設定 */
.inputRadio:checked + .bloCommonRadio {
    border-color: #0168b7;
}
.inputRadio:checked + .bloCommonRadio::before {
    border-color: #0168b7;
}
.inputRadio:checked + .bloCommonRadio::after {
    content: "";
    position: absolute;
    top: calc(50% - var(--radio-inner-radius) / 2);
    left: calc(var(--radio-outer-offset) + var(--radio-outer-radius) / 2 - var(--radio-inner-radius) / 2);
    width: var(--radio-inner-radius);
    height: var(--radio-inner-radius);
    border-radius: 50%;
    background: #0168b7;
}
/* 選択不可 */
.inputRadio:disabled + .bloCommonRadio {
    border-color: #d9d9d9;
    background: #d9d9d9;
    color: #787976;
    cursor: not-allowed;
}
.inputRadio:disabled + .bloCommonRadio::before {
    border-color: #787976;
    background: #d9d9d9;
}


/* #txtLargeInputLabel
----------------------------------------------- */
#txtLargeInputLabel {
    font-size: 24px;
    font-weight: bold;
}
@media print, screen and (min-width: 768px) {   /* PC */
    #txtLargeInputLabel {
        margin-bottom: 21px;
    }
}
@media only screen and (max-width: 767px) {     /* SP */
    #txtLargeInputLabel {
        margin-bottom: 14px;
    }
}


/* .txtInputLabel 性別・年齢・プランラベル
----------------------------------------------- */
.txtInputLabel {
    display: block;
}
@media print, screen and (min-width: 768px) {   /* PC */
    .txtInputLabel {
        font-size: 18px;
        line-height: 1.7;
    }
}
@media only screen and (max-width: 767px) {     /* SP */
    .txtInputLabel {
        font-size: 14px;
        margin-bottom: 5px;
    }
}


/* #bloSimSex 性別エリア
----------------------------------------------- */
#bloSimSex {
    display: flex;
    flex-wrap: wrap;
}
#bloSimSex {
	gap: 0px 20px;
	justify-content: start;
	margin-bottom: 35px;
}
@media only screen and (max-width: 767px) {     /* SP */
    #bloSimSex {
        gap: 0 10px;
        margin-bottom: 27px;
    }
}


/* .bloInputSex 性別ラジオボタン
----------------------------------------------- */
.bloInputSex {
    border-radius: 4px;
    padding: 4px 29px 4px 50px;
    color: black;
}
.bloInputSex {
	width: 228px;
	height: 61px;
	font-size: 20px;
	--radio-outer-radius: 32px;
	--radio-inner-radius: 18px;
	--radio-outer-offset: 10px;
}
@media only screen and (max-width: 767px) {     /* SP */
    .bloInputSex {
        /* width: 100%; */
        width: calc((100% - 10px)/2);
        height: 48px;
        font-size: 16px;
        --radio-outer-radius: 24px;
        --radio-inner-radius: 14px;
        --radio-outer-offset: 8px;
    }
}


/* #bloInputAge, #bloInputShiboAmt 年齢、コースセレクトボックスラッパー
----------------------------------------------- */
#bloInputAge,
#bloInputShiboAmt {
    position: relative;
    border: 2px solid #b2b2b2;
    border-radius: 4px;
    background: #ffffff;
    color: black;
}
#bloInputAge select,
#bloInputShiboAmt select {
    color: black;
}
#bloInputAge,
#bloInputShiboAmt {
	width: 257px;
	height: 60px;
	margin-bottom: 35px;
	display: inline-block;
}
span.course{
	/* display: block; */
	padding: 0.5em;
	font-size: 18px;
}
@media only screen and (max-width: 767px) {     /* SP */
    #bloInputAge,
    #bloInputShiboAmt {
        width: 200px;
        height: 48px;
        margin-bottom: 27px;
    }
    #bloInputShiboAmt {
        margin-bottom: 0px;
    }
	span.course{
		font-size: 14px;
	}
}
#bloInputAge::after,
#bloInputShiboAmt::after {
    content: "";
    position: absolute;
    top: calc(50% - 4px);
    right: 12px;
    display: block;
    border-top: 7px solid #b2b2b2;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    pointer-events: none;
}
/* ハイライト設定 */
#bloInputAge.isSelected,
#bloInputShiboAmt.isSelected {
    border-color: #0168b7;
}
#bloInputAge.isSelected::after,
#bloInputShiboAmt.isSelected::after {
    border-top-color: #0168b7;
}

/* #age, #course 年齢、コースセレクトボックス
----------------------------------------------- */
#age, #course {
    -webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
    display: block;
    width: 100%;
    height: 100%;
    border: none;
    padding: 5px 40px 5px 20px;
    background: transparent;
    text-align: center;
    outline: none;
    cursor: pointer;
}
@media print, screen and (min-width: 768px) {   /* PC */
    #age, #course {
        font-size: 20px;
    }
	#age option,
	#course option{
        font-size: 16px;
    }
}
@media only screen and (max-width: 767px) {     /* SP */
    #age, #course {
        font-size: 16px;
    }
}

/* .bloCalaBaseDate 計算基準日
----------------------------------------------- */
.bloCalaBaseDate {
    display: grid;
    justify-content: end;
    justify-items: end;
    grid-template: auto / auto 35px auto repeat(2, 19px auto);
    gap: 2.5px;
    margin-bottom: 20px;
}

/* .simulationResultBoxDetail 保険料計算結果
----------------------------------------------- */
.simulationResultAreaTitle {
	border-radius: 5px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #0168b7;
	color: #ffffff;
	font-size: 24px;
	font-weight: bold;
	padding: 5px;
}
@media only screen and (max-width: 767px) {     /* SP */
    .simulationResultAreaTitle {
		font-size: 16px;
	}
}
.simulationResultAreaDetail {
	margin: 10px auto;
	display: flex;
	gap: 10px;
}
.simulationResultBoxDetail {
	border: solid 2px #0168b7;
	border-radius: 5px;
	width: 100%;
	display: flex;
	flex-flow: column;
}
dl.simulationResultBoxDetail > dt {
	width: 40%;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #0168b7;
	color: #ffffff;
	font-weight: bold;
	padding: 5px 10px;
	width: 100%;
	font-size: 14px;
}
dl.simulationResultBoxDetail > dd {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	font-weight: bold;
	padding: 10px 25px;/
	width: 100%;
	height: 100%;
	font-size: 250%;
}
dl.simulationResultBoxDetail > dd .txYen {
	font-size: 71%;
}
@media only screen and (max-width: 767px) {     /* SP */
    dl.simulationResultBoxDetail > dt {
		font-size: 12px;
		min-height: 56px;
	}
	dl.simulationResultBoxDetail > dd {
		font-size: 179%;
		padding: 5px 10px;
	}
	dl.simulationResultBoxDetail > dd .txYen {
		font-size: 56%;
	}
}

ul.shibo_amt_1400 li span.komeCaution {
    left: 0;
    position: absolute;
    top: 6px;
}
ul.shibo_amt_1400 li span.komeCaution img {
	vertical-align: top;
}
ul.nonsmoker li {
	font-size: 12px;
}

/*- error, warning 
----------------------------------------------- */
#sex_error,
#age_error,
#course_error {
	flex-basis: 100%;
}
body.lightFit p.error,
body.lightFit p.warning {
	line-height: 1.4;
	padding: 0 0 3px 15px;
	background: url(../../../shared/images/sim/icon_error_l.gif) no-repeat left 0.2em;
	color: #ff0101;
}

/* .dialog	
----------------------------------------------- */
.textArea.simQuestion{
	margin-left: 0;
}

/* .buttonBanner フローティングバナー用ボタン
----------------------------------------------- */
.buttonBannerSim {
    text-decoration: none !important;
}
.floatingBanner {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 999;
	width: 100%;
	margin: 0;
	background: #f6e8a8;
}
.innerFloatingBanner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	align-content: center;
	padding: 0 48px 0 50px;
}
.buttonShiryoAreaFloatingBanner {
	display: grid;
	align-items: center;
	justify-content: center;
	border: 0;
	border-radius: 50px;
	background: #e98300;
	color: #ffffff !important;
	letter-spacing: 0.01em;
	cursor: pointer;
	text-decoration: none !important;
	grid-template: auto / auto auto;
	gap: 22px;
	width: 330px;
	height: 60px;
	font-size: 20px;
}
.iconButtonShiryoAreaFloatingBanner {
	width: 28px;
}
.buttonSimAreaFloatingBanner {
	width: 290px;
	background: rgba(29,163,143);
	text-align: center;
	text-decoration: none !important;
	padding: 16px 0px;
	border-radius: 45px;
	color: white !important;
	font-weight: bold;
	font-size: 18px;
	display: flex;
	justify-content: center;
	vertical-align: middle;
	height: 60px;
}
.iconButtonSimAreaFloatingBanner {
	width: 35px;
	margin-right: 10px;
}
@media print, screen and (min-width: 768px) {   /* PC */
	.floatingBanner {
		align-content: center;
		justify-content: center;
		grid-template: auto / 748px minmax(auto, 262px);
		height: 110px;
	}
}
@media only screen and (max-width: 767px) {     /* SP */
	.bottomNavi {
		display: none;
	}	
	.dBlock-sp {
		display: block;
	}
	.innerFloatingBanner {
		justify-content: space-between;
		width: 100%;
		padding: 10px 18px 0;
		margin-bottom: 10px;
	}
	.shiryoAreaFloatingBanner {
		width: calc(50% - 3px);
	}
	.buttonShiryoAreaFloatingBanner {
		display: flex;
		width: 100%;
		font-size: 16px;
	}
	.iconButtonShiryoAreaFloatingBanner {
		width: 25px;
		margin-right: -10px;
	}
	.simAreaFloatingBanner {
		width: calc(50% - 3px);
	}
	.buttonSimAreaFloatingBanner {
		width: 100%;
		font-size: 16px;
		align-items: center;
	}
	.imgExampleFigAreaRspGakushi {
		width: 100%;
		margin: 0 auto;
	}
	.txIconImgExampleFigAreaRspGakushi {
		font-size: 13px;
		padding: 3px 5px;
	}
}



