@charset "UTF-8";
/*
Theme Name: MY THEME 
Author: Zenshin
Description: オリジナルテーマ
Version: 1.0
*/
img {
    max-width: 100%;
    height: auto;
	vertical-align: bottom;
}

.img-full img {
	width: 100%;
	height: auto;
	text-align: center;
	vertical-align: bottom;
}


@media screen and (max-width: 780px) {
	.flex_res{
		flex-direction: column;
		align-items: center;
	}
}

.flex_hanyo{
	display: flex;
	justify-content: center;
}

.flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.flex-center {
	display: flex;
	justify-content: center;
}

.flex-base {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 3%;
}

.alignleft {
	float: left;
	margin-left: 0;
	margin-right: 1em;
}

.alignright {
	float: right;
	margin-left: 1em;
	margin-right: 0;
}

.aligncenter {
	margin-left: auto;
	margin-right: auto;
}

.wp-block-categories.aligncenter,
.wp-block-latest-posts.aligncenter,
.wp-block-archives.aligncenter,
.wp-block-tag-cloud.aligncenter,
.wp-block-latest-comments.aligncenter,
.wp-block-rss.aligncenter {
	text-align: center;
}

figure {
	margin-left: 0;
	margin-right: 0;
}

body {
	box-sizing: border-box;
}

body *,
body *::before,
body *::after {
	box-sizing: inherit;
}

ul {
	padding-inline-start: 1rem;
}

pre {
	font-family: unset;
}

/* 変数 */
:root {
	--f1: 2.44em;
	/* 39.04px */
	--f2: 1.95em;
	/* 31.2px */
	--f3: 1.56em;
	/* 24.96px */
	--f4: 1.25em;
	/* 20px */
	--f5: 1em;
	/* 16px */
	--f6: 0.8em;
	/* 12.8px */

	--f7: 0.66em;
	/* 12.8px */

	--basecolor: #63a211;
	/* 基本色 */
	--gradient: linear-gradient(81.7deg, rgba(34, 126, 34, 1) 8.1%, rgba(99, 162, 17, 1) 86.5%);

	--myfont: "zen-maru-gothic", sans-serif;
	--myw: 720px;
	/*標準幅*/
}


/* フォント */
body {
	font-family: var(--myfont);
	font-size: 21px;
}

p {
	line-height: 1.8;
	font-size: var(--f5);
}


h1 {
	font-size: var(--f1);
	font-weight: 300;
}

h2 {
	font-size: var(--f3);
	margin-block-start: 0;
}

h3 {
	font-size: var(--f3);
}

h4 {
	font-size: var(--f4);
}

h5 {
	font-size: var(--f5);
}

h6 {
	font-size: var(--f6);
}

.text_item_double_L{
	width: 55%;
	padding: 30px 0;
	margin: 0 auto;
}

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

.text_img_double_R{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 45%;
	padding: 30px 0;
	margin-left: 8%;
}

.text_img_double_R img{
	vertical-align: middle;
}
.title_wrapper{
	margin-right: 50%;
}

.title_img{
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 30px 0;
}

.top_assist_text{
	font-size: 14px;
	/* margin-top: 35px; */
}

@media screen and (max-width: 780px) {
	.text_item_double_L{
		width: 100%;
		display: flex;
		flex-direction: column; /* 要素を縦方向に並べる */
		justify-content: center; /* 横方向（左右方向）の中央揃え */
		align-items: center; /* 縦方向（上下方向）の中央揃え */
		padding: 0;
	}
	.text_img_double_R{
		width: 70%;
		margin-left: 0;
		margin-bottom: 10px;
	}
	.title_img{
		width: 70%;
		margin: 20px 0 30px 0;
	}
	.text_item_double_L p{
		font-size: 14px;
	}
	.title_wrapper{
		width: 100%;
		display: flex;
		flex-direction: column; /* 要素を縦方向に並べる */
		justify-content: center; /* 横方向（左右方向）の中央揃え */
		align-items: center; /* 縦方向（上下方向）の中央揃え */
	}
	.osirase_img{
		width: 50%;
	}
}


/* 横幅 */
body {
	margin: 0;
}


.alignfull {
	width: 100%;
	height: auto;
	overflow: hidden;
}

.alignwide {
	margin-top: 5%;
	padding-left: 25%;
	padding-right: 25%;
}

/*スマホ*/
@media (max-width: 600px) {
	.alignwide {
		padding-left: 20px;
		padding-right: 20px;
	}
}

@media (min-width: 1320px) {}


/*配置*/
.center {
	text-align: center;
}

.space-between {
	justify-content: space-between;
}

/* ポジション */
.relative {
	position: relative;
}

.top {
	vertical-align: top;
}

/*リンク*/
a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	color: inherit;
	opacity: 0.7;
}

/*色*/
.white {
	color: white;
}

.red {
	color: red;
}

.green {
	color: green;
}

.grey {
	background-color: #F2F2F2;
	padding-bottom: 5%;
}

.white-bg {
	background-color: white;
}

/*スマホ限定/PC限定*/
/*フッターの画像切替のみに使用 bootstrapのxlに対応*/

@media only screen and (max-width:768px) {
	.sp-md {
		display: block;
	}

}

/*-----マージン共通-----*/
.margin_hanyo {
	margin-top: 120px;
}

.margin_hanyo_sub2 {
	margin-top: 100px;
}

.margin_right_pc{
	margin-right: 20px;
}

.margin_hanyo_bottom {
	margin-bottom: 5%;
}

@media screen and (max-width: 780px) {
	.margin_hanyo{
		margin-top: 50px;
	}
	.margin_hanyo_sub {
		margin-top: 10px;
	}
	.margin_hanyo_sub2 {
		margin-top: 50px;
	}
	.margin_top_res{
		margin-top: 15px;
	}
	.margin_right_pc{
		margin-right: 0;
	}
}

p {
	font-size: 21px;
}

/* ベーシックプラン用。汎用CSS */
/* width指定 */
.w-10 {width: 10%}
.w-15 {width: 15%}
.w-18 {width: 18%}
.w-20 {width: 20%}
.w-25 {width: 25%}
.w-30 {width: 30%}
.w-33 {width: 33%} /* flexの3等分用 */
.w-40 {width: 40%}
.w-45 {width: 45%}
.w-48 {width: 48%} /* flexの2等分用 */
.w-50 {width: 50%}
.w-55 {width: 55%}
.w-60 {width: 60%}
.w-65 {width: 65%} /* flexの2:1の比率用 */
.w-70 {width: 70%}
.w-75 {width: 75%}
.w-80 {width: 80%} /* 基本のサイズ */
.w-90 {width: 90%}
.w-95 {width: 95%}
.w-100 {width: 100%}
.w-fit {width: fit-content}
/* 余白 */
.p-2 {padding: 0.29rem !important}
.p-10 {padding: 10px}
.p-15 {padding: 15px}
.p-20 {padding: 20px}
.p-30 {padding: 30px}
.p-40 {padding: 40px}
.p-60 {padding: 60px}
.gap4 {gap: 4%;}
.gap2 {gap: 2%;}
.gap1 {gap: 1%;}
.gap1_2 {gap: 0.5%;}
/* flexなど位置系 */
.flex-center {display: flex;justify-content: center;align-items: center;gap: 2%}
.flex-between {display: flex;justify-content: space-between;align-items: center;}
.column {display: flex;flex-direction: column;align-items: center;gap: 2%}
.flex-start {display: flex;justify-content: flex-start;align-items: start;}
.flex-end {display: flex;justify-content: flex-end;align-items: center;gap: 2%}
.right {text-align: right;}
.center {text-align: center;}
.left {text-align: left;}
.wrap {flex-wrap: wrap;row-gap: 20px;}
/* font-size汎用 */
.font10 {font-size: 10px}
.font12 {font-size: 12px}
.font14 {font-size: 14px}
.font16 {font-size: 16px}
.font18 {font-size: 18px}
.font20 {font-size: 20px}
.font24 {font-size: 24px}
.font30 {font-size: 30px;font-weight: bold}
.font40 {font-size: 40px;font-weight: bold}
@media only screen and (max-width:768px) and (min-width: 561px) {
	.font16 {font-size: 14px}
	.font18 {font-size: 16px}
	.font20 {font-size: 18px}
	.font24 {font-size: 20px}
	.font30 {font-size: 24px;font-weight: bold}
	.font40 {font-size: 30px;font-weight: bold}
}
@media only screen and (max-width:560px) {
	.font16 {font-size: 14px}
	.font18 {font-size: 15px}
	.font20 {font-size: 16px}
	.font24 {font-size: 18px}
	.font30 {font-size: 20px;font-weight: bold}
	.font40 {font-size: 24px;font-weight: bold}
}
/* その他汎用 marginやpaddingそのほか */
.style-none {list-style: none;padding: 0;}
.bold {font-weight: bold}
.m-auto {margin: auto}
.m-0 {margin: 0}
.m-l-3 {margin-left: 3%}
.m-l-5 {margin-left: 5%}
.m-t-5 {margin-top: 5%;}
.m-r-2 {margin-right: 2%;}
.m-l-8 {margin-left: 8%;}
.p-l-8 {padding: 0 0 0 8%;}
.p-l-15px {padding-left: 15px;}
.p-b-5 {padding-bottom: 5px;}
.p-b-20 {padding-bottom: 20px;}
.p-t-5 {padding-top: 5px;}
.p-t-30 {padding-top: 30px;}
.vertical-top {vertical-align: top;}
.p-y-10 {padding: 10px 0;}
.p-y-20 {padding: 20px 0;}
.transparent {color: transparent;}
.b-box {border: 1px solid #000}
.b-rad {border-radius: 8px;}
/* レスポ化用汎用 */
@media only screen and (min-width: 769px) {
	.sp {display: none} /* SP表示（769px未満で表示） */
	.pc-w-45 {width: 45%;}
}
@media only screen and (max-width: 768px) {
	.pc {display: none} /* PC表示（768px以上で表示） */
	.sp-column {display: flex;flex-direction: column;align-items: center;}
	.sp-column-re {display: flex;flex-direction: column-reverse;align-items: center;}
	.hamburger_menu_btn_wrap.sp {display: block;}
	.sp-w-70 {width: 70%;}
	.sp-gap4 {gap: 4%;}
	.sp-w-100 {width: 100% !important;}
	.sp-p-20 {padding: 20px;}
	.sp-center {text-align: center;}
	.sp-m-auto {margin: auto;}
	.sp-w-45 {width: 45%;}
	.sp-fl-center {justify-content: center;}
}
@media only screen and (min-width: 561px) {
	.sm {display: none} /* スマホ表示（561px未満で表示） */
}
@media only screen and (max-width: 560px) {
	.extra {display: none} /* それ以外表示（560px以上で表示） */
	.sm-column {display: flex;flex-direction: column;align-items: center;gap: 10px;}
	.sm-w-90 {width: 90%;}
	.pc-w-45 {width: 70%;}
}
/* header */
.myhead {padding: 2% 0;background-color: #f4e4e4;}
.font-brown {color: #5d4b28;}
.font-pink {color: #ef7191;}
/*-----ハンバーガーメニュー-----*/
.hamburger_menu_btn_wrap {display: none;margin-right: 1.4%;margin-left: auto;position: fixed;right: 0;top: 15%;}
.hamburger_menu_btn {width: 30px;height: 24px;position: relative;cursor: pointer;z-index: 1001;display: flex;flex-direction: column;justify-content: space-between;}
.hamburger_menu_btn span {display: block;width: 100%;height: 3px;background-color: #442c16;border-radius: 2px;transition: all 0.3s ease;}
.hamburger_menu_btn.active span:nth-child(1) {transform: translateY(10.5px) rotate(45deg);}
.hamburger_menu_btn.active span:nth-child(2) {opacity: 0;}
.hamburger_menu_btn.active span:nth-child(3) {transform: translateY(-10.5px) rotate(-45deg);}
.hamburger_window {position: fixed;top: 0;right: -300px;width: 300px;height: 100vh;background-color: rgba(30, 30, 30, 0.95);padding-top: 80px;box-sizing: border-box;transition: right 0.5s ease;z-index: 1000;visibility: hidden;overflow-y: auto;}
.hamburger_window.open {right: 0;visibility: visible;}
.hamburger_list_item {list-style: none;padding: 0;margin: 0;}
.hamburger_list_item li {border-bottom: 1px solid rgba(255, 255, 255, 0.2);}
.hamburger_list_item li:first-child {border-top: 1px solid rgba(255, 255, 255, 0.2);}
.hamburger_list_item li a {display: block;padding: 15px 20px;color: white;text-decoration: none;font-size: 1.1rem;transition: background-color 0.3s ease;}
.hamburger_list_item li a:hover {background-color: rgba(255, 255, 255, 0.1);}
.hamburger_background {position: fixed;top: 0;left: 0;width: 100vw;height: 100vh;background-color: rgba(0, 0, 0, 0.5);z-index: 999;opacity: 0;visibility: hidden;transition: opacity 0.5s ease;}
.hamburger_background.open {opacity: 1;visibility: visible;}
/* footer  背景画像変更アリ */
.myfoot {background: url('./image/g73.png')no-repeat;padding: 20px 0 0;background-size: cover;}
.sp-li {background-color: #ef7191;color: #fff;margin-bottom: 10px;width: 100%;text-align: center;font-weight: bold}
@media only screen and (max-width: 850px) {
	.c-width {width: 90% !important;margin: auto;}
	.pc-850 {display: none !important;}
}
@media only screen and (min-width: 851px) {
	.sp-850 {display: none !important;}
}
/* front-page */
.bg-main {background-color: #f9f6f4;}
.bg-green {background-color: #007940;}
.bg-white {background-color: #fff}
.arrow-button {background-color: #f4e4e4;color: #5d4b28;width: fit-content;padding: 1px 6px;border-radius: 100%;}
.news-container {background-color: #fff;border: 1px solid #ef7191;border-radius: 12px;width: 80%;margin: auto;}
.news-button {width: fit-content;margin: auto;padding: 10px 10px;border: 1px solid #ef7191;border-radius: 24px;}
.button-style {display: flex;justify-content: space-between;}
/* お知らせ欄 */
.news-tag {background-color: #f4e4e4;padding: 2px 15px;border-radius: 12px;font-size: 16px !important;color: #5d4b28;}
.b-b-bl {border-bottom: 1px solid #000;}
/* overview */
.b-b-dot {border-bottom: 1px dotted #000;}
.normal {font-weight: normal}
.greeting {background: url("./image/greeting.png")no-repeat;background-size: cover;}
@media only screen and (max-width: 768px) {
	.b-b-brown-ash {background-image: none;flex-direction: column;justify-content: center;align-items: center !important;}
	.b-b-brown-ash th {background-color: #442c16;color: white;width: 100% !important;text-align: center; padding: 10px 0;}
	.b-b-brown-ash td {border-bottom: 1px solid #ccc; width: 100% !important;text-align: center;padding: 10px 0;}
}
/* contact */
.cform {width: 100%;background-color: #fff;border: 1px solid #000;border-radius: 8px;border-collapse: separate;}
.cform tbody {width: 100%}
.cform tr {width: 100%;border: none;}
.bg-form {color: #5d4b28;padding: 10px 25px 10px 50px;border: none;}
.bg-form p,.border-form p {margin: 0; font-size: 18px;}
.required-srt {background-color: #f4e4e4;padding: 2px 15px;border-radius: 12px;font-size: 16px !important;color: #5d4b28;}
.border-form input[type="text"],.border-form textarea {width: 80%;margin:10px 0 10px 4%;border: none;background-color: #f8ecb8;border-radius: 8px;padding: 10px;}
.border-form input[type="tel"],.border-form input[type="email"] {width: 80%;margin:10px 0 10px 4%;border: none;background-color: #f8ecb8;border-radius: 8px;padding: 10px;}
.wpcf7-spinner {display: none !important;}
@media only screen and (max-width: 768px) and (min-width: 561px) {
	.sp-w-90 {width: 90% !important}
	.cform tr {display: flex;flex-direction: column;align-items: center;justify-content: center;}
	.bg-form {width: 100%;}
	.border-form {width: 100%;text-align: center;}
	.border-form input[type="text"],.border-form textarea {width: 90%;margin:10px auto;}
	.border-form input[type="tel"],.border-form input[type="email"] {width: 90%;margin:10px auto;}
}
@media only screen and (max-width: 560px) {
	.sp-w-90 {width: 95% !important}
	.cform tr {display: flex;flex-direction: column;align-items: center;justify-content: center;}
	.bg-form {width: 100%;}
	.border-form {width: 100%;text-align: center;}
	.border-form input[type="text"],.border-form textarea {width: 90%;margin:10px auto;}
	.border-form input[type="tel"],.border-form input[type="email"] {width: 90%;margin:10px auto;}
	.sm-w-100 {width: 100% !important; text-align: center !important;}
}
/* facility */
.b-b-dot-big {border-bottom: 5px dotted #000;}
/* products */
.table-label {background-color: #f4e4e4;color: #5d4b28;}
/* sending-button */
.send-btn-wrap {position: relative;}
.send-btn-wrap input[type="submit"] {position: absolute;inset: 0;opacity: 0;z-index: 2;}
.fake-btn {display: block;padding: 22px 70px 22px 40px;border-radius: 999px;background: #eacbca;color: #5d4b28;position: relative;width: 25%;margin: auto;text-align: center;font-weight: bold;}
.fake-btn .arrow {position: absolute;right: 18px;top: 50%;transform: translateY(-50%);background: #f4e4e4;color: #5d4b28;width: 20px;height: 20px;border-radius: 50%;display: flex;align-items: center;justify-content: center;padding: 15px;font-size: 14px;}
@media only screen and (max-width: 1300px) and (min-width: 1000px) {.fake-btn {width: 50%;}}
@media only screen and (max-width: 1000px) and (min-width: 700px) {.fake-btn {width: 60%;}}
@media only screen and (max-width: 700px) and (min-width: 500px) {.fake-btn {width: 70%;}}
@media only screen and (max-width: 500px) {.fake-btn {width: 80%;}}
/* news */
.nav-links {width: 100%;}
#nav-links {list-style: none;display: flex;justify-content: center;gap: 5%;}
#nav-links li {color: #5d4b28;}
#nav-links .current {background-color: #eacbca;color: #5d4b28;padding: 1px 10px;}


/* ここから小川追記 */
.thisisask  {
	text-align: center;
	padding-bottom: 5%;
}

.wood-wrap {
  display: flex;
  gap: 20px;           /* 画像の間隔 */
}

.wood-wrap img {
  width: 33.33%;      /* 3等分 */
  height: auto;
}

@media only screen and (max-width: 560px) {
	.wood-wrap {flex-direction: column;text-align: center;align-items: center;}
	.wood-wrap img {width: 70%;}
}

/* スライド */
.slider-container {
	position: relative;
	overflow: hidden;
	width: 100%;
	display: inline-block;
	z-index: 10;
	height: 34vw;
}
.slide {
	opacity: 0;
	/* 初期状態では非表示 */
	transition: opacity 1s ease-in-out;
	/* フェードのアニメーション */
	position: absolute;
	width: 100%;
}
.slide.active {
	opacity: 1;
	/* 表示するとき */
}
.slider-container img {
	width: 100%;
}
  /* 左右の矢印 */
.arrow {
	position: absolute;
	top: 50%;
	font-size: 40px; /* 矢印のサイズ */
	color: white;
	opacity: 0.6;
	cursor: pointer;
	z-index: 3;
	transform: translateY(-50%);
}
.left-arrow {
	left: 10px;
} 
.right-arrow {
	right: 10px;
} 
  /* 半透明の背景とホバー時に色を濃く */
.arrow:hover {
	opacity: 1;
}
/* 左右の矢印のスタイル */
.arrow {
    position: absolute;
    top: 50%;
    font-size: 30px;
    color: white;
    opacity: 0.6;
    cursor: pointer;
    z-index: 1;
}
.left-arrow {
    left: 10px;
    transform: translateY(-50%);
}
.right-arrow {
    right: 10px;
    transform: translateY(-50%);
}
/* 半透明の背景 */
.arrow:hover {	
    opacity: 1;
}

/* 追記 */
/* ヘッダー */
.myhead {
    padding: 18px 0;
    background-color: #f4e4e4;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.5);
    position: relative;
    z-index: 10;
}

.myhead ul.pc {
    display: flex;
    justify-content: center; 
    gap: 30px;               
    width: auto !important;
    margin: 0 40px;
}

.myhead ul.pc li {
    width: auto !important;
    white-space: nowrap;
}

.myhead .flex-between.w-35 {
    width: auto !important;
    display: flex;
    gap: 12px;
}

.myhead .flex-between.w-35 img {
    height: 50px;
    width: auto;
	object-fit: contain;
    display: block;
}

.home .myhead {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    
    background-color: rgba(244, 228, 228, 1) !important; 
    
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.5);
}

.main-visual {
    position: relative;
}

.mv-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.mv-copy-box {
    position: absolute;
    top: 25%;
    right: 5%;
    color: #fff;
}

.white-shadow {
    text-shadow: 
        0 2px 4px rgba(0, 0, 0, 0.8),
        0 0 15px rgba(0, 0, 0, 0.4);
        
    line-height: 1.5;
}

.mv-logo-badge {
    position: absolute;
    bottom: 25%;
    right: 10%;
    background-color: rgba(255, 255, 255, 0.9);
    padding: 15px 25px;
    width: fit-content;
}

.shadow {
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.25);
}

@media only screen and (max-width: 768px) {
    .mv-copy-box {
        top: 10%;
        right: 5%;
        width: 90%;
        text-align: right;
    }
    .mv-logo-badge {
        padding: 8px 15px;
        right: 2%;
        bottom: 2%;
    }
}

/* フッター */
.myfoot {
    background: url('./image/g73.png') no-repeat center top;
    background-size: cover;
    padding-top: 30px;
    background-color: #f4e4e4;
}

.p-l-3 {
	padding-left: 4%;
}

.map-container-full {
    width: 100%;
    margin: 0 auto;
    border-radius: 0;
    overflow: hidden;
    line-height: 0;
}

.foot-btn-group {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 15px;
}

.foot-btn-img-large {
    display: block;
    height: auto;
    width: 100%;
    max-width: 220px;
    margin: 0 auto;
}

.b-b-brown {
    border-bottom: 1px solid rgba(93, 75, 40, 0.4);
}

.foot-nav li a {
    text-decoration: none;
    display: block;
    padding-left: 5px;
}

/* 施設案内 */
.compact-facility-grid {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 60px;
    max-width: 1000px;
    margin: 0 auto;
}

.facility-left-item {
    flex: 0 0 45%;
    text-align: right;
}

.facility-left-item img {
    width: 100%;
    max-width: 400px;
}

.facility-right-item {
    flex: 0 0 45%;
}

.lift-car-small-box {
    width: 50%;
    min-width: 150px;
    margin-top: 35px;
}

.lift-car-small-box img {
    width: 100%;
    height: auto;
}


.bg-white .w-90.m-auto .flex-between.sm-column {
    align-items: flex-start !important;
}

.w-90.m-auto .flex-between.sm-column > .w-20 {
    margin-top: 15px !important; 
}

.w-90.m-auto .flex-between.sm-column > .w-20 {
    width: 160px !important;
    height: 160px !important;
    background-color: #f8edc3;
    border: 2px solid #5d4037;
    border-radius: 50%;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center;
    flex-shrink: 0;
}

.w-90.m-auto .w-20 img {
    display: none !important;
}

.bg-white > .w-90.m-auto:nth-child(2) .w-20::before {
    content: "1F";
    font-size: 35px !important;
    font-weight: bold;
    color: #5d4037;
    line-height: 1;
}
.bg-white > .w-90.m-auto:nth-child(2) .w-20::after {
    content: "事務所";
    font-size: 20px !important;
    color: #5d4037;
    margin-top: 5px;
}

.bg-white > .w-90.m-auto:nth-child(3) .w-20::before {
    content: "3F&4F";
    font-size: 30px !important;
    font-weight: bold;
    color: #5d4037;
    line-height: 1;
}
.bg-white > .w-90.m-auto:nth-child(3) .w-20::after {
    content: "グループホーム";
    font-size: 20px !important;
    color: #5d4037;
    margin-top: 5px;
}

.bg-white > .w-90.m-auto:nth-child(4) .w-20::before {
    content: "屋上";
    font-size: 22px !important;
    font-weight: bold;
    color: #5d4037;
    line-height: 1;
}
.bg-white > .w-90.m-auto:nth-child(4) .w-20::after {
    content: "ルーフガーデン";
    font-size: 20px !important;
    color: #5d4037;
    margin-top: 5px;
}

/* 会社案内 */
.chairman-container {
    display: flex !important;
    justify-content: center;
    align-items: flex-end !important;
    gap: 75px;
    margin-bottom: 20px;
}

.c-photo {
    width: 190px !important;
    height: auto;
    display: block;
}

.c-sign {
    width: 450px !important;
    height: auto;
    display: block;
    margin-top: 5px;
}

.full-width-buttons {
    display: flex;
    justify-content: space-between;
    width: 95% !important;
    gap: 15px;
    margin: 0 auto;
}

.btn-wrap {
    flex: 1;
}

.btn-large {
    width: 100% !important;
    height: auto;
    max-width: none !important;
    display: block;
}

@media screen and (max-width: 767px) {
    .full-width-buttons {
        flex-direction: column;
    }
}

/* 料金 */
.price-table {
    border-collapse: collapse;
    margin-top: 10px;
    font-size: 16px;
}

.table-label {
    background-color: #F2E6E6 !important;
    padding: 12px 10px !important;
    text-align: center;
    border: none;
    font-weight: bold;
}

.price-table tbody tr {
    border-bottom: 1px dotted #D7CCC8;
}

.price-table td, .price-table th {
    padding: 12px 10px;
    text-align: center;
    color: #5D4037;
}

.bold {
    font-weight: bold;
}

.other-costs-list {
    list-style: none;
    padding-left: 0;
}
.other-costs-list li {
    padding: 5px 0;
}

.add-row {
    background-color: #FAF7F2;
}

@media screen and (max-width: 768px) {
    .bg-white { padding: 20px 10px !important; }
    .price-table { font-size: 12px; display: block; overflow-x: auto; }
}


/* 採用情報 */
.flex-end-bottom {
    display: flex !important;
    justify-content: center;
    align-items: flex-end !important;
    gap: 30px;
    margin-bottom: 30px;
}

.c-photo {
    width: 150px !important;
    height: auto;
    display: block;
}

.c-sign {
    width: 320px !important;
    height: auto;
    display: block;
    margin-top: 5px;
}

.w-100 {
    width: 100% !important;
}

.btn-large {
    width: 95% !important;
    max-width: none !important;
    height: auto;
    display: block;
}

@media screen and (max-width: 767px) {
    .flex-between.sp-column.w-100 .w-48 {
        width: 100% !important;
        margin-bottom: 20px;
    }
}


/* レスポ化 */
/* ヘッダー */
@media screen and (max-width: 1024px) {
    .myhead .flex-between.w-35 img {
        height: 45px;
        transition: height 0.3s ease;
    }
}

@media screen and (max-width: 960px) {
    .myhead ul.pc {
        gap: 15px;
        margin: 0 20px;
    }

    .myhead ul.pc li {
        font-size: 16px;
    }

    .myhead .flex-between.w-35 img {
        height: 40px;
    }
}

@media only screen and (max-width: 850px) {
    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }

    .hamburger_menu_btn_wrap {
        display: block;
    }
}

@media screen and (max-width: 768px) {
    .myhead {
        padding: 10px 0;
    }

    .myhead a img:first-child {
        width: auto !important;
        max-width: 150px !important;
        height: auto;
        margin-left: 15px;
        display: block;
    }

    .myhead .alignfull > .flex-between {
        justify-content: space-between !important;
        align-items: center;
    }
}

@media screen and (max-width: 600px) {
    .myhead .flex-between.w-35 {
        display: none !important;
    }
}



/* top */
.mv-copy-box {
    top: 32% !important;
    right: 5%;
    text-align: right;
    z-index: 5;
}

.mv-logo-badge {
    bottom: 8% !important;
    right: 5% !important;
    max-width: 400px;
}

.main-visual img.w-100 {
    min-height: 480px;
    object-fit: cover;
    object-position: center;
}

@media screen and (max-width: 768px) {
    .myhead {
        height: 70px;
        display: flex;
        align-items: center;
    }
    .myhead a img:first-child {
        width: auto !important;
        max-width: 120px !important;
        margin-left: 15px;
        transition: none;
    }

    .mv-copy-box {
        top: 110px !important;
        right: 0 !important;
        left: 0 !important;
        width: 90%;
        margin: 0 auto;
        text-align: center;
    }
    .mv-copy-box p {
        display: inline-block;
        width: 100%;
        font-size: 17px !important;
        line-height: 1.6;
    }
    .mv-copy-box p br {
        display: block;
    }

    .mv-logo-badge {
        display: flex !important;
        flex-direction: column;
        align-items: center;
        bottom: 5% !important;
        right: 0 !important;
        left: 0 !important;
        margin: 0 auto;
        width: 90% !important;
        padding: 6px 10px !important;
        background-color: rgba(255, 255, 255, 0.95);
    }
    .mv-logo-badge p {
        font-size: 10px !important;
        line-height: 1.2;
        margin-bottom: 3px;
    }
    .mv-logo-badge img {
        height: 30px !important;
        width: auto;
    }

    .font-brown.p-y-20.l-h-2 {
        padding-top: 10px !important;
        line-height: 1.6;
    }
    .font-brown.p-y-20.l-h-2 p {
        font-size: 15px !important;
        margin-bottom: 15px;
    }

    .flex-between.sp-column.w-75.m-auto {
        gap: 15px;
    }
}


@media screen and (max-width: 768px) {
    .news-container .extra { 
        display: none !important; 
    }
    .news-container .sm { 
        display: flex !important;
        align-items: center !important;
        padding: 15px 0 !important;
        border-bottom: 1px dotted #ccc;
    }
    .news-container .sm .column.w-80 {
        width: 85% !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 8px !important;
    }
    .news-container .sm p.font16 {
        font-size: 13px !important;
        margin: 0 !important;
        color: #888;
    }
    .news-container .sm h2 {
        display: block !important;
        font-size: 15px !important;
        line-height: 1.5 !important;
        margin: 0 !important;
        white-space: normal !important;
    }
    .news-tag {
        display: block !important;
        width: fit-content;
        margin-bottom: 5px !important;
        padding: 2px 10px !important;
        font-size: 12px !important;
    }
    .news-container .sm .w-15 {
        width: 30px !important;
        flex-shrink: 0;
        display: flex;
        justify-content: flex-end;
    }
}

@media screen and (min-width: 769px) {
    .news-container .sm { 
        display: none !important; 
    }
    .news-container .extra { 
        display: flex !important;
        align-items: center !important;
        padding: 15px 0;
        border-bottom: 1px dotted #ccc;
    }
    .news-container .extra .w-20 {
        width: 120px !important;
        flex-shrink: 0;
    }
    .news-container .extra h2 {
        flex: 1;
        font-size: 16px !important;
        margin: 0 20px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
}

@media screen and (max-width: 560px) {
    .news-container { 
        width: 95% !important; 
    }
}


.font-brown.p-y-20.l-h-2 {
    display: block;
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 20px 0 !important;
}

.font-brown.p-y-20.l-h-2 p {
    font-size: 18px !important;
    line-height: 1.8 !important;
    margin-bottom: 2em !important;
    word-break: break-all;
}

@media screen and (max-width: 768px) {
    .font-brown.p-y-20.l-h-2 {
        padding: 10px 0 !important;
    }
    .font-brown.p-y-20.l-h-2 p {
        font-size: 16px !important;
        line-height: 1.6 !important;
        margin-bottom: 1.5em !important;
    }
    .font-brown.p-y-20.l-h-2 p br {
        display: none;
    }
}

@media screen and (max-width: 380px) {
    .font-brown.p-y-20.l-h-2 p {
        font-size: 15px !important;
        line-height: 1.5 !important;
    }
}


/* フッター */
@media screen and (max-width: 1024px) and (min-width: 851px) {
    .myfoot .flex-between.pc-850 {
        width: 92% !important;
        margin: 0 auto !important;
        justify-content: space-between !important;
        gap: 0 !important;
    }
    .p-l-3 {
        padding-left: 0 !important;
        width: 26% !important;
        text-align: left;
    }
    .myfoot .w-25 img {
        height: 48px !important;
        width: auto !important;
    }
    .myfoot .w-25 p {
        font-size: 14px !important;
        line-height: 1.6 !important;
    }
    .myfoot .w-40 {
        width: 33% !important;
    }
    .map-container-full iframe {
        height: 200px !important;
    }
    .myfoot .w-35 {
        width: 38% !important;
        display: flex !important;
        justify-content: space-between !important;
        gap: 15px;
    }
    .foot-nav {
        width: 46% !important;
    }
    .foot-nav li a {
        font-size: 14px !important;
        white-space: nowrap;
    }
    .foot-btn-group {
        width: 50% !important;
        gap: 10px !important;
    }
    .foot-btn-img-large {
        max-width: 170px !important;
    }
}

@media screen and (max-width: 850px) {
    .myfoot .pc-850 {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        width: 100% !important;
    }
    .myfoot .w-25, 
    .myfoot .w-40, 
    .myfoot .w-35 {
        width: 100% !important;
        margin: 0 auto 30px auto;
        text-align: center;
    }
    .p-l-3 {
        padding-left: 0 !important;
    }
    .map-container-full {
        width: 90% !important;
        margin: 0 auto;
    }
    .myfoot .w-35.flex-between {
        flex-direction: column !important;
        gap: 20px;
    }
    .foot-nav {
        width: 80% !important;
        margin: 0 auto;
    }
    .foot-btn-group {
        width: 100% !important;
        flex-direction: row !important;
        justify-content: center !important;
        gap: 10px;
    }
    .foot-btn-group a {
        width: 45% !important;
        max-width: 200px;
    }
}

@media screen and (max-width: 480px) {
    .foot-btn-group {
        flex-direction: column !important;
        align-items: center !important;
    }
    .foot-btn-group a {
        width: 80% !important;
        margin-bottom: 10px;
    }
}


/* 施設案内 */
.bg-white.b-box.b-rad.p-20 {
    padding: 40px 30px !important;
}

.w-90.m-auto.b-b-dot-big {
    width: 100% !important;
    padding-bottom: 25px;
    margin-bottom: 25px;
}

.compact-facility-grid {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 60px;
    max-width: 1000px;
    margin: 0 auto;
}

.facility-left-item {
    flex: 0 0 45%;
    text-align: right;
}

.facility-left-item img {
    width: 100%;
    max-width: 400px;
}

.facility-right-item {
    flex: 0 0 45%;
}

.lift-car-small-box {
    width: 50%;
    min-width: 150px;
    margin-top: 35px;
}

.lift-car-small-box img {
    width: 100%;
    height: auto;
}

.w-90.m-auto .w-20 {
    width: 160px !important;
    height: 160px !important;
    border-radius: 50% !important;
    background-color: #f8edc3;
    border: 2px solid #5d4037;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    flex-shrink: 0;
    box-sizing: border-box;
}

.bg-white > .w-90.m-auto .w-20::before {
    font-size: 26px !important;
    line-height: 1.1;
    font-weight: bold;
    color: #5d4037;
}

.bg-white > .w-90.m-auto .w-20::after {
    font-size: 15px !important;
    white-space: nowrap !important;
    letter-spacing: -0.02em;
    margin-top: 5px !important;
    color: #5d4037;
}

.bg-white > .w-90.m-auto:last-child {
    padding-top: 25px !important;
}

.bg-white > .w-90.m-auto:nth-child(4) .w-75 {
    width: 75% !important;
}

.bg-white > .w-90.m-auto:nth-child(4) .w-48 {
    width: 48% !important;
    margin-top: 10px;
}

.bg-white > .w-90.m-auto:nth-child(4) .w-75 .p-20 {
    padding: 0 !important;
    height: 10px !important;
    margin: 0 !important;
}

@media screen and (max-width: 1024px) and (min-width: 851px) {
    .compact-facility-grid {
        gap: 30px !important;
        width: 95% !important;
    }
}

@media screen and (max-width: 850px) {
    .compact-facility-grid {
        flex-direction: column !important;
        align-items: center !important;
        gap: 0 !important;
    }

    .facility-left-item, .facility-right-item {
        width: 100% !important;
        text-align: center !important;
    }

    .facility-right-item {
        max-width: 340px;
        margin: 0 auto !important;
        text-align: left !important;
    }

    .bg-white .w-90.m-auto .flex-between.sm-column {
        flex-direction: column !important;
        align-items: center !important;
        gap: 25px !important;
    }

    .w-90.m-auto .flex-between.sm-column > .w-20 {
        width: auto !important;
        min-width: 180px !important;
        height: 54px !important;
        border-radius: 27px !important;
        flex-direction: row !important;
        padding: 0 25px !important;
        margin: 0 auto 15px auto !important;
        transform: none !important;
    }

    .bg-white > .w-90.m-auto .w-20::before {
        font-size: 22px !important;
        margin-right: 10px;
    }

    .bg-white > .w-90.m-auto .w-20::after {
        font-size: 16px !important;
        margin-top: 0 !important;
    }

    .bg-white > .w-90.m-auto:nth-child(4) .w-20 {
        min-width: 250px !important;
    }

    .w-90.m-auto .flex-between.sm-column > .w-75 {
        width: 100% !important;
        max-width: 360px;
        margin: 0 auto !important;
    }

    .bg-white > .w-90.m-auto:nth-child(4) .w-75 {
        width: 100% !important;
        max-width: 360px !important;
    }

    .sp-column, .w-75 .flex-between.sp-column {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 15px !important;
    }

    .w-75 .flex-between.sp-column .w-48, .bg-white > .w-90.m-auto:nth-child(4) .w-48 {
        width: 100% !important;
        margin-top: 0 !important;
    }

    .sp-w-70 {
        width: 90% !important;
        max-width: 340px;
        margin: 0 auto !important;
    }

    .w-75 img, .sp-w-70 img, .bg-white > .w-90.m-auto:nth-child(4) img {
        width: 100% !important;
        height: auto !important;
        border-radius: 8px;
    }

    .column .p-10 {
        height: 10px !important;
    }

    .w-90.m-auto p.font20, .bg-white > .w-90.m-auto:nth-child(4) .w-75 p.font20 {
        font-size: 15px !important;
        line-height: 1.6 !important;
        text-align: left !important;
        margin-top: 15px !important;
        padding: 0 10px !important;
    }

    .bg-white > .w-90.m-auto:last-child .w-48 {
        width: 100% !important;
        max-width: 360px !important;
        margin: 0 auto !important;
    }

    .bg-white > .w-90.m-auto:last-child .w-75 p.font20 {
        padding: 0 10px !important;
    }
}

@media screen and (max-width: 380px) {
    .bg-white.b-box.b-rad.p-20 {
        padding: 30px 15px !important;
    }
    .w-90.m-auto .flex-between.sm-column > .w-20 {
        transform: scale(0.9) !important;
    }
    .facility-left-item img {
        width: 90% !important;
    }
    .facility-right-item {
        width: 95% !important;
    }
    .w-90.m-auto .flex-between.sm-column > .w-75, .bg-white > .w-90.m-auto:nth-child(4) .w-75 {
        max-width: 100% !important;
        padding: 0 5% !important;
    }
    .bg-white > .w-90.m-auto:nth-child(4) .w-20 {
        min-width: 220px !important;
    }
}

@media screen and (max-width: 1024px) and (min-width: 851px) {
    .compact-facility-grid {
        gap: 30px !important;
        width: 95% !important;
        justify-content: space-around !important;
    }
    .facility-left-item, .facility-right-item {
        flex: 0 0 46% !important;
    }
    .facility-left-item {
        text-align: center !important;
    }
}

@media screen and (max-width: 850px) {
    .compact-facility-grid {
        flex-direction: column !important;
        align-items: center !important;
        gap: 0 !important;
    }
    .facility-left-item {
        width: 100% !important;
        text-align: center !important;
        margin-bottom: 10px !important;
    }
    .facility-left-item img {
        width: 80% !important;
        max-width: 320px !important;
        height: auto;
        margin: 0 auto !important;
    }
    .facility-right-item {
        width: 80% !important;
        max-width: 320px !important;
        margin: 0 auto !important;
        text-align: left !important;
    }
    .facility-right-item p.font20 {
        font-size: 16px !important;
        line-height: 1.6 !important;
        margin-top: 0 !important;
        padding: 0 !important;
    }
    
    .lift-car-small-box {
        width: 100% !important;
        max-width: 280px !important;
        margin: 20px auto 0 !important;
        text-align: center !important;
    }
    .lift-car-small-box img {
        width: 100% !important;
        height: auto;
    }
}

@media screen and (max-width: 380px) {
    .facility-left-item img {
        width: 90% !important;
    }
    .facility-right-item {
        width: 95% !important;
    }
}

/* 会社案内 */
.font20.font-brown {
    line-height: 1.8;
}

.center.w-80.m-auto img {
    max-width: 100%;
    height: auto;
}

.chairman-container {
    display: flex !important;
    justify-content: center;
    align-items: flex-end !important;
    gap: 75px;
    margin-bottom: 20px;
}

.chairman-container .photo-box .c-photo {
    width: 190px !important;
    height: auto !important;
    display: block;
}

.c-sign {
    width: 450px !important;
    height: auto;
    display: block;
    margin-top: 5px;
}

.full-width-buttons {
    display: flex;
    justify-content: space-between;
    width: 95% !important;
    gap: 15px;
    margin: 0 auto;
}

.btn-wrap {
    flex: 1;
}

.btn-large {
    width: 100% !important;
    height: auto;
    max-width: none !important;
    display: block;
}

.bg-white > .w-90.m-auto:last-child .w-75 p.font20 {
    padding: 0 !important;
    text-align: left !important;
}

@media screen and (max-width: 1024px) {
    .chairman-container {
        gap: 30px !important;
    }
    .c-sign {
        width: 300px !important;
    }
}

@media screen and (max-width: 850px) {
    .chairman-container {
        flex-direction: column !important;
        align-items: center !important;
        gap: 15px !important;
    }
    
    .chairman-container .photo-box .c-photo {
        width: 130px !important;
    }
    
    .chairman-info-wrap {
        text-align: center;
        width: 100%;
    }
    
    .c-sign {
        width: 65% !important;
        max-width: 280px !important;
        margin: 5px auto 0 !important;
    }

    .bg-white table, 
    .bg-white tbody, 
    .bg-white tr, 
    .bg-white th, 
    .bg-white td {
        display: block !important;
        width: 100% !important;
    }
    
    .bg-white th {
        background-color: #f8edc3;
        padding: 5px 10px !important;
        border-bottom: none !important;
        font-size: 16px !important;
    }
    
    .bg-white td {
        padding: 10px 10px 20px 10px !important;
        font-size: 16px !important;
    }
    
    .bg-white tr {
        border-bottom: 2px solid #f8edc3;
        margin-bottom: 10px;
    }

    .bg-white .flex-between.sp-column {
        flex-direction: column !important;
        gap: 20px !important;
    }
    
    .bg-white .w-40, 
    .bg-white .w-55 {
        width: 100% !important;
    }
    
    .bg-white iframe {
        height: 200px !important;
        border-radius: 8px;
    }
}

@media screen and (max-width: 767px) {
    .full-width-buttons {
        flex-direction: column;
    }
	.company-guide-page .bg-white div.p-20 {
        display: none !important;
    }
}

@media screen and (max-width: 450px) {
    .chairman-container .photo-box .c-photo {
        width: 90px !important;
    }
    .chairman-info-wrap p.font24 {
        font-size: 16px !important;
    }
    .c-sign {
        width: 50% !important;
        max-width: 180px !important;
    }
}

@media screen and (max-width: 380px) {
    .font24 { font-size: 20px !important; }
    .font20 { font-size: 15px !important; }
    .sp-w-90 { width: 95% !important; }
}


/* 料金 */
   @media screen and (max-width: 850px) {
    .price-page .price-table,
    .price-page .price-table thead,
    .price-page .price-table tbody,
    .price-page .price-table tr {
        display: table !important;
        width: 100% !important;
        table-layout: fixed !important;
    }

    .price-page .price-table tr {
        display: table-row !important;
    }

    .price-page .price-table th,
    .price-page .price-table td {
        display: table-cell !important;
        vertical-align: middle !important;
        text-align: center !important;
        padding: 12px 5px !important;
        box-sizing: border-box !important;
    }

    .price-page .price-table:not(.unit-table) th,
    .price-page .price-table:not(.unit-table) td {
        width: 12.5% !important;
    }

    .price-page .unit-table th,
    .price-page .unit-table td {
        width: 14.28% !important;
    }


    .price-page .price-table thead th {
        white-space: normal !important;
        font-size: 12px !important;
        line-height: 1.3 !important;
        background-color: #F2E6E6 !important;
    }

    .price-page .price-table tbody td {
        white-space: nowrap !important;
        font-size: 13px !important;
    }

    .price-page .bg-white .w-95.m-auto {
        display: block !important;
        width: 100% !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        border: 1px solid #efebe9 !important;
        border-radius: 8px !important;
        margin: 20px 0 !important;
    }

    .price-page table.price-table {
        min-width: 850px !important; 
    }
}

.sp-br { display: none; }

@media screen and (max-width: 850px) {
    .sp-br { display: block; }
    
    .price-page .unit-table td .font12 {
        font-size: 11px !important;
        white-space: normal !important;
        display: block;
        line-height: 1.2;
    }

    .price-page .unit-table th, 
    .price-page .unit-table td {
        width: 14.28% !important;
    }
}

/* 採用情報 */
@media screen and (max-width: 850px) {
	.recruit-page .sp-column, .w-75 .flex-between.sp-column {
		width: 75% !important;
		margin: 0 auto;
		display: flex !important;
		flex-direction: column !important;
		align-items: center !important;
		gap: 15px !important;
	}
}

@media screen and (max-width: 767px) {
	.recruit-page .bg-white div.p-20 {
        display: none !important;
    }
	.recruit-page .bg-white td {
        padding: 10px 10px 00px 10px !important;
        font-size: 16px !important;
    }
}

/* お問い合わせ */
.contact-page .font30 { line-height: 1.4; }

@media screen and (max-width: 767px) {
    .contact-page div.p-20 {
        display: none !important;
    }
    
    .contact-page .bg-main > .w-80 > .p-30 {
        display: block !important;
        height: 20px !important;
    }
}

@media screen and (max-width: 850px) {
	.border-form input[type="text"],.border-form textarea {width: 80%;margin:10px 20px 10px 4%;border: none;background-color: #f8ecb8;border-radius: 8px;padding: 10px;}
    .contact-page table.cform, 
    .contact-page table.cform tbody, 
    .contact-page table.cform tr, 
    .contact-page table.cform th, 
    .contact-page table.cform td {
        display: block !important;
        width: 100% !important;
    }

    .contact-page th.bg-form {
        background-color: #ffffff !important;
        padding: 10px 15px !important;
        text-align: left !important;
        border-bottom: none !important;
    }

    .contact-page td.border-form {
        padding: 10px 10px 20px 10px !important;
        border-bottom: 1px solid #eee !important;
    }

    .contact-page input[type="text"],
    .contact-page input[type="tel"],
    .contact-page input[type="email"],
    .contact-page textarea {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        padding: 12px !important;
        font-size: 16px !important;
        border: 1px solid #ccc !important;
        border-radius: 5px !important;
    }

    .contact-page .required-srt {
        background-color: #d84315 !important;
        color: #fff !important;
        padding: 2px 8px !important;
        font-size: 12px !important;
        border-radius: 3px !important;
        margin-left: 10px !important;
    }
}

@media screen and (max-width: 767px) {
    .send-btn-wrap {
        width: 90% !important;
        margin: 20px auto !important;
        position: relative !important;
    }

    .contact-page .send-btn-wrap input[type="submit"],
    .contact-page .send-btn-wrap .fake-btn {
        width: 100% !important;
        height: 60px !important;
        font-size: 18px !important;
        border-radius: 30px !important;
    }
    
    .contact-page .send-btn-wrap .arrow {
        right: 20px !important;
    }
}

@media screen and (max-width: 380px) {
    .contact-page .font30 { font-size: 22px !important; }
    .contact-page th.bg-form { font-size: 14px !important; }
}

@media screen and (max-width: 850px) {
    .contact-page table.cform,
    .contact-page table.cform tbody,
    .contact-page table.cform tr,
    .contact-page table.cform th,
    .contact-page table.cform td {
        display: block !important;
        width: 98% !important;
        box-sizing: border-box !important;
    }

    .contact-page td.short,
    .contact-page td.long,
    .contact-page .zip-code,
    .contact-page .textarea-container {
        width: 100% !important;
        max-width: 100% !important;
        padding-right: 0 !important;
    }

    .contact-page th.bg-form {
        padding: 10px 15px !important;
		margin: 2px;
        text-align: left !important;
        background-color: #ffffff !important;
    }

    .contact-page .border-form span.wpcf7-form-control-wrap,
    .contact-page .border-form input,
    .contact-page .border-form textarea {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
    }

    .contact-page input[type="text"],
    .contact-page input[type="tel"],
    .contact-page input[type="email"],
    .contact-page textarea {
        border: 1px solid #ccc !important;
        padding: 12px !important;
        border-radius: 5px !important;
        font-size: 16px !important;
    }

    .contact-page textarea {
        min-height: 150px !important;
    }

    .contact-page tr:has(th.p-30) {
        display: none !important;
    }
}

@media screen and (max-width: 767px) {
    .send-btn-wrap {
        width: 95% !important;
        max-width: 320px !important;
        margin: 40px auto !important;
        position: relative !important;
        height: 60px !important;
    }

    .contact-page .send-btn-wrap .fake-btn {
        position: absolute !important;
        top: 0; left: 0;
        width: 100% !important;
        height: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background-color: #eacbca !important;
        border-radius: 30px !important;
        pointer-events: none !important;
        z-index: 1;
    }

    .contact-page .send-btn-wrap input[type="submit"] {
        position: absolute !important;
        top: 0; left: 0;
        width: 100% !important;
        height: 100% !important;
        opacity: 0 !important;
        z-index: 2 !important;
        cursor: pointer !important;
    }

    .contact-page .send-btn-wrap .arrow {
        position: absolute !important;
        right: 20px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
}

.privacy-box {
  height: 300px;
  overflow-y: scroll;
  border: 1px solid #ccc;
  padding: 10px;
  margin: 20px 0;
  background-color: #f9f9f9;
}