@charset "UTF-8";
/*body{
	background: #ededed;
}*/

/*短期入所TOP*/
p.fb{
	font-weight: bold;
}
p.fontw{
	font-size: 1.25rem;
	font-weight: bold;
}
p.orange{
	font-weight: bold;
}
p span.fb{
	font-weight: bold;
}
table th{
	width: 13%;
}
table th,table td{
	padding: 15px;
}
table td{
	text-align: left;
	vertical-align: middle;
}
.table2 th{
	width: 21%;
}
.table3 th{
	width: 28%;
	text-align:left;
}
.table3 td{
	vertical-align: middle;
}
.tanki .column{
	flex-wrap: wrap;
	gap:30px;
}
.tanki .column .col{
	width: calc(100%/2 - 15px);
}
.tanki h4{
	padding-left: 28px;
	color: #FC6100;
	font-size: 1.25rem;
	position: relative;
}
.tanki h4::before{
	content: "";
	width: 18px;
	height: 18px;
	background: url("../../guidance/img/tanki_icon.png");
	background-size: 100%;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate(0,-50%);
}
.tanki .flow{
	position: relative;
	margin-bottom: 40px;
}
.tanki .flow::before{
	content: "";
	width: 20px;
	height: 12px;
	background: url("../../guidance/img/arrow.png");
	background-size: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	transform: translate(20px, 25px);
}
.tanki .flow.arrownone::before{
	content: "";
	display: none;
}
.tanki .flow p{
	border: solid 1px #A2A2A2;
	padding: 20px;
	border-radius: 8px;
}
/*分岐*/
.bunki_area{
	position: relative;
	margin-bottom: 30px;
}
.bunki_area::before{
	content: "";
	width: 30%;
	height: 3px;
	background: #FC6100;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%,0);
	z-index: 9;
}
#checkbox-area .check_ttl{
	font-size: 1.125rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 20px;
}
#checkbox-area .check_txt{
	text-align: center;
	margin-bottom: 30px;
}
#checkbox-area,.question {
	background: white;
    padding: 30px;
    border-radius: 8px;
	border: solid 1px #A2A2A2;
    text-align: left;
}
#checkbox-area .checkboxes{
	margin-bottom: 20px;
}
.checkbox-area label {
	display: block;
    margin-bottom: 10px;
    font-size: 1rem;
}
.tanki button {
	max-width: 176px;
	font-size: 1rem;
    padding:20px;
    margin: 10px;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    color: white;
    transition: background 0.3s;
}
.tanki .checkboxes label{
	display:flex;
}
.tanki .checkboxes label:last-child{
	margin-bottom: 0px;
}
.question {
	display: none;
    text-align: center;
    position: relative;
}
.question.show {
	display: block;
	opacity: 1;
}
.question .none p{
	color: #004697;
}
.content {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.5s ease, transform 0.5s ease;
}
.question.show .content {
	opacity: 1;
	transform: translateY(0);
}
.question .column{
	justify-content: center;
}
.question .column .col{
	width: calc(100%/2);
}
.question button{
	max-width: 176px;
	margin-top: 30px;
	border-radius: 8px;
}
.question .btn{
	margin-top: 30px;
}
.btn-yes {
	background-color: #FC6100;
}
.btn-yes:hover {
	background-color: #FC6100;
}
.btn-no {
	background-color: #004697;
}
.btn-no:hover {
	background-color: #004697;
}
a.form-link {
	text-decoration: none;
}
button.form-btn {
	background-color: #4caf50;
    color: white;
    font-size: 18px;
    padding: 12px 24px;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.3s;
}
button.form-btn:hover {
	background-color: #388e3c;
}
#next-button {
    margin-top: 20px;
    background-color: #E6E6E6;
	display: block;
	margin: 0 auto;
	color: #C6C6C6;
	width: 100%;
	background-color: #ccc;
	color: #666;
	pointer-events: none;
	cursor: not-allowed;
}
/* 有効状態（全チェック済み） */
#next-button.active {
  background-color: #FC6200;
  color: #fff;
  pointer-events: auto;
  cursor: pointer;
}

.question2,.question2_2{
	background: white;
    padding: 30px;
    border-radius: 8px;
    border: solid 1px #A2A2A2;
    text-align: left;
	text-align: center;
}
.question2 .content{
	opacity: 1;
	transform: translateY(0px);
	transition: opacity 0.5s ease, transform 0.5s ease;
}
.question2_2 {
	display: none;
    text-align: center;
    position: relative;
}
.question2_2.show {
	display: block;
	opacity: 1;
}
.question2 .none p{
	color: #004697;
}
.question2_2 .content {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.5s ease, transform 0.5s ease;
}
.question2_2.show .content {
	opacity: 1;
	transform: translateY(0);
}
.question2 .column{
	justify-content: center;
}
.question2 .column .col{
	width: calc(100%/2);
}
.question2 button{
	max-width: 176px;
	margin-top: 30px;
	border-radius: 8px;
}
.question2_2 .btn{
	margin-top: 30px;
}
@media screen and (max-width: 1280px) {
	.table2 th {
    	width: 26%
	}
	.question .column,.question2 .column{
		gap:0px;
	}
	.question button,.question2 button{
		max-width: 138px;
	}
	.table3 th{
		width: 45%;
	}
}
@media screen and (max-width: 820px) {
	.table2 th {
        width: 21%;
    }
}
@media screen and (max-width: 767px) {
	.tanki .column{
		gap: 10px;
	}
	.tanki .column .col{
		width: calc(100% / 2 - 6px);
	}
	.table2 th {
        width: 30%;
    }
	.table3 th {
        width: 42%;
    }
	.question button, .question2 button {
        max-width: 115px;
    }
	.question2 .column .col {
		width: calc(100% / 2);
	}
}
@media screen and (max-width: 390px) {
	.question .column, .question2 .column {
        gap: 0px;
    }
	.question .column .col {
		width: calc(100% / 2);
	}
	.question button, .question2 button {
        max-width: 95px;
    }
}

.error-message {
	color: red;
	font-size: 0.9em;
	margin-top: 10px;
	margin-bottom: 5px;
}
.form-group {
	margin-bottom: 1em;
}
.hidden {
	display: none;
}
.cnt{
	max-width: 1200px;
	margin: 0 auto;
	background: #fff;
	padding: 50px;
}
.cnt p{
	margin: 0px;
}
p span.orange{
	color: #FC6100;
}
p a{
	color: #FC6100;
	text-decoration: underline;
}

.form-group{
	margin-bottom: 30px;
}
.form-group p.ttl{
	margin-bottom: 13px;
	font-size: 1rem;
}
.form-group p.ttl span{
	background: #D52C2C;
	color: #fff;
	border-radius: 5px;
	padding: 5px;
	margin-right: 25px;
	font-size: 0.875rem;
	font-weight: bold;
}
.form-group p.ttl span.any{
	background: #868686;
}
input[type="text"],input[type="date"],input[type="email"],input[type="tel"],textarea{
	width: 100%;
	height: 60px;
	border-radius: 6px;
	border: solid 1px #cccccc;
	padding: 20px;
	box-sizing: border-box; /* ← これを追加 */
	background: #f2f2f2;
	font-size: 1rem;
	line-height: 1.6;
}
input[type="checkbox"]{
	-webkit-appearance:auto;
	width: auto;
}
textarea{
	height: 220px;
}
.column{
	display: flex;
	gap:20px;
	align-items: center;
}
.column .col{
	width:100%;
}
.select-wrapper {
	position: relative;
	width: 100%;
}
select{
	width: 100%;
	height: 60px;
	border-radius: 6px;
	border: solid 1px #cccccc;
	padding: 20px;
	box-sizing: border-box; /* ← これを追加 */
	background: #f2f2f2;
	appearance: none; /* ← ネイティブの矢印を非表示 */
	-webkit-appearance: none;
	-moz-appearance: none;
}
/* ▼カスタム矢印 */
.select-wrapper::after {
	content: "";
	position: absolute;
	pointer-events: none;
	top: 50%;
	right: 15px;
	transform: translateY(-50%) rotate(45deg);
	width: 8px;  /* ← 矢印サイズ */
	height: 8px;
	border-right: 2px solid #333333; /* ← 色 */
	border-bottom: 2px solid #333333;
	transition: 0.3s;
}
.school_year{
	max-width: 228px;
}

/*ラジオボタン*/
.form-group.radio input[type="radio"] {
	display: none;
}
.form-group.radio label {
	display: inline-flex;
	align-items: center;
	cursor: pointer;
	position: relative;
	padding-left: 30px;
	margin-right: 20px;
	font-size: 16px;
}
/* 外枠（未選択） */
.form-group.radio label::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
	height: 20px;
	border: 1px solid #a2a2a2; /* ← ここを1pxに変更 */
	background-color: #e5e4e4;
	border-radius: 50%;
	box-sizing: border-box;
}
/* 内側の丸（選択されたときに表示） */
.form-group.radio label::after {
	content: "";
	position: absolute;
	left: 5px;
	top: 50%;
	transform: translateY(-50%) scale(0);
	width: 10px;
	height: 10px;
	background-color: #fc6200;
	border-radius: 50%;
	transition: transform 0.3s ease;
}

/* 選択時の背景と枠線 */
.form-group.radio input[type="radio"]:checked + label::before {
	border-color: #fc6200;
	background-color: #fff;
}
/* 選択時：内側の丸がスケールアップ */
.form-group.radio input[type="radio"]:checked + label::after {
	transform: translateY(-50%) scale(1);
}

/*チェックボックス*/
input[type="checkbox"] {
  	appearance: none;
  	-webkit-appearance: none;
  	-moz-appearance: none;
  	width: 18px;
  	height: 18px;
  	border: 1px solid #A2A2A2;
  	background-color: #F2F2F2;
  	border-radius: 3px;
  	position: relative;
  	cursor: pointer;
  	transition: all 0.2s ease;
}

/* チェック時の背景と枠線 */
input[type="checkbox"]:checked {
  	background-color: #fff;
  	border-color: #FC6200;
}

/* チェックマーク（疑似要素） */
input[type="checkbox"]:checked::after {
  	content: '';
  	position: absolute;
  	left: 7px;
  	top: 3px;
  	width: 4px;
  	height: 9px;
  	border: solid #FC6200;
  	border-width: 0 2px 2px 0;
  	transform: rotate(45deg);
}
.checkboxes label {
  	display: inline-flex;
  	align-items: center;
  	gap: 6px; /* チェックボックスと文字の間隔 */
  	margin-right: 12px; /* ラベル同士の余白（任意） */
  	font-size: 1rem; /* 任意で調整 */
	line-height: 1.6;
	margin-bottom: 10px;
}

.tel > p.ttl{
	margin-bottom: 23px;	
}
.mb{
	margin-bottom: 10px;
}

/*id*/
.id .column{
	align-items: center;
}
.id .column2{
	align-items: center;
}
.id .column2 .col2:first-child{
	width: 15%;
}
.id .column2 .col2:last-child{
	width: 100%;
}

/*手帳*/
.notebook-details .col_cnt{
	margin-bottom: 10px;
}
.notebook-details .column{
	align-items: center;
}
.notebook-details .column .col:first-child{
	width: 35%;
}
.notebook-details .column .col.grade{
	width: 30%;
}

/*サービス受給者*/
#serviceDetails > div:last-child{
	margin-top: 25px;
}
#serviceDetails > div:last-child input[type="date"]{
	max-width: 298px;
}

/*利用しているサービス*/
.use_service-details .column{
	align-items: center;
}
.use_service-details .column .col:first-child{
	width: 23%;
}


/*本利用予約*/
.id input[type="text"]{
	max-width: 345px;
}
.desired .column{
	position: relative;
}
.desired .column div{
	width: calc(100%/3);
}
.desired .column > p{
}
.used_date .column div{
	width: calc(100%/3);
}

/*リダイレクトページ*/
.kikangai{
	padding: 66px;
    background: #F2F2F2;
	text-align: center;
}
.kikangai p:first-child{
	font-size: 1.25rem;
	font-weight: bold;
	margin-bottom: 30px;
}
.kikangai p.orange{
	font-size: 1rem;
	font-weight: bold;
}

@media screen and (max-width: 1280px) {
	.form-group.radio label{
		margin-bottom: 10px;
	}
	.notebook-details .column{
		display: block;
	}
	.notebook-details .column .col:first-child{
		width: 60%;
		margin-bottom: 0px;
	}
	.notebook-details .column .col{
		margin-bottom: 10px;
	}
	.use_service-details .column{
		display: block;
	}
	.use_service-details .column .col:first-child{
		width: 40%;
	}
}
@media screen and (max-width: 767px) {
	.id .column{
		display: block;
	}
	.id .column .col:first-child{
		margin-bottom: 10px;
	}
	
	/*本利用予約*/
	.desired .column div {
		width: calc(100% / 3 + 31px);
	}
	.used_date .column div{
		width: calc(100%/3 + 31px);
	}
	
	.column{
		gap:10px;
	}
	.form-group p.ttl span{
		margin-right: 5px;
	}
	input[type="text"], input[type="date"], input[type="email"], input[type="tel"], textarea{
		font-size: 0.8rem;
	}
}
@media screen and (max-width: 390px) {
	input[type="text"], input[type="date"], textarea,select{
		padding: 10px;
	}
	/*本利用予約*/
	.desired .column,.used_date .column{
		gap:10px;
	}
}

/*打ち消し*/
/* Chrome/Edge/Safari 対応 */
input:-webkit-autofill {
  box-shadow: 0 0 0 1000px #f2f2f2 inset !important;
  -webkit-text-fill-color: #000 !important;
  transition: background-color 5000s ease-in-out 0s;
}

/* Firefox（将来対応）用：現時点ではあまり有効でないが記述だけしておく */
input:autofill {
  background-color: #f2f2f2 !important;
}
.wpcf7-list-item{
	margin: 0;
}
input[type="submit"]{
	width: 246px;
    border-radius: 50px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    height: 72px;
    background: #FC6100;
    border: none;
    color: #fff;
    font-size: 1.25rem;
	cursor: pointer;
	transition: 0.3s;
	text-align: center;
	align-items: center;
  	justify-content: center;
}

.error-message#error{
	font-size: 1.4em;
    text-align: center;
    margin-bottom: 20px;
}
.sent_ok{
	display: none;
}
.wpcf7 form .wpcf7-response-output{
	text-align: center;
    padding: 20px;
    border: solid 3px red !important;
    font-size: 20px;
    line-height: 1.6;
    font-weight: bold;
    color: red;
}