@charset "utf-8";

/* CSS Document */

.pc_hid{
    display: none;
}

.sp_hid {
    display: block;
}

.post_content ol,
.post_content ul {
    list-style: none;
}

.post_content p{
	font-size: 18px;
}

/*top
--------------------------------------------------------------*/
.top{
    position: relative;
}

#key_visual_wrap {
    background: url(/wp-content/uploads/2025/06/top.jpg)no-repeat 18% top;
    background-size: cover;
    padding: 0 0 1em 0;
/*    min-height: 35vh;*/
}

#key_visual_inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 20px;
	/*position: relative;*/
	display: flex;
    align-items: flex-end;
    justify-content: space-between;
	position: relative;
}

#post_title {
    color: #0b2651;
    font-size: 70px;
    font-weight: 800;
	width: 13ch;
	word-break: break-all;
	text-shadow: 3px 3px 0px rgba(255, 255, 255, 0.8);
	line-height: 1.1;
	z-index: 99;
}

#key_visual_inner::before{
	content: "";
    position: absolute;
    top: 15%;
    left: -45%;
    width: 100%;
    height: 80%;
    background: rgb(255 204 85 / 0.7);
}

.top_button {
	/*position: absolute;
	right: 0;
	bottom: 0;*/
    color: #fff;
    height: 160px;
    width: 160px;
    background: #dd3812;
    border-radius: 50vh;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    line-height: 1.2em;
    text-align: center;
    font-weight: 800;
    box-shadow: 3px 6px 2px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease-out;
	z-index: 9;
}

.top_button:hover {
    background: #ce2105;
	color: #fff;
	transform: translateY(2px);
}

/*plan-inclusions
--------------------------------------------------------------*/
.post_content #course > h2 {
    font-size: 26px;
    font-weight: 800;
    color: #0b2651;
    padding: 10px 0 0 12px;
}

#course > h2::before {
    font-family: "Font Awesome 6 Free";
    content: "\f0c8";
    font-weight: 900;
    position: relative;
    left: -6px;
}

.post_content ul.plan-inclusions {
	display: flex;
	justify-content: space-between;
	width: 90%;
    margin: 28px auto 20px auto;
}

.plan-inclusions li {
	flex: 1;
	display: flex;
    align-items: center;
    justify-content: center;
	flex-direction: column;
	color: #0b2651;
	text-align: center;
	border: solid 3px #0b2651;
	height: 120px;
	border-radius: 10px;
	font-size: 30px;
	font-weight: 800;
	line-height: 1.1;
	position: relative;
}

.plan-inclusions li span {
	font-size: 17px;
	padding-top: 10px;
}

.plan-inclusions li:not(:last-child) {
	margin-right: 60px;
}

.plan-inclusions li:not(:last-child)::after {
	font-family: "Font Awesome 6 Free";
	content: "\2b";
	font-weight: 900;
	position: absolute;
	top: 50%;
	right: -20%;
	transform: translateY(-50%);
}

.plan-inclusions li::before {
  content: "";
  position: absolute;
  top: 8px;
  left: 8px;
  width: 100%;
  height: 100%;
  background: #ffcc55;
  border-radius: 16px;
  z-index: -1;
}

.plan-inclusions .rentalInsurance a {
	text-decoration: underline;
	cursor: pointer;
	color: #0b2651;
}

.plan-inclusions .rentalInsurance:hover {
	text-decoration: none;
}

/*course_tab
--------------------------------------------------------------*/

.course_tab {
	position: relative;
}

.post_content .course_tab > p {
	position: absolute;
    top: -70px;
	left: -30px;
    color: #dd3812;
    background: #fff;
    font-size: 50px;
    font-weight: 800;
    transform: rotate(-6deg);
    border-bottom: #dd3812 double 4px;
	line-height: 1em;
	z-index: 99;
}

.course_tab > p span {
-webkit-text-emphasis: filled;
  text-emphasis: filled;
}

.post_content ul.tab-list {
	display: flex;
	margin: 110px auto 10px;
}

.tab-menu {
	border: #ddd solid 4px;
    padding: 16px;
    width: 49%;
	display: flex;
	align-items: flex-start;
	cursor: pointer;
	position: relative;
	transition: all 0.3s ease-out;
}

.tab-menu:hover {
	border: #0b2651 solid 4px;
	background: rgba(11,38,81,0.1);
}

.tab-menu:first-child{
	margin: 0 2% 0 0;
}

.tab-menu img {
	width: 32%;
	margin-right: 10px;
}

.course_tab_inner {
	padding: 16px 10px 0 10px;
}

.tab-menu strong {
	font-size: 36px;
	font-weight: 800;
	color: #0b2651;
	line-height: 1.1;
}

.tab-menu strong span {
	font-size: 72px;
	padding: 0 4px 0 8px;
}

.post_content .tax_inclusive {
	text-align: right;
	color: #0b2651;
	font-weight: 500;
}

.tax_inclusive span{
	font-size: 22px;
}

.tab-menu .course-name {
	font-size: 22px;
    color: #0b2651;
    font-weight: 600;
    padding: 4px 10px;
    border: #0b2651 solid 1px;
    border-radius: 10px;
	background: #fff;
    display: inline-block;
	margin: 0 auto 1em 2px;
}

.tab-menu .learn-more {
	color: #0b2651;
	text-decoration: underline;
	font-size: 16px;
	text-align: right;
}

.tab-menu .learn-more .fa-chevron-down {
	padding-left: 8px;
}

.tab-menu::after {
	content: "";
    position: absolute;
    top: 10px;
    left: 2%;
    width: 96%;
    height: 100%;
    background: #ffcc55;
    clip-path: polygon(0 0, 100% 0, 100% 26%, 0% 60%);
    z-index: -1;
}
.aggregate {
	text-align: right;
	margin: 5px 0 0 0;
}

.post_content .aggregate p {
	font-size: 14px;
}

.aggregate p a{
	color: #0b2651;
	text-decoration: underline;
}

.course_tab p a:hover{
	text-decoration: none;
}

.post_content .aggregate > a {
	display: inline-block;
    border: #0b2651 solid 1px;
    padding: 8px 16px;
    margin: 5px 0 0 0;
    border-radius: 50vh;
    color: #0b2651;
    transition: all 0.3s ease-out;
    cursor: pointer;
}

.aggregate .fa-chevron-right {
  	padding-left: 8px;
}

.aggregate > a:hover {
    background: #ddd;
}

/*course_box
--------------------------------------------------------------*/

.course_box {
	border: #ddd solid 4px;
    padding: 22px 36px;
	margin: 3em 0 0 0;
	position: relative;
}

.course_box::after{
	content: "";
    position: absolute;
    top: 10px;
    left: 10px;
    width: 90px;
    height: 90px;
    background: #ffcc55;
    /*clip-path: polygon(0 0, 100% 0, 100% 0, 0 60%);*/
    z-index: -1;
}

.course_head {
	display: flex;
	justify-content: space-between;
    align-items: flex-end;
	border-bottom: #0b2651 solid 6px;
	margin: 20px 0;
}

.post_content .course_box h2 {
	font-size: 32px;
	color: #0b2651;
    font-weight: 800;
}

.course_box h2 span{
	font-size: 21px;
    color: #0b2651;
    font-weight: 800;
    padding: 0 0 0 1em;
}

.post_content .course_icon {
	display: flex;
	flex-wrap: wrap;
	margin: 0;
}

.course_icon li {
	box-sizing: border-box;
    color: #0b2651;
    font-weight: 600;
    padding: 8px 3px 4px 3px;
    border: #0b2651 solid 1px;
    background: #fff;
    border-radius: 10px;
    display: inline-block;
	width: 65px;
    height: 65px;
    margin: 0 10px 8px 0;
	text-align: center;
    line-height: 1.3;
	font-size: 18px;
}

.course_icon .distance {
	font-size: 13px;
}

.course_icon .distance span {
	font-size: 26px;
}

.course_icon .distance .nationwide {
	font-size: 22px;
}

.course_icon .speaker {
	font-size: 17px;
}

.course_icon .speaker span {
	font-size: 12px;
}

.course_box_inner1 {
	display: flex;
	justify-content: space-between;
    align-items: flex-start;
}

.course_box_inner1 > img {
	width: 25%;
	padding: 10px 20px 20px;
}

.post_content .course_box h3 {
	font-size: 20px;
	font-weight: 800;
	color: #0b2651;
	padding: 10px 0 0 12px;
}

.post_content .course_box h3:first-of-type {
	margin-top: 20px;
}

.post_content .course_box h3::before {
	font-family: "Font Awesome 6 Free";
	content: "\f0c8";
	font-weight: 900;
	position: relative;
    left: -6px;
}

.post_content .course_box h3 a {
	color: #0b2651;
	text-decoration: underline;
	transition: all 0.3s ease-out;
}

.post_content .course_box h3 a:hover {
	text-decoration: none;
}

.course_box .option {
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 8px 20px;
}

.course_box .option li{
	margin-right: 1em;
	font-size: 18px;
}

.post_content .course_box h3 + p {
	margin: 0 0 0 20px;
}

.course_box .scene {
	display: flex;
}

.course_box .scene li:not(:last-child) {
	margin-right: 20px;
}

.course_box .scene li {
    flex: 1;
}

.course_box .scene li figure {
	max-width: 220px;
}

.course_box .scene figcaption {
	text-align: center;
}

.course_box_inner2 {
	border-top: 1px solid #ddd;
	padding-top: 10px;
}

.course_box_inner2 dl {
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 0 20px;
}

.course_box_inner2 dt {
	width: 24%;
}

.course_box_inner2 dd {
	width: 76%;
	margin-bottom: 8px;
}


/*application
--------------------------------------------------------------*/

#application h2 {
	text-align: center;
}

#application h2 a{
	font-size: 28px;
    background: #dd3812;
    color: #fff;
    font-weight: 800;
    padding: 18px 24px;
    display: inline-block;
    width: 60%;
    margin: 2em auto;
    border: 5px solid #fff;
    box-shadow: 0 0 0 4px #dd3812, 0 0 0 6px #fff;
    border-radius: 2px;
	transition: all 0.3s ease-out;
	
}

#application h2 a::after{
	font-family: "Font Awesome 6 Free";
	content: "\f078";
	font-weight: 900;
	position: relative;
    right: -16px;
}

#application h2 a:hover{
	text-decoration: none;
	transform: translateY(2px);
	background: #ce2105;
	box-shadow: 0 0 0 4px #ce2105, 0 0 0 6px #fff;
}


/*notice_box
--------------------------------------------------------------*/

#application h3 {
    font-weight: 600;
    border-left: #0b2651 14px solid;
    padding: 5px 0 5px 10px;
    margin: 1em auto 0.7em 10%;
}

#application #notice_box {
    margin: 0 10% 1.2em 10%;
    padding: 1em 1em 1em 1.3rem;
    border: 2px solid #505050;
    height: 12em;
    overflow-y: scroll;
    background: #fff;
    font-size: 92%;
}

#application #notice {
    margin-bottom: 1em;
    font-family: '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
	margin-left: 0;
}

#application #notice li {
    list-style: none;
}

#application #notice li:before {
    content: "※";
    margin: 0 0.3rem 0 -1rem;
}

.post_content #application #notice a {
	color: #0b2651;
    text-decoration: underline;
}

.post_content #application #notice a:hover {
	text-decoration: none;
}

#application #confirm_chk {
    width: 60%;
    margin: 0 auto 4em auto;
    padding: 0.5rem;
    border: 1px solid #ccc;
    border-radius: 2px;
    transition: 0.5s all ease-out;
    background: #fff;
}

#application #confirm_chk:hover {
    background-color: #cfdbec;
}

#application input[type="checkbox"] {
    border: solid 1px #ccc;
    transform: scale(1.3);
    margin: 0 0.5em;
}

/*form
--------------------------------------------------------------*/

#application_form {
	background: #f9f9f9;
	padding: 3.6em 2em;
}

.post_content table {
    font-size: 18px;
	width: 90%;
    margin: 0 auto;
}

.post_content td,
.post_content th {
    border: none;
	text-align: left;
	vertical-align: top;
}

.post_content th {
	background: none;
	font-weight: 600;
	width: 16em;
}

.post_content tr:nth-child(10) {
	margin-top: 6em;
}

table input,
table textarea,
table select {
    box-sizing: border-box;
    border: 1px solid #ccc;
    line-height: 1.2;
    padding: 8px 12px;
}

input#zip,
input#zip2 {
	width: 10em;
}

input#company,
input#name,
input#tel,
input#tel2,
input#fax,
input#maillabel {
	width: 20em;
}

input#email,
input#email2,
input#addr,
input#addr2,
textarea {
	width: 95%;
}

.submit_button {
	text-align: center;
}

#form_submit {
	font-size: 20px;
	line-height: 2.8em;
	width: 400px;
    background: #dd3812;
    color: #fff;
    font-weight: 600;
    margin: 2em auto;
	border: none;
	border-radius: 2px;
    box-shadow: 0px 1px 3px 1px rgb(0 0 0 / 25%);
    transition: all 0.3s ease-out;
}

#form_submit:hover {
	transform: translateY(2px);
	background: #ce2105;
}

#same_addr_label {
	padding: 8px 18px;
    border: 2px solid #ccc;
    font-size: 17px;
    margin: 0 0 0 20px;
	border-radius: 2px;
	transition: all 0.3s ease-out;
}

#same_addr_label:hover{
	background: #cfdbec;
}

.form-bg {
    background-color: rgb(255 235 238);
}

.form_hr {
    width: 80%;
    margin: 3em auto;
    border-top: #ccc dotted 3px;
}

caption {
    font-size: 22px;
    margin: 0 0 16px 0;
    font-weight: 500;
	line-height: 1.2;
}

.required {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    color: #fff;
    background: #d32626;
    padding: 0 6px 0 5px;
    margin: 0 10px 0 0;
    line-height: 18px;
}

#application .contact_button {
    display: flex;
	justify-content: space-around;
    margin: 1em auto 0 auto;
    width: 70%;
}

#application .note {
	text-align: center;
}

#application .contact_button a {
	font-size: 18px;
    color: #0b2651;
    text-decoration: underline;
    padding: 0 2em;
    display: block;
	transition: all 0.3s ease-out;
}

#application .contact_button a:hover {
	text-decoration: none;
}

/*contact
--------------------------------------------------------------*/

.post_content .contact {
	display: flex;
	flex-direction: column;
    background: #f9f9f9;
    padding: 1em 0;
    margin: 8em 16% 0;
    text-align: center;
    border-top: #0b2651 6px solid;
    border-bottom: #0b2651 2px solid;
    transition: all 0.3s ease-out; 
}

.post_content .contact:hover {
    background: #e2e2e2;
	text-decoration: none;
}

.contact p:first-child {
    color: #0b2651;
    font-weight: 600;
    margin-bottom: 1.2em;
}

.contact p:nth-child(2) {
    color: #222;
    font-weight: 600;
    font-size: 120%;
}

.contact .button {
    background: #0b2651;
    padding: 0 2em;
    border-radius: 50vh;
    color: #fff;
    font-size: 160%;
    font-weight: 600;
    display: inline-block;
    line-height: 3em;
    margin: 8px auto 12px;
    transition: all 0.3s ease-out;
}

.contact .button img {
    vertical-align: middle;
    padding: 0 0 5px 8px;
}

/*カレンダー
--------------------------------------------------------------*/
.xo-event-calendar table.xo-month button span.nav-next {
    border-right: 2px solid #ddd;
    border-top: 2px solid #ddd;
}

.xo-event-calendar table.xo-month button span.nav-prev {
    border-bottom: 2px solid #999;
    border-left: 2px solid #999;
}

.xo-event-calendar table.xo-month .month-header {
    color: #ddd;
	font-size: 15px;
	line-height: 24px;
}


/*スマートフォン
--------------------------------------------------------------*/
@media screen and (max-width: 767px) {


	.pc_hid {
		display: block;
	}

	.sp_hid {
		display: none;
	}

	.post_content p {
		font-size: 16px;
	}

	/*top
--------------------------------------------------------------*/

	#key_visual_wrap {
		background: url(/wp-content/uploads/2025/06/top.jpg) no-repeat 72% top;
		background-size: cover;
		height: 240px;
	}

	#key_visual_inner {
		width: auto;
		flex-direction: column;
	}

	.page #post_title {
		font-size: 32px;
		margin: 0 auto 16px 0;
		width: 10ch;
	}

	.top_button {
		position: absolute;
		width: 100px;
		height: 100px;
		font-size: 16px;
		bottom: 0;
	}

	#key_visual_inner::before {
		left: 0;
		width: 60%;
		height: 54%;
	}


	/*plan-inclusions
--------------------------------------------------------------*/


	.post_content ul.plan-inclusions {
		flex-direction: column;
	}

	.plan-inclusions li {
		display: block;
		font-size: 24px;
		width: 92%;
		margin: 0 auto;
		line-height: 2.2;
	}

	.plan-inclusions li span {
		font-size: 18px;
	}

	.plan-inclusions li:not(:last-child) {
		margin: 0 auto 40px auto;
	}

	.plan-inclusions li:not(:last-child)::after {
		top: 100%;
		right: 0;
		left: 50%;
		transform: translateX(-50%);
	}


	/*course_tab
--------------------------------------------------------------*/
	.post_content .course_tab > p {
		font-size: 38px;
		left: -10px;
	}

	.tab-list {
		flex-direction: column;
	}

	.tab-menu {
		width: 100%;
		box-sizing: border-box;
		align-items: center;
		position: relative;
		padding: 58px 4px 10px 4px;
	}
	
	.tab-menu img {
    	width: 30%;
    	margin-right: 6px;
	}

	.tab-menu strong span {
		font-size: 50px;
	}


	.tab-menu:first-child {
		margin: 0 0 20px 0;
	}
	
	.tab-menu::after {
    	top: 6px;
	}

	.tab-menu strong {
		font-size: 30px;
		position: absolute;
		top: 20px;
		right: 10px;
	}

	.post_content .course-description {
		font-size: 15px;
		line-height: 1.6;
	}


	.post_content .tax_inclusive {
		font-size: 12px;
		margin: 5px 0;
	}

	.tax_inclusive span {
		font-size: 16px;
	}

	.tab-menu .course-name {
		font-size: 16px;
		margin: 0 0 5px 0;
	}

	.post_content .aggregate p{
		font-size: 12px;
		text-align: left;
		        margin: 0;
	}

	.tab-menu .learn-more {
		font-size: 14px;
	}

	/*course_box
--------------------------------------------------------------*/

	.course_box {
		padding: 22px 10px;
	}

	.course_head {
		flex-direction: column;
		justify-content: flex-start;
    	align-items: flex-start;
		margin: 5px 0;
	}

	.post_content .course_box h2 {
		font-size: 28px;
	}

	.course_box h2 span {
		font-size: 18px;
		padding: 0;
	}

	.course_icon li {
		font-size: 15px;
		width: 50px;
        height: 50px;
        border-radius: 8px;
		padding: 5px 4px 4px 4px;
	}

	.course_icon .distance {
		font-size: 10px;
	}

	.course_icon .distance .nationwide {
		font-size: 17px;
	}

	.course_icon .speaker {
		font-size: 13px;
	}

	.course_icon .speaker span {
		font-size: 8px;
	}

	.course_box_inner1 {
		flex-direction: column-reverse;
	}

	.course_box_inner1 > img {
		width: 50%;
		margin: 0 auto;
	}

	.course_box .option li {
		font-size: 15px;
	}

	.post_content .course_box h3 {
		font-size: 17px
	}

	.course_box_inner2 dt,
	.course_box_inner2 dd {
		width: 100%;
	}

	/*application
--------------------------------------------------------------*/

	#application h2 a {
		width: 100%;
		box-sizing: border-box;
		font-size: 26px;
	}

	#application h3 {
		margin: 0 0 0.7em 0;
	}

	#application #notice_box {
		margin: 0 0 1.2em 0;
	}

	#application #confirm_chk {
		width: 100%;
		box-sizing: border-box;
	}

	.contact {
		margin: 8em 0 0;
	}

	.contact .button {
		font-size: 125%;
		line-height: 3.3em;
	}

	.contact .button img {
		width: 36px;
	}

	#application_form {
		padding: 2.4em 8px;
	}

	.post_content table {
		font-size: 16px;
	}

	.post_content td,
	.post_content th {
		padding: 5px 0;
	}

	#application tr {
		display: flex !important;
		flex-direction: column;
	}

	#application td span {
		font-size: 14px;
	}

	select#Course,
	input#company,
	input#name,
	input#email,
	input#email2,
	input#tel,
	input#tel2,
	input#fax,
	input#addr,
	input#maillabel {
		width: 90%;
	}
	
	input[type="date"] {
		-webkit-appearance: none;
		height: 38px;
		width: 10em;
	}

	#same_addr_label {
		margin: 0;
		padding: 2px 18px;
	}

	#form_submit {
		width: 260px;
	}

	#application .contact_button {
		display: block;
		width: 100%;
	}


	#application .contact_button a {
		padding: 0;
		font-size: 16px;
	}

	#application .contact_button li:first-of-type {
		margin-bottom: 1em;
	}
	
	#application .note {
		text-align: left;
	}
	
	.post_content .contact {
		padding: 1em 10px;
		margin: 0 auto;
	}
}

/*　小さい幅のスマホ　*/
@media screen and (max-width: 414px) {
	.page #post_title {
		font-size: 26px;
		width: 11ch;
		}
}

/*タブレット
-------------------------------------------------------------------------------- */
@media all and (min-width: 768px) and (max-width: 1024px) {
	
	#post_title {
		font-size: 55px;
	}
	
	#key_visual_wrap {
    	background: url(/wp-content/uploads/2025/06/top.jpg) no-repeat 60% top;
	}
	
	.top_button {
		height: 140px;
    	width: 140px;
		font-size: 25px;
	}
	
	.plan-inclusions li {
		font-size: 26px;
	}
	
	.post_content .course_tab > p {
    	left: -9px;
	}
	
	.tab-menu strong{
		font-size: 22px;
	}
	
	.tab-menu strong span {
    font-size: 56px;
	}
	
	.tab-menu .course-name {
    	font-size: 18px;
	}
	
	.course_box h2 span {
    	padding: 0;
	}
	
}

@media all and (min-width: 1025px) and (max-width: 1150px) {
	#key_visual_wrap {
    	background: url(/wp-content/uploads/2025/06/top.jpg) no-repeat 52% top;
	}
	
	
}
