@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap');

.jsurvey2025 h1,
.jsurvey2025 h2
{
	position: relative;
	margin: auto;
	padding-bottom: 10px;
	font-size: inherit;
	line-height: 1.4;
}

.jsurvey2025 h1::after,
.jsurvey2025 h2::after
{
	content: none;
}

.jsurvey2025
{
	/* ------------------------------------------------------------------------- */
	/*　共通部分 */
	/* ------------------------------------------------------------------------- */
	background-color: #FFF;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 16px;
	line-height: 1.5;
}


.jsurvey2025 input,
.jsurvey2025 textarea
{
	font-family: 'Noto Sans JP', sans-serif;
}

.jsurvey2025 main a
{
	text-decoration: underline;
	color: #9A0002;
	font-weight: 600;
}

.jsurvey2025 a:hover
{
	text-decoration: none;
	color: #C23A3C;
}

.jsurvey2025 main ul
{
	list-style-type: disc;
	margin-left: 1.4em;
	padding-bottom: 2em;
}

.jsurvey2025 main ul li
{
	margin-bottom: 5px;
}

.btn_area
{
	padding: 10px 0 40px 0;
	text-align: center;
}

.jsurvey2025 main .ui_button,
.jsurvey2025 main .btn_area a
{
	display: block;
	font-weight: 600;
	font-size: 16px;
	padding: 8px;
	color: #fff;
	border-radius: 10px;
	background: rgba(154, 0, 2, 1.00);
	box-shadow: none;
	border: 0;
	text-decoration: none;
	text-align: center;
	cursor: pointer;
}

a:hover img,
.ui_button:hover,
.jsurvey2025 main .btn_area a:hover
{
	opacity: .7;
}

/*.heading
{
	font-size: 42px;
	color: #4683E1;
	text-align: center;
	margin-top: 90px;
}
.heading .sub
{
	margin-bottom: -42px;
	font-size: 100px;
	color: #EAEAEA;
	text-align: center;
}
@media screen and (max-width: 900px)
{
	.heading
	{
		font-size: 32px;
	}
	.heading .sub
	{
		margin-bottom: -32px;
		font-size: 64px;
	}
}*/
/* ------------------------------------------------------------------------- */
/*　ヘッダー */
/* ------------------------------------------------------------------------- */
/*header
{
	padding: 20px 2vw;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
header .logo, header .logo img
{
	height: 35px;
	display: block;
}
header nav li
{
	list-style: none;
	text-align: center;
}
header nav li a
{
	text-decoration: none;
	color: inherit;
	font-weight: 600;
}
@media screen and (max-width: 767.9px)
{
	header nav
	{
		flex-direction: column !important;
		gap: 10px;
	}
	header nav ul
	{
		width: 80%;
		justify-content: space-around;
	}
	.navbar_toggle
	{
		z-index: 9999;
		position: absolute;
		right: 5%;
		cursor: pointer;
	}
	.navbar_toggle_icon
	{
		position: relative;
		display: block;
		height: 1px;
		width: 28px;
		background: #1C1C1C;
		-webkit-transition: ease 0.5s;
		transition: ease 0.5s;
	}
	.navbar_toggle_icon:nth-child(1)
	{
		top: 0;
	}
	.navbar_toggle_icon:nth-child(2)
	{
		margin: 8px 0;
	}
	.navbar_toggle_icon:nth-child(3)
	{
		top: 0;
	}
	.navbar_toggle.open .navbar_toggle_icon:nth-child(1)
	{
		top: 9px;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	.navbar_toggle.open .navbar_toggle_icon:nth-child(2)
	{
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		opacity: 0;
	}
	.navbar_toggle.open .navbar_toggle_icon:nth-child(3)
	{
		top: -9px;
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	.menu
	{
		z-index: 1000;
		top: 70px;
		-webkit-transform: translateX(-100%);
		transform: translateX(-100%);
		-webkit-transition: ease 0.5s;
		transition: ease 0.5s;
		width: 100%;
		position: absolute;
		text-align: left;
		background: #fff;
		left: 0;
	}
	.menu ul
	{
		background: #f2f2f2;
	}
	.menu ul > li
	{
		padding: 0;
		box-sizing: border-box;
		border-bottom: 1px solid #fff;
	}
	.menu ul > li:nth-child(4)
	{
		text-align: center;
		padding: 10px 0;
	}
	.menu ul > li.sp_last
	{
		text-align: center;
		padding: 10px 0;
	}
	.menu ul > li > a
	{
		display: block;
		padding: 20px;
		text-decoration: none;
		height: auto;
		line-height: 1.2;
		font-size: 16px;
	}
	.menu ul > li > a.ui_button
	{
		width: 80%;
		margin: 0 auto;
		display: flex;
		align-items: center;
	}
	.menu.open
	{
		-webkit-transform: translateX(0);
		transform: translateX(0);
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}
	.navbar_toggle
	{
		top: 25px;
	}
}
@media screen and (min-width: 768px)
{
	.drawer
	{
		display: none;
	}
	.menu ul
	{
		display: flex;
		justify-content: flex-end;
		column-gap: 20px;
		align-items: center;
	}
}
@media screen and (min-width: 1028px)
{
	.menu ul
	{
		column-gap: 70px;
	}
}
@media screen and (max-width: 524px)
{
	header nav ul
	{
		width: 100%;
	}
}*/
/* ------------------------------------------------------------------------- */
/*　メイン */
/* ------------------------------------------------------------------------- */
/* --------------------------------------------------------------------- */
/*　動画配信サービス */
/* --------------------------------------------------------------------- */
/* ----------------------------------------------------------------- */
/*　背景1の内容 */
/* ----------------------------------------------------------------- */

.jsurvey2025 .main_area section:not([class]) {
	padding-bottom: 20px;
}
section#place
{
	padding-bottom: 30px;
}

.jsurvey2025 .main_area
{
	width: 92vw;
	max-width: 1028px;
	margin: 0 auto;
}

.jsurvey2025 main .intro
{
	margin: 0 0 30px 0;
	padding: 10px 0;
	background-color: rgba(154, 0, 2, 1.00);
}

.jsurvey2025 main .intro_heading
{
	font-size: 40px !important;
	color: #fff !important;
	padding: 0 !important;
	line-height: 1.3 !important;
	font-family: "Noto Serif JP", serif;
	font-weight: 600;
}

.jsurvey2025 main .intro_heading .sub
{
	font-size: 28px;
	line-height: 1.4;
}


.jsurvey2025 h2
{
	border-bottom: 1px solid rgba(154, 0, 2, 1.00);
	font-family: "Noto Sans JP", serif !important;
	font-weight: 600;
}

.jsurvey2025 h3
{
	color: rgba(154, 0, 2, 1.00);
	font-family: "Noto Sans JP", serif !important;
	font-weight: 600;
	font-size: 18px !important;
	margin-bottom: 20px;
	padding-left: 15px;
	position: relative;
}

.jsurvey2025 .note {
	font-size: .8em;
	color: #666;
	margin-bottom: 20px;
	display: inline-block;
}
.jsurvey2025 .note2 {
	font-weight: bold;
	font-size: .8em;
	padding: 5px;
	border: 1px solid #BFB000;
	margin-bottom: 20px;
	display: inline-block;
}

.jsurvey2025 span.hissu {
	color: #FF0000;
	font-size: .8em;
	display: inline-block;
	margin-left: 10px;
	padding: 0 5px;
	border: 1px solid #FF0000;
	border-radius: 3px;
}
.jsurvey2025 .text_l {
	text-align: left !important;
}


.jsurvey2025 .text_area p
{
	padding-bottom: .8em;
}

.jsurvey2025 .map_area iframe
{
	aspect-ratio: 16/9;
	width: 100%;
}

.jsurvey2025 #date strong,
.jsurvey2025 #place strong
{
	font-size: 1.3em;
}

.jsurvey2025 ol
{
	margin-left: 1.8em;
	padding-bottom: 2em;
}

.jsurvey2025 ol li:not(:last-child)
{
	margin-bottom: 5px;
}

.jsurvey2025 dl
{
	padding-bottom: 30px;
}

.jsurvey2025 dl dd
{
	margin-bottom: 10px;
}

.lead
{
	padding-bottom: 2em;
}

.jsurvey2025 .text_area,
.jsurvey2025 h2+p
{
	padding-bottom: 2em;
}

@media screen and (max-width: 767.9px)
{
	.sp_only
	{
		display: block;
	}

	main .service .intro
	{
		padding: 40px 4vw;
	}

	main .service .intro .intro_heading
	{
		font-size: 30px !important;
	}

	main .service .intro .sub
	{
		font-size: 18px !important;
	}

	main .service .intro p
	{
		font-size: 14px;
	}
}

@media screen and (min-width: 768px)
{

	.jsurvey2025 dl
	{
		display: flex;
		flex-wrap: wrap;
		width: 100%;
	}

	.jsurvey2025 dl dt
	{
		width: 22em;
		padding-left: 15px;
		box-sizing: border-box;

	}

	.jsurvey2025 dl.label_input dt
	{
		width: 24em;
		flex-shrink: 0;
		padding-left: 0;
	}

	.jsurvey2025 dl dd
	{
		width: calc(100% - 24em);
	}
}

/* アニメーション
@keyframes slide
{
  0%
  {
    transform: translateX(0);
  }
  25%
  {
    transform: translateX(-33.33%);
  }
  50%
  {
    transform: translateX(-66.66%);
  }
  75%
  {
    transform: translateX(-100%);
  }
  100%
  {
    transform: translateX(-133.33%);
  }
}

*/
/* ------------------------------------------------------------- */
/*　オンライン配信の内容 */
/* ------------------------------------------------------------- */
.intro_contents
{
	text-align: center;
	padding-bottom: 50px;
}

.intro_contents .heading
{
	font-size: 42px;
	color: #4683E1;
	margin-top: 48px;
	margin-bottom: 20px;
}

.intro_contents .heading h2,
.jsurvey2025 .tit_l
{
	color: #4683E1;
	font-size: 45px !important;
	padding: 30px 0;
	text-align: center;
}

.jsurvey2025 .tit_m
{
	font-size: 30px;
	font-weight: 600;
	text-align: center;
	margin-bottom: 20px;
}

.intro_contents p
{
	font-size: 20px;
	margin: 0;
	line-height: 1.6;
}

/* メディアクエリ */
@media screen and (max-width: 767.9px)
{
	.pc_only
	{
		display: none;
	}

	.jsurvey2025 main .intro_heading
	{
		font-size: 36px !important;
	}

	.jsurvey2025 main .intro_heading .sub
	{
		font-size: 18px;
	}

	.jsurvey2025 h2
	{
		font-size: 22px !important;
	}

	.jsurvey2025 h3
	{
		padding-left: 0;
		padding-bottom: 5px;
		font-size: 17px;
	}

	.jsurvey2025 h3::before
	{
		content: "";
		display: block;
		height: 3px;
		width: 50px;
		background-color: rgba(154, 0, 2, 1.00);
		position: absolute;
		left: 0;
		bottom: 0;
	}

	.jsurvey2025 .tit_l
	{
		font-size: 26px !important;
		margin-bottom: 15px;
		padding: 0;
	}

	.jsurvey2025 .tit_m
	{
		font-size: 20px !important;
		margin-bottom: 15px;
	}

	.intro_contents
	{
		padding: 0 4vw;
	}

	.intro_contents .heading
	{
		font-size: 32px;
	}

	.intro_contents .heading h2
	{
		font-size: 26px !important;
		text-align: left;
	}

	.intro_contents p
	{
		text-align: left;
		padding-bottom: 1em;
	}
}

@media screen and (max-width: 650px)
{
	.intro_contents .heading
	{
		font-size: 26px;
	}
}

@media screen and (min-width: 768px)
{
	.jsurvey2025 main a[href*="tel:"]
	{
		pointer-events: none;
		cursor: default;
		text-decoration: none;
		color: inherit;
	}

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

	.flex_box .map_area
	{
		width: 45%;
		max-width: 400px;
		margin-left: 30px;
	}

	.jsurvey2025 h3::before
	{
		content: "";
		display: block;
		height: 3px;
		width: 10px;
		background-color: rgba(154, 0, 2, 1.00);
		position: absolute;
		left: 0;
		top: 0;
		bottom: 0;
		margin: auto 0;
	}

	.jsurvey2025 .text_area,
	.jsurvey2025 h2+p
	{
		padding-left: 2em;
	}
}

@media screen and (max-width: 768px)
{

	html,
	body,
	div,
	span,
	dl,
	dt,
	dd,
	ol,
	ul,
	li,
	footer,
	header,
	nav,
	section,
	textarea
	{
		font-size: 14px;
	}
}

/* 
---------------------------------------------------------------------
// お問合せ
// ---------------------------------------------------------------------*/
.contact_box .contact_method
{
	background-image: url("/images/jsurvey2025/video2.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

.contact_box .contact_method .conte
{
	display: flex;
	flex-direction: row;
	justify-content: center;
	padding: 20px 20px 48px;
}

.contact_box .contact_method .conte>div
{
	flex: 1;
}

.contact_box .contact_method .conte>div p
{
	display: flex;
	flex-direction: column;
	font-weight: 600;
	text-align: center;
	font-size: 20px;
	color: #FFF;
	align-items: center;
	justify-content: center;
}

.contact_box .contact_method .conte .card
{
	width: 70%;
	margin: 20% 15% 20px;
	height: 200px;
	font-size: 42px;
	color: #000;
	align-self: center;
	background-color: #fff;
}

.contact_box .contact_method .conte .card .font_small
{
	font-size: 20px;
}

.contact_box .contact_method .conte .font_xsmall
{
	font-size: 16px;
}

/* -----------------------------------------------------------------
// お問い合わせの送信フォーム
// -----------------------------------------------------------------*/
.contact_box .contact_form>p
{
	text-align: center;
	margin: 48px;
}

.contact_box .contact_form form
{
	text-align: center;
}

.contact_box .contact_form form .red
{
	color: red;
}

.contact_box .contact_form form .conte
{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding-top: 20px;
}

.contact_box .contact_form form .conte .label_input
{
	text-align: left;
}

.contact_box .contact_form form .conte .label_input dd
{
	margin-bottom: 15px;
}

.contact_box .contact_form form .conte .label_input label
{
	flex: 5;
	font-weight: 600;
}

.contact_box .contact_form form .conte .label_input #famname,
.contact_box .contact_form form .conte .label_input #firname,
.contact_box .contact_form form .conte .label_input #famnamekana,
.contact_box .contact_form form .conte .label_input #firnamekana
{
	width: 45%;
}

.contact_box .contact_form form .conte .label_input input[type="text"],
.contact_box .contact_form form .conte .label_input input[type="email"],
.contact_box .contact_form form .conte .label_input input[type="tel"]
{
	border: 1px solid #666;
	border-radius: 3px;
	padding: 3px;
	width: 100%;
	box-sizing: border-box;
	line-height: 2em;
}

.contact_box .contact_form form .conte .label_input input[type="tel"]
{
	width: 6em;
}

.contact_box .contact_form form .personal_info
{
	margin: 48px;
	display: flex;
	justify-content: center;
	align-items: center;
	grid-gap: 10px;
}

.contact_box .contact_form form .personal_info input[type="checkbox"]
{
	width: 20px;
	height: 20px;
	margin: 0;
}

.contact_box .contact_form form .pointer
{
	cursor: pointer;
}

.contact_box .contact_form form .personal_info a
{
	color: #4683E1;
	font-weight: 600;
}

.contact_box .contact_form form .submit_button
{
	width: 80%;
	margin: 20px auto;
	align-items: center;
	justify-content: center;
	position: relative;
	cursor: pointer;
}

.contact_box .contact_form form .submit_button input[type="submit"]
{
	background-color: transparent;
	outline: none;
	font-weight: 600;
	font-size: 16px;
	color: #fff;
	box-shadow: none;
	border: 0;
	text-decoration: none;
	letter-spacing: 40px;
	text-indent: 40px;
	cursor: pointer;
}

.contact_form
{
	padding-bottom: 30px;
}

.contact_tel p
{
	text-align: center;
	font-weight: 600;
	padding-bottom: 1em;
}

.contact_tel p strong
{
	font-size: 1.4em;
}

.scrollbox
{
	width: 100%;
}

.scrollbox__summary
{
	display: block;
	background: #E0E0E0;
	font-weight: bold;
	position: relative;
	list-style: none;
	/* cursor: pointer; */
	padding: 10px 38px 10px 10px;
}

/* .accordion__summary::-webkit-details-marker
{
	display: none;
} */

/* .accordion__summary::after
{
	content: "+";
	font-size: 1.4em;
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
} */

/* .accordion[open] .accordion__summary::after
{
	content: "−";
}
 */














.scrollbox__detail {
	padding: 4px 10px;
	margin: 10px 0;
	text-align: left;
	font-size: 13px;
	height: 300px;           /* 高さを固定 */
	overflow-y: auto;        /* 縦スクロールを有効に */
	border: 1px solid #ccc;  /* 任意で枠線追加 */
  }
  
  .scrollbox__detail p,
  .scrollbox__detail li {
	font-size: 13px;
  }
  
  .scrollbox__detail p {
	padding-bottom: 24px;
  }
  
  .scrollbox__text {
	margin: 0;
  }
  
  .jsurvey2025 .scrollbox__detail h4 {
	font-size: 14px;
	margin-bottom: 5px;
	font-weight: bold;
  }
  
  .jsurvey2025 .scrollbox__detail p + h4 {
	padding-top: 10px;
  }
  
  .jsurvey2025 .scrollbox__detail ol {
	list-style: none;
	counter-reset: number;
	margin-left: 0;
  }
  
  .jsurvey2025 .scrollbox__detail ol ul {
	padding-bottom: 5px;
  }
  
  .jsurvey2025 .scrollbox__detail ol > li {
	position: relative;
	padding-left: 2.2em;
  }
  
  .jsurvey2025 .scrollbox__detail ol > li::before {
	counter-increment: number;
	content: '（' counter(number) '）';
	position: absolute;
	left: 0;
  }
  

































.accordion__detail
{
	padding: 4px 10px;
	margin: 10px 0;
	text-align: left;
	font-size: 13px;
}

.accordion__detail p,
.accordion__detail li
{
	font-size: 13px;
}

.accordion__detail p
{
	padding-bottom: 24px;

}

.accordion__text
{
	margin: 0;
}

.jsurvey2025 .accordion__detail h4
{
	font-size: 14px;
	margin-bottom: 5px;
	font-weight: bold;
}

.jsurvey2025 .accordion__detail p+h4
{
	padding-top: 10px;
}

.jsurvey2025 .accordion__detail ol
{
	list-style: none;
	counter-reset: number;
	margin-left: 0;
}

.jsurvey2025 .accordion__detail ol ul
{
	padding-bottom: 5px;
}

.jsurvey2025 .accordion__detail ol>li
{
	position: relative;
	padding-left: 2.2em;
}

.jsurvey2025 .accordion__detail ol>li::before
{
	counter-increment: number;
	content: '（' counter(number) '）';
	position: absolute;
	left: 0;
}


@media screen and (max-width: 1027.9px)
{
	/*.contact_box .contact_form form .conte .label_input
	{
	width: 90%;
	}
*/
}

@media screen and (min-width: 1028px)
{
	.contact_box .contact_form form .conte .label_input dt label {
		display: block;
		line-height: 34px;
	
	}
	.contact_box .contact_form form .conte span.hissu {
		line-height: 24px;
	}
	.contact_box .contact_form form .submit_button
	{
		max-width: 300px;
	}
	.contact_box {
		width: 80%;
		margin: 0 auto;
		padding-top: 30px;
		
	}
	.contact_box .contact_form form .conte .label_input
	{
		display: flex;
		flex-direction: row;
		align-items: flex-start;
		justify-content: center;
	}
}

/*@media screen and (max-width: 500px)
{
    #about_us .heading
	{
        font-size: 6.5vw;
    }
    #about_us .heading .sub
	{
        margin-bottom: -6vw;
        font-size: 12vw;
    }
}

#about_us .conte
{
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}

#about_us .conte .left
{
    flex: 5.5;
    margin: 48px;
}
#about_us .conte .left img
{
    max-width: 100%;
    height: auto;
}
#about_us .conte .left p
{
    margin: 20px 0;
}

#about_us .conte .right
{
    display: flex;
    flex-direction: row;
    flex: 4.5;
    gap: 25px;
    overflow: hidden;
}

#about_us .conte .right .image_left,
#about_us .conte .right .image_right
{
    display: flex;
    flex-direction: column;
    gap: 25px;
}

#about_us .conte .right .image_left .spacer,
#about_us .conte .right .image_right .spacer
{
    margin-top: 25%;
}

#about_us .more_detail
{
    margin: 90px;
    padding: 20px;
}

#about_us .more_detail .conte
{
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 20px;
}

#about_us .more_detail .conte .left
{
    flex: 7;
}
#about_us .more_detail .conte .left a
{
    display: block;
    margin-left: auto;
    width: 200px;
    text-align: center;
}

#about_us .more_detail .conte .right
{
    flex: 3;
    margin: 20px;
}

#about_us .more_detail .conte .right figure
{
    height: 100%;
    width: auto;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}
*/
#about_us .service_gallery
{
	display: flex;
	justify-content: center;
	grid-gap: 15px;
	margin-top: 20px;
}

#about_us .service_gallery figure
{
	border-radius: 15px;
	overflow: hidden;
	border: 1px solid #2D78DA;
	width: 245px;
	height: 136px;
}

#about_us .service_gallery figure img
{
	width: 100%;
	object-fit: cover;
	height: 100%;
}

.home_nav
{
	text-align: center;
	padding: 40px 0;
}

#about_us p
{
	text-align: center;
	font-size: 20px;
}

.home_nav a.ui_button
{
	width: 70%;
	max-width: 330px;
	margin: 15px auto;
	height: 68px;
	box-sizing: border-box;
}

.home_nav a.ui_button img
{
	width: 250px;
	height: auto;
}

@media screen and (max-width: 1027.9px)
{
	#about_us .service_gallery
	{
		flex-wrap: wrap;
		grid-gap: 10px;
	}

	#about_us .service_gallery figure
	{
		width: 42vw;
		height: 24vw;
	}

	.home_nav a.ui_button
	{
		padding: 15px;
	}
}

/* ------------------------------------------------------------------------- */
/*　一番下のfooter部分 */
/* ------------------------------------------------------------------------- */
footer
{
	color: #7A7A7B;
	background-color: #F5F5F6;
	padding: 8px;
	font-size: 14px;
}

footer .conte .logo
{
	font-size: 12px;
	width: 230px;
	text-align: center;
	margin-right: auto;

}

footer .conte .logo a
{
	display: block;
	color: #7a7a7b;
}

footer .conte .logo img
{
	width: 190px;
}

footer .conte .about_us p
{
	font-weight: 600;
	margin-bottom: 5px;
}

footer .conte .about_us ul
{
	display: grid;
	grid-template-columns: 50% 50%;
	gap: 5px 20px;
	display: grid;
	grid-template-columns: 50% 50%;
	gap: 5px 20px;
	list-style-type: none;
	padding-left: 0;
}

footer .conte .about_us ul li
{
	font-size: 12px;
	white-space: nowrap;
	padding-right: 10px;
}

footer .conte .about_us ul a
{
	text-decoration: none;
	color: inherit;
	font-weight: 400;
}

footer .conte .about_us ul a:hover
{
	text-decoration: underline;
}

.container.bottom
{
	width: 92vw;
	max-width: 1028px;
	margin: 0 auto;
	border-top: 1px solid #D8D8D8;
	font-size: 10px;
	text-align: center;
	color: rgba(0, 0, 0, 0.5);
	padding-top: 20px;
}

.container.bottom p
{
	font-size: 10px;
}

footer .footlinks
{
	display: flex;
	justify-content: flex-end;
	grid-gap: 30px;
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: 12px;
	padding-top: 5px;
}

footer .footlinks li a
{
	color: rgba(0, 0, 0, 0.5);
	font-size: 12px;
}

@media screen and (max-width: 767.9px)
{
	.jsurvey2025 .flow_box#flow h2
	{
		margin-bottom: 0 !important;
	}

	dl.info
	{
		padding-top: 5px;
	}

	dl.info dd
	{
		margin-bottom: 10px;
	}

	#about_us p,
	.intro_gallery_2 .card h3,
	.contact_box .contact_form form .conte .label_input label
	{
		font-size: 16px !important;
	}

	.intro_gallery_2 .card figure
	{
		height: 150px;
	}
	.contact_box .contact_form form .conte .label_input {
    width: 90%;
}
	.contact_box .contact_form form .conte .label_input label
	{
		margin-bottom: 5px;
		display: block;
	}

	.contact_box .contact_form>p
	{
		margin: 20px 0;
	}

	footer .conte .logo img
	{
		width: 60vw;
	}

	footer .main_area.conte
	{
		padding: 40px 0;
	}

	footer .main_area.conte .service
	{
		padding: 20px 0;
	}

	footer .container.bottom
	{
		text-align: left;
	}

	footer .footlinks
	{
		justify-content: flex-start;
		grid-gap: 15px;
	}
}

@media screen and (min-width: 768px)
{
	.sp_only
	{
		display: none;
	}

	.jsurvey2025 main .btn_area a
	{
		max-width: 350px;
		margin: 0 auto;
	}

	footer .conte
	{
		display: flex;
		gap: 40px;
		padding: 48px 0;
		justify-content: center;
	}

	footer .container.bottom
	{
		display: flex;
		flex-direction: row;
		justify-content: space-between;

	}

	footer .container.bottom .footlinks
	{
		padding-top: 0;
	}
}

html,
body
{
	overflow-x: hidden;
	margin: 0;
	padding: 0;
}

@keyframes scroll
{
	from
	{
		transform: translateX(0);
	}

	to
	{
		transform: translateX(-50%);
	}
}

@media screen and (max-width: 767.9px)
{

	.intro_contents .heading
	{
		margin-top: 0px;
	}

	.intro_contents .heading h2
	{
		padding: 15px 0;
		margin: 0 !important;
	}
}