/* --------------------------------------------------------------------------------
misc
-------------------------------------------------------------------------------- */

br.small {
	display: inline;
}
br.large {
	display: none;
}
img.small {
	display: block;
}
img.large {
	display: none;
}



/* --------------------------------------------------------------------------------
page
-------------------------------------------------------------------------------- */

div.banner-tel a {
	display: block;
	padding: 20px 0px;
}
div.banner-tel div.text {
	display: block;
}
div.banner-tel div.text p.number {
	margin-right: 0px;
}
div.banner-tel div.text p.number i.icon {
	width: 35px;
	height: 35px;
	font-size: 1.25rem;
	margin-right: 10px;
}
div.banner-tel div.text p.number span {
	font-size: 2rem;
	line-height: 2.5rem;
}
div.banner-tel div.text p.time {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	padding-top: 0px;
}
div.banner-tel div.text p.time span:not(:last-child) {
	margin-right: 5px;
}
div.banner-tel-alternate div.text p.label {
	font-size: 1rem;
	line-height: 1.5rem;
}
div.banner-tel-alternate div.text p.label i {
	font-size: 1.125rem;
}
div.float {
	width: 100%;
	left: 0px;
	right: auto;
	top: auto;
	bottom: 0px;
	transition: 0.25s transform ease;
}
body.admin-bar div.float {
	top: auto;
}
div.scroll div.float {
	transform: translateY(100%);
}
@media (max-width:1260px) {
div.float {
	top: auto;
}
body.admin-bar div.float {
	top: auto;
}
}
div.float div.banner-tel-alternate a {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: auto;
	height: 95px;
	padding: 0px;
	border-radius: 10px 10px 0px 0px;
}
div.float div.banner-tel-alternate div.text {
	display: flex;
	width: 100%;
	padding-top: 5px;
}
div.float div.banner-tel-alternate div.text p.label {
	width: 100%;
}
div.float div.banner-tel-alternate div.text p.number {
	margin-right: 10px;
}
div.float div.banner-tel-alternate div.text p.number span {
	font-size: 1.625rem;
	line-height: 2.25rem;
}



/* --------------------------------------------------------------------------------
header
-------------------------------------------------------------------------------- */

header#header :where(*#logo, nav#navi) {
	top: auto;
}
body.admin-bar header#header :where(*#logo, nav#navi) {
	top: auto;
}
header#header *#logo {
	left: 30px;
	top: 31px;
	z-index: 10;
}
header#header *#logo img {
	width: 220px;
}
header#header :where(p#button-tel, p#button-menu, div#menu) {
	position: fixed;
}
header#header :where(p#button-tel, p#button-menu) {
	width: 45px;
	height: 45px;
	top: 20px;
	overflow: hidden;
	cursor: pointer;
	border-radius: 5px;
}
header#header p#button-tel {
	display: block;
	right: 75px;
	z-index: 10;
	font-size: 1.625rem;
}
header#header p#button-tel a {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	height: 100%;
	color: #ffffff;
	background-color: #f0641a;
}
header#header p#button-menu {
	right: 20px;
	z-index: 30;
	background-color: #ffffff;
}
header#header p#button-menu i {
	display: block;
	position: absolute;
	width: 26px;
	height: 0px;
	left: calc(50% - 13px);
	top: calc(50% - 1px);
	border-bottom: 2px solid #000000;
	transition: 0.25s all ease;
}
header#header p#button-menu i:nth-child(1) {
	transform: translateY(-8px);
}
header#header p#button-menu i:nth-child(2) {
	transform: translateY(8px);
}
div.menu-header header#header p#button-menu i:nth-child(-n+3) {
	width: 0px;
	left: 50%;
	opacity: 0;
	transform: translateY(0px);
}
div.menu-header header#header p#button-menu i:nth-child(4) {
	transform: rotate(45deg);
}
div.menu-header header#header p#button-menu i:nth-child(5) {
	transform: rotate(-45deg);
}
header#header div#menu {
	width: 100%;
	height: 100%;
	right: 0px;
	top: 0px;
	overflow: auto;
	z-index: 20;
	background-color: #f7f6f0;
	transform: translateX(100%);
	transition: 0.25s transform ease;
	-webkit-overflow-scrolling: touch;
}
div.menu-header header#header div#menu {
	transform: translateX(0%);
}
header#header div#menu::-webkit-scrollbar {
	display: none;
}
header#header div#menu div.inner-menu {
	padding: 105px 40px 40px 40px;
}
header#header nav#navi {
	position: static;
	right: auto;
	margin-bottom: 40px;
}
@media (max-width:1260px) {
header#header nav#navi {
	right: auto;
}
}
header#header nav#navi ul {
	flex-direction: column;
	height: 220px;
	margin-right: -20px;
}
header#header nav#navi ul li {
	width: calc(50% - 20px);
	font-size: 1.125rem;
	line-height: 1.875rem;
	margin-right: 20px;
}
header#header nav#navi ul li a {
	display: block;
	padding: 12.5px 0px;
}
header#header div.banner-tel-alternate {
	display: block;
}
header#header div.banner-tel-alternate a {
	border-radius: 10px;
}
header#header div.banner-tel-alternate div.text p.number span {
	font-size: 2.25rem;
	line-height: 2.75rem;
}
header#header div.banner-tel-alternate div.text p.time {
	line-height: 1.875rem;
}
header#header div.banner-tel-alternate div.text p.time span:not(:last-child) {
	margin-right: 10px;
}
header#header div.banner-tel-alternate div.text p.time span.label {
	font-size: 0.75rem;
	line-height: 1.25rem;
}
header#header div.banner-tel-alternate div.text p.time span.body {
	font-size: 1.125rem;
}



/* --------------------------------------------------------------------------------
cover
-------------------------------------------------------------------------------- */

div#cover {
	height: 100svh;
	min-height: 720px;
	padding-top: 140px;
}
div#cover div.illust-title {
	flex-direction: row;
	justify-content: center;
	width: auto;
	margin: 0px auto 40px auto;
	padding-right: 0px;
}
div#cover div.illust-title p.illust {
	width: calc(277px * 0.575);
	padding-top: 40px;
}
div#cover div.illust-title div.title {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	align-items: flex-start;
	width: 190px;
	padding-bottom: 0px;
}
div#cover div.illust-title div.title p.sub {
	display: flex;
	font-size: 1.5rem;
	line-height: 2.25rem;
	margin: 0px 0px 0px 15px;
}
div#cover div.illust-title div.title p.sub span {
	display: block;
	writing-mode: vertical-rl;
	border-left: 2px solid #0062c4;
	border-bottom: none;
	padding: 0px;
}
div#cover div.illust-title div.title h2 img {
	width: 120px;
}
div#cover p.catch,
div#cover p.catch span {
	display: flex;
	flex-wrap: wrap;
}
div#cover p.catch {
	justify-content: center;
	position: static;
	width: auto;
	left: auto;
	top: auto;
	font-size: 1.125rem;
	line-height: 1.5rem;
}
div#cover p.catch span {
	width: 320px;
	height: 70px;
	color: #ffffff;
	padding: 0px;
	background-color: #0062c4;
	border-radius: 35px;
}
div#cover p.button-scroll {
	display: none;
}



/* --------------------------------------------------------------------------------
main
-------------------------------------------------------------------------------- */

main section div.inner-section {
	width: auto;
	padding: 80px 20px;
}
main section header {
	margin-bottom: 60px;
}
main section header h2 {
	justify-content: center;
	height: 70px;
}
main section header h2 img {
	height: calc(43px * 0.925);
}

/* home
-------------------------------------------------------------------------------- */

main section#worry::before {
	height: 25px;
	top: -25px;
}
main section#worry div.block-worry {
	margin-bottom: 160px;
}
main section#worry div.block-worry::before {
	width: calc(482px * 0.75);
	height: calc(482px * 0.75);
	left: calc(50% - calc(241px * 0.75));
	bottom: -340px;
}
main section#worry div.block-worry h2 {
	margin-bottom: 40px;
}
main section#worry div.block-worry h2 span {
	margin: 0px 0px 20px 5px;
}
main section#worry div.block-worry div.balloon {
	height: 450px;
}
main section#worry div.block-worry div.balloon p.row {
	font-size: 1rem;
	line-height: 1.5rem;
}
main section#worry div.block-worry div.balloon p.row span i:not(:last-child) {
	margin-bottom: 2.5px;
}
main section#worry div.block-worry div.balloon p.row span i.main-emphasis {
	font-size: 1.25rem;
	line-height: 1.875rem;
}
main section#worry div.block-worry div.balloon p.row-01 {
	width: calc(204px * 0.75);
	height: calc(152px * 0.75);
	left: calc(50% - 175px);
	top: 0px;
}
main section#worry div.block-worry div.balloon p.row-02 {
	width: calc(269px * 0.75);
	height: calc(194px * 0.75);
	left: calc(50% - 20px);
	top: 20px;
}
main section#worry div.block-worry div.balloon p.row-03 {
	width: calc(254px * 0.75);
	height: calc(189px * 0.75);
	left: calc(50% - 175px);
	right: auto;
	top: 150px;
}
main section#worry div.block-worry div.balloon p.row-04 {
	width: calc(204px * 0.75);
	height: calc(152px * 0.75);
	left: calc(50% + 20px);
	right: auto;
	top: 335px;
}
main section#worry div.block-worry div.balloon p.row-05 {
	width: calc(224px * 0.75);
	height: calc(167px * 0.75);
	left: calc(50% + 20px);
	top: 190px;
}
main section#worry div.block-worry div.balloon p.row-06 {
	width: calc(218px * 0.75);
	height: calc(157px * 0.75);
	left: calc(50% - 165px);
	right: auto;
	top: 310px;
}
main section#worry div.block-solve {
	padding-bottom: 60px;
}
main section#worry div.block-solve::before {
	height: 60px;
	top: -60px;
}
main section#worry div.block-solve p.illust {
	transform: translateY(-160px);
	margin-bottom: -120px;
}
main section#worry div.block-solve p.illust img {
	width: calc(244px * 0.575);
}
main section#worry div.block-solve div.headline {
	margin-bottom: 40px;
}
main section#worry div.block-solve div.headline div.line {
	top: 150px;
}
main section#worry div.block-solve div.headline div.line::before {
	height: 100px;
}
main section#worry div.block-solve div.headline div.line::after {
	height: 60px;
	left: -15px;
}
main section#worry div.block-solve div.headline div.line-left {
	left: calc(50% - 115px);
}
main section#worry div.block-solve div.headline div.line-right {
	right: calc(50% - 115px);
}
main section#worry div.block-solve div.headline h3 {
	font-size: 2rem;
	line-height: 2.5rem;
	margin-bottom: 20px;
}
main section#worry div.block-solve div.headline p.sub {
	font-size: 1.25rem;
}
main section#worry div.block-solve div.headline p.sub i:not(:last-child) {
	margin-bottom: 10px;
}
main section:where(#business, #reason) div.image-text {
	display: block;
	margin: 0px 0px 80px 0px;
}
main section:where(#business, #reason) div.image-text div.text {
	width: auto;
	margin-bottom: 40px;
}
main section:where(#business, #reason) div.image-text div.text h3 {
	justify-content: center;
	font-size: 2rem;
	line-height: 2.5rem;
}
main section:where(#business, #reason) div.image-text p.image {
	width: auto;
	height: auto;
	margin-top: 0px;
}
main section#business div.block {
	position: relative;
	padding-left: 80px;
}
main section#business div.block:not(:last-child) {
	margin-bottom: 60px;
}
main section#business div.block h3 {
	position: absolute;
	left: 10px;
	top: 0px;
	writing-mode: vertical-rl;
	font-size: 1.5rem;
	font-feature-settings: normal;
	margin-bottom: 0px;
	padding: 25px 0px 0px 0px;
}
main section#business div.block h3::before {
	width: 0px;
	height: 15px;
	left: 14px;
	top: 0px;
	border-right: 2px solid #98c9ef;
	border-bottom: none;
}
main section#business div.block div.list {
	display: block;
	margin: 0px;
}
main section#business div.block div.list div.row {
	width: auto;
	margin: 0px;
}
main section#business div.block div.list div.row:not(:last-child) {
	margin-bottom: 20px;
}
main section#flow :where(div.list, p.description, div.banner-tel) {
	margin-bottom: 40px;
}
main section#flow div.list {
	display: block;
}
main section#flow div.list div.row {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	width: auto;
}
main section#flow div.list div.row:not(:last-child) {
	margin-bottom: 40px;
}
main section#flow div.list div.row p.icon {
	width: 95px;
	margin: 0px;
}
main section#flow div.list div.row:not(:last-child) p.icon::before {
	width: 20px;
	height: 15px;
	left: 37.5px;
	right: auto;
	top: auto;
	bottom: -30px;
	clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
}
main section#flow div.list div.row p.icon img {
	width: calc(105px * 0.6875);
}
main section#flow div.list div.row p.caption {
	width: calc(100% - 125px);
	text-align: left;
}
main section#flow p.description {
	text-align: justify;
}
main div#notice {
	margin: 60px 0px;
	padding: 60px 20px;
	background-image: url(../images/notice-image-small.jpg);
}
main div#notice div.text p.description {
	text-align: justify;
}
main section#reason div.list-wrapper {
	padding: 60px 0px;
}
main section#reason div.list {
	display: block;
	margin-right: 0px;
}
main section#reason div.list div.row {
	position: relative;
	width: auto;
	margin-right: 0px;
	padding-left: 40px;
}
main section#reason div.list div.row:not(:last-child) {
	margin-bottom: 40px;
}
main section#reason div.list div.row p.number {
	position: absolute;
	left: 0px;
	top: 0px;
	margin-bottom: 0px;
}
main section#example div.list {
	display: block;
	margin: 0px 0px 60px 0px;
}
main section#example div.list div.row {
	width: auto;
	margin: 0px;
}
main section#example div.list div.row:not(:last-child) {
	margin-bottom: 40px;
}
main section#example p.description {
	text-align: center;
	font-size: 1.125rem;
	margin-bottom: 20px;
}
main section#merit div.summary {
	margin-bottom: 60px;
}
main section#merit div.summary h3 {
	text-align: center;
	font-size: 1.875rem;
	line-height: 2.5rem;
}
main section#merit div.summary h3 span {
	font-size: 2.625rem;
	line-height: 3rem;
	margin: 10px 0px 0px 0px;
}
main section#merit div.list div.row {
	display: block;
	overflow: hidden;
	padding: 0px;
}
main section#merit div.list div.row p.image {
	width: auto;
}
main section#merit div.list div.row div.text {
	width: auto;
	padding: 20px 20px 40px 20px;
}
main section#merit div.list div.row div.text p.number {
	margin-bottom: 20px;
}
main section#merit div.list div.row div.text h3 {
	font-size: 1.75rem;
	margin-bottom: 20px;
}
main section#merit div.list div.row div.text h3 span.main {
	font-size: 2rem;
	line-height: 2.5rem;
}
main section#company div:where(.list-wrapper, .map) {
	margin-bottom: 40px;
}
main section#company div.list-wrapper {
	display: block;
}
main section#company div.list-wrapper div.list {
	width: auto;
}
main section#company div.list-wrapper div.list:not(:first-child) div.row:first-child {
	border-top: none;
}
main section#company div.list-wrapper div.list:not(:first-child) div.row:first-child::after {
	display: none;
}
main section#company div.map iframe {
	height: 240px;
}
main section#contact div.block {
	padding: 40px 20px;
}
main section#contact div.block div.header p.description {
	text-align: justify;
}

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

main section.form div.component-wrapper {
	margin-bottom: 40px;
}
main section.form div.component {
	display: block;
}
main section.form div.component p.label {
	width: auto;
	height: auto;
	margin-bottom: 10px;
}
main section.form div.component div.body {
	width: auto;
}
main section.form div.component div.body div.postal-code p.text:has(input[name=postal_code_01]) {
	width: 90px;
}
main section.form div.component div.body div.postal-code p.text:has(input[name=postal_code_02]) {
	width: 120px;
}
main section.form div.action {
	display: block;
}
main section.form div.action :where(input:where([type=button], [type=submit]), button) {
	margin: 0px auto;
}
main section.form div.action :where(input:where([type=button], [type=submit]), button):not(:last-child) {
	margin: 0px auto 20px auto;
}
