@charset "UTF-8";
/*RESET*/
.p-news_single__content p {
	margin-bottom: 0;
}

.kengakukai-cta {
	text-align: center;
}
.kengakukai-cta a {
	background:#ffe164;
	color: #03644e;
	padding: 20px 40px;
	border-radius: 30px;
	font-weight: 600;
	font-size: 1.2rem;
}
.c-btn03 {
	display: none;
}
@media only screen and (max-width: 768px) {
td,th {
	padding: 0;
}
}
input, textarea {
	padding: 0;
}

@media only screen and (min-width: 769px) {
.pc-only {
	display: none;
}
}


/*========アイキャッチ非表示========*/
.p-news_single__eyecatch {
	display: none;
}

/*========コンテンツ幅の拡張========*/
.p-news_single__body {
    max-width: 880px;
}



/*=================================
セクション1_ファーストビュー
=================================*/
.rt-sec-1 {

}



/*=================================
セクション2_イントロ
=================================*/
.rt-sec-2 {

}

.rt-sec-2 h2 {
	font-size: 2.2rem;
	font-weight: 600;
	text-align: center;
	margin-bottom: 50px;
	position: relative;
	margin-top: 50px;
}
.rt-sec-2 h2:before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -15px;
	border-bottom: 1px solid #000;
	width : 100px ;
	margin: 0 auto;
}
@media only screen and (max-width: 768px) {
.rt-sec-2 h2 {
	font-size: 1.8rem;
}
}
.rt-sec-2 p {
	font-size: 1.8rem;
	font-weight: 600;
	text-align: center;
	margin-bottom: 50px;
}
@media only screen and (max-width: 768px) {
.rt-sec-2 p {
	font-size: 1.5rem;
}
}
.rt-sec-2-list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 70px;
}
.rt-sec-2-list dl {
	width: 32%;
	/*width: 45%;*/
	margin-bottom: 30px;
}
@media only screen and (max-width: 768px)  {
.rt-sec-2-list dl {
	width: 48%;
}
}
.rt-sec-2-list dl dt {
	margin-bottom: 5px;
}
.rt-sec-2-list dl dd {
	/*font-size: 1.1rem;*/
	font-size: 1.4rem;
	text-align: center;
}
@media only screen and (max-width: 768px) {
.rt-sec-2-list dl dd {
	font-size: 1.1rem;
}
}

/*=================================
セクション3_住んでいるからこそ分かる、“本当の暮らし”を見学
=================================*/
.rt-sec-3 {

}


.rt-sec-3-intro {

}
.rt-sec-3-intro h2 {
	font-size: 2.2rem;
	font-weight: 600;
	margin-bottom: 40px;
}
@media only screen and (max-width: 768px) {
.rt-sec-3-intro h2 {
	font-size: 1.8rem;
}
}
.rt-sec-3-intro p {
	font-size: 1.8rem;
	margin-bottom: 70px;
	line-height: 2.0;
}
@media only screen and (max-width: 768px) {
.rt-sec-3-intro p {
	font-size: 1.3rem;
}
}

.kengakukai-concept {
	margin-bottom: 50px;
}
.kengakukai-concept h2 {
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
	align-items: center;
 	display: flex;
 	justify-content: center;
 	margin-bottom: 20px;
}
@media only screen and (max-width: 768px) {
.kengakukai-concept h2 {
	font-size: 1.6rem;
}
}
.kengakukai-concept h2:before,.kengakukai-concept h2:after {
	background-color: #333;
	content: "";
	height: 40px;
	width: 0.75px;
}
.kengakukai-concept h2:before {
	margin-right: 30px;
 	transform: rotate(-40deg);
}
.kengakukai-concept h2:after {
	margin-left: 30px;
 	transform: rotate(40deg);
}
.kengakukai-concept-u {
	background: #e3e2d7;
	padding: 30px 40px;
	border-radius: 30px;
	margin-bottom: 50px;
}
.kengakukai-concept-u h3 {
	font-weight: 600;
	margin-bottom: 15px;
	font-size: 1.6rem;
}
.kengakukai-concept-u p {
	font-size: 1.8rem;
	line-height: 2.0;
}
@media only screen and (max-width: 768px) {
.kengakukai-concept-u p {
	font-size: 1.4rem;
}
}

@media only screen and (max-width: 768px) {
.kengakukai-concept-u h3,.kengakukai-concept-u p {
	font-size: 1.3rem;
}
}

.kengakukai-concept-y-b {
	display: flex;
	justify-content: space-between;
}
.kengakukai-concept-y {
	width: 60%;
}

@media only screen and (max-width: 768px) {
.kengakukai-concept-y-b {
	display: block;
}
.kengakukai-concept-y {
	width: 100%;
}
}

@media only screen and (max-width: 768px) {
.kengakukai-concept-m dl dt,.kengakukai-concept-m dl dd {
	width: 100%;
}
.kengakukai-concept-m dl dt {
	margin-bottom: 10px;
}
.kengakukai-concept-m-u {
	margin-bottom: 50px;
}
.kengakukai-concept-m-u dl {
	display: block;
}
.kengakukai-concept-m-u dl dt {

}
.kengakukai-concept-m-u dl dd {
	padding-left: 20px;
	padding-right: 20px;
	margin-top: 0;
}
.kengakukai-concept-m-b-in dl dt {
	position: static;
	
}
.kengakukai-concept-m-b-in dl dd {
	position: static;
}

}
.kengakukai-concept-b {
	border: 1px solid #b0aeb0;
	width: 35%;
	/*width: 250px;*/
	/*margin-top: 70px;*/
	margin-left: 30px;
}
.kengakukai-concept-b table {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: left;
	margin: 0;
	padding:  30px 10px;
}
.kengakukai-concept-b table th,.kengakukai-concept-b table td {
	border: none;
	border-bottom: 1px dotted #b0aeb0;
	font-size: 1.2rem;
}
.kengakukai-concept-b table th {
	width: 100px;
}
@media only screen and (max-width: 768px) {
.kengakukai-concept-b {
	width: 100%;
	margin-left: 0;
	margin-right: 0;
	margin-top: 30px;
}
.kengakukai-concept-b table th,.kengakukai-concept-b table td {
	font-size: 1.3rem;
	padding: 10px 0;
}
.kengakukai-concept-b table th {
	width: 70px;
}
.kengakukai-concept-b table td {
	padding-left: 50px;
}
}
.kengakukai-concept-b table tr:last-child th,.kengakukai-concept-b table tr:last-child td {
	border: none;
}






/*=================================
セクション4_こんな方におすすめ
=================================*/
.rt-sec-4 {
	/*margin-bottom: 100px;*/
	background: #faf2d5;
	width: 100vw;
    margin-left: calc(50% - 50vw);
}
.rt-sec-4-inner {
	margin: 0 auto;
	width: 680px;
}
@media only screen and (max-width: 768px) {
.rt-sec-4-inner {
	width: 100%;
}
}

/*.rt-sec-4 h2 {
	font-size: 1.8rem;
	position: relative;
	text-align: center;
	margin-bottom: 50px;
	font-weight: 600;
}
@media only screen and (max-width: 768px) {
.rt-sec-4 h2 {
	font-size: 1.6rem;
}
}
.rt-sec-4 h2:before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -15px;
	border-bottom: 1px solid #000;
	width : 100px ;
	margin: 0 auto;
}
.rt-sec-4content {

}
.rt-sec-4content {
    background: #fbf0d0;
    padding: 30px 40px;
    border-radius: 30px;
    margin-bottom: 50px;
}
.rt-sec-4content ul {

}
.rt-sec-4content ul li {
	font-size: 1.8rem;
	line-height: 2.0;	
}
@media only screen and (max-width: 768px) {
.rt-sec-4content ul li {
	font-size: 1.3rem;
	margin-bottom: 30px;
}
}
*/



/*=================================
セクション5_見どころ
=================================*/
.rt-sec-5 {
	background: #e3e3d8;
	width: 100vw;
    margin-left: calc(50% - 50vw);
}
.kengakukai-exp {
	max-width: 880px;
	padding: 50px 40px;
	margin: 0 auto;
	margin-bottom: 80px;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp {
	padding: 50px 20px;
}
}
.kengakukai-exp h2 {
	text-align: center;
	font-weight: 600;
	margin-bottom: 70px;
	font-size: 1.8rem;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp h2 {
	font-size: 1.5rem;
}
}
.kengakukai-exp h2 span {
	display: inline-block;
	border: 1px solid #000;
	padding: 10px 30px;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp h2 span {
	padding: 10px 20px;
}
}
.kengakukai-exp-inner {
	/*display: flex;*/
}

.kengakukai-exp-inner dl {
	display: flex;
	justify-content: space-between;
	margin-bottom: 180px;
}
.kengakukai-exp-inner dl:nth-child(2n) {
	flex-direction: row-reverse;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp-inner dl {
	display: block;
	margin-bottom: 60px;
}
.kengakukai-exp-inner dl:nth-child(2n) {
	display: block;
}
}
.kengakukai-exp-inner dl dt,.kengakukai-exp-inner dl dd {
	width: 47%;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp-inner dl dt,.kengakukai-exp-inner dl dd {
	width: 100%;
}
}
.kengakukai-exp-inner dl dt h3 {
	text-align: center;
	font-weight: 600;
	font-size: 2.0rem;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	margin-bottom: 25px;
	padding-top: 5px;
}
.kengakukai-exp-inner dl dt p {
	font-weight: 200;
	font-size: 1.5rem;
	line-height: 1.8;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp-inner dl dt p {
	margin-bottom: 20px;
	font-size: 1.3rem;
}	
}

.kengakukai-exp-inner dl dd {
	position: relative;
}
.kengakukai-exp-inner dl dd img {
	border-radius: 11%;
	position: absolute;
	top: 0;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp-inner dl dd img {
	border-radius: 0%;
}
}
.kengakukai-exp-inner dl dd p {
	background: #fff;
	font-size: 1.2rem;
	font-weight: 600;
 	padding: 15px 0;
 	position: absolute;
 	top: -60px;
}
@media only screen and (min-width: 769px) {
.kengakukai-exp-inner dl dd p {
	-ms-writing-mode: tb-rl;
 	writing-mode: vertical-rl;
 	text-orientation: upright;
}
}
@media only screen and (max-width: 768px) {
.kengakukai-exp-inner dl dd img {
	position: static;
	/*margin-bottom: 10px;*/
}
.kengakukai-exp-inner dl dd p {
	position: static;
	text-align: center;
	padding: 5px 0;
}
}


.kengakukai-exp-inner dl:first-child dd p,.kengakukai-exp-inner dl:nth-child(3) dd p,.kengakukai-exp-inner dl:nth-child(5) dd p {
	right: 20px;
}
.kengakukai-exp-inner dl:nth-child(2) dd .ctrlno1 {
	left: 55px;
}
.kengakukai-exp-inner dl:nth-child(2) dd .ctrlno2,.kengakukai-exp-inner dl:nth-child(4) dd p {
	left: 20px;
}
@media only screen and (max-width: 768px) {
.kengakukai-exp-inner dl:nth-child(2) dd .ctrlno1 {
	padding-bottom: 0;
}
.kengakukai-exp-inner dl:nth-child(2) dd .ctrlno2 {
	padding-top: 0;
}
}


/*=================================
セクション6_green建築工房とは
=================================*/
.rt-sec-6 {

}
.about-green {
    /*background: #dfedd6;*/
    width: 100vw; /* 画面の幅いっぱいにする */
    margin-left: calc(50% - 50vw); /* 要素の中央を画面の中央に合わせ、左に引き出す */
}
.about-greenInner {
    max-width: 780px;
    margin: 0 auto;
    padding: 50px 0;
}
@media only screen and (max-width: 768px) {
.about-greenInner {
    width: 100%;
    padding: 0 6.6vw;
}
}

.about-greenInner h2 {
    font-size: 1.8rem;
    text-align: center;
    margin-bottom: 80px;
    position: relative;
}
@media only screen and (max-width: 768px) {
.about-greenInner h2 {
    font-size: 1.7rem;
    margin-bottom: 60px;
}
}
.about-greenInner h2:before {
    content: '';
    position: absolute;
    left: 50%;
    top: -15px;
    display: inline-block;
    width: min(500px, 90%);
    height: 1px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #b0aeb0;
    border-radius: 2px;
}
.about-greenInner h2:after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -15px;
    display: inline-block;
    width: min(500px, 90%);
    height: 1px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #b0aeb0;
    border-radius: 2px;
}
.about-greenInner h2 span {
    display: block;
}
.about-greenInner h2 span:first-child {
    font-weight: 600;
}
.about-green-content {
    display: flex;
    justify-content: space-between;
    margin-top: 50px;
}
@media only screen and (max-width: 768px) {
.about-green-content {
    display: block;
}
}
.about-green-content .agc-l {
    width: 50%;
}
@media only screen and (max-width: 768px) {
.about-green-content .agc-l {
    width: 100%;
}
}
.about-green-content .agc-l .pWrap {
    margin-top: 30px;
}
.about-green-content .agc-l p {
    font-size: 1.7rem;
    margin-bottom: 50px;
    font-weight: 200;
}
@media only screen and (max-width: 768px) {
.about-green-content .agc-l p {
    font-size: 1.4rem;
    margin-bottom: 30px;
    line-height: 2.0;
}
}
.about-green-content .agc-l img {
    width: 90%;
    display: block;
    margin-top: 150px;
    margin-left: 50px;
}
@media only screen and (max-width: 768px) {
.about-green-content .agc-l img {
    width: 100%;
    display: block;
    margin-left: 0;
    margin-bottom: 5px;
    margin-top: 30px;
}
}
.about-green-content .agc-r {
    width: 40%;
    /*margin-top: 80px;*/
}
@media only screen and (max-width: 768px)  {
.about-green-content .agc-r {
    width: 100%;
}
}
.about-green-content .agc-r .agc-r-img1 {
    display: block;
    margin-left: -10px;
}
@media only screen and (max-width: 768px) {
.about-green-content .agc-r .agc-r-img1 {
    margin-left: 0;
    margin-bottom: 5px;
}
}
.about-green-content .agc-r .agc-r-img2 {
    width: 60%;
    display: block;
    margin-top: 60px;
    margin-left: 20px;
}
@media only screen and (max-width: 768px) {
.about-green-content .agc-r .agc-r-img2 {
    width: 100%;
    display: block;
    margin-top: 0;
    margin-left: 0;
}
}


/*=================================
セクション7_よくある質問
=================================*/
.rt-sec-7 {
	padding: 50px 0 50px 0;
	background: #dfedd6;
	width: 100vw;
    margin-left: calc(50% - 50vw);
}

.rt-sec-7 h2 {
	font-size: 2.2rem;
	font-weight: 600;
	text-align: center;
	margin-bottom: 50px;
	position: relative;
	margin-top: 50px;
}

.p-faq__section {
	max-width: 880px;
	margin: 0 auto;
}









/*=================================
開催概要
=================================*/

.event-details {
    margin: 70px 0;
}
.event-details h2 {
    text-align: center;
    font-weight: 600;
    margin-bottom: 50px;
    font-size: 1.3rem;
    
}
.event-details h2 p {
    border: 1px solid #000;
    border-radius: 30px;
    display: inline-block;
    padding: 8px 70px;
    line-height: 1.4;
    font-size: 1.5rem;
}
.event-details h2 span {
    display: block;
    font-weight: 200;
    font-size: 1rem;
}
.event-details table {
    
}
.event-details table th {
    width: 150px;
    border: none;
    border-bottom: 1px solid #8d8d8d;
    padding: 20px 0;
}

.event-details table td {
    border: none;
    border-bottom: 1px solid #8d8d8d;
    padding: 20px 0;
}
@media only screen and (max-width: 768px) {
.event-details table th,.event-details table td {
    font-size: 1.4rem;
    display: block;
    width: 100%;
}
.event-details table th {
    padding: 0;
}
.event-details table td {
    border: none;
}
}
.event-details-appeal {
	font-size: 1.6rem;
	text-align: center;
	font-weight: 600;
	margin: 50px 0;
}

/*========フォーム========*/
.event-form p {
    margin-bottom: 0;
}

.event-form {
    background: #e3e3d8;
    padding: 50px 80px;
}

@media only screen and (max-width: 768px) {
.event-form {
    padding: 50px 30px;
}
}
.event-form h2 {
    font-size: 1.8rem;
    font-weight: 600;
    text-align: center;
}
.event-form-appeal {
	margin-top: 10px;
	text-align: center;
	font-size: 1.4rem;
}
.event-form h3 {
	font-size: 1.6rem;
    font-weight: 600;
    text-align: center;
    margin-top: 30px;
}
.event-form .form-desc {
    margin-bottom: 40px;
    text-align: center;
    font-size: 1.2rem;
}
.event-form table th {
    width: 200px;
    border: none;
    font-weight: 200;
    font-size: 1.1rem;
    vertical-align: middle;
}
.event-form table td {
    border: none;
    font-weight: 200;
}
.event-form .req {
    color: #f4a261;
    margin-left: 4px;
    font-size: 0.9rem;
}
@media only screen and (max-width: 768px) {
.event-form table th {
    display: block;
    width: 100%;
    font-size: 1.4rem;
}
.event-form table td {
    display: block;
    width: 100%;
    margin-bottom: 20px;
    font-size: 1.4rem;
}
.event-form .req {
    font-size: 1rem;
}
}

.event-form table .form-group-select span {
    display: inline-flex;
    align-items: center;
    position: relative;
}

.event-form table .form-group-select span::after {
    position: absolute;
    right: 15px;
    width: 10px;
    height: 7px;
    background-color: #535353;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    pointer-events: none;
}

.event-form table td select {
    appearance: none;
    min-width: 230px;
    height: 2.8em;
    padding: .4em calc(.8em + 30px) .4em .8em;
    border: 1px solid #d0d0d0;
    border-radius: 3px;
    background-color: #fff;
    color: #333333;
    font-size: 1.1rem;
    cursor: pointer;
    line-height: 1;
}
@media only screen and (max-width: 768px) {
.event-form table td select {
    font-size: 1.5rem;
}
}

.event-form table td input,.event-form table td textarea {
    border: none;
    box-sizing: border-box;
    max-width: 100%;
    padding-left: 10px;
}
.event-form table td textarea {
    resize: vertical;
}
@media only screen and (max-width: 768px) {
.event-form table td textarea {
    width: 100%;
}
}
.event-form .form-group-ac .ac-ctrl {
    display: inline-block;
    margin-right: 10px;
}
.event-form .form-group-ac p {
    font-size: 1.1rem;
}
@media only screen and (max-width: 768px) {
.event-form .form-group-ac p {
    font-size: 1.5rem;
}
}
.event-form .form-group-ac input {
    width: 50px;
    padding: 0 10px;
}
.wpcf7-list-item-label {
    font-size: 1.1rem;
}
.form-group-check input {
    width: auto !important;
    max-width: auto !important;
}
.event-form .form-btns {
    display: flex;
    justify-content: center;
}
.event-form .form-btns input {
    border: none;
    background: #ffe164;
    color: #006450;
    border-radius: 30px;
    padding: 10px 40px;
    font-size: 1.2rem;
    margin-right: 30px;
    cursor: pointer;
}
.wpcf7-spinner {
    display: none !important;
}
.event-form .btn-tel-cta {
    text-align: center;
    background: #c17c5e;
    color: #fff;
    display: block;
    line-height: 1.1;
    padding: 12px 40px;
    border-radius: 30px;
    font-size: 1.2rem;
}
.event-form .btn-tel-cta span {
    display: block;
    font-size: 0.9rem;
}
@media only screen and (max-width: 768px) {
.event-form .form-btns {
    display: block;
}
.event-form .form-btns input {
    width: 100%;
    text-align: center;
}
.event-form .form-btns div:first-child {
    margin-bottom: 30px;
}
}

/*========フォームのエラー文========*/
.wpcf7-not-valid-tip,.wpcf7-response-output {
    font-size: 1rem;
}
.wpcf7-response-output {
    color: red;
    border-color: red !important;
}

@media only screen and (max-width: 768px) {
/*.wpcf7-form-control-wrap {
  display: block;
  text-align: center;
}
.wpcf7-form p {
  text-align: center;
}
*/

}

/* リセットのtd,thはフォーム内に影響しないよう限定する */
@media only screen and (max-width: 768px) {
    td, th {
        padding: 0;
    }
    /* フォーム内は上書きして戻す */
    .event-form table th,
    .event-form table td {
        padding: 4px 0;
    }
}

/* inputのはみ出し対策 */
.event-form table td input,
.event-form table td textarea {
    width: 100%;
    box-sizing: border-box;
    max-width: 100%;
}
@media only screen and (max-width: 768px) {
.event-form table td input {
	height: 30px;
}
}



