@charset "utf-8";
html {
    overflow-x: hidden;
}
body {
    font-size: 3.73vw;
    -webkit-text-size-adjust: 100%;
        overflow-x: hidden;
    letter-spacing: inherit;
}
.sp {
    display: block !important;
}
.tb {
    display: none;
}
.pc {
    display: none !important;
}
main {
    width: 94%;
}
#tinymce p, main p {
    line-height: 1.5;
    font-size: 3.8vw;
    padding: 0.5em 0;
}
.display_none {
    display: none;
}
#breadcrumbs {
    padding: 0;
    width: 94%;
    font-size: 3vw;
}
.wrap {
    width: 89.3%;
}

main.top {
    padding-top: 0vw;
    width: 100%;
}
/* btn */
.btn {
    padding: 4.5vw 0;
    font-size: 4.4vw;
    width: 70vw;
    border-radius: 8px;
}
.btn:after {
    font-size: 0.8em;
}
/*--------------------------------------------------------------------------------------------
	　見出し
----------------------------------------------------------------------------------------------*/
h2 {
    line-height: 1;
    font-size: 5.2vw;
    padding: 4vw 2vw;
}
h2:before {
    top: 3px;
}
h2:after {
    bottom: 3px;
}
h3 {
    font-size: 4.6vw;
    padding: 2.5vw 0;
    line-height: 1.3; 
    margin: 6vw 0 3vw;
    padding-left: 1vw;
}
h4 {
    font-size: 4.4vw;
    line-height: 1.2;
    padding: 1.8vw 0;
    padding-left: 1vw;
}

h5 {
    font-size: 4.2vw;
    padding: 0.3vw 2vw;
    line-height: 1.2;
}

h6 {
    font-size: 3.6vw;
    padding: 2.53vw;
    line-height: 1.2 ;
}

main h2,
main h3,
main h4,
main h5,
main h6 {
    margin-top: 6vw;
    margin-bottom: 5vw;
}
.page-title {
    height: 40vw;
}
.page-title__h2 {
    font-size: 6vw;
}
img.alignright {
    padding: 4px;
    margin: 0 0 0.1em 0.5em;
    display: inline;
    max-width: 50%;
    float: right;
    height: auto;
}
img.alignleft {
    max-width: 50%;
}
li {
    line-height: 1.5em;
}
/*--------------------------------------------------------------------------------------------
	　mv
----------------------------------------------------------------------------------------------*/

.mv {
    margin-top: 16vw;
}
.mv {
    background-image: url(/kaikei/wp-content/uploads/2025/11/mv__bg_sp.jpg);
    padding: 5.5vw 0 6vw;
}
.mv.margin-top {
    margin-top: 0;
}
.mv__title {
    width: 100%;
    padding: 1.5vw 1vw 3vw;
    box-sizing: border-box;
}
.mv__title span {
    display: block;
    text-align: right;
}
.mv__sub-title {
    width: 71vw;
    height: 12vw;
    font-size: 4.7vw;
    margin: 0 0 0 4vw;
}
.mv__sub-title-text {
    font-size: 4vw;
    padding: 1.5vw 0 0 4vw;
}
.mv__text {
    font-size: 5vw;
    line-height: 1.3;
    padding: 3vw 2.5vw 38vw;
}
.mv__catch-list {
    gap: 0 2vw;
    justify-content: center;
    flex-wrap: wrap;
	width: 62vw;
    margin: 0 0 2vw 2vw;
}
.mv__catch-item {
    width: 30vw;
    height: 30vw;
}
.mv__catch-item-text {
    font-size: 4vw;
}
.mv__catch-item:nth-child(3) .mv__catch-item-text {
    font-size: 3.8vw;
}
.mv__box {
    width: 100%;
}
.mv__image {
    top: 46.5vw;
    width: 41vw;
    right: 0;
}
.mv__catch {
    gap: 2vw;
    padding: 9vw 0 0 0;
    justify-content: center;
    position: relative;
    z-index: 2;
}
.mv__btn {
	width: 92%;
    right: inherit;
	bottom: inherit;
    position: inherit;
    height: 25vw;
    border-radius: 7px;
    box-shadow: 0px 2px 0px 0px #9b9b9a;
	margin: 0 auto;
}
.mv__btn a {
    padding: 2.5vw 3vw;
}
.mv__btn-sub-title {
	font-size: 4vw;
    padding: 1.5vw 0;
    margin: 0 0 3vw;
    border-radius: 5px;
}
.mv__btn-main-title {
    font-size: 5.2vw;
}
/*--------------------------------------------------------------------------------------------
	gn
----------------------------------------------------------------------------------------------*/

.global-nav {
    display: none;
    position: fixed;
	background: #508545f5;
    top: 16vw;
    height: 100%;
    width: 100%;
}
.global-nav__list {
    flex-wrap: wrap;
}
.global-nav__list > li a {
    color: #fff;
    padding: 8vw 0;
    font-size: 4.2vw;
    gap: 2vw;
}
.global-nav .menu-icon {
    width: 6vw;
}
.global-nav__list > li:after {
    bottom: 0;
    display: block;
    width: 100%;
    height: 1px;
    content: '';
    top: inherit;
    position: absolute;
    border-right: inherit;
    transform: inherit;
    background: #ffff;
}
.global-nav .menu-title br {
    display: none;
}
.global-nav__list > li:last-child:before {
    content: none;
}
.global-nav .sub-menu {
    top: 14vw;
	 flex-wrap: wrap;
	display: none!important;
}
.global-nav__list > li:hover .sub-menu {
    display: none;
}
.global-nav__list > li .sub-menu.active {
	 display: flex;
	 flex-wrap: wrap;
}

.global-nav .sub-menu li {
    width: 50%;
}
.global-nav .sub-menu li a {
    font-size: 3.8vw;
    text-align: center;
}
.global-nav__list > li:before,
.global-nav__list > li:last-child:after {
    content: none;
}
/*--------------------------------------------------------------------------------------------
	ヘッダー、フッター
----------------------------------------------------------------------------------------------*/
/* .site-info */
.site-info {
	width: 100%;
	padding: 0 0 0 2vw;
	height: 16vw;
}
header .site-info__contact-container {
    display: none;
}
footer .site-info {
    height: 42vw;
    flex-wrap: wrap;
    justify-content: center;
     padding: 3vw 0 3vw 0;
    gap: 2vw;
    width: 89.3%;
}
footer .site-info__contact-num {
    font-size: 6.7vw;
    padding: 0 0 3vw 0;
    gap: 1.5vw;
}
.site-info__contact-num-icon {
    width: 4.5vw;
    height: 4.5vw;
}
footer .site-info__contact-reception-hours {
    font-size: 3vw;
    padding: 0.7vw 0 1vw;
}
.site-info__logo-image {
    width: 65vw;
}
.site-info__contact-btn-line {
    background-position: top 1.5vw center;
}
.site-info__contact-btn-contact {
    background-position: top 1.5vw center;
}
.site-info__contact-btn-contact-text {
    padding: 4vw 0 0 0;
    height: 5vw;
}
.site-info__title-container {
    gap: 3vw;
}
.site-info__title {
    width: 33vw;
    padding: 0.8vw 0;
}
.site-info__logo {
    width: 8vw;
}
.site-info__catch {
    font-size: 2.3vw;
}
.site-info__logo-company {
    font-size: 2.3vw;
}
.site-info__contact-btn-03 {
    border-radius: 4px;
    width: 40vw;
    height: 14vw;
}
.site-info__contact-btn-03-text {
    font-size: 4.2vw;
}
.site-info__contact-btn-03-text-small {
    display: block;
}
.site-info__contact-btn-03-text strong {
    display: inline;
}
.site-info__contact-btn a {
    width: 21vw;
}
.site-info__contact-container {
    justify-content: space-between;
    width: 100%;
}
.site-info__contact-box {
    margin: 0;
}
.site-info__contact-btn {
    height: 19vw;
}
.site-info__contact-btn-text {
    font-size: 2.8vw;
    padding: 3vw 0 3vw;
}
/* .menu-btn.sp */
.menu-btn.sp {
    height: 16vw;
    width: 16vw;
    position: relative;
	background: var(--main-color);
    box-sizing: border-box;
    padding: 2.5vw 0;
}
.menu-btn__toggle {
    position: relative;
	width: 50%;
	margin: 0 auto;
    height: 6vw;
}
.menu-btn__toggle span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    width: 100%;
    height: 2px;
    background: #fff;
	border-radius:10px;
}
.menu-btn__toggle span:nth-of-type(1) {
    top: 0;
}
.menu-btn__toggle span:nth-of-type(2) {
	top: 50%;
	transform: translateY(-50%);
}
.menu-btn__toggle span:nth-of-type(3) {
    bottom: 0;
}
.menu-btn__toggle.active span:nth-of-type(1) {
    transform: translateX(-50%) translateY(-50%) rotate(-45deg);
	left: 50%;
    top: 50%;
    width: 80%;
}
.menu-btn__toggle.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-btn__toggle.active span:nth-of-type(3) {
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
	left: 50%;
    top: 50%;
    bottom: inherit;
    width: 80%;
}
.menu-btn__title {
    color: #fff;
    font-size: 2.4vw;
    text-align: center;
    padding-top: 2vw;
	font-weight: bold;
}
header {
    top: 0;
    z-index: 99999;
    width: 100%;
    background: white;
    position: fixed;
}
header.fixed {
    position: fixed;
    z-index: 100;
    top: 0;
    box-shadow: 1px 3px 3px #949494;
}

footer {
    margin-bottom: 24vw;
}
/* .company-info */
.company-info{
    padding: 10vw 0 15vw;
}
.company-info__menu-list {
	width: 100%;
    gap: 6vw 5%;
    flex-wrap: wrap;
}
.company-info__menu-item {
    flex: inherit;
    width: 47.5%;
}
.company-info__menu-item-title {
    font-size: 4.4vw;
    line-height: 2;
}
.company-info__menu-item-btn a {
    font-size: 3.2vw;
    height: 9vw;
    gap: 2vw;
    padding: 0 0 0 2vw;
}
.company-info__menu-item-content:has(.company-info__menu-item-btn) {
    padding: 1vw;
}
.company-info__menu-item-office-name {
    font-size: 4.5vw;
}
.company-info__menu-item-content {
    aspect-ratio: 320 / 472;
    border-width: 1px;
}
.company-info__menu-item-office-address {
    font-size: 3.4vw;
}
.company-info__menu-item-office-hour {
    font-size: 2.8vw;
    line-height: 1.3;
}
.company-info__menu-item-office-hour span {
    display: block;
}
.company-info__menu-item-office-tel {
    font-size: 3.8vw;
    padding: 4vw 0 3vw;
    gap: 1vw;
}
.company-info__menu-item-office-tel-icon {
    width: 3vw;
    height: 3vw;
}
.company-info__menu-item-search-box input#submit {
    font-size: 2.8vw;
    border-radius: 3px;
    width: 10vw;
    height: 7vw;
}
.company-info__menu-item-search-box input#s {
    height: 7vw;
    flex: inherit;
    width: 72%;
}
.company-info__menu-item-btn a:before {
    font-size: 1.2em;
}
.company-info__menu-item-office-inner {
    padding: 4vw 0 0 0;
}
.company-info__menu-item-search-title {
    font-size: 3.4vw;
    padding: 3vw 0 1.5vw 1vw;
}
.company-info__menu-item-search-box form {
    gap: 0;
}
.footer-inner {
    display: flex;
    flex-direction: column;
}
/* .footer-menu */
.footer-menu {
    padding: 8vw 0;
}
.footer-menu__container {
    flex-wrap: wrap;
     width: 89.3%;
     gap: 8vw 0;
}
.footer-menu__menu {
    flex: inherit;
    width: 50%;
}
.footer-menu ul li {
    line-height: 1.2;
}
.footer-menu ul li a {
    font-size: 3.4vw;
}
.footer-menu ul li:before {
    padding-right: 2vw;
}
.footer-menu ul li:not(:first-child) {
    margin-top: 2vw;
}
footer .copy {
    padding: 3.2vw 0;
    font-size: 3vw;
}

/*floating-footer */
.floating-footer {
    background: #fff;
    position: fixed;
    z-index: 99999;
    left: 0;
    bottom: 0;
    width: 100%;
    text-align: center;
}
.floating-footer__btns {
    display: flex;
}
.floating-footer__btn a {
    display: block;
	height: 100%;
    position: relative;
    text-decoration: none;
}
.floating-footer__btn-tel {
    border-top: 1px solid var(--main-color);
	border-bottom: 1px solid var(--main-color);
	width: 60%;
}
.floating-footer__btn-tel a {
	box-sizing: border-box;
	padding: 2.5vw;
}
.floating-footer__btn-tel-num {
    display: flex;
    font-weight: bold;
    font-size: 5.5vw;
    align-items: center;
    place-content: center;
    gap: 1vw;
    line-height: 1;
    padding: 0 0 1vw 0;
	color: #333;
}
.floating-footer__btn-tel-num-icon {
    display: block;
    width: 4.5vw;
    height: 4.5vw;
}
.floating-footer__btn-tel-hour {
    color: #333;
    display: block;
    font-size: 3vw;
	line-height: 1;
	padding: 1vw 0;
	background: #f1f1f1;
	font-weight: 500;
}
.floating-footer__btn-title {
    display: block;
    font-size: 3vw;
    font-weight: 500;
	line-height: 1;
	color:#fff;
	padding: 2.8vw 0;
}
.floating-footer__btn-icon {
	display: block;
	width: 30%;
	margin: auto;
}
.floating-footer__btn-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.floating-footer__btn-dl {
    background: var(--sub-color);
    width: 20%;
}
.floating-footer__btn-mail {
    background: var(--main-color);
	width: 20%;
}

/*--------------------------------------------------------------------------------------------
	　TOP
----------------------------------------------------------------------------------------------*/
h2 .main-title {
    font-size: 6vw;
	line-height: 1.2;
}
h2 .main-title span {
    display: block;
}
h2 .main-title:after {
    height: 3px;
    width: 12vw;
    margin: 3vw auto 0;
}
h2 .sub-title {
	font-size: 4.5vw;
	padding: 0 0 2vw 0;
}
/* reason */
.reason {
    padding: 24vw 0 10vw;
    background-image: url(/kaikei/wp-content/uploads/2025/11/reason__bg_sp.jpg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top;
    background-color: #949494;
}
.reason__list {
    padding: 13vw 0 0 0;
    gap: 10vw;
    box-sizing: border-box;
    width: 100%;
    flex-wrap: wrap;
    justify-content: center;
}
.reason__item {
    width: 90%;
    aspect-ratio: 601 / 365;
}
.reason__item-catch {
    width: 32vw;
    height: 10vw;
    gap: 4vw;
    font-size: 5vw;
}
.reason__item-title {
    font-size: 5vw;
    line-height: 1.5;
    padding: 9vw 0 3vw 0;
}
.reason__item-text {
    font-size: 3.5vw;
}
.reason__item-num {
    font-size: 13vw;
}
/* .comparison-chart */
.comparison-chart {
    padding: 9vw 0 18vw;
}
.comparison-chart__table {
    width: 178vw;
    margin: 14vw auto 0;
}
.comparison-chart__table,
.comparison-chart__table tr,
.comparison-chart__table th,
.comparison-chart__table td {
    font-size: 3.2vw;
}
.comparison-chart__table td {
    height: 31vw;
}
.comparison-chart__table tr:last-child td {
    height: 11vw;
}
.comparison-chart__title {
    font-size: 4vw;
    height: 13vw;
    padding: 0 0 5vw;
}
.comparison-chart__title:after {
    width: calc(100% + 6px);
    height: 6vw;
    top: -6vw;
    left: -3px;
    border-radius: 7px 7px 0 0;
}
.comparison-chart__col-2 {
    border-width: 2px;
}
.comparison-chart__table tr:nth-child(1) th {
    font-size: 3.6vw;
}
.comparison-chart__text {
    font-size: 3.3vw;
}
.comparison-chart__mark {
    font-size: 8vw;
	padding: 0 0 7vw 0;
}
.comparison-chart__table tr td:nth-child(2) .comparison-chart__mark {
    padding: 0 0 6vw 0;
}
/* .cost-cut */
.cost-cut {
    padding: 17vw 0 3vw 0;
}
.cost-cut__list {
    padding: 3vw 0 0 0;
}
.cost-cut__item {
    flex-wrap: wrap;
    padding: 6vw 0;
    gap: 10vw;
}
.cost-cut__item-type {
    width: 100%;
}
.cost-cut__item-cost {
    width: 100%;
}
.cost-cut__item-type-title {
    font-size: 4.4vw;
    margin: 0 0 3.5vw 0;
    line-height: 2.2;
}
.cost-cut__item-type-inner {
    width: 60%;
    margin: auto;
}
.cost-cut__item-type-text {
    font-size: 4.2vw;
    bottom: -6vw;
}
.cost-cut__item-cost-fee {
    height: 10.5vw;
    font-size: 6.5vw;
    margin: 0 0 2.5vw 0;
}
.cost-cut__item-cost-fee-num {
    padding: 0 0 0 3.3vw;
}
.cost-cut__item:nth-child(3) .cost-cut__item-cost-fee-num {
    font-size: 4.6vw;
    padding: 0 0 0 4vw;
}
.cost-cut__item-cost-text {
    border-radius: 8px;
    font-size: 3.8vw;
    padding: 2% 2.5%;
    margin: 2.5vw 0 0 0;
}
.cost-cut__item:nth-child(3) .cost-cut__item-cost-fee-text {
    font-size: 3.3vw;
}
.cost-cut__item:not(:first-child) .cost-cut__item-type-title {
    display: block;
}
.cost-cut__item-cost-title {
    font-size: 4.4vw;
    margin: 0 0 3.5vw 0;
    line-height: 2.2;
}
.cost-cut__item:not(:first-child) .cost-cut__item-cost-title {
    display: block;
}
.cost-cut__item-cost-note {
    font-size: 3vw;
}
.cost-cut__item:nth-child(3) .cost-cut__item-cost-fee-text:before,
.cost-cut__item:nth-child(3) .cost-cut__item-cost-fee-text:after {
    width: 4.86vw;
    height: 2.43vw;
}
/* .plan */
.plan {
    padding: 12vw 0 20vw 0;
}
.plan__btn {
    box-shadow: 0px 2px 0px 0px #a6a6a6;
    border-radius: 6px;
    width: 100%;
    margin: 15vw auto 0;
    aspect-ratio: 599 / 264;
}
.plan__btn-text {
    font-size: 3.6vw;
    height: 58%;
    line-height: 1.3;
}
.plan__btn-title {
    font-size: 6.5vw;
    place-content: center;
    height: 42%;
}
.plan__btn-title:after {
    font-size: 0.65em;
}
.plan__list {
    flex-wrap: wrap;
    justify-content: center;
    gap: 13vw;
    padding: 9vw 0 0 0;
}
.plan__item {
    flex-direction: column;
    flex: inherit;
    width: 92%;
}
.plan__item:not(:last-child) .plan__item-title, .plan__item:not(:last-child) .plan__item-text {
    border-right: 1px solid var(--main-color);
}
.plan__item-title {
    font-size: 5.2vw;
    padding: 5vw 0;
}
.plan__item-text {
    height: 50vw;
    padding: 8% 3%;
}
.plan__item-text ul {
    gap: 3.5vw;
}
.plan__item-text li {
    font-size: 3.6vw;
}
.plan__item-text:after {
    width: 28vw;
    bottom: 3vw;
}
/* .case */
.case {
    padding: 10vw 0 12vw;
}
.case__message {
    font-size: 3.4vw;
    line-height: 1.8;
    padding: 7vw 0 0 0;
	text-align: left;
    margin: 0 auto;
    width: 89.3%;
}
.case__container {
    width: 100%;
}
.case__category-container {
    flex-wrap: wrap;
    padding: 10vw 0 2vw 0;
}
.case__category-01, .case__category-02 {
    width: 100%;
}
.case__category-title {
    font-size: 4.6vw;
    padding: 4vw 0;
}
.case__list {
    padding: 8vw 0 10vw 0;
}
.case__item a {
    margin: 0 5vw;
}
.case__item-image {
    aspect-ratio: 510 / 357;
}
.case__item-text-container {
    aspect-ratio: 510 / 503;
}
.case__item-title {
    font-size: 4vw;
    height: 18vw;
    padding: 3vw 0;
}
.case__item-comment {
    font-size: 3.4vw;
	padding: 3vw 1vw 0 1vw;
}
.case__item-tag {
	font-size: 3.2vw;
	height: 7.2vw;
	width: 21vw;
}
.case__item-info-list {
    gap: 1vw;
}
.case__item-info-item {
    padding: 2vw;
    font-size: 3.2vw;
}
.case__item-info-item-title {
    width: 28%;
}
.case__prev, .case__next {
    width: 11vw;
    height: 11vw;
}
.case__prev::before, .case__next::before {
    font-size: 4vw;
}
.case__prev {
    left: 2vw;
}
.case__next {
    right: 2vw;
}
/* .about */
.about {
    padding: 14vw 0 16vw;
}
.about__messgae-container {
    padding: 0;
    gap: 4vw;
    flex-wrap: wrap-reverse;
	justify-content: center;
}
.about__messgae-image {
    width: 80%;
}
.about__messgae {
    flex: inherit;
}
main.top .about__messgae-text p {
    font-size: 3.4vw;
}
.about__menu {
    flex-wrap: wrap;
    padding: 7vw 0 0 0;
    gap: 6vw;
}
.about__menu-item {
    width: 100%;
}
.about__menu-item-title-en {
    display: block;
    font-size: 6vw;
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: 0.03em;
}
.about__menu-item-title-jp {
    display: block;
    font-size: 3.2vw;
}
.about__menu-item a:after {
    width: 2.2vw;
    height: 2.2vw;
    right: 1.3vw;
    bottom: 1.3vw;
}
/* .news */
.news {
    padding: 13vw 0;
}
.news__list {
    padding: 8vw 0 8vw;
}
.news__item-title {
    font-size: 3.6vw;
    flex: inherit;
    line-height: 1.5;
    width: 100%;
	padding: 3vw 0 0 0;
}
.news__item a {
    flex-wrap: wrap;
    gap: 0;
    padding: 3vw 0;
}
.news__item-category {
    font-size: 3vw;
    width: 20vw;
    height: 6vw;
}
.news__item-date {
    font-size: 3.2vw;
	padding: 0 6vw 0 0;
}
/*--------------------------------------------------------------------------------------------
	　共通
----------------------------------------------------------------------------------------------*/
/* .contact-banner */
.contact-banner {
    padding: 6vw 0 7vw;
}
.contact-banner__title {
    font-size: 5vw;
    padding: 0 0 4vw 21vw;
}
.contact-banner__title span {
	display: block;
}
.contact-banner__title-text {
    font-size: 5.5vw;
    width: 85vw;
    padding: 0;
    height: 16vw;
    flex-wrap: wrap;
    justify-content: center;
	place-content: center;
}
.contact-banner__title:before,
.contact-banner__title:after {
    width: 11vw;
    height: 10vw;
    top: 9vw;
}
.contact-banner__container {
    justify-content: center;
    flex-wrap: wrap;
    border-radius: 13px;
    margin: 0;
    height: 59vw;
    padding: 3vw;
}
.contact-banner__tel {
    width: 100%;
    padding: 0 2vw 4vw 2vw;
    border-right: none;
    border-bottom: 1px solid #e4e4e4;
    pointer-events: inherit;
}
.contact-banner__tel-title {
    font-size: 4.4vw;
}
.contact-banner__tel-num-icon {
    width: 5.5vw;
    height: 5.5vw;
}
.contact-banner__tel-hour {
    line-height: 2.2;
    font-size: 3.4vw;
}
.contact-banner__mail {
	width: 100%;
	padding: 0 2vw;
}
.contact-banner__mail a {
    gap: 8vw;
    border-radius: 8px;
    height: 18vw;
    padding: 0 0 0 9vw;
    box-shadow: 0px 2px 0px 0px #7a969a;
}
.contact-banner__mail-icon {
    width: 9vw;
    height: 9vw;
}
.contact-banner__mail-title {
    font-size: 4.3vw;
    line-height: 1.15;
}
.contact-banner__mail-hour {
    font-size: 3.4vw;
}
.contact-banner__icon {
    left: 1vw;
    bottom: inherit;
    width: 21vw;
    top: 0;
    transform: translateY(-100%);
}
.contact-banner__tel-num {
    font-size: 7.5vw;
	padding: 1vw 0 2vw;
    gap: 2vw
}
/*main*/

main .page_under01 {
    margin-bottom: 6vw;
}
main .page_under01 ul.child li a {
    padding: 5vw;
}
/*ページネーション*/
main .pagenation li {
    display: inline-block;
    padding: 0 0.67vw;
}
main .pagenation li a {
    display: block;
    padding: 2vw 1.73vw;
    color: #4c4c4c !important;
    text-decoration: none;
    padding: 1vw 4vw !important;
    font-size: 3.4vw !important;
}
/*--------------------------------------------------------------------------------------------
  執筆者
----------------------------------------------------------------------------------------------*/
.writer__content {
    flex-wrap: wrap;
    justify-content: center;
    gap: 10vw;
    padding: 0;
}
/*--------------------------------------------------------------------------------------------
	　archive
----------------------------------------------------------------------------------------------*/
.archive__item > a {
    padding: 5vw 0 3vw;
}
.archive__item-date {
    font-size: 3.2vw;
}
.archive__item-title {
    font-size: 4.6vw;
	padding: 1.5vw 0 2vw;
}
.archive__item-text {
    font-size: 3.6vw;
}
/* .archive-category */
.archive-category__item {
    width: 49%;
    font-size: 3.2vw;
}
.archive-category__item a {
    padding: 2.5vw;
}
.archive-category__list {
    gap: 3vw 2%;
    padding: 4vw 0;
}
/* .archive-case */
.archive-case__parent-tab-item {
    font-size: 3.6vw;
	border-radius: 5px 5px 0 0;
}
.archive-case__parent-tab-item a:before {
    font-size: 0.9em;
}
.archive-case__child-tab-item a {
    height: 10vw;
}

.archive-case__child-tab-container {
    padding: 3vw;
}
.archive-case__child-tab-list {
    gap: min(5px, 0.5vw) 0.5%;
}
.archive-case__parent-tab-item.is-active {
    font-size: 1.1em;
    height: 9vw;
}
.archive-case__child-tab-item {
    width: 49.5%;
}
.archive-case__parent-tab-item {
    height: 8vw;
}
.archive-case__list {
    gap: 5vw;
}
.archive-case__item {
    width: 100%;
}
.archive-case__item a {
    padding: 0 0 5vw 0;
}
.archive-case__item-category-list {
    gap: 1vw;
    padding: 3vw;
}
.archive-case__item-category {
    padding: 0 1vw;
    font-size: 2.8vw;
    line-height: 1.5;
}
.archive-case__item-image {
    height: 52vw;
}
.archive-case__item-title,
.archive-case__item-comment {
    font-size: 4vw;
	padding: 3vw;
}
.archive-case__item:after {
    right: 3vw;
    bottom: 3vw;
    font-size: 4vw;
}
/*--------------------------------------------------------------------------------------------
	　single
----------------------------------------------------------------------------------------------*/
.single .thumbnail img {
    margin-bottom: 30px;
    padding: 20px 0;
    width: 100%;
}
main .single img {
    width: inherit;
}
table, td, th, tr {
    font-size: inherit;
    font: 100%;
    line-height: 1.3em
}

table.line {
    border-collapse: collapse;
    border-spacing: 0;
}

table.line th {
    background-color: #eae8e3;
    border: #d3d3d3 1px solid;
    padding: 10px;
    vertical-align: middle;
    text-align: left;
}

table.line td {
    border: #d3d3d3 1px solid;
    padding: 10px;
    text-align: left;
    vertical-align: middle;
}

/*検索*/
input#search-input {
    width: -webkit-fill-available;
}
button.search-btn {
    margin-top: 3vw;
}
main .search_ttl {
    font-size: 5.5vw;
    width: 35vw;
}
h2.underline b {
    font-size: 5.4vw;
    line-height: 1.4em;
}
/* お問い合わせページ */
.page-contact {
    padding: 3vw 3vw 10vw 3vw;
}
.page-contact table {
    box-sizing: border-box;
}
main .page-contact table tr {
    flex-direction: column;
}
main .page-contact__item-title p {
    font-size: 3.6vw;
}
main .page-contact .required,
main .page-contact .optional{
    width: 10vw;
    height: 5vw;
}
main .page-contact table th {
    gap: 2vw;
	width: 100%;
}
main .page-contact table td {
    flex: inherit;
}
.page-contact input[type="text"], .page-contact input[type="email"], .page-contact input[type="tel"], .page-contact input[type="date"], .page-contact textarea {
    height: 10vw;
    width: 100%;
}
.page-contact textarea {
	height: 40vw;
}
.page-contact__submit {
    width: 70vw;
    height: 13vw;
}
.page-contact__submit input[type="submit"] {
    font-size: 4.5vw;
}
.page-contact .page-contact__item-date-container input[type="date"],
.page-contact .page-contact__item-date-container input[type="text"] {
    width: 26vw;
    font-size: 3.4vw;
}
.page-contact__item-date-container p {
    gap: 3vw;
}
main .page-contact .acceptance-container {
    justify-content: start;
}
main .page-contact .acceptance-container p {
    font-size: 3.4vw;
}
main .page-contact .acceptance-container .required p {
    font-size: 0.78em;
}
.page-contact .page-contact__item-post-code input[type="text"] {
    width: 22vw;
}
/*--------------------------------------------------------------------------------------------
  サービスページ共通
----------------------------------------------------------------------------------------------*/
main.page-service h2 .main-title {
    font-size: 7.8vw;
}
main.page-service h2 .sub-title {
    font-size: 4.5vw;
}
main.page-service h2 .sub-title:after {
    height: 0.65vw;
    width: 11vw;
    margin: 4vw auto 0;
}
/* .service-contact */

.service-contact {
    padding: 8vw 0 13vw;
}
.service-contact__inner {
    width: 100%;
    margin: 7vw auto 7vw;
}
.service-contact__item-title {
    gap: 2vw;
    font-size: 3.6vw;
    width: 100%;
}
.service-contact__item-required {
    border-radius: 2px;
    width: 9vw;
    height: 4vw;
}
.service-contact label {
    flex-wrap: wrap;
	gap: 2vw;
}
.service-contact .wpcf7-form-control-wrap {
    width: 100%;
}
.service-contact input[type="text"], .service-contact input[type="email"], .service-contact input[type="tel"], .service-contact textarea {
    padding:3.2vw;
    width: 100%;
}
.service-contact__submit input {
    font-size: 4.5vw;
}
.service-contact__submit {
    width: 80%;
    height: 14vw;
    border-radius: 3px;
}
/*--------------------------------------------------------------------------------------------
  記帳代行ページ
----------------------------------------------------------------------------------------------*/
/* .bookkeeping-mv */
.bookkeeping-mv {
    background-image: url(/kaikei/wp-content/uploads/2025/11/bookkeeping-mv__bg_sp.jpg);
    padding: min(75px, 7vw) 0 min(33px, 3vw);
}
.bookkeeping-mv__box {
    width: 89.3%;
}
.bookkeeping-mv__title {
    width: 98%;
    margin: 0 0 4vw 0;
}
.bookkeeping-mv__catch-item {
    border-radius: 10px 0 10px 0;
    gap: 1.5vw;
    width: 50%;
    height: 24vw;
    padding: 0;
    display: grid;
    place-content: center;
}
.bookkeeping-mv__catch-item:nth-child(2),
.bookkeeping-mv__catch-item:nth-child(3) {
    margin: 0;
}
.bookkeeping-mv__catch-item-icon {
    width: 5.3vw;
    height: 5.3vw;
    margin: 0 auto;
}
.bookkeeping-mv__catch-item-text {
    font-size: 3.5vw;
    text-align: center;
	width: 100%;
    line-height: 1.3;
}
.bookkeeping-mv__catch-item-text .new-line-pc {
    display: inline;
}
.bookkeeping-mv__catch-item-text .new-line-sp {
    display: block;
}
/* .bookkeeping-worries */
.bookkeeping-worries {
    padding: 8vw 0 2vw;
}
.bookkeeping-worries:after {
    width: 24vw;
    height: 6vw;
}
.bookkeeping-worries__image {
    padding: 6vw 0 0 0;
}
/* .bookkeeping-plan */
.bookkeeping-plan {
    padding: 15vw 0 9vw;
}
.bookkeeping-plan h2 .sub-title {
    padding: 0 0 4vw 0;
}
.bookkeeping-plan__table {
    width: 165vw;
    margin: 18vw auto 7vw;
}
.bookkeeping-plan__container {
    margin: 0 0 0 5.35%;
}
.bookkeeping-plan__catch {
    width: 16vw;
    height: 16vw;
    top: -10vw;
    left: -6vw;
    z-index: 3;
    font-size: 3vw;
    border-width: 2px;
}
.bookkeeping-plan__quality strong {
    font-size: 2.4em;
    padding: 0 0 3vw 0;
}
.bookkeeping-plan__col-2,
.bookkeeping-plan__col-3,
.bookkeeping-plan__col-4 {
    border-radius: 8px;
    border-width: 2px;
}
.bookkeeping-plan__col-1 {
    width: 17%;
}
.bookkeeping-plan__col-blank-01,
.bookkeeping-plan__col-blank-02,
.bookkeeping-plan__col-blank-03 {
    width: 0.5%;
}
.bookkeeping-plan__col-4 {
    width: 20.5%;
}
.bookkeeping-plan__title {
    font-size: 4.2vw;
    height: 16vw;
    padding: 0 0 5vw;
    line-height: 1.2;
    gap: 1.5vw;
}
.bookkeeping-plan__text {
    font-size: 3.2vw;
}
.bookkeeping-plan__fee strong {
    font-size: 6vw;
	padding: 0 0 3vw 0;
}
.bookkeeping-plan__fee {
    font-size: 3vw;
    font-weight: bold;
    padding: 0 2vw;
}
.bookkeeping-plan__soft:after {
    width: calc(100% + 4px);
    height: 2vw;
    bottom: -2vw;
    left: -2px;
    border-radius: 0 0 8px 8px;
}
.bookkeeping-plan__row-title {
    font-size: 3vw;
    border-radius: 7px;
    height: 18vw;
    width: 22vw;
    font-weight: bold;
    margin: 0;
}
.bookkeeping-plan__title:after {
    width: calc(100% + 6px);
    height: 5vw;
    top: -5vw;
    left: -3px;
    border-radius: 7px 7px 0 0;
}
.bookkeeping-plan__table tr:nth-child(2) td:nth-child(2), .bookkeeping-plan__table tr:nth-child(2) td:nth-child(4), .bookkeeping-plan__table tr:nth-child(2) td:nth-child(6) {
    padding: 2% 3%;
}
.bookkeeping-plan__message {
    font-size: 6.5vw;
    font-weight: 600;
    line-height: 1.3;
    padding: 3vw 0 0 0;
}
.bookkeeping-plan__message span {
    display: block;
}
.bookkeeping-plan__soft-image {
    width: 82%;
    margin: auto;
}
.bookkeeping-plan__table tr:nth-child(4) td:nth-child(6) strong {
    font-size: 3.8vw;
}
.bookkeeping-plan__soft {
    font-size: 3.2vw;
    line-height: 1.3;
}
.bookkeeping-plan__mark {
    font-size: 8vw;
    padding: 0 0 3vw 0;
}
.bookkeeping-plan__quality {
    font-size: 3.2vw;
    font-weight: bold;
}
.bookkeeping-plan__visit {
    font-size: 3.2vw;
    font-weight: bold;
    padding: 0 2vw;
}
/* .bookkeeping-reason */
.bookkeeping-reason {
    padding: 13vw 0 14vw;
}
.bookkeeping-reason__list {
    flex-wrap: wrap;
    gap: 21vw;
    padding: 25vw 0 0 0;
}
.bookkeeping-reason__item {
    width: 80%;
    border-radius: 15px;
    padding: 18% 4% 8% 4%;
}
.bookkeeping-reason__item-image {
    width: 37vw;
}
.bookkeeping-reason__item-title {
    font-size: 5.2vw;
    height: 25vw;
}

.bookkeeping-reason__item-text {
    font-size: 3.5vw;
    padding: 4vw 4vw 0 4vw;
    line-height: 1.7;
}
.bookkeeping-reason__item-title:after {
    width: 9vw;
    height: 0.5vw;
}
/* 	.bookkeeping-tab */
.bookkeeping-tab {
    padding: 12vw 0 10vw;
}
.bookkeeping-tab__container {
    width: 89.3%;
}
.bookkeeping-tab__tab-content {
    padding: 6vw 0;
    border-width: 2px;
}
.bookkeeping-tab__tab-title {
    font-size: 4.2vw;
    border-radius: 5px 5px 0 0;
    padding: 2vw 0;
    border-width: 1px;
    display: grid;
    place-content: center;
}
.bookkeeping-tab__tab-title span {
    display: block;
}
.bookkeeping-tab__tab-content-title {
    font-size: 4.5vw;
    width: 48%;
}
.bookkeeping-tab__tab-content-title:before,
.bookkeeping-tab__tab-content-title:after {
    height: 1px;
    width: 19vw;
}
.bookkeeping-tab__feature-item {
    width: 29%;
    border-radius: 5px;
    aspect-ratio: 195 / 287;
    display: flex;
    flex-direction: column;
    gap: 1vw;
	padding: 2% 3%;
}
.bookkeeping-tab__tab-titles {
    margin: 10vw auto 0;
    gap: 4%;
}
.bookkeeping-tab__flow-list {
    margin: 5vw 5.5% 5vw 3.5%;
}
.bookkeeping-tab__flow-item {
    height: 20vw;
    line-height: 1.3;
    gap: 1vw;
}
.bookkeeping-tab__flow-item-title {
    font-size: 2.6vw;
    width: 19vw;
    line-height: 1.45;
}

.bookkeeping-tab__flow-item-text {
    font-size: 3.2vw;
    height: 12vw;
}
.bookkeeping-tab__feature-item-title {
    font-size: 3.2vw;
    text-align: left;
    display: block;
    height: inherit;
    line-height: 1.3;
}
.bookkeeping-tab__feature-item-num {
    font-size: 5.2vw;
}
.bookkeeping-tab__feature-item-text {
    font-size: 2.7vw;
    padding: 4% 0 0 0;
}
.bookkeeping-tab__feature-list {
    gap: 2vw;
    margin: 4vw 0 0 0;
}
.bookkeeping-tab__plan-item-title {
    font-size: 4vw;
    height: 12vw;
}
.bookkeeping-tab__plan-list {
    gap: 3vw 3.5%;
    margin: 5vw 0 0 0;
}
.bookkeeping-tab__plan-item {
    width: 43.5%;
    box-shadow: 0px 0px 2px #ddd;
    padding: 0 0 4vw 0;
}
.bookkeeping-tab__plan-item-text {
    font-size: 3.2vw;
    height: 27vw;
    padding: 3vw 4vw;
    line-height: 1.3;
}
.bookkeeping-tab__plan-item-btn {
    font-size: 3.2vw;
    border-radius: 5px;
    padding: 1.5vw 0 1vw;
}
.bookkeeping-tab__flow-item:before {
    width: 17px;
}
.bookkeeping-tab__flow-item:after {
    width: 16px;
}
.bookkeeping-tab__flow-item:last-child {
    right: 9px;
    padding: 0 0 0 4vw;
    width: 30%;
}
.bookkeeping-tab__flow-item:last-child:before {
    right: -8px;
}
.bookkeeping-tab__flow-item:last-child:after {
    right: -8px;
}
.bookkeeping-tab__tab-content-message {
    font-size: 4.2vw;
}
/* 	.bookkeeping-fee */
.bookkeeping-fee {
    padding: 14vw 0 12vw;
}
.bookkeeping-fee__message {
    gap: 6vw;
    padding: 7.5vw 0 10vw;
}
main .bookkeeping-fee__message p {
    font-size: 3.8vw;
    text-align: left;
}
.bookkeeping-fee__container {
    width: 89.3%;
}
.bookkeeping-fee__list {
    gap: 8vw;
}
.bookkeeping-fee__item {
    border-radius: 8px;
    width: 100%;
    aspect-ratio: 670 / 940;
}
.bookkeeping-fee__item-title {
    font-size: 5vw;
}
.bookkeeping-fee__item-title:after {
    width: 3.6vw;
    height: 2vw;
}
.bookkeeping-fee__item-category {
    font-size: 3vw;
    padding: 1vw 0;
}
.bookkeeping-fee__item-content-title {
    font-size: 4.2vw;
    padding: 0 0 3vw 4vw;
}
.bookkeeping-fee__item-content {
    padding: 4.5% 4%;
}
.bookkeeping-fee__item-content-text {
    font-size: 3.5vw;
    padding: 0 0 4vw 4vw;
    height: auto;
    line-height: 1.4;
}
.bookkeeping-fee__item-data-type {
    padding: 0.5vw 1.5vw;
    font-size: 3.2vw;
}
.bookkeeping-fee__item-data-fee-num {
    font-size: 8vw;
    line-height: 1.3;
}
.bookkeeping-fee__item-data {
    border-color: #e0dfdf;
    margin: 0 0 2vw 0;
}
.bookkeeping-fee__item-data-title {
    width: 35%;
    font-size: 4vw;
    height: 31vw;
}
.bookkeeping-fee__item-data-title:after {
    width: 5vw;
}
.bookkeeping-fee__item-data-num {
    font-size: 5.5vw;
}
.bookkeeping-fee__item-image {
    height: 37vw;
}
.bookkeeping-fee__item-image img {
	width: 100%;
    height: 100%;
	object-fit: cover;
	object-position: top;
}
/*--------------------------------------------------------------------------------------------
  経理改善支援ページ
----------------------------------------------------------------------------------------------*/
/* .improvement-mv */
.improvement-mv {
    background-image: url(/kaikei/wp-content/uploads/2025/12/improvement-mv__bg_sp.jpg);
    padding: 40vw 0 40vw;
}
.improvement-mv__title {
    width: 88%;
    margin: auto;
}
.improvement-mv__sub-title {
    font-size: 3.2vw;
    letter-spacing: 0.05em;
}
/* .improvement-worries */
.improvement-worries__inner {
    width: 100%;
    margin: 10vw auto 7vw;
    padding: 4.5% 5%;
    border-radius: 5px;
}
.improvement-worries__list {
    gap: 3vw;
}
.improvement-worries__item {
    gap: 1.7vw;
}
.improvement-worries__item-text {
    font-size: 4vw;
}
.improvement-worries__item-icon {
    width: 4.5vw;
    height: 4.5vw;
}
.improvement-worries__message {
    font-size: 3.8vw;
}
.improvement-worries__image {
    bottom: 28vw;
    right: -8vw;
    width: 30vw;
}
/* .improvement-request */
.improvement-request {
    padding: 19vw 0 12vw;
}
.improvement-request__inner {
    width: 100%;
    margin: 6vw auto 0;
    padding: 6.5% 5%;
    border-radius: 5px;
}
.improvement-request__item {
    gap: 1.7vw;
}
.improvement-request__item-text {
    font-size: 4vw;
}
.improvement-request__item-icon {
    width: 4.5vw;
    height: 4.5vw;
}
.improvement-request__inner-text {
    line-height: 1.6;
    font-size: 3.5vw;
    padding: 4vw 0 0 0;
}
.improvement-request__inner-text span {
    display: block;
}
/* .improvement-reason */
.improvement-reason {
    padding: 10vw 0 10vw;
}
.improvement-reason__container {
    gap: 6vw;
    padding: 8vw 0 0 0;
    flex-wrap: wrap-reverse;
	justify-content: center;
}
.improvement-reason__list {
    gap: 8vw;
    width: 100%;
}
.improvement-reason__item {
    position: relative;
}
.improvement-reason__image {
    width: 65%;
}

.improvement-reason__item-title {
	position: absolute;
    font-size: 4.5vw;
    width: 14vw;
    line-height: 1.8;
    top: 0;
    transform: translateY(-50%);
}
.improvement-reason__item-text {
    font-size: 4vw;
    line-height: 1.35;
    flex: inherit;
    padding: 7% 4% 5% 4%;
}
.improvement-reason__flow-num {
    width: 17vw;
    height: 17vw;
    font-size: 3.4vw;
}
/* .improvement-flow */
.improvement-flow {
    padding: 10vw 0 10vw;
}
.improvement-flow__list {
    width: 100%;
    gap: 13vw;
    padding: 16vw 0 0 0;
}
.improvement-reason__flow-inner {
    padding: 3vw 0 0 0;
}
.improvement-flow__item {
    align-items: inherit;
}
.improvement-reason__flow-title {
    font-size: 5.8vw;
    padding: 0 1vw 3vw 0;
    line-height: 1.2;
}
.improvement-reason__flow-text {
    font-size: 3.8vw;
    line-height: 1.5;
    font-weight: normal;
    padding: 0 1vw 0 1vw;
}
.improvement-flow__item:not(:last-child) .improvement-reason__flow-num:after {
    height: 35vw;
}
/* .improvement-merit */
.improvement-merit {
	padding: 10vw 0 12vw;
}
.improvement-merit__image-list {
    gap: 4vw;
    padding: 10vw 0 0 0;
}
/*--------------------------------------------------------------------------------------------
  給与計算代行ページ
----------------------------------------------------------------------------------------------*/
/* .payroll-mv */
.payroll-mv {
    background-image: url(/kaikei/wp-content/uploads/2025/12/improvement-mv__bg_sp.jpg);
    padding: 40vw 0 40vw;
}
.payroll-mv__title {
    width: 88%;
    margin: auto;
}
.payroll-mv__sub-title {
    font-size: 3.2vw;
    letter-spacing: 0.05em;
}
/* .payroll-worries */
.payroll-worries__inner {
    width: 100%;
    margin: 10vw auto 7vw;
    padding: 4.5% 5%;
    border-radius: 5px;
}
.payroll-worries__list {
    gap: 3vw;
}
.payroll-worries__item {
    gap: 1.7vw;
}
.payroll-worries__item-text {
    font-size: 4vw;
}
.payroll-worries__item-icon {
    width: 4.5vw;
    height: 4.5vw;
}
.payroll-worries__message {
    font-size: 3.8vw;
}
.payroll-worries__image {
    bottom: 28vw;
    right: -8vw;
    width: 30vw;
}
/* .payroll-request */
.payroll-request {
    padding: 19vw 0 12vw;
}
.payroll-request__inner {
    width: 100%;
    margin: 6vw auto 0;
    padding: 6.5% 5%;
    border-radius: 5px;
}
.payroll-request__item {
    gap: 1.7vw;
}
.payroll-request__item-text {
    font-size: 4vw;
}
.payroll-request__item-icon {
    width: 4.5vw;
    height: 4.5vw;
}
.payroll-request__inner-text {
    line-height: 1.6;
    font-size: 3.5vw;
    padding: 4vw 0 0 0;
}
.payroll-request__inner-text span {
    display: block;
}
/* .payroll-reason */
.payroll-reason {
    padding: 10vw 0 10vw;
}
.payroll-reason__container {
    gap: 6vw;
    padding: 8vw 0 0 0;
    flex-wrap: wrap-reverse;
	justify-content: center;
}
.payroll-reason__list {
    gap: 8vw;
    width: 100%;
}
.payroll-reason__item {
    position: relative;
}
.payroll-reason__image {
    width: 65%;
}

.payroll-reason__item-title {
	position: absolute;
    font-size: 4.5vw;
    width: 14vw;
    line-height: 1.8;
    top: 0;
    transform: translateY(-50%);
}
.payroll-reason__item-text {
    font-size: 4vw;
    line-height: 1.35;
    flex: inherit;
    padding: 7% 4% 5% 4%;
}
.payroll-reason__flow-num {
    width: 17vw;
    height: 17vw;
    font-size: 3.4vw;
}
/* .payroll-flow */
.payroll-flow {
    padding: 10vw 0 10vw;
}
.payroll-flow__list {
    width: 100%;
    gap: 13vw;
    padding: 16vw 0 0 0;
}
.payroll-reason__flow-inner {
    padding: 3vw 0 0 0;
}
.payroll-flow__item {
    align-items: inherit;
}
.payroll-reason__flow-title {
    font-size: 5.8vw;
    padding: 0 1vw 3vw 0;
    line-height: 1.2;
}
.payroll-reason__flow-text {
    font-size: 3.8vw;
    line-height: 1.5;
    font-weight: normal;
    padding: 0 1vw 0 1vw;
}
.payroll-flow__item:not(:last-child) .payroll-reason__flow-num:after {
    height: 35vw;
}
/* .payroll-merit */
.payroll-merit {
	padding: 10vw 0 12vw;
}
.payroll-merit__image-list {
    gap: 4vw;
    padding: 10vw 0 0 0;
}