@charset "utf-8";
/*
Theme Name: iketax
Theme URI: https://iketax.com/
Version: 1.0
*/

/* common
---------------------------------------------------------------------------*/
@import url("css/easing.css");

:root {
	--color-text: #4E4E4E;
	--color-text-dark: #3E3B3E;
	--color-bg: #F0F9F9;
	--color-bg-gray: #E8ECEC;
	--color-border: #CEE7EA;
	--color-blue: #1F8399;
	--color-blue-light: #A7D0D7;
	--color-blue-mid: #5A8BA4;
	--color-blue-dark: #517D94;
	--color-pink: #D34C6B;

	/* 500 */
	--font-gothic-jp: Gothic Medium BBB, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'Hiragino Sans', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif;

	/* 700 */
	--font-gothic-jp-b: Midashi Go MB31, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'Hiragino Sans', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif;

	--font-gothic-jp-device: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'Hiragino Sans', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, sans-serif;
	
	/* 400 */
	--font-gothic-en: "Roboto", sans-serif;

	/* 400 */
	--font-serif-en: palatino-linotype, serif;

	--base-font: 16;
  --base-width: 375px;
  --scale-rate: 1;
}

html {
	font-size: calc(100% * (1 + ((100vw - var(--base-width)) / var(--base-width)) * var(--scale-rate)) / var(--base-font));
}

body {
	overflow-y: scroll;
	/*background-color: var(--color-bg);*/
	color: var(--color-text);
	font-size: 14rem;
	font-family: var(--font-gothic-jp);
	line-height: 1;
	font-feature-settings: 'palt' 1;
	-webkit-text-size-adjust: none !important;
}

body:has(#wrap.bg),
body:has(#topContents),
body:has(#newsContents) {
	background-color: var(--color-bg);
}

body #wrap:after {
	display: block;
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	background: url(img/souzoku/bg.jpg?260421) repeat left top / 126rem auto;
	width: 100%;
	height: 100%;
	transition: 1s linear;
	opacity: 0;
	z-index: -1;
}

body:not(:has(#wrap.bg)) #wrap:not(:has(#topContents)):not(:has(#newsContents)):after,
body:has(#wrap.bg-pink) #wrap:after {
	opacity: 1;
}

body:has(#wrap.bg-blue):not(:has(#wrap.bg-pink)) #wrap:after {
	opacity: 0;
}

body.noscroll { position: fixed; width: 100%; }

::-moz-selection { background: rgba(0,0,0,0.1); color: #000000; }
::selection { background: rgba(0,0,0,0.1); color: #000000; }

p { font-size: 14rem; line-height: 1.9; letter-spacing: 0.1em; margin-bottom: 1em; }
p:last-child { margin-bottom: 0 !important; }

address,i { font-style: normal; }
img { max-width: none; }
figure img { width: 100%; }
picture { display: block; }
.dash { padding: 0 5rem 0 4rem; letter-spacing: -0.01em; }

.block { display: inline-block !important; }
.wide { display: none !important; }
.narrow { display: inline-block !important; }

.title-h1 { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

/* #loading
------------------------------------*/
#loading {
	display: none !important;
}

/* link
------------------------------------*/
a { color: var(--color-text); text-decoration: none; }

p a {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.1em;
}

.line { display: inline-block; position: relative; padding-bottom: 1px; line-height: 1; }
.line:after {
	display: block;
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: var(--color-text);
	width: 100%;
	height: 1px;
}

/* .btn
------------------------------------*/
button.btn-color,
.btn-color a {
	display: inline-block;
	background: var(--color-blue);
	border-radius: 3rem;
	padding: 12rem 14rem 12rem 16rem;
	color: #FFFFFF !important;
	/*font-family: var(--font-gothic-jp-b);
	font-weight: 700;*/
	font-size: 14rem;
	letter-spacing: 0.12em;
	text-align: center;
}

#souzokuContents button.btn-color,
#souzokuContents .btn-color a {
	background: var(--color-pink);
}

button.btn-color.size-m {
	padding: 19rem 38rem 19rem 40rem;
	font-size: 17rem;
}

.btn-link a {
	display: inline-block;
	position: relative;
	padding: 5rem 0 5rem 40rem;
	font-size: 15rem;
	letter-spacing: 0.1em;
	opacity: 1 !important;
}

.btn-link a i {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	background: url(img/share/btn-arrow.svg) no-repeat left top / 100% auto;
	width: 27rem;
	height: 27rem;
}

.btn-link a span {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.3em;
}

.btn-link-s a {
	display: inline-block;
	padding: 4rem 26rem;
	font-size: 13rem;
	letter-spacing: 0.1em;
	opacity: 1 !important;
}

.btn-link-s a i {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	background: url(img/share/btn-arrow-s.svg) no-repeat left top / 100% auto;
	width: 19rem;
	height: 19rem;
}

/* .btn-nav
------------------------------------*/
.btn-nav {
	visibility: hidden;
	position: fixed;
	top: 0;
	right: 0;
	width: 88rem;
	height: 80rem;
	padding: 12rem 0 0 16rem;
	text-align: left;
	z-index: 10000;
	opacity: 0;
	transition: .15s ease-out;
}

.btn-nav.visible {
	visibility: visible;
	opacity: 1;
}

.btn-nav > div {
	display: inline-block;
	position: relative;
	padding: 0 0 2rem 1rem;
}

.btn-nav .txt {
	display: inline-block;
	position: relative;
	overflow: hidden;
	height: 15rem;
	color: var(--color-blue);
	font-family: var(--font-serif-en);
	font-size: 13.6rem;
	letter-spacing: 0;
}

.btn-nav .open img { width: 38rem; }
.btn-nav .close img { width: 36rem; }

.btn-nav .close {
	position: absolute;
	top: 0;
	left: 1rem;
	opacity: 0;
}

.btn-nav.active .open { opacity: 0; }
.btn-nav.active .close { opacity: 1; }

.btn-nav .line-btm {
	position: absolute;
	bottom: 0;
	right: 0;
	background-color: var(--color-blue);
	width: 100%;
	height: 1px;
	opacity: 0.5;
}

.btn-nav .line-btm {
	animation: btn_nav_line .35s var(--easeOutQuart) forwards;
}

@keyframes btn_nav_line {
	0% { width: 100%; right: 0; left: auto; }
	50% { width: 0%; right: 0; left: auto; }
	51% { width: 0%; left: 0; right: auto; }
	100% { width: 100%; left: 0; right: auto; }
}

.btn-nav.active .line-btm {
	animation: btn_nav_line_active .35s var(--easeOutQuart) forwards;
}

@keyframes btn_nav_line_active {
	0% { width: 100%; right: 0; left: auto; }
	50% { width: 0%; right: 0; left: auto; }
	51% { width: 0%; left: 0; right: auto; }
	100% { width: 100%; left: 0; right: auto; }
}

/* .nav-sp
------------------------------------*/
.nav-sp {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	background: var(--color-bg);
	width: 100%;
	height: 100vh;
	height: 100dvh;
	z-index: 9999;
	opacity: 0;
}

.nav-sp .inner {
	overflow-y: scroll;
	width: 100%;
	height: 100%;
}

.nav-sp .inner > div {
	display: flex;
	align-items: flex-end;
	width: 100%;
	min-height: 100%;
}

.nav-sp .inner > div > div {
	position: relative;
	overflow: hidden;
	width: 100%;
	padding: 25dvh 12% 120rem;
}

.nav-sp .gnav > ul > li {
	margin-bottom: clamp(8px, 1.4dvh, 12px);
}

.nav-sp .gnav li {
	position: relative;
}

.nav-sp .gnav li a {
	display: inline-block;
	position: relative;
	padding: 0 10rem clamp(10px, 2dvh, 14px) 0;
	font-size: clamp(14px, 2.2dvh, 16px);
	letter-spacing: 0.1em;
}

.nav-sp .gnav li ul {
	padding: clamp(14px, 2.6dvh, 24px) 0 clamp(6px, 1.6dvh, 12px) 11rem;
}

.nav-sp .gnav li li {
	margin-bottom: clamp(6px, 1.8dvh, 10px);
}

.nav-sp .gnav li li a {
	color: var(--color-blue);
	letter-spacing: 0.08em;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
}

.nav-sp .gnav li a:nth-of-type(1) { pointer-events: none; }
.nav-sp .gnav li a:nth-of-type(2) { position: absolute; top: 2rem; left: 0; opacity: 0 !important; }
body.top .nav-sp .gnav li a:nth-of-type(1) { pointer-events: all; }
body.top .nav-sp .gnav li a:nth-of-type(2) { pointer-events: none; }

.nav-sp .top-news-head {
	margin-top: 5.5vh;
	line-height: 1.6;
	z-index: 7;
}

.nav-sp .top-news-head time {
	display: block;
	margin-bottom: clamp(4px, 0.8dvh, 6px);
	font-size: clamp(11px, 1.8dvh, 12px);
	letter-spacing: 0.06em;
}

.nav-sp .top-news-head strong a {
	font-size: clamp(13px, 2dvh, 15px);
	letter-spacing: 0.06em;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.15em;
}

.nav-sp .pic {
	position: absolute;
	bottom: -2rem;
	right: 8%;
}

.nav-sp .pic img {
	width: 106rem;
}


/* #wrap
---------------------------------------------------------------------------*/
body.souzoku #wrap {
	padding: 0;
}

#newsContents,
#errorContents {
	padding-top: 130rem;
	padding-left: 9.5%;
	padding-right: 9.5%;
}

.top-support,
.top-message,
.top-access-inner,
.top-news,
.sec-contact {
	padding-right: 9.5%;
	padding-left: 9.5%;
}

#top-support,
#top-message,
#top-news,
#sec-contact,
#support1,#support2,#support3 {
	margin-top: -130rem;
	padding-top: 130rem;
}


/* header
---------------------------------------------------------------------------*/
header {
	margin: 0;
	padding: 0;
	/*opacity: 0;*/
}

.logo {
	position: fixed;
	top: 30rem;
	left: 26rem;
	z-index: 10002;
	opacity: 0;
}

.logo a {
	display: flex;
	align-items: flex-end;
}

.logo .mark {
	width: 29rem;
	height: 29rem;
	margin-right: 14rem;
}

.logo .mark img { width: 100%; }

.logo .mark i {
	display: block;
	position: absolute;
	width: 14rem;
	font-size: 0;
	transform-origin: center bottom;
}

.logo .mark .i1 { top: 0; left: 0; }
.logo .mark .i2 { top: 0; left: 15rem; }
.logo .mark .i3 { top: 23rem; left: 15rem; }
.logo .mark .i4 { top: 6rem; left: 0; }

.logo .type {
	position: relative;
	padding: 1px;
}

.logo .type > img {
	opacity: 0 !important;
	pointer-events: none;
}

.logo .type .mask {
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	transition: .6s var(--easeOutQuint);
}

.logo .type .mask img { transition: .15s linear; }
.logo.hidden .type .mask { width: 0; transition: .3s var(--easeOutQuart); }
.logo.hidden .type .mask img { transition: .15s linear .15s; opacity: 0; }

.logo .type img {
	display: inline-block;
	width: 154rem;
}

.logo img {
	filter: brightness(90%);
}

header .gnav {
  display: none !important;
}


/* footer
---------------------------------------------------------------------------*/
footer {
	margin: 0;
	padding: 120rem 20rem 18rem;
	opacity: 0;
}

body.souzoku footer {
	background-color: #FFFFFF;
}

.copyright img {
	width: 132rem;
}


/* contents
---------------------------------------------------------------------------*/
#mainContents {
	display: block;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	text-align: left;
}

.contents {
	opacity: 0;
}

/* .title-sec
------------------------------------*/
.title-sec {
	margin-bottom: 35rem;
	color: var(--color-blue);
}

.title-sec em {
	display: block;
	margin: 0 0 15rem -1rem;
}

.title-sec strong {
	display: block;
  margin-left: 1rem;
	font-size: 12rem;
	letter-spacing: 0.18em;
}

/* .dot-list
------------------------------------*/
.dot-list li {
	position: relative;
	margin: 0 0 6rem 3rem;
	padding-left: 15rem;
	font-size: 14rem;
	line-height: 1.6;
	letter-spacing: 0.1em;
}

.dot-list li:last-of-type { margin-bottom: 0; }
.dot-list li:before { display: block; content: '・'; position: absolute; top: 0; left: 0; }

/* .attention-list
------------------------------------*/
.attention-list li {
	position: relative;
	margin: 0 0 10rem;
	padding-left: 20rem;
	font-size: 14rem;
	line-height: 1.6;
	letter-spacing: 0.1em;
}

.attention-list li:last-of-type { margin-bottom: 0; }
.attention-list li:before { display: block; content: '※'; position: absolute; top: 0; left: 0; }


/* news archive
---------------------------------------------------------------------------*/
#newsContents .title-sec {
	margin: 0 0 42rem 10rem;
}

/* .news-list
------------------------------------*/
.news-list {
	border-top: 1px solid var(--color-border);
}

.news-list article {
	border-bottom: 1px solid var(--color-border);
}

.news-list article a {
	display: block;
	background: url(img/share/ico-arrow-line.svg) no-repeat right 13rem top 52rem / 20rem auto;
	padding: 22rem 50rem 20rem 2rem;
	line-height: 1.6;
}

.news-list time {
	display: block;
	margin-bottom: 4rem;
	font-size: 11rem;
	letter-spacing: 0.09em;
}

.news-list h3 {
	font-size: 14rem;
	line-height: 1.7;
	letter-spacing: 0.1em;
}


/* news single
---------------------------------------------------------------------------*/
.news-area {
	margin: 0 0 0 10rem;
}

/* .news-title
------------------------------------*/
.news-title {
	margin-bottom: 21rem;
	padding-top: 18rem;
}

.news-title time {
	display: block;
	margin: 0 0 14rem 1rem;
	font-size: 12rem;
	letter-spacing: 0.1em;
}

.news-title h1 {
	color: var(--color-blue);
	font-size: 15rem;
	line-height: 1.9;
	letter-spacing: 0.1em;
}

/* .news-main
------------------------------------*/
.news-main > * {
	font-family: var(--font-gothic-jp) !important;
}

.news-main, .news-main h2, .news-main p {
	font-size: 14rem;
	line-height: 2.1;
	letter-spacing: 0.08em;
}

.news-main h2 {
	margin: 60rem 0 18rem;
	font-size: 16rem;
}

.news-main > h2:first-child {
	margin-top: 0;
}

.news-main p {
	text-align: justify;
	word-break: break-all;
}

.news-main p:last-child { margin-bottom: 0; }
.news-main a { text-decoration: underline; word-break: break-all; }
.news-main strong { font-weight: bold; }
.news-main em { font-style: italic; }
.news-main del { text-decoration: line-through; }

.news-main img {
	display: block;
	max-width: calc(100% + 0rem);
	height: auto;
	margin: 30rem 0 30rem !important;
}

.news-main .wp-caption { max-width: 100%; margin-bottom: 40rem; }
.news-main .wp-caption-text { margin: -30rem 0 0; font-size: 12rem; }

.news-main .gallery > dl { width: 49.5% !important; margin-right: 1% !important; }
.news-main .gallery > dl:nth-child(even) { margin-right: 0 !important; }
.news-main .gallery a { pointer-events: none; }
.news-main .gallery img { border: none !important; width: 100% !important; margin: 0 !important; }

.news-main ul, .news-main ol { margin: 30rem 0 30rem; }
.news-main ul li { list-style: disc; margin: 0 0 6rem 18rem; }
.news-main ol li { list-style: decimal; margin: 0 0 6rem 24rem; }
.news-main ul li:last-of-type,
.news-main ol li:last-of-type { margin-bottom: 0; }

.news-main blockquote { background: #F5F5F5; margin: 40rem 0; padding: 28rem 36rem; text-align: justify; }
.news-main blockquote p { font-size: 14rem; line-height: 1.9; }

.post-main iframe { width: 840rem; height: 476rem; }
/*.post-main iframe { width: 100%; height: calc(85vw * 0.5625); }*/

/* .news-table
------------------------------------*/
.news-table-wrap {
	margin-top: 50rem;
}

.news-table-wrap h3 {
	margin: 60rem 0 8rem;
	font-size: 14rem;
	line-height: 1.6;
	letter-spacing: 0.1em;
}

.news-table-wrap h3:first-child { margin-top: 0; }

.news-table-wrap table {
	width: calc(100% + 10rem);
	font-size: 14rem;
	line-height: 1.6;
	letter-spacing: 0.06em;
}

.news-table-wrap table:has(tr) {
	margin: 40rem -5rem 40rem;
}

.news-table-wrap h3 + table {
	margin-top: 0;
}

.news-table tr { border-bottom: 1px solid var(--color-border); }

.news-table th, .news-table td {
	padding-top: 18rem;
	padding-bottom: 8rem;
}

.news-table th {
	position: relative;
	min-width: 60rem;
	max-width: 90rem;
	padding-right: 20rem;
	padding-left: 5rem;
	color: var(--color-blue);
	text-align: left;
	vertical-align: top;
}

.news-table td {
	width: 100%;
	padding-right: 5rem;
}

.news-table table.right td { text-align: right; }

.news-table-attention {
	margin-top: -24rem;
	font-size: 12rem;
	line-height: 1.8;
	letter-spacing: 0.06em;
}

/* .news-link
------------------------------------*/
.news-link { margin-top: 30rem; }
.news-link li { display: inline-block; margin: 0 8rem 12rem 0; }

/* .news-other
------------------------------------*/
.news-other {
	position: relative;
	margin: 110rem 0 0;
}

.news-other h2 {
	margin: 0 0 28rem 10rem;
	color: var(--color-blue);
	font-size: 15rem;
	letter-spacing: 0.1em;
}

.news-other .btn-link-s {
	position: absolute;
	top: -3rem;
	right: 14rem;
}


/* .wp-pagenavi
---------------------------------------------------------------------------*/
.wp-pagenavi {
	overflow: hidden;
	margin: 50rem 0 0;
	font-size: 14rem;
	text-align: center;
}

.wp-pagenavi .extend {
	padding: 0 10rem;
}

.wp-pagenavi a {
	margin: 0 4rem;
	padding: 5rem;
}

.wp-pagenavi .current {
	display: inline-block;
	border-bottom: 1px solid #9ACBD5;
	margin: 0 7rem;
	padding: 5rem 3rem 10rem;
}

.wp-pagenavi a.first,
.wp-pagenavi a.last {
	display: none;
}

.wp-pagenavi a.previouspostslink,
.wp-pagenavi a.nextpostslink {
	display: inline-block;
	background: url(img/share/ico-arrow-line-s.svg) no-repeat center center;
	text-indent: -9999px;
}

.wp-pagenavi a.previouspostslink {
	margin-right: 15rem;
	transform: scaleX(-1);
}

.wp-pagenavi a.nextpostslink {
	margin-left: 15rem;
}


/* page top
---------------------------------------------------------------------------*/
#topContents .top-news-head {
	display: none !important;
}

/* .top-main
------------------------------------*/
.top-main {
	position: relative;
	margin-bottom: 80rem;
	padding: 230rem 0 0;
}

.top-main h2 {
	position: absolute;
	top: 120rem;
	right: 9.6%;
	opacity: 0;
}

.top-main h2 img {
	width: 67rem;
}

.top-main .txt {
  margin: 0 0 58rem 12%;
	opacity: 0;
}

.top-main .txt p {
	line-height: 2.1;
	letter-spacing: 0.17em;
}

.top-main .img1 {
	width: 45.5%;
	margin: 0 0 44rem 12%;
	opacity: 0;
}

.top-main .img2 {
	width: 36%;
  margin: 0 0 14% 16%;
	opacity: 0;
}

.top-main .img3 {
	width: 56%;
	margin: 0 0 0 31%;
	opacity: 0;
}

/* .top-nav
------------------------------------*/
.top-nav {
	display: block !important;
	position: fixed;
	bottom: -57rem;
	left: 0;
	background-color: var(--color-bg);
	border-top: 1px solid var(--color-border);
	width: 100%;
	padding: 0 6%;
	z-index: 10;
	transition: .4s var(--easeOutQuart);
}

.top-nav.active {
	bottom: 0;
}

.top-nav ul {
	display: flex;
	justify-content: space-between;
}

.top-nav li a {
	display: inline-block;
	position: relative;
	padding: 15rem 13rem 19rem;
	color: var(--color-blue-light);
	font-size: 14rem;
	line-height: 1.6;
	letter-spacing: 0.1em;
}

.top-nav li.current a {
	color: var(--color-blue);
}

.top-nav li a:after {
	display: block;
	content: '';
	position: absolute;
	bottom: 19rem;
	right: 14rem;
	background-color: var(--color-blue);
	width: 0;
	height: 1px;
	opacity: 0.8;
	transition: .2s var(--easeOutQuart);
}

.top-nav li.current a:after {
	left: 13rem;
	width: calc(100% - 27rem);
	transition: .4s var(--easeOutQuart);
}

/* .top-support
------------------------------------*/
.top-support {
	margin: 0 0 130rem;
}

.top-support .lead {
	margin-bottom: 42rem;
}

.top-support .lead .title-sec strong {
	margin-left: 1rem;
}

.top-support .lead .title-sec em {
  margin-left: -1rem;
}

_::-webkit-full-page-media, _:future, :root .top-support .lead .title-sec em {
  margin-left: -4rem;
}

.top-support .lead .title-sec em img {
	width: 142rem;
}

.top-support .lead p {
	letter-spacing: 0.08em;
	text-align: justify;
}

.top-support .lead p br {
  display: none;
}

.top-support-inner .img {
	margin-bottom: 75rem;
}

.top-support-inner .img img {
	width: 100%;
}

.top-support-inner .inner:not(:last-child) {
	margin-bottom: 80rem;
}

.top-support-inner .inner h3 {
	margin-bottom: 30rem;
	color: var(--color-blue);
	font-size: 14rem;
	line-height: 1.7;
	letter-spacing: 0.1em;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.4em;
}

.top-support-inner .inner h4 {
	margin-bottom: 16rem;
	font-size: 19rem;
	line-height: 1.8;
	letter-spacing: 0.15em;
}

.top-support-inner .inner p {
	margin-bottom: 13rem;
	line-height: 2.1;
	letter-spacing: 0.1em;
}

.top-support-inner .inner p.let {
	margin-right: -15rem;
	letter-spacing: 0.02em;
}

.top-support-inner .inner .btn-color {
	margin: 25rem 0 0;
}

.top-support-inner .inner .list {
	position: relative;
	background-color: #FFFFFF;
	border-radius: 3px;
	margin: 0 0 0 -3rem;
	padding: 30rem 30rem 28rem;
}

.top-support-inner .inner.support1 .list { margin-top: 45rem; }
.top-support-inner .inner.support2 .list { margin-top: 85rem; }
.top-support-inner .inner.support3 .list { margin-top: 45rem; }

.top-support-inner .inner .list .pic {
	display: block;
	position: absolute;
	z-index: 1;
}

.top-support-inner .inner.support1 .list .pic { bottom: -45rem; right: -10rem; width: 95rem; }
.top-support-inner .inner.support2 .list .pic { top: -52rem; right: 20rem; width: 96rem; }
.top-support-inner .inner.support3 .list .pic { bottom: -55rem; right: 15rem; width: 88rem; }

.top-support-inner .inner .list h5 {
	margin: 0 0 32rem;
	color: var(--color-blue);
}

.top-support-inner .inner .list h5 strong {
	display: block;
	margin: 0 0 10rem -1rem;
	font-size: 15rem;
	letter-spacing: 0.08em;
}

.top-support-inner .inner .list h5 em {
	display: block;
	font-family: var(--font-serif-en);
	font-size: 13rem;
}

_::-webkit-full-page-media, _:future, :root .top-support-inner .inner .list h5 em {
	margin-left: -1rem;
}

.top-support-inner .inner .list h5 em img {
	width: 66rem;
}

.top-support-inner .inner .list li {
	position: relative;
	padding: 0 0 0 22rem;
	font-size: 14rem;
	line-height: 1.6;
	letter-spacing: 0.05em;
}

.top-support-inner .inner .list li:not(:last-of-type) {
	margin-bottom: 8rem;
}

.top-support-inner .inner .list li i {
	display: block;
	position: absolute;
	top: -1rem;
	left: 0;
	color: var(--color-blue);
	font-family: var(--font-gothic-en);
	font-weight: 500;
	font-size: 16rem;
}

.top-support-inner .inner .list li span {
	display: block;
	font-size: 12rem;
}

/* .top-img
------------------------------------*/
.top-img {
	position: relative;
	margin: 0 0 90rem;
	padding: 0 0 165rem;
}

.top-img .img1 {
	width: 63.5%;
	margin: 0 0 18.5% 25%;
}

.top-img .img2 {
	width: 37%;
	margin: 0 0 0 10%;
}

.top-img .img3 {
	position: absolute;
	bottom: 0;
	left: 32%;
	width: 46%;
}

/* .top-message
------------------------------------*/
.top-message {
	margin: 0 0 90rem;
}

.top-message .title-sec em {
	margin-bottom: 10rem;
}

.top-message .title-sec em img {
	width: 94rem;
}

.top-message .title-sec {
	margin-bottom: 40rem;
}

.top-message figure {
	margin-right: 10%;
	margin-bottom: 44rem;
}

.top-message figure .img2 {
	display: none;
}

.top-message .txt h3 {
	margin: 0 0 26rem 2rem;
}

.top-message .txt h3 img {
	width: 262rem;
}

.top-message .txt > p {
	margin-left: 2rem;
}

.top-message .txt p {
	font-size: 14rem;
	line-height: 2.15;
	letter-spacing: 0.07em;
}

.top-message .txt p.name {
	margin-top: 22rem;
	font-size: 14rem;
	letter-spacing: 0.1em;
	text-align: right;
}

.top-message .txt p.name span {
	padding-right: 7rem;
	font-size: 11rem;
}

.top-message .txt h4 {
	margin: 65rem 0 22rem -2rem;
	color: var(--color-blue);
	font-size: 14rem;
	letter-spacing: 0.15em;
}

.top-message .txt dl {
	display: flex;
}

.top-message .txt dl:not(:last-of-type) {
	margin-bottom: 7rem;
}

.top-message .txt dt,
.top-message .txt dd,
.top-message .txt dd p {
	font-size: 13rem;
	line-height: 1.6;
	letter-spacing: 0.04em;
}

.top-message .txt dt {
	width: 64rem;
	min-width: 64rem;
}

/* .top-access
------------------------------------*/
.top-access {
	margin: 0 0 90rem;
}

.top-access figure {
	position: relative;
	margin: 0 0 48rem;
}

.top-access figure .pic {
	display: none;
}

.top-access-inner .txt {
	margin: 0 5rem 50rem;
}

.top-access-inner .txt h1 {
	margin: 0 0 32rem;
}

.top-access-inner .txt h1 img {
	width: 256rem;
}

.top-access-inner .txt dl,
.top-access-inner .txt dt,
.top-access-inner .txt dd,
.top-access-inner .txt dd p {
	font-size: 14rem;
	line-height: 1.65;
	letter-spacing: 0.08em;
}

.top-access-inner .txt dl {
	display: flex;
	margin-bottom: 12rem;
}

.top-access-inner .txt dl:first-of-type {
	margin-bottom: 17rem;
}

.top-access-inner .txt dt {
	width: 82rem;
	min-width: 82rem;
}

.top-access-inner .txt dd p span {
	font-size: 12rem;
}

.top-access-inner .txt .btn-link {
	margin: 26rem 0 0;
}

.top-access-inner .map {
	position: relative;
	overflow: hidden;
	align-self: flex-start;
	width: 100%;
	height: 252rem;
}

.top-access-inner .map iframe {
	position: absolute;
	top: -150rem;
	left: 0;
	width: 100%;
	height: calc(100% + 150rem);
}

/* .top-news
------------------------------------*/
.top-news {
	position: relative;
	margin: 0 0 90rem;
}

.top-news .title-sec {
	margin-bottom: 40rem;
	margin-left: 1rem;
}

.top-news .title-sec em img,
#newsContents .title-sec em img {
	width: 63rem;
}

.top-news .btn-link-s {
	position: absolute;
	top: 180rem;
	right: calc(9% + 16rem);
}


/* page souzoku
---------------------------------------------------------------------------*/
#souzokuContents {
	color: var(--color-text-dark);
}

#souzokuContents h1 {
	display: none !important;
}

#souzokuContents h1 strong {
	display: inline-block;
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	clip-path: inset(0% 0% 0% 0%);
	transition: .6s var(--easeOutQuart) .25s;
}

#souzokuContents h1.hidden strong {
	clip-path: inset(0% 100% 0% 0%);
	transition: .2s var(--easeOutQuart);
}

.souzoku-side .mask {
	transition: .25s var(--easeInCubic);
}

.souzoku-side.visible .mask {
	width: 0;
	transition: .6s var(--easeOutQuart) .1s;
}

/* .souzoku-main
------------------------------------*/
.souzoku-main {
	background: url(img/souzoku/bg.jpg?260421) repeat left top / 126rem auto;
	width: 100%;
	height: 100vh;
	/*height: 100dvh;*/
}

.souzoku-main.active {
	transition: .9s var(--easeOutQuart);
}

.souzoku-main .inner {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%) !important;
	margin-top: 6dvh;
	text-align: center;
}

.souzoku-main h2 {
	display: inline-block;
	margin: 0 0 min(4vh, 30rem) -4rem;
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	font-size: min(3vh, 24rem);
	line-height: 1.8;
	letter-spacing: -0.04em;
	text-align: left;
	font-feature-settings: 'palt' 0;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	white-space: nowrap;
	opacity: 0;
}

.souzoku-main .pic {
	display: grid;
	grid-template-columns: 1fr;
	gap: min(3vh, 24rem) 0;
	width: 204rem;
	max-width: 30vh;
	margin-left: -2vw;
	padding-bottom: 4rem;
}

.souzoku-main .pic > div {
	position: relative;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 12rem;
}

.souzoku-main .pic img { width: 100%; }
.souzoku-main .pic > div > div img { opacity: 0; }

.souzoku-main .pic i {
	display: block;
	position: absolute;
	bottom: -1rem;
	left: 50%;
	transform: translateX(-50%) !important;
	width: 349rem;
}

.souzoku-main .pic img { width: 100%; }
.souzoku-main .pic > div > div img { opacity: 0; }

.souzoku-main .pic i img { display: block; width: 100%; transform-origin: center bottom; transform: scaleY(0.4); }
.souzoku-main .pic .left i img { clip-path: inset(0% 100% 0% 0%); }
.souzoku-main .pic .right i img { clip-path: inset(0% 0% 0% 100%); }

.souzoku-main .pic.active .left i img { animation: souzoku_main_line_left 1.4s var(--easeInOutQuart) forwards; }
.souzoku-main .pic.active .right i img { animation: souzoku_main_line_right 1.4s var(--easeInOutQuart) forwards; }

@keyframes souzoku_main_line_left {
	0%   { clip-path: inset(0% 100% 0% 0%); }
	50%  { clip-path: inset(0% 0% 0% 0%); }
	51%  { clip-path: inset(0% 0% 0% 0%); }
	100% { clip-path: inset(0% 0% 0% 100%); }
}
@keyframes souzoku_main_line_right {
	0%   { clip-path: inset(0% 0% 0% 100%); }
	50%  { clip-path: inset(0% 0% 0% 0%); }
	51%  { clip-path: inset(0% 0% 0% 0%); }
	100% { clip-path: inset(0% 100% 0% 0%); }
}

.souzoku-main h3 {
	position: absolute;
	top: 10.5vh;
	right: 9%;
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	font-size: min(2.6vh, 14rem);
	letter-spacing: 0;
	font-feature-settings: 'palt' 0;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	white-space: nowrap;
}

.souzoku-main h3 i {
	display: inline-block;
	position: relative;
	width: min(2.6vh, 14rem);
	height: min(2.6vh, 14rem);
	opacity: 0;
}

.souzoku-main h3 i span { display: block; }
.souzoku-main h3 i span.top { transform: rotate(180deg) translateX(-5rem) translateY(1.5rem); }
.souzoku-main h3 i span.btm { transform: rotate(0deg) translateX(-4rem) translateY(1rem); }
_::-webkit-full-page-media, _:future, :root .souzoku-main h3 i span.top { transform: rotate(90deg) translateX(-2rem); }
_::-webkit-full-page-media, _:future, :root .souzoku-main h3 i span.btm { transform: rotate(-90deg) translateX(-2rem); }

.souzoku-main h3 i:after {
	display: block;
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	background-color: var(--color-text-dark);
	width: min(14rem, 2.6vh);
	height: 1px;
}

.souzoku-main h3 i.hidden:after {
	transition: .1s ease-out;
	opacity: 0;
}

.souzoku-main h3 i.stop:after {
	animation: souzoku_main_h3_line_stop .6s linear forwards;
}

@keyframes souzoku_main_h3_line_stop {
	0% { opacity: 1; }
	10% { opacity: 0; }
	50% { opacity: 0; }
	60% { opacity: 1; }
	90% { opacity: 1; }
	100% { opacity: 0; }
}

/* .souzoku-wrap
------------------------------------*/
.souzoku-wrap {
	position: relative;
}

.souzoku-nav {
	position: fixed;
	bottom: -75rem;
	left: 0;
	background-color: #FFFFFF;
	border-top: 1px solid #E5E9EB;
	width: 100%;
	padding: 0 14rem;
	z-index: 10;
	transition: .4s var(--easeOutQuart);
}

.souzoku-nav.active {
	bottom: 0;
}

.souzoku-nav ul {
	display: flex;
	justify-content: space-between;
}

.souzoku-nav li a {
	display: inline-block;
	position: relative;
	padding: 22rem 4rem 21rem 6rem;
	color: var(--color-text-dark);
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	font-size: 13rem;
	line-height: 1.6;
	letter-spacing: 0;
}

.souzoku-nav li a:after {
	display: block;
	content: '';
	position: absolute;
	bottom: 23rem;
	right: 6rem;
	background-color: var(--color-text-dark);
	width: 0;
	height: 1px;
	transition: .2s var(--easeOutQuart);
}

.souzoku-nav li.current a:after {
	left: 6rem;
	width: calc(100% - 10rem);
	transition: .4s var(--easeOutQuart);
}

/* .souzoku-side
------------------------------------*/
.souzoku-side {
	display: none !important;
}

/* .souzoku-inner
------------------------------------*/
.souzoku-inner {
	position: relative;
	z-index: 1;
}

.souzoku-inner:after {
	display: block;
	content: '';
	position: absolute;
	top: 45rem;
	left: 0;
	background-color: #FFFFFF;
	width: 100%;
	height: 100%;
	z-index: -1;
}

.souzoku-about .lead {
	padding-right: 11.5%;
	padding-left: 11.5%;
}

/* .souzoku-about
------------------------------------*/
#souzoku-about {
	margin-top: -45rem;
	padding-top: 45rem;
}

.souzoku-about {
	padding-top: 65rem;
}

.souzoku-about .lead {
	margin-bottom: 65rem;
}

.souzoku-about .lead h2 {
	margin-bottom: 30rem;
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	font-size: 25rem;
	line-height: 1.45;
	letter-spacing: -0.02em;
}

.souzoku-about .lead p {
	margin-bottom: 12rem;
	line-height: 2.1;
	letter-spacing: 0.04em;
}

.souzoku-about .check {
	background-color: #E5E9E5;
	padding: 52rem 6% 0;
	text-align: center;
}

.souzoku-about .check p {
	display: inline-block;
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	font-size: 19rem;
	line-height: 1.65;
	letter-spacing: 0.02em;
	text-align: left;
}

.souzoku-about .check .inner {
	background: url(img/souzoku/bg-check_sp.png?260422) no-repeat left top / 100% auto;
	margin: 18rem auto 0;
	padding: 68rem 12.5% 98rem;
	text-align: left;
}

.souzoku-about .check h3 {
	margin-bottom: 30rem;
}

.souzoku-about .check h3 img {
	width: 68rem;
}

.souzoku-about .check ul {
	margin: 0 20rem 0 20rem;
}

.souzoku-about .check li {
	background: url(img/souzoku/ico-check.svg) no-repeat left top 1rem / 12rem auto;
	margin-bottom: 9rem;
	padding: 0 0 0 22rem;
	font-size: 14rem;
	line-height: 1.5;
	letter-spacing: 0.02em;
	text-align: justify;
}

/* .souzoku-service
------------------------------------*/
#souzoku-service {
	margin-top: -45rem;
	padding-top: 45rem;
}

.souzoku-service {
	background: url(img/souzoku/bg-line.svg) repeat-y center top / 180% auto;
	margin: 0 0 55rem;
	padding: 72rem 44rem 66rem;
}

.souzoku-service .title {
	margin: 0 0 30rem 4rem;
}

.souzoku-service h2 em {
	display: inline-block;
	position: relative;
	background-color: var(--color-blue-mid);
	border-radius: 100rem;
	margin: 0 0 12rem;
	padding: 14rem 20rem 14rem;
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	color: #FFFFFF;
	font-size: 14rem;
	line-height: 0;
	letter-spacing: 0.02em;
}

.souzoku-service h2 em:before {
	display: block;
	content: '';
	position: absolute;
	top: 18rem;
	left: -3rem;
	background: url(img/souzoku/parts-fukidashi.svg?260422) no-repeat left top / 100% auto;
	width: 24rem;
	height: 18rem;
	transform: rotate(-90deg);
}

.souzoku-service h2 strong {
	display: block;
	margin-left: 7rem;
	color: var(--color-blue-mid);
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	font-size: 24rem;
	line-height: 1.3;
}

.souzoku-service .inner {
	background: #FEFBD7;
	border-radius: 30rem;
	margin-bottom: 24rem;
	padding: 28rem 28rem 24rem;
	text-align: center;
	z-index: 1;
}

.souzoku-service .inner:last-of-type {
	margin-bottom: 0;
}

.souzoku-service .inner h3 {
	position: relative;
	margin: 0 0 12rem;
	padding: 0 17rem 0 22rem;
	font-size: 19rem;
	line-height: 1.45;
	letter-spacing: 0;
	color: var(--color-blue-dark);
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	text-align: left;
}

.souzoku-service .inner h3 i {
	display: block;
	position: absolute;
	top: 0.5rem;
	left: 0;
}

.souzoku-service .inner p {
	font-size: 14rem;
	line-height: 1.65;
	letter-spacing: 0.04em;
	text-align: justify;
}

/* .souzoku-service .inner2 p {
	letter-spacing: 0;
} */

.souzoku-service .inner .pic {
	margin: 21rem 0 12rem;
}

.souzoku-service .inner1 .pic img { width: 160rem; margin-top: -5rem; }
.souzoku-service .inner2 .pic img { width: 144rem; margin-top: 8rem; }
.souzoku-service .inner3 .pic img { width: 154rem; margin-top: 0rem; }
.souzoku-service .inner4 .pic img { width: 144rem; margin-top: 5rem; }
.souzoku-service .inner5 .pic img { width: 138rem; margin-top: -5rem; }

/* .souzoku-fee
------------------------------------*/
.souzoku-fee {
	position: relative;
	background-color: var(--color-bg-gray);
	border-radius: 30rem;
	margin: 0 9.5% 100rem;
	padding: 46rem 31rem 43rem;
}

.souzoku-fee h2 {
	position: relative;
	margin-bottom: 15rem;
	color: var(--color-pink);
	font-family: var(--font-gothic-jp-b);
	font-weight: 700;
	font-size: 22rem;
	line-height: 1.3;
	letter-spacing: 0.04em;
}

.souzoku-fee h2 i {
	display: block;
	position: absolute;
	top: -65rem;
	left: -45rem;
}

.souzoku-fee h2 i img {
	width: 65rem;
}

.souzoku-fee p {
	font-size: 15rem;
	line-height: 1.7;
	letter-spacing: 0.04em;
	text-align: justify;
}

.souzoku-fee p br {
	display: none;
}

.souzoku-fee .price {
	position: relative;
	display: flex;
	border-bottom: 3px solid #FFFFFF;
	width: max-content;
	margin-top: 34rem;
	padding: 26rem 0 10rem 2rem;
	color: var(--color-pink);
}

.souzoku-fee .price > div em {
	display: block;
	margin-right: 11rem;
	font-size: 22rem;
	line-height: 1.28;
	letter-spacing: 0.02em;
}

.souzoku-fee .price > div span {
	display: block;
	position: absolute;
	top: 0;
	left: 3rem;
}

.souzoku-fee .price > div span img {
  width: 154px;
}

.souzoku-fee .price strong {
	transform: translateY(3rem);
}

.souzoku-fee .price strong img {
	width: 90rem;
}

.souzoku-fee .pic {
	position: absolute;
	bottom: -14rem;
	right: -6rem;
	width: 106rem;
}


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

/* .sec-contact
------------------------------------*/
.sec-contact .title-sec {
	margin-left: 1rem;	
}

.sec-contact .title-sec em img {
	width: 86rem;
}

.sec-contact > p,
.sec-contact > .p,
.sec-contact > .p p {
  text-align: justify;
	letter-spacing: 0.06em;
	line-height: 1.8;
}

.sec-contact > p br,
.sec-contact > .p p br {
  display: none;
}

.sec-contact .tel {
	margin-top: 28rem;
}

.sec-contact .tel em {
	display: block;
	margin-bottom: 14rem;
	font-size: 14rem;
	letter-spacing: 0.08em;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.3em;
}

.sec-contact .tel strong {
	display: inline-block;
	padding-right: 11rem;
	font-family: var(--font-gothic-en);
	font-weight: 300;
	font-size: 26rem;
	letter-spacing: 0;
	transform: translateY(2rem);
	opacity: 0.8;
}

.sec-contact .tel strong i {
	display: inline-block;
	transform: translateY(-1rem);
}

.sec-contact .tel strong i:nth-of-type(1) { margin: 0 2rem 0 2rem; }
.sec-contact .tel strong i:nth-of-type(2) { margin: 0 0 0 3rem; }

.sec-contact .tel strong .let {
	display: inline-block;
	margin-right: -3rem;
}

.sec-contact .tel > span {
	font-size: 13rem;
	text-underline-offset: 0.06em;
}

.sec-contact .tel time {
	padding-left: 3rem;
	font-family: var(--font-gothic-en);
	font-size: 14rem;
	letter-spacing: 0.02em;
}

.sec-contact .btn-color {
	margin: 38rem 0 0;
}

/* #souzokuContents .sec-contact
------------------------------------*/
#souzokuContents .sec-contact {
	margin-right: auto;
	margin-left: auto;
}

#souzokuContents .sec-contact .title-sec em {
	color: var(--color-pink);
	font-family: var(--font-gothic-en);
	font-size: 26rem;
	font-weight: 500;
}

#souzokuContents .sec-contact .title-sec strong {
	color: var(--color-text-dark);
	font-size: 13rem;
	letter-spacing: 0.04em;
}

/* .form-wrap
------------------------------------*/
.form-wrap {
	margin: 70rem 0 0;
}

.form-wrap dl, .form-wrap dl p { line-height: 1.6; }
.form-wrap dl div { margin-bottom: 18rem; }
.form-wrap dl div:last-of-type { margin-bottom: 0; }

.form-wrap dt {
	margin-bottom: 6rem;
}

.form-wrap dt,
.form-wrap dt p {
	font-size: 14rem;
	letter-spacing: 0.08em;
}

.form-wrap dt span {
	padding-left: 2rem;
	font-size: 12rem;
	letter-spacing: 0.06em;
}

.form-wrap dd {
	overflow: hidden;
	width: 100%;
	min-height: 48rem;
}

.form-wrap dd p {
	font-size: 12rem;
	line-height: 1.7;
	text-align: justify;
}

.sec-contact p.form-attention {
	margin: 17rem 0 0;
	font-size: 13rem;
	line-height: 1.8;
	letter-spacing: 0;
	text-align: justify;
}

/* input
------------------------------------*/
.wpcf7-form-control-wrap {
	display: inline-block;
	position: relative;
	width: 100%;
}

.form-wrap input[type="text"],
.form-wrap input[type="email"],
.form-wrap input[type="tel"],
.form-wrap select,
.form-wrap textarea {
  -webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
  border-radius: 0;
	color: var(--color-text-dark);
	font-family: var(--font-gothic-jp-device);
	outline: none !important;
}

.form-wrap input[type="text"],
.form-wrap input[type="email"],
.form-wrap input[type="tel"],
.form-wrap select,
.form-wrap textarea,
.form-wrap .btn-select .customSelect {
	display: inline-block;
	background-color: rgba(255,255,255,0.8);
	border: none;
	border-radius: 3rem;
	width: 100%;
	height: 48rem;
	padding: 10rem 18rem;
	font-size: 16rem;
	letter-spacing: 0.06em;
}

.form-wrap input[type="text"],
.form-wrap input[type="email"],
.form-wrap input[type="tel"],
.form-wrap textarea {
	width: calc((100% / 0.875) - 1px);
	transform: scale(0.875);
  transform-origin: left top;
}

.form-wrap select {
	width: calc(100% - 1px);
	font-size: 14rem;
}

.form-wrap select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: relative;
	padding-right: 54rem;
	z-index: 1;
}

.btn-select .wpcf7-form-control-wrap .customSelect {
	position: relative;
	z-index: 0;
}

.btn-select .wpcf7-form-control-wrap:before {
	display: block;
	content: '';
	position: absolute;
	top: 13rem;
	right: 16rem;
	background: url(img/share/btn-arrow.svg) no-repeat left top / 100% auto;
	width: 23rem;
	height: 23rem;
	transform: rotate(90deg);
	z-index: 2;
	pointer-events: none;
}

.form-wrap textarea {
	display: block;
	height: 340rem;
	padding: 16rem 18rem;
	line-height: 1.8;
}

::-webkit-input-placeholder { display: none; font-size: 0; }
:-moz-placeholder { display: none; font-size: 0; }
::-moz-placeholder { display: none; font-size: 0; }
:placeholder-shown { display: none; font-size: 0; }

/* .privacy-check
------------------------------------*/
.privacy-check {
	margin: 15rem 0 0;
}

.privacy-check p {
	font-size: 14rem;
	letter-spacing: 0.05em;
}

.privacy-check .wpcf7-form-control-wrap {
	width: auto;
}

@supports (-webkit-appearance: none) and (not (-webkit-touch-callout: none)) {
	.privacy-check .wpcf7-form-control-wrap input {
		margin-right: 9rem;
	  transform-origin: left center;
		transform: scale(1.2);
	}
}

_::-webkit-full-page-media, _:future, :root .privacy-check .wpcf7-form-control-wrap input {
	margin-right: 9rem;
  transform-origin: left center;
	transform: scale(1.2);
}

/* .btn-submit
------------------------------------*/
.btn-submit {
	display: block;
	position: relative;
	margin: 55rem 0 0;
}

.btn-submit input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: block;
	background: #2D7687;
	border: none;
	border-radius: 0;
	width: 100%;
	margin: 0;
	padding: 15rem 15rem 15rem;
	color: #FFFFFF;
  /*font-family: var(--font-gothic-jp-b);
  font-weight: 700;*/
	font-size: 17rem;
	line-height: 1.4;
	letter-spacing: 0.1em;
	text-align: center;
	white-space: nowrap;
}

/* error
------------------------------------*/
.form-wrap .txt-error,
.wpcf7-not-valid-tip,
.txt-response,
.wpcf7-response-output { display: block; }

.form-wrap .txt-error,
.wpcf7-not-valid-tip {
	margin: 10rem 0 0;
	padding: 0;
	font-size: 13rem;
	line-height: 1.6;
	letter-spacing: 0.06em;
}

.screen-reader-response { display: none; }

.txt-response,
.wpcf7-response-output {
	margin: 40rem 0 0 190rem;
	color: var(--color-blue);
	font-size: 15rem;
	line-height: 1.6;
	letter-spacing: 0.08em;
}

.wpcf7-response-output:first-child {
	margin: -45rem 0 45rem;
	padding-top: 45rem;
}

.wpcf7-response-output:empty {
	margin: 0;
	padding-top: 0;
}

.hidden-fields-container {
	border: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* .sec-privacy
------------------------------------*/
.sec-privacy {
	box-sizing: border-box;
	background-color: #E1F0F0;
	border: none;
	border-radius: 3rem;
	margin: 40rem 0 0;
	padding: 0;
}

.sec-privacy .inner {
	overflow-y: scroll;
	box-sizing: border-box;
	width: 100%;
	height: 300rem;
	padding: 34rem 30rem 0 30rem;
	overflow-x: auto;
	position: relative;
}

.sec-privacy .inner::-webkit-scrollbar { width: 1px !important; }
.sec-privacy .inner::-webkit-scrollbar-track { background: none; }
.sec-privacy .inner::-webkit-scrollbar-thumb { background: var(--color-blue-dark); }

.sec-privacy h2 {
	margin-bottom: 25rem;
	font-size: 15rem;
	line-height: 1.8;
	letter-spacing: 0.08em;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.1em;
}

.sec-privacy dl > div {
	margin-bottom: 25rem;
}

.sec-privacy dt {
	margin: 32rem 0 8rem;
}

.sec-privacy dt,
.sec-privacy dt p {
	font-size: 13rem;
	line-height: 1.8;
	letter-spacing: 0.06em;
}

.sec-privacy dt:first-of-type {
	margin-top: 0;
}

.sec-privacy dd {
	color: #565656;
	text-align: justify;
}

.sec-privacy dd p {
	font-size: 13rem;
	line-height: 1.85;
	letter-spacing: 0;
}

.sec-privacy .dot-list li:before {
	top: 2rem;
}

.sec-privacy ol {
	padding: 15rem 0rem 20rem 18rem;
}

.sec-privacy ol:last-child {
	padding-bottom: 0;
}

.sec-privacy ol li {
	margin-bottom: 4rem;
	list-style: decimal;
	font-size: 12rem;
	line-height: 1.8;
	letter-spacing: 0.06em;
}

/* #souzokuContents .form-wrap
------------------------------------*/
#souzokuContents .form-wrap input[type="text"],
#souzokuContents .form-wrap input[type="email"],
#souzokuContents .form-wrap input[type="tel"],
#souzokuContents .form-wrap select,
#souzokuContents .form-wrap textarea,
#souzokuContents .form-wrap .btn-select .customSelect {
	border: 1px solid var(--color-bg-gray);
	border-radius: 0;
}

#souzokuContents .btn-select .wpcf7-form-control-wrap:before {
	top: 22rem;
	right: 20rem;
	background-image: url(img/share/ico-arrow-line-black.svg);
	width: 12rem;
	height: 7rem;
	transform: rotate(0deg);
}

#souzokuContents .sec-privacy {
	background-color: #EEF0EE;
}

#souzokuContents .txt-response,
#souzokuContents .wpcf7-response-output {
	color: var(--color-pink);
}

#souzokuContents .btn-submit input {
	background-color: var(--color-pink);
}

/* recaptcha
------------------------------------*/
.grecaptcha-badge { pointer-events: none; z-index: -999; opacity: 0; transition: .15s ease-out; }
/*body.contact .grecaptcha-badge { pointer-events: auto; z-index: 0; opacity: 1; }*/


/* page error
---------------------------------------------------------------------------*/
#errorContents .title-sec strong { font-size: 16rem; }