@charset "utf-8";

#title_area{
	padding: 10px 30px;
	min-height: 46px;
}
#input_area{
	padding: 0 30px 20px; 
}

.sm_view #title_area{
	padding: 3vw;
}
.sm_view #input_area{
	padding: 2vw 3vw 5vw 3vw;
	border-radius: 0;
}

#form_name>span,
#error_area,
.conf_table,
.conf_table *,
.input_table,
.input_table *{
	font-size: 15px;
	line-height: 23px;
}
#error_area{
	padding-top: 20px;
}
#error_area>br:first-child{
	display: none;
}
.sm_view #error_area{
	padding-top: 3vw;
}


.sm_view .conf_table,
.input_table{
	width: 100%;
}

.sm_view .conf_table tr,
.input_table tr{
	display: block;
	position: relative !important;
}

.sm_view .conf_table th,
.input_table th{
	position: absolute;
	left: 0;
	top: 0;
}
.sm_view .conf_table td,
.input_table td{
	position: relative;
	padding-top: 24px;
	padding-bottom: 18px;
	display: block;
	box-sizing: border-box;
	width: 100%;
}

.sm_view .conf_table th{
	font-size: 14px;
}
.conf_table th:before{
	content: "[";
	display: inline-block;
	width: 10px;
}
.conf_table th:after{
	content: "]";
	display: inline-block;
	width: 10px;
	text-align: right;
	
}
.conf_table td{
	padding-left: 10px;
}
.pc_view .conf_table th{
	padding-bottom: 10px;
}



span.red{
	font-size: 0;
	line-height: 0;
	letter-spacing: 0;
}
span.red:before{
	content: "必須";
	display: inline-block;
	position: relative;
	top: -1px;
	font-size: 12px;
	line-height:  16px;
	padding: 0 5px;
	color: #ffffff;
	background: rgb(var(--color_strong));
	margin-left: 5px;
	border-radius: 4px;
}

.pc_view input[name="item_tel"],
.pc_view input[name="item_mail_2"],
.pc_view input[name="item_mail_1"],
.pc_view input[name="item_stext01"],
.pc_view input[name="item_kana_1"],
.pc_view input[name="item_name_1"]{
	width: 340px !important;
}

input[name="item_stext02"]{
	width: 150px !important;
}
input[name="item_age"]{
	width: 80px !important;
}

/* ----------------------------------------------------------
	フォーム系
------------------------------------------------------------- */
input, textarea, select {
	margin: 0;
}

input[type=text],
input[type=password],
textarea {
	box-sizing: border-box;
	padding: 7px;
	width: 100%;
	background-color: rgba(var(--color_cmn),.07);
	border: none;
	border-radius: 4px;
	font-size: 16px;
	line-height: 24px;

}
input[type=text]:focus,
input[type=password]:focus,
textarea:focus { 
}

textarea {
	overflow: auto;
	vertical-align: top;
}

input[type=checkbox],
input[type=radio]{
}
label {
	display: inline-block;
	background-color: rgba(var(--color_cmn),.07);
	padding: 7px 15px 7px 7px;
	border-radius: 4px;
	margin: 2px 4px 2px 0;
	cursor: pointer;
}

input[type=button],
input[type="submit"]{
	cursor: pointer;
	border: none !important;
}


input[type=checkbox]{
	cursor: pointer;
}

input[type=submit]:disabled,
input[type=button]:disabled,
input[type=checkbox]:disabled { cursor: default; }

select{
	-webkit-appearance: none;
	appearance: none;
	
	padding: 7px 30px 7px 15px;
	font-size: 15px;
	line-height: 23px;
	border: none;
	background-color: rgba(var(--color_cmn),.07);
	border-radius: 4px;
	color: rgb(68,68,68);
}

div.select{
	display: inline-block;
	position: relative;
}
div.select:after{
	content: "";
	position: absolute;
	top: 15px;
	right: 10px;
	display: block;
	width: 0;
	height: 0;
	border-width: 7px 5px 0 5px;
	border-style: solid;
	border-color: #666666 transparent transparent transparent;
	pointer-events: none;
}


/* ----------------------------------------------------------
	汎用
------------------------------------------------------------- */
/* マージン系 */
.m0 { margin: 0 !important; }
.m5 { margin: 5px !important; }
.m10 { margin: 10px !important; }
.m15 { margin: 15px !important; }
.m20 { margin: 20px !important; }
.m25 { margin: 25px !important; }
.m30 { margin: 30px !important; }
.m35 { margin: 35px !important; }
.m40 { margin: 40px !important; }
.m44 { margin: 44px !important; }
.m40 { margin: 40px !important; }
.mt0 { margin-top: 0 !important; }
.mt5 { margin-top: 5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt45 { margin-top: 45px !important; }
.mt50 { margin-top: 50px !important; }
.mb0 { margin-bottom: 0 !important; }
.mb5 { margin-bottom: 5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb45 { margin-bottom: 45px !important; }
.mb50 { margin-bottom: 50px !important; }
.ml0 { margin-left: 0 !important; }
.ml5 { margin-left: 5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml35 { margin-left: 35px !important; }
.ml40 { margin-left: 40px !important; }
.ml45 { margin-left: 45px !important; }
.ml50 { margin-left: 50px !important; }
.mr0 { margin-right: 0 !important; }
.mr5 { margin-right: 5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
.mr35 { margin-right: 35px !important; }
.mr40 { margin-right: 40px !important; }
.mr45 { margin-right: 45px !important; }
.mr50 { margin-right: 50px !important; }

/* パディング系 */
.p0 { padding: 0 !important; }
.p5 { padding: 5px !important; }
.p10 { padding: 10px !important; }
.p15 { padding: 15px !important; }
.p20 { padding: 20px !important; }
.p25 { padding: 25px !important; }
.p30 { padding: 30px !important; }
.p35 { padding: 35px !important; }
.p40 { padding: 40px !important; }
.p45 { padding: 45px !important; }
.p50 { padding: 50px !important; }
.pt0 { padding-top: 0 !important; }
.pt5 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt45 { padding-top: 45px !important; }
.pt50 { padding-top: 50px !important; }
.pb0 { padding-bottom: 0 !important; }
.pb5 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb45 { padding-bottom: 45px !important; }
.pb50 { padding-bottom: 50px !important; }
.pl0 { padding-left: 0 !important; }
.pl5 { padding-left: 5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pl35 { padding-left: 35px !important; }
.pl40 { padding-left: 40px !important; }
.pl45 { padding-left: 45px !important; }
.pl50 { padding-left: 50px !important; }
.pr0 { padding-right: 0 !important; }
.pr5 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
.pr35 { padding-right: 35px !important; }
.pr40 { padding-right: 40px !important; }
.pr45 { padding-right: 45px !important; }
.pr50 { padding-right: 50px !important; }

/* 幅指定(%) */
.w5per { width: 5% !important; }
.w10per { width: 10% !important; }
.w15per { width: 15% !important; }
.w20per { width: 20% !important; }
.w25per { width: 25% !important; }
.w30per { width: 30% !important; }
.w35per { width: 35% !important; }
.w40per { width: 40% !important; }
.w45per { width: 45% !important; }
.w50per { width: 50% !important; }
.w55per { width: 55% !important; }
.w60per { width: 60% !important; }
.w65per { width: 65% !important; }
.w70per { width: 70% !important; }
.w75per { width: 75% !important; }
.w80per { width: 80% !important; }
.w85per { width: 85% !important; }
.w90per { width: 90% !important; }
.w95per { width: 95% !important; }
.w100per { width: 100% !important; }

/* フロート */
.fl { float: left !important; }
.fr { float: right !important; }

/* テキスト系 */
.tal { text-align: left !important; }
.tar { text-align: right !important; }
.tac { text-align: center !important; }
.breakAll { word-break: break-all !important; }

/* 表示系 */
.dispN { display: none !important; }
.dispI { display: inline !important; }
.dispIB { display: inline-block !important; }
.dispB { display: block !important; }
.dispF { display: flex !important; }

/* フォント系 */
.fontNormal { font-weight: normal !important; }
.fontBold { font-weight: bold !important; }
.font10 { font-size: 10px !important; }
.font12 { font-size: 12px !important; }
.font14 { font-size: 14px !important; }

/* カラー系 */
.colorBlack { color: #000; }

/* Clearfix */
.clear, .cf { clear: both; }
.clearfix:before, .clearfix:after,
.cf:before, .cf:after {
	content: " ";
	display: table;
}
.clearfix:after, .cf:after { clear: both; }
.clearfix, .cf { *zoom: 1; }

/* ボタンを囲うclassタグ */
.button_box {
	clear : both ;
	padding : 8px ;
	text-align : center ;
}

/* 左詰の文字を表示するためのclassタグ */
.left_txt {
	text-align : left;
}

/* 説明文を表示するためのidタグ */
#txt_explain {
	color: #000000;
}

