@charset "utf-8";

/* ****************************************************************************

　目次

-------------------------------------------------------------------------------

　01. モジュール

******************************************************************************* */
/* ==

　01. モジュール

=============================================================================== */
/* 大枠
------------------------------------------------------------------------------- */
.cfContent {
	max-width: 1240px;
	margin: 0 auto 115px;
	padding: 0 15px;
}
.cfForm01 {
	margin: 100px 0 0;
}
/* 見出し
------------------------------------------------------------------------------- */
.cfHeading01 {
	position: relative;
	line-height: 1.6;
	margin: 30px 0 44px;
	padding: 22px 0 24px;
	font-size: 300%;
	font-weight: 700;
	border-bottom: 1px solid #E5E4E0;
}
.cfHeading01::before {
	content: "";
	display: block;
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 124px;
	height: 3px;
	background-color: #CC3B33;
}
.cfHeading02 {
	line-height: 1.6;
	margin: 30px 0 26px;
	font-size: 250%;
	font-weight: 700;
}
.cfHeading02 span {
	display: inline-block;
	margin: 0 0 0 10px;
	color: #CC3B33;
	font-size: 60%;
	vertical-align: 0.2em;
}
.cfHeading03 {
	position: relative;
	line-height: 1.6;
	margin: 31px 0 25px;
	padding: 0 0 0 25px;
	color: #CC3B33;
	font-size: 200%;
	font-weight: 700;
}
.cfHeading03::before {
	content: "";
	display: block;
	position: absolute;
	top: 5px;
	left: 0;
	bottom: 3px;
	width: 6px;
	background-color: #CC3B33;
}
.cfHeading04 {
	display: -webkit-box;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.cfHeading04-reverse {
	flex-direction:row-reverse;
}
.cfHeading04_tit {
	width: 36%;
	margin: 0;
	padding: 9px 0 11px;
	background-color: #3F3E3C;
	color: #fff;
	font-size: 150%;
	font-weight: 500;
	text-align: center;
}
.cfHeading04_txt {
	width: 64%;
	line-height: 1;
	margin: 0;
	padding: 0 0 0 48px;
	font-size: 150%;
	font-weight: 500;
	box-sizing: border-box;
}
.cfHeading05 {
	line-height: 1.6;
	margin: 39px 0 17px;
	font-size: 18px;
	font-weight: 700;
}
.cfHeading05:first-child {
	margin-top: 0;
}
.cfHeading05 span {
	font-weight: 400;
}
/* カタログ選択
------------------------------------------------------------------------------- */
.cfCatalog01 {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	flex-direction:row-reverse;
}
.cfCatalog01_w {
	width: 65.968%;
	max-width: 818px;
}
.cfCatalog01_n {
	width: 31.936%;
	max-width: 396px;
}
.cfCatalog01_w .cfList01_item {
	width: 48.412%;
}
.cfCatalog01_n .cfList01_item {
	width: 100%;
}
.cfList01 {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	font-size: 100%;
}
.cfList01_item {
	position: relative;
	width: 31.936%;
	padding: 20px;
	background-color: #fff;
	box-sizing: border-box;
	cursor: pointer;
}
.cfList01_item-selected {
	background-color: #F5F4F0;	
}
.cfList01_box {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
}
.cfList01_img {
	display: block;
	width: 39.888%;
	max-width: 142px;
}
.cfList01_info {
	width: 54.494%;
}
.cfList01_tit {
	line-height: 1.6;
	margin: 0 0 15px;
	padding: 7px 0 9px;
	border-bottom: 1px solid #E5E4E0;
	font-size: 150%;
	font-weight: 700;
}
.cfList01_txt {
	line-height: 1.6;
	margin: 0;
	font-size: 134%;
	font-weight: 400;
}
.cfList01_btn1 {
	line-height: 53px;
	margin: 16px 0 0;
	padding: 0 0 3px;
	border: 1px solid #807F7D;
	background-color: #fff;
	color: #807F7D;
	font-size: 134%;
	font-weight: 500;
	text-align: center;
}
.cfList01_btn2 {
	line-height: 53px;
	margin: 16px 0 0;
	padding: 0 0 3px;
	border: 1px solid #CC3B33;
	background-color: #CC3B33;
	color: #fff;
	font-size: 134%;
	font-weight: 500;
	text-align: center;
}
.cfList01_item .cfList01_btn1 {
	display: block !important;
}
.cfList01_item .cfList01_btn2 {
	display: none !important;
}
.cfList01_item-selected .cfList01_btn1 {
	display: none !important;
}
.cfList01_item-selected .cfList01_btn2 {
	display: block !important;
}
/* ステップ
------------------------------------------------------------------------------- */
.cfFlow01 {
	display: -webkit-box;
	display: flex;
	max-width: 858px;
	line-height: 1.6;
	margin: 0 auto 58px;
	font-size: 16px;
	font-weight: 500;
	background-color: #F5F4F0;
	overflow: hidden;
}
.cfFlow01_item {
	display: -webkit-box;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 25%;
	height: 58px;
	padding: 0 0 0 4px;
	text-align: center;
	box-sizing: border-box;
}
.cfFlow01_item:nth-child(2),
.cfFlow01_item:nth-child(3) {
	padding: 0 0 0 22px;
}
.cfFlow01_item:nth-child(2),
.cfFlow01_item:nth-child(4) {
	padding: 0 0 0 10px;
}
.cfFlow01_item-current {
	background-color: #CC3B33;
	color: #fff;
}
.cfFlow01_item::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: -23px;
	bottom: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 0 30px 23px;
	border-color: transparent transparent transparent #E5E4E0;
}
.cfFlow01_item::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: -21px;
	bottom: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 0 30px 23px;
	border-color: transparent transparent transparent #F5F4F0;
}
.cfFlow01_item-current::before {
	border-color: transparent transparent transparent #CC3B33;
}
.cfFlow01_item-current::after {
	content: none;
}
.cfFlow01_item:last-child::before,
.cfFlow01_item:last-child::before {
	content: none;
}
.cfFlow01_item-before::before {
	border-color: transparent transparent transparent #F5F4F0;
	z-index: 4;
}
/* フォーム選択
------------------------------------------------------------------------------- */
.cfSelect01 {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 30px 0 0;
}
.cfSelect01_item {
	position: relative;
	width: 49.4%;
	margin: 20px 0 0;
	padding: 34px 0 97px;
	border: 1px solid #CCCAC8;
	background-color: #F5F4F0;
	text-align: center;
	cursor: pointer;
	box-sizing: border-box;
}
.cfSelect01_item:nth-child(1),
.cfSelect01_item:nth-child(2) {
	margin-top: 0;
}
.cfSelect01_tit {
	line-height: 1.6;
	margin: 0 0 17px;
	font-size: 200%;
	font-weight: 700;
}
.cfSelect01_img {
	display: block;
	width: 120px;
	margin: 0 auto;
}
.cfSelect01_btn1 {
	display: block;
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	line-height: 59px;
	padding: 0 0 2px;
	background-color: #fff;
	color: #807F7D;
	font-size: 134%;
	font-weight: 500;
	text-align: center;
}
.cfSelect01_btn2 {
	display: block;
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	line-height: 59px;
	padding: 0 0 2px;
	background-color: #CC3B33;
	color: #fff;
	font-size: 134%;
	font-weight: 500;
	text-align: center;
}
.cfSelect01_item .cfSelect01_btn1 {
	display: block !important;
}
.cfSelect01_item .cfSelect01_btn2 {
	display: none !important;
}
.cfSelect01_item-selected .cfSelect01_btn1 {
	display: none !important;
}
.cfSelect01_item-selected .cfSelect01_btn2 {
	display: block !important;
}
/* エラー表示
------------------------------------------------------------------------------- */
.cfError01 {
	margin: 0 0 30px;
}
.cfError01_item {
	margin: 0 0 15px;
}
.cfError01_item:last-child {
	margin-bottom: 0;
}
.cfError01_txt {
	display: inline-block;
	position: relative;
	padding: 10px 25px 11px 40px;
	border: 2px solid #E70000;
	border-radius: 2px;
	background-color: #FFE7E5;
	color: #E70000;
	font-weight: 500;
}
.cfError01_txt::before {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 14px;
	width: 18px;
	height: 18px;
	margin: -8px 0 0;
	background: url(/tochikatsu/d-room/common/images/rn03/svg/ico_alert01.svg) center center no-repeat;
	background-size: contain;
}
.cfError02 {
	line-height: 1.6;
	margin: 7px 0 0;
	color: #E70000;
	font-size: 12px;
	font-weight: 700;
}
/* 入力画面
------------------------------------------------------------------------------- */
.cfLayout01 {
	width: 100%;
}
.cfLayout01 th {
	width: 36%;
	line-height: 1.6;
	position: relative;
	height: 106px;
	padding: 10px 40px;
	border-bottom: 1px solid #E5E4E0;
	background-color: #F5F4F0;
	font-size: 150%;
	font-weight: 700;
	vertical-align: middle;
	box-sizing: border-box;
}
.cfLayout01 th span {
	font-weight: 400;
}
.cfLayout01 td {
	width: 64%;
	line-height: 1.6;
	padding: 43px 40px 42px 48px;
	border-bottom: 1px solid #fff;
	background-color: #fff;
	font-size: 134%;
	font-weight: 400;
	vertical-align: middle;
}
/* 確認画面
------------------------------------------------------------------------------- */
.cfLayout02 {
	width: 100%;
}
.cfLayout02 th {
	line-height: 1.6;
	width: 36%;
	height: 106px;
	padding: 10px 40px;
	border-bottom: 1px solid #E5E4E0;
	background-color: #F5F4F0;
	font-size: 150%;
	font-weight: 700;
	vertical-align: middle;
	box-sizing: border-box;
}
.cfLayout02 th span {
	font-weight: 500;
}
.cfLayout02 td {
	width: 64%;
	line-height: 1.6;
	padding: 40px 48px;
	border-bottom: 1px solid #fff;
	background-color: #fff;
	color: #807F7D;
	font-size: 134%;
	font-weight: 400;
	vertical-align: middle;
}
.cfLayout02_list {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	max-width: 550px;
	font-size: 100%;
}
.cfLayout02_item {
	width: 30%;
}
.cfLayout02_thumb {
	display: block;
	max-width: 106px;
	margin: 0 auto;
}
.cfLayout02_thumb img {
	border: 1px solid #E5E4E0;
}
.cfLayout02_caption {
	line-height: 1.6;
	margin: 24px 0 0;
	font-size: 100%;
	font-weight: 400;
	text-align: center;
}
/* 完了画面
------------------------------------------------------------------------------- */
.cfEnd01 {
	max-width: 480px;
	margin: 77px auto 0;
}
.cfEnd01_tit {
	line-height: 1.6;
	margin: 0 0 26px;
	font-size: 250%;
	font-weight: 700;
}
.cfEnd01_txt {
	line-height: 1.6;
	margin: 0;
	font-size: 134%;
	font-weight: 400;
}
.cfEnd01_btn {
	display: inline-block;
	line-height: 1.6;
	margin: 35px 0 0;
	color: #CC3B33;
	font-size: 134%;
	font-weight: 700;
}
/* ボタン
------------------------------------------------------------------------------- */
.cfBtns01 {
	margin: 60px 0 0;
	text-align: center;
}
.cfBtns01_btn {
	display: inline-block;
	position: relative;
	-webkit-appearance: none;
	appearance: none;
	line-height: 1.6;
	margin: 0 10px;
	padding: 17px 35px 19px;
	border: none;
	border-radius: 4px;
	color: #fff;
	font-family: inherit;
	font-size: 134%;
	font-weight: 500;
	text-decoration: none;
	box-sizing: border-box;
	cursor: pointer;
	vertical-align: top;
	text-align: center;
	letter-spacing: normal;
}
.cfBtns01_btn-t1 {
	border: 1px solid #CC3B33;
	background-color: #fff;
	color: #CC3B33;
	transition: all .3s;
}
.d_hover .cfBtns01_btn-t1:hover {
	border: 1px solid #CC3B33;
	background-color: #CC3B33;
	color: #fff;
}
.cfBtns01_btn-t2 {
	border: 1px solid #CC3B33;
	background-color: #CC3B33;
	transition: all .3s;
}
.d_hover .cfBtns01_btn-t2:hover {
	border: 1px solid #B2B1AE;
	background-color: #B2B1AE;
	color: #fff;
}
.cfBtns01_btn-t3 {
	border: 1px solid #999;
	background-color: #999;
	cursor: default;
}
.cfPolicy01 {
	width: 100%;
	height: 140px;
	padding: 13px 20px;
	border: 1px solid #ddd;
	overflow: auto;
	box-sizing: border-box;
}
.cfPolicy01 p {
	margin: 0 0 10px;
	font-size: 14px;
}
/* フォーム部品
------------------------------------------------------------------------------- */
input::-webkit-input-placeholder { padding-bottom: 0.4em; }
.fText {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	height: 40px;
	line-height: 1;
	padding: 0 16px;
	border: 1px solid #B2B1AE;
	border-radius: 0;
	background-color: #fff;
	color: #000;
	font-family: inherit;
	font-size: 16px;
	font-weight: 400;
	box-sizing: border-box;
	transition: border 0.3s, background 0.3s;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	outline: none;
}
.fText::placeholder {
	color: #B2B1AE;
}
.fText:-ms-input-placeholder {
	color: #B2B1AE;
}
.fText::-ms-input-placeholder {
	color: #B2B1AE;
}
.fText::-webkit-input-placeholder {
	padding-top: 0.25em;
}
.fText::-ms-clear {
	visibility:hidden;
}
.fText-error {
	border-color: #E70000;
}
.fText-required {
	border-color: #E70000;
}
.fArea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	line-height: 1.6875;
	padding: 10px 16px;
	border: 1px solid #807F7D;
	border-radius: 0;
	background-color: #fff;
	color: #000;
	font-family: inherit;
	font-size: 16px;
	font-weight: 400;
	resize: none;
	box-sizing: border-box;
	-webkit-appearance: none;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	outline: none;
}
.fArea::placeholder {
	color: #B2B1AE;
}
.fArea:-ms-input-placeholder {
	color: #B2B1AE;
}
.fArea::-ms-input-placeholder {
	color: #B2B1AE;
}
.fArea::-webkit-input-placeholder {
	padding-top: 0.25em;
}
.fArea-error {
	border-color: #E70000;
}
.fArea-required {
	border-color: #E70000;
}
.fArea-h1 {
	height: 321px;
}
.fArea-h2 {
	height: 321px;
}
.fSelect {
	display: inline-block;
	position: relative;
	border: none;
	background: #fff;
	overflow: hidden;
	cursor: pointer;
	vertical-align: middle;
}
.fSelect select {
	width: 220px;
	height: 40px;
	text-indent: 0.01px;
	text-overflow: ellipsis;
	border: 1px solid #B2B1AE;
	border-radius: 0;
	padding: 0 45px 0 10px;
	outline: none;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
	color: #000;
	font-size: 16px;
	font-weight: 400;
	font-family: inherit;
	cursor: pointer;
}
.fSelect select::-ms-expand {
	display: none;
}
.fSelect-error select {
	border-color: #E70000;
}
.fSelect-required select {
	border-color: #E70000;
}
.fSelect::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 20px;
	width: 0;
	height: 0;
	margin: -6px 0 0;
	border-style: solid;
	border-width: 13px 11px 0 11px;
	border-color: #807F7D transparent transparent transparent;
	pointer-events: none;
}
.cfCheck01 {
	line-height: 1;
	margin: -35px 0 0;
	font-size: 18px;
	font-weight: 500;
	letter-spacing: -0.5em;
}
.cfCheck01 li {
	display: inline-block;
	margin: 35px 18px 0 0;
	letter-spacing: normal;
}
.cfCheck01 li:last-child {
	margin-right: 0;
}
.fCheck_wrap {
	display: inline-block;
	position: relative;
	min-height: 16px;
	padding: 0 0 0 29px;
	box-sizing: border-box;
	vertical-align: middle;
	cursor: pointer;
}
.fCheck-hide {
	display: none !important;
}
.fCheck + span {
	display: inline-block;
	position: absolute;
	top: 3px;
	left: 0;
	width: 16px;
	height: 16px;
	cursor: pointer;
	outline: none;
}
.fCheck + span::before {
	content: "";
	display: block;
	width: 16px;
	height: 16px;
	border: 1px solid #E70000;
	background-color: #fff;
	box-sizing: border-box;
}
.fCheck-error + span::before {
	border-color: #E70000;
}
.fCheck-required + span::before {
	border-color: #E70000;
}
.fCheck + span::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 7px;
	height: 4px;
	border-bottom: 2px solid #fff;
	border-left: 2px solid #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.fCheck-required + span::before {
	background-color: #FFE6ED;
}
.fCheck-required + span::after {
	background-color: #FECCDA;
}
.fCheck:checked + span::after {
	border-bottom: 2px solid #807F7D;
	border-left: 2px solid #807F7D;
}
.cfRadio01 {
	line-height: 1;
	margin: -35px 0 0;
	font-size: 18px;
	font-weight: 500;
	letter-spacing: -0.5em;
}
.cfRadio01 li {
	display: inline-block;
	margin: 35px 30px 0 0;
	letter-spacing: normal;
}
.cfRadio01 li:last-child {
	margin-right: 0;
}
.fRadio_wrap {
	display: inline-block;
	position: relative;
	min-height: 23px;
	padding: 1px 0 0 33px;
	box-sizing: border-box;
	vertical-align: middle;
	cursor: pointer;
}
.fRadio-hide {
	display: none !important;
}
.fRadio + span {
	display: inline-block;
	position: absolute;
	top: 2px;
	left: 0;
	width: 20px;
	height: 20px;
	margin: 0 10px 0 0;
	cursor: pointer;
	outline: none;
}
.fRadio + span::before {
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	border: 1px solid #807F7D;
	border-radius: 100%;
	box-sizing: border-box;
}
.fRadio-error + span::before {
	border-color: #E70000;
}
.fRadio-required + span::before {
	border-color: #E70000;
}
.fRadio + span::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 14px;
	height: 14px;
	border-radius: 100%;
}
.fRadio-error + span::before {
	border: 1px solid #aaa;
	background-color: #fcc;
}
.fRadio:checked + span::before {
	border-color: #807F7D;
	background-color: #fff;
}
.fRadio:checked + span::after {
	background-color: #807F7D;
}
/* レイアウト
------------------------------------------------------------------------------- */
.cfBlock01 {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
}
.cfBlock01_item {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin: 0 20px 0 0;
}
.cfBlock01_item-w1 {
	width: 234px;
}
.cfBlock01_head {
	width: 50px;
	line-height: 1;
	margin: 0;
	font-size: 18px;
	font-weight: 700;
}
.cfBlock01_body {
	width: -webkit-calc(100% - 50px);
	width: calc(100% - 50px);
}
.cfBlock02 {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
}
.cfBlock02_item {
	width: 70px;
}
.cfBlock02_line {
	width: 42px;
	line-height: 42px;
	font-size: 15px;
	font-weight: 400;
	text-align: center;
}
.cfBlock03 {
	max-width: 474px;
}
.cfBlock04 {
	display: -webkit-box;
	display: flex;
	align-items: center;
}
.cfBlock04_item1 {
	width: 184px;
	margin: 0 15px;
}
.cfBlock04_item2 {
	width: 93px;
	margin: 0 15px;
}
.cfBlock04_ex {
	line-height: 1;
	font-size: 18px;
	font-weight: 500;
}
.cfBlock05 {
	display: -webkit-box;
	display: flex;
	align-items: center;
}
.cfBlock05_item {
	width: 70px;
}
.cfBlock05_line {
	width: 42px;
	line-height: 42px;
	font-size: 15px;
	font-weight: 400;
	text-align: center;
}
.cfBlock05_ex {
	width: 30px;
	line-height: 42px;
	font-size: 18px;
	font-weight: 500;
}
.cfBlock05_func {
	width: 164px;
	margin: 0 0 0 20px;
}
.cfBlock05_btn {
	display: block;
	height: 35px;
	line-height: 33px;
	background-color: #CC3B33;
	color: #fff;
	font-size: 12px;
	font-weight: 500;
	text-align: center;
	transition: opacity .3s;
	cursor: pointer;
}
.d_hover .cfBlock05_btn:hover {
	opacity: 0.6;
}
.cfBlock06 {
	margin: -15px 0 0;
}
.cfBlock06::after {
	content: '';
	display: block;
	clear: both;
	height: 0;
}
.cfBlock06_item {
	display: -webkit-box;
	display: flex;
	align-items: center;
	float: left;
	width: 330px;
	margin: 15px 0 0;
}
.cfBlock06_head {
	width: 3em;
	line-height: 1;
	margin: 0;
	font-size: 18px;
	font-weight: 700;
}
.cfBlock06_body {
	width: 93px;
	margin: 0 12px;
}
.cfBlock06_ex {
	width: 135px;
	line-height: 1;
	margin: 0;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: -0.05em;
}
/* 必須項目
------------------------------------------------------------------------------- */
.cfRequired01 {
	display: inline-block;
	width: 24px;
	height: 24px;
	line-height: 1;
	margin: 0 0 0 20px;
	vertical-align: -0.05em;
}
.cfRequired02 {
	display: inline-block;
	width: 24px;
	height: 24px;
	line-height: 1;
	margin: 0 0 0 20px;
	vertical-align: -0.25em;
}
/* 文字装飾
------------------------------------------------------------------------------- */
.cfNote01 {
	line-height: 1.6;
	margin: 25px 0 0 1em;
	color: #807F7D;
	font-size: 16px;
	font-weight: 400;
	text-indent: -1em;
}
.cfTxt01 {
	margin: 80px 0 0;
}
.cfLink01 {
	display: inline-block;
	margin: 22px 0 0;
	color: #CC3B33;
	font-size: 16px;
	font-weight: 700;
}