/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: May 20 2025 | 03:53:03 */
@media screen and (max-width: 768px){
.entry-content #original .lead {
    text-align: center!important;
}
	
.entry-content #original .pointTtl {
    font-size: var(--tl);
    font-weight: 700;
    text-align: center;
}
/*=====================================

【SMP】

=====================================*/
	html .admin-bar{
    margin-top: -46px !important;
}
	
	.pickup .wp-block-column{
		overflow:hidden;
	}
.es-container{
width:100%!important;
max-width:100%!important;
margin:0!important;
padding:0!important;
}
.es-separate-container #primary, .es-separate-container #secondary {
    padding-bottom: 0!important;
}
.top-news .es-list-wrapper {
    padding-bottom: 0;
    padding-top: 0;
}

#original .es-list.list-border-bottom li {
	border-bottom: none;
    margin: 0;
    padding: 0;
}
#original .es-list.list-direction-column li:last-child {
    margin-bottom: initial!important;
}
.entry-content #original p {
    margin-bottom: 0;
}
footer#colophon{
	display:none;
}
	.es-normal-title-enabled #page {
margin-top: 60px;
}
.es-normal-title-enabled  #page header {
    position: relative;
    z-index: 1;
    margin: auto;
    width: 100%;
}
#page .es-header-breadcrumb ol{
		padding:1em!important;
	}
/*=====================================
初期設定
=====================================*/
html, body {
	margin: 0;
	padding: 0;
	height: 100%;
	width: 100%;
	color: #1d1d1e;
	font-family: 'Inter', 'Noto Sans JP', sans-serif;
    letter-spacing: .03em
}
body {
    width: 100%;
}
body * {
	box-sizing: border-box;
	word-wrap: break-word;
}
/* タグのリセット */
h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, caption, img, form, blockquote, label {
	padding: 0;
	margin: 0;
	border: none;
	font-size: 100%;
	font-style: normal;
	font-weight: normal;
	line-height: 1.8;
	list-style-type: none;
}
table, th, td {
	/*	border: none;*/
	font-size: 100%;
	font-style: normal;
	font-weight: normal;
	line-height: 1.8;
	list-style-type: none;
}
/* テキストエリア内文字サイズのブラウザ間での統一 */
textarea {
	font-size: 100%;
}
/* 画像の下にできる隙間を除去 */
/* 画像綺麗に縮小 */
img {
	vertical-align: bottom;
	-ms-interpolation-mode: bicubic;
	-webkit-backface-visibility: hidden
}
ins {
    text-decoration: none;
}
/* フォーカスしたらプレースホルダーを非表示に */
input:focus::-webkit-input-placeholder,textarea:focus::-webkit-input-placeholder{
	color: transparent;
}
input:focus::-moz-placeholder,textarea:focus::-moz-placeholder {
	color: transparent;
}
input:focus::-ms-input-placeholder,textarea:focus::-ms-input-placeholder {
	color: transparent;
}
input:focus::placeholder,textarea:focus::placeholder{
	color: transparent;
}
/* プレースホルダーテキストの調整 */
::-webkit-input-placeholder { /* WebKit, Blink, Edge */
    color: rgb(189, 188, 188);
    font-size: 80%;
}
   :-ms-input-placeholder { /* Internet Explorer 10-11 */
    color: rgb(189, 188, 188);
    font-size: 80%;
}
   ::placeholder{ /* Others */
    color: rgb(189, 188, 188);
    font-size: 80%;
}

/* フォントレンダリング設定: 1x解像度ではsubpixel、2x以上の解像度ではgrayscale */
body {
	-webkit-font-smoothing: subpixel-antialiased;
	-moz-osx-font-smoothing: unset;
}
@media only screen and
(-webkit-min-device-pixel-ratio: 2),
(min-resolution: 2dppx) {
	body {
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
	}
}


/*=====================================
テキスト・カラー指定
=====================================*/
:root {
    --wht: #fff;
    --blk: #1d1d1e;
    --gry: #77777c;
    --pgry: #f5f5f5;
    --lgry: #d5d5d5;
    --dgry: #36363a;
    --nvy: #243a66;
    --red: #c40202;
    --blu: #3575d3;
    --lblu: #5390ea;
    --nblu:#385889;
    --wine: #a54a4a;
    --grn: #749750;
    --gld: #c19227;
    --trp: rgba(255,255,255,0);
    --c: center;
    --r: right;
    --x2l: clamp(28px, 7.18vw, 33px);
    --xl: clamp(23px, 6.15vw, 25px);
    --tl: clamp(19px, 4.87vw, 21px);
    --tm: clamp(17px, 4.35vw, 18px);
    --nm: clamp(15px, 3.846vw, 16px);
    --ts: clamp(10px, 2.8vw, 13px);
    --t2s: clamp(9px, 2.56vw, 11px)
}
a {
	color: var(--blu);
    text-decoration: underline
}
img {
    max-width: 100%
}
.cont-l {
    padding: min(12.5%, 75px) 0;
}
.cont-m {
    padding: min(7.5%, 50px) 0;
}
.cont-s {
    padding: min(5%, 30px) 0;
}
.inner-l, .inner-m, .inner-s {
    padding-left: 7%;
    padding-right: 7%
}
[class^="inner-"] + [class^="inner-"],
[class^="inner-"] + [class*=" inner-"],
[class*=" inner-"] + [class^="inner-"],
[class*=" inner-"] + [class*=" inner-"] {
    margin-top: min(12.5%, 75px)
}
[class^="inner-"].cmn-box,
[class*=" inner-"].cmn-box {
    margin-left: auto;
    margin-right: auto;
    width: 96%;
}
.cmn-box {
    padding: min(5%, 30px)
}
.cmn-box > * + * {
    margin-top: min(7.5%, 50px)
}
.cmn-base > * + * {
    margin-top: min(7.5%, 30px)
}
.pdt00 {
    padding-top: 0!important
}
.pdt03 {
    padding-top: 5%!important
}
.pdg00 {
    padding-top: 0!important;
    padding-bottom: 0!important
}
.pdb00 {
    padding-bottom: 0!important
}
.bg-wht {
    background: var(--wht)
}
.bg-gry {
    background: var(--gry)
}
.bg-pgry {
    background: var(--pgry)
}
.bg-lgry {
    background: #ddd
}
.bg-wine {
    background: var(--wine)
}
.bg-grn {
    background: var(--grn)
}
.bg-gld {
    background: var(--gld)
}
.bg-nblu {
    background: var(--nblu)
}
.txt-wht {
    color: var(--wht)!important
}
.txt-gry {
    color: var(--gry)!important
}
.txt-nvy {
    color: var(--nvy)!important
}
.txt-red {
    color: var(--red)!important
}
.txt-wine {
    color: var(--wine)!important
}
.txt-grn {
    color: var(--grn)!important
}
.txt-gld {
    color: var(--gld)!important
}
.txt-underline {
    text-decoration: underline;
}
.txt-upper {
    text-transform: uppercase;
}
.txt-c {
    text-align: var(--c)!important
}
.txt-l {
    text-align: var(--l)!important
}
.txt-r {
    text-align: var(--r)!important
}
.fs-es {
    font-size: var(--t2s)!important
}
.fs-s {
    font-size: var(--ts)!important
}
.fs-l {
    font-size: var(--tm)!important
}
.fs-el {
    font-size: var(--tl)!important
}
.spno {
    display: none!important
}
.gry-frame {
    border: 1px solid var(--lgry)
}
.wd100 {
    width: 100%
}

.fs-bold {
 font-weight: 700!important;
}


/*=====================================
ローディング
=====================================*/
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99999;
    width: 100vw;
    height: 100vh;
    background: #fff;
    transition: 1s
}
.loaded {
    opacity: 0;
    visibility: hidden
}


/*=====================================
ヘッダー
=====================================*/
header {
    flex-shrink: 0;
    position: fixed;
    z-index: 9999;
    top: 0;
    left: 0;
    width: 100%;
    height: max(10vw, 60px);
    background: var(--wht)
}
header.fixed {
    box-shadow: 0px 1px 3px -2px rgba(191,191,191,.5), 0px 1px 6px 0px rgba(191,191,191,.5);
}
header + * {
    margin-top: 60px
}
.header__wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: max(10vw, 60px);
}
.header__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4%;
    height: 60px
}
.header__logo {
    font-size: 0
}
.bh-logo {
    display: inline-block;
    margin: 0;
    width: 40vw;
    max-width: 200px;
    aspect-ratio: 4.5/1;
}
.bh-logo img {
    width: 100%
}
.accordion__link img,
.accordion__link [class^="ic-"] {
    display: none
}


/*=====================================
フッター
=====================================*/
footer {
    padding: min(8%,40px) min(5%,25px) calc(90px + env(safe-area-inset-bottom));;
    background: var(--dgry);
    color: var(--wht)
}
footer a,
footer a:hover {
    color: var(--wht);
    text-decoration: none
}
footer .bh-logo {
    display: block;
    margin: 0 auto min(5%,25px);
}
.footer__inner {
    padding: min(6%,30px) 0;
    border-top: 1px solid rgba(213,213,213,.2)
}
.footer__inner:last-of-type {
    padding-bottom: 0
}
.footer__menu {
  margin-top: 2%;
  padding: 0 4px;
}
.footer__menu > li {
    padding-top: min(4%,20px);
    font-size: clamp(12px, 1.1vw, 14px);
    font-weight: 700;
}
.footer__menu > li ul {
    display: flex;
    flex-wrap: wrap;
    padding-top: 4px;
}
.footer__menu > li ul li {
    padding: 4px 20px 4px 0;
    font-size: var(--ts)
}
.footer__menu > li ul li a {
    color: #c9c9cd;
}
.footer__menu > li ul li a:hover {
    color: var(--pgry)
}
.footer__menu > li ul li a::before {
    content: "\e315";
    flex-shrink: 0;
    font-family: 'Material Symbols Outlined';
    font-weight: normal;
}
.footer__group + .footer__group {
    margin-top: min(8%, 40px)
}
.footer__group img {
    width: 100%;
    object-fit: cover;
    object-position: 50% 30%;
    aspect-ratio: 3/1
}
.footer__group h2 {
    padding: 15px 4px 5px;
    font-size: var(--ts);
    font-weight: 700;
    color: var(--wht);
}
.footer__group p {
    padding: 0 4px;
    font-size: var(--ts)
}
.footer__btm ul {
    padding-bottom: min(5%,25px);
    text-align: center
}
.footer__btm li {
    display: inline-block;
    padding-left: 12px;
    padding-right: 12px;
    font-size: var(--ts);
}
.footer__btm li a {
    color: #c9c9cd;
}
.copyright {
    color: #c9c9cd;
    font-size: var(--t2s);
    text-align: center
}


/*=====================================
スマホフッターメニュー
=====================================*/
.smp__btm {
    z-index: 999;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: var(--dgry);
    border-top: 1px solid rgba(213,213,213,.2)
}
.smp__btm ul {
    display: flex;
}
.smp__btm ul li {
    flex-basis: 25%;
}
.smp__btm ul li:not(:first-child) {
    border-left: 1px solid rgba(213,213,213,.2)
}
.smp__btm ul li a {
    display: block;
    width: 100%;
    padding-top: 9px;
    height: calc(60px + env(safe-area-inset-bottom));
    color: var(--wht);
    font-size: var(--t2s);
    font-weight: 700;
    text-align: center;
    text-decoration: none
}
.smp__btm ul li a [class^="material-symbols-"] {
    display: block;
    font-size: var(--xl);
}


/*=====================================
コンテンツ
=====================================*/
.entry-content>* {
    padding-left: 0;
    padding-right: 0;
}
	
	
main section {
    width: 100%
}
main section:last-of-type {
    padding-bottom: min(12.5%, 75px);
}
main p, main li {
    font-size: var(--nm);
    line-height: 1.8
}
main p {
    margin-left: auto;
    margin-right: auto;
    width: min(100%,90vw)
}
sup {
    display: inline-block;
    font-size: 50%;
    vertical-align: top
}

/*ボタン*/
.btnArea {
    margin-top: min(10%, 50px);
    margin-bottom: min(10%, 50px);
}
.gryBtn {
    padding: 2px 10px 2px 6px;
    background: var(--gry);
    border-radius: 3px;
    color: var(--wht);
    font-weight: 700
}

/*見出し*/
.ttl-blk {
    width: min(100%, 90vw)!important;
    margin: 0 auto min(5%,25px);
    font-size: var(--tl)!important;
    font-weight: 700!important;
    text-align: center!important
}
* + .ttl-blk {
    margin-top: min(12.5%, 75px)!important
}
.ttl-blk a {
    color: #1d1d1e!important;
    font-weight: 700!important;
    text-decoration: none!important
}
.ttl-blk small {
    font-size: var(--ts)!important;
    font-weight: 400!important
}
.ttl-blk.line::after {
    content: ''!important;
    display: block!important;
    margin: min(5%,20px) auto!important;
    width: 60px!important;
    height: 1px!important;
    background: var(--blk)!important
}
.ttl-cmn {
    margin: 0 auto min(3%,15px);
    width: min(100%, 90vw)!important;
    font-size: var(--tm)!important;
    font-weight: 700!important;
    letter-spacing: .05em!important
}
.ttl-nvy {
    margin: 0 auto min(5%,25px);
    width: min(100%, 90vw)!important;
    color: var(--nvy)!important;
    font-size: var(--tm)!important;
    font-weight: 700!important;
    letter-spacing: .05em!important;
    text-align: center!important
}
* + .ttl-nvy {
    margin-top: min(12.5%, 75px)!important
}
.ttl-nvy.line {
    padding-bottom: min(3%,15px)!important;
    border-bottom:  1px solid var(--lgry)!important;
    text-align: left!important
}
.ttl-nvy a {
    color: var(--nvy)!important;
    text-decoration: none!important
}
.ttl-wht {
    margin-bottom: min(5%,25px)!important;
    color: var(--wht)!important;
    font-weight: 700!important
}
.ttl-wht.fs-el {
    font-size: var(--nm)!important
}
.ttl-wht a {
    color: var(--wht)!important;
    text-decoration: none!important
}

/*レイアウト*/
.fbox > * + * {
    margin-top: min(12.5%, 75px);
}
.frame__box.fbox > * + * {
    margin-top: min(5%, 15px);
}
.check__list.fbox > * + * {
    margin-top: 0
}
.fbox.sp__half {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 4.35%
}
.fbox.sp__half > * + * {
    margin-top: 0
}
.fbox.sp__half > * {
    flex-basis: 47.825%
}
.fbox.sp__half .half {
    flex-basis: 100%
}


/*=====================================
TOP PAGE
=====================================*/
/*MV*/
.mv-slider {
    width: 100%;
}
.mv-slider .slick-track {
    overflow: hidden;
    width: 100%;
    height: 400px;
}
.mv-slider .slick-slide {
    position: relative
}
.mv-slider .slick-slide span {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-80%);
    z-index: 10;
    width: 90%;
    color: #fff;
    font-size: var(--tm);
    font-weight: 700;
    letter-spacing: .2em;
    text-align: center;
    text-shadow: rgba(35,35,35,.75) 0 0 6px;
	font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.mv-slider .slick-slide img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 400px;
    object-fit: cover;
}
.mv-slider .slick-slide .mv-logo {
    position: relative;
    display: block;
    width: 240px;
    aspect-ratio: 4.5/1;
    background: url("/app/uploads/sites/1105/2023/10/logo-bh-nvy.png") no-repeat left top / contain;
    font-size: 0!important
}

/*top news*/
.top-news {
    padding: min(3.8%,20px) min(4%,30px);
}
.top-news li {
    padding: 0;
    font-size: 13px!important
}
	.top-news li h3{
    padding: 0;
    font-size: 13px!important;
		font-weight:normal!important;
}
.top-news strong {
    margin-right: 15px
}
.top-news .date {
    font-weight: 700
}
.top-news a {
    color: var(--blk);
    text-decoration: none
}
.top-news a:hover {
    color: var(--gry);
    text-decoration: none
}
	
	.top-news .list_content.es-list-content::before{
  content: "NEW　";
	color: var(--nvy)!important;
	font-weight:bold;
}
.top-news .es-list.list-direction-column li:last-child {
    margin-bottom: 0;
}

/*pick up*/
.pickup {
    padding: 8% 0;
}

	
	.pickup-slider .es-list-items {
    display: flex!important;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center
}
	
.pickup	.es-list-wrapper{
    padding-top:0;
	padding-bottom:0;
}
.pickup-slider {
    display: flex!important;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center
}
.pickup-slider .ic-prev,
.pickup-slider .ic-next  {
    font-size: 20px;
    line-height: 1.8;
    cursor: pointer;
    transition: .2s
}
.pickup-slider .ic-prev:hover,
.pickup-slider .ic-next:hover  {
    color: var(--gry)
}
.pickup-slider .slick-list {
    order: 1;
    margin-bottom: 15px;
}
.pickup-slider .ic-prev {
    order: 2
}
.pickup-slider .slick-dots {
    order: 3;
}
.pickup-slider .ic-next {
    order: 4
}
.pickup-slider .slick-track {
    float: none;
    display: flex;
    gap: 20px;
}
.pickup-slider .slick-slide {
    width: 74vw;
}
.pickup-slider .slick-slide img {
    width: 100%;
    max-width: auto!important
}
.pickup-slider .img_4_3:before {
    padding-top: 60%;
}
/*service*/
.service {
    padding-top: 8%
}
.service-owner {
    margin-top: 5%
}
.s-owner {
    flex-basis: calc((100% / 3) * 2);
    flex-shrink: 0;
    border-top: 1px solid var(--lgry);
}
.s-consulting {
    flex-basis: calc(100% / 3);
    flex-shrink: 0;
    border-top: 1px solid var(--lgry);
}
.s-owner .ttl-nvy,
.s-consulting .ttl-nvy {
    padding: 18px 0;
    margin-bottom: 0
}
.top-s-bnr {
    color: var(--blk);
    text-decoration: none
}
.top-s-bnr:hover {
    color: var(--gry)
}
.top-s-bnr span {
    overflow: hidden;
    display: block;
    width: 100%;
    aspect-ratio: 1.7794/1
}
.top-s-bnr span img {
    transform: scale(1);
    transition: .4s
}
.top-s-bnr:hover span img {
    transform: scale(1.1)
}
.top-s-bnr .ttl {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: max(2%,10px) max(5%,15px) 0;
    font-size: var(--tl);
    font-weight: 700
}
.top-s-bnr .ttl::after {
    content: "\e879";
    flex-shrink: 0;
    font-family: 'Material Symbols Outlined';
    font-weight: normal;
    font-size: 21px;
    color: var(--dgry);
    transition: .2s
}
.top-s-bnr:hover .ttl::after {
    color: var(--gry)
}
.top-s-bnr p {
    padding-bottom: max(5%,25px);
    font-size: var(--ts)
}
.top-indi {
    width: 86%;
    margin: 4% auto;
}
.top-indi > * + * {
    margin-top:min(5%,25px)
}
.top-indi-bnr {
    background: var(--wht);
    display: flex;
    align-items: stretch;
    color: var(--blk);
    text-decoration: none;
    cursor: pointer
}
.top-indi-bnr:hover {
    color: var(--gry);
}
.top-indi-bnr .ph {
    overflow: hidden;
    flex-shrink: 0;
    width: 35%;
}
.top-indi-bnr .ph img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1/1;
    object-fit: cover;
    transform: scale(1);
    transition: .4s
}
.top-indi-bnr:hover .ph img {
    transform: scale(1.1);
}
.top-indi-bnr .txt {
    position: relative;
    flex-grow: 1;
    padding: 7% 5%;
    font-size: clamp(15px, 1.26vw, 19px);
    font-weight: 700;
    line-height: 1.6
}
.top-indi-bnr .txt strong {
    display: block;
    font-size: clamp(21px, 1.87vw, 28px);
    font-weight: 400
}
.top-indi-bnr .txt img {
    width: 100%;
    margin-top: 8px;
}
.top-indi-bnr .txt::after {
    content: "\e879";
    position: absolute;
    bottom: -.5px;
    right: -.5px;
    font-size: 21px;
    line-height: 1;
    font-family: 'Material Symbols Outlined';
    font-weight: normal;
    color: var(--dgry);
    transition: .2s
}
.top-indi-bnr:hover .txt::after {
    color: var(--gry)
}
/*modal*/
.modal_wrap input {
  display: none;
}
.modal_overlay {
  display: flex;
  justify-content: center;
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  opacity: 0;
  transition: opacity 0.5s, transform 0s 0.5s;
  transform: scale(0);
}
.modal_trigger {
  position: absolute;
  width: 100%;
  height: 100%;
}
.modal_content {
    align-self: center;
    width: 90%;
    padding: 12% 5% 8%;
    box-sizing: border-box;
    background: #fff;
    line-height: 1.4em;
    transition: 0.5s;
}
.modal_content .ttl-nvy {
    display: flex;
    align-items: center
}
.modal_content p {
  padding-top: 0;
}
.modal_menu {
    color: var(--blk);
    line-height: 1.5;
    text-decoration: none
}
.modal_menu:hover {
    color: var(--gry);
}
.modal_menu img {
    margin-bottom: 10px;
    opacity: 1;
    transition: .3s
}
.modal_menu:hover img {
    opacity: .8
}
.close_button {
  position: absolute;
  top: 8px;
  right: 16px;
  font-size: 24px;
  cursor: pointer;
}
.modal_wrap input:checked ~ .modal_overlay {
  opacity: 1;
  transform: scale(1);
  transition: opacity 0.5s;
}
.modal_wrap input:checked ~ .modal_overlay .modal_content {
  transform: translateY(20px);
}

/*news release*/
	
	#newsrelease .es-list-wrapper {
    padding-bottom: 0;
    padding-top: 0;
}
#newsrelease .es-list-items {
    border-top: 1px solid var(--lgry);
}
#newsrelease .es-list-items a {
    position: relative;
    display: block;
    color: var(--blk);
    text-decoration: none
}
#newsrelease .es-list-items a::after {
    content: "\e315";
    position: absolute;
    top: calc(50% - 11px);
    right: min(1%,5px);
    font-size: 22px;
    line-height: 1;
    font-family: 'Material Symbols Outlined';
    font-weight: normal;
    color: var(--dgry);
    transition: .2s
}
#newsrelease .es-list-items a:hover {
    color: var(--gry);
}
#newsrelease .es-list-items a:hover::after {
    right: min(1.74%,20px);
}
#newsrelease .es-list-items .list_content {
    padding: min(5%,25px) min(8%,40px) min(5%,25px) min(2%,10px);
    border-bottom: 1px solid var(--lgry)
}
#newsrelease .es-list-items span {
    display: block;
    font-weight: 700;
}
#newsrelease .es-list-items h3 {
    display: inline;
}

/*=====================================
CV
=====================================*/
.cv {
	margin-top: min(12.5%, 75px);
    padding: min(10%,100px) 0;
    background: var(--nvy);
    color: var(--wht)
}
.cv__wrap {
    margin: 5% auto;
}
.cv__bnr {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px min(2.8%,14px);
    padding: 5%;
    aspect-ratio: 3/1;
    background: var(--wht);
    color: var(--blk);
    font-size: var(--tl);
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none
}
.cv__bnr.tel {
    flex-direction: column
}
.cv__bnr + .cv__bnr {
    margin-top: 5%
}
.cv__bnr span {
    text-align: center
}
.cv__bnr .tag {
    padding: min(1.8%,10px);
    width: 100%;
    background: var(--nvy);
    color: var(--wht);
    font-size: 12px;
    line-height: 1.4
}
.cv__bnr strong {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0 min(2.8%,14px);
    color: var(--nvy);
    font-size: var(--x2l);
    white-space: nowrap
}
.cv__bnr small {
    display: block;
    font-size: var(--ts);
    font-weight: 400
}
.cv__bnr [class^="ic-"] {
    color: var(--blk);
    font-size: 36px;
    transition: .3s
}
.cv__bnr:hover,
.cv__bnr:hover [class^="ic-"] {
    color: var(--gry)
}


/*=====================================
中面
=====================================*/
.pgbnr {
    display: flex;
    align-items: center;
    width: 100%;
    aspect-ratio: 3/1;
    background-position: center center;
    background-repeat: no-repeat
}
.pgbnr h1 {
    padding: 0 min(3%,30px);
    width: 100%;
    color: #fff;
    font-size: var(--tm);
    font-weight: 700;
    letter-spacing: .2em;
    text-align: center;
    text-shadow: rgba(35,35,35,.75) 0 0 6px;
}
.pgbnr.bnr01 {
    background-image: url("/app/uploads/sites/1105/2023/10/img_kashitai.webp")
}
.pgbnr.bnr02 {
    background-image: url("/app/uploads/sites/1105/2023/10/img_service.webp")
}
.pgbnr.bnr03 {
    background-image: url("/app/uploads/sites/1105/2023/10/img_uritai.webp")
}
.pgbnr.bnr04 {
    background-image: url("/app/uploads/sites/1105/2023/12/besthomes_header_sp.webp")
}
.pgbnr.bnr05 {
    background-image: url("/app/uploads/sites/1105/2023/10/img_tokucho.webp")
}
.pgbnr.bnr06 {
    background-image: url("/app/uploads/sites/1105/2023/10/img_topmessage.webp")
}
.pgbnr.bnr07{
    background-image: url("/app/uploads/sites/1105/2023/10/img_companyhistory.webp")
}
.pgbnr.bnr08{
    background-image: url("/app/uploads/sites/1105/2023/10/img_staff.webp")
}
.pgbnr.bnr09{
    background-image: url("/app/uploads/sites/1105/2023/10/img_syukutoku.webp")
}
.pgbnr.bnr10{
    background-image: url("/app/uploads/sites/1105/2023/10/img_sumaisagashi.webp")
}
.pgbnr.bnr11{
    background-image: url("/app/uploads/sites/1105/2023/10/img_heyasagashi.webp")
}
.pgbnr.bnr12{
    background-image: url("/app/uploads/sites/1105/2023/10/img_reform.webp")
}
.pgbnr.bnr13{
    background-image: url("/app/uploads/sites/1105/2023/11/img_reform.webp")
}
.pgbnr.bnr14{
    background-image: url("/app/uploads/sites/1105/2023/10/img_consulting.webp")
}
.pgbnr.bnr15 {
    background-image: url("/app/uploads/sites/1105/2025/05/navy.jpg")
}
.point__num {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: -50px;
    padding-top: 6px;
    width: 70px;
    height: 70px;
    border-radius: 50%;
    color: var(--wht);
    font-size: var(--ts);
    font-weight: 700;
    transform: translateY(-50%)
}
.point__num strong {
    display: block;
    font-size: var(--tm);
}
.point__num span {
    font-weight: normal;
}
.pointTtl {
    font-size: var(--tl);
    font-weight: 700;
    text-align: center
}
.plan {
    display: flex;
    flex-direction: column;
    justify-content: space-between
}
.plan__img {
    margin-top: min(7.5%,50px);
    display: block;
    flex-shrink: 0;
    width: 100%;
    aspect-ratio: 2.2/1;
    object-fit: cover
}
.plan__txt p {
    margin-top: 4%;
}
.plan__logo {
    margin-top: 5%
}
.frame__box {
    padding: 5%;
    border-style: solid;
    border-width: 2px;
    border-color: var(--nvy)
}
.frame__box.wine {
    border-color: var(--wine)
}
.frame__box.grn {
    border-color: var(--grn)
}
.frame__box.gld {
    border-color: var(--gld)
}
.pic__box {
    margin-left: auto;
    margin-right: auto;
    text-align: center
}
.fbox.pic__box {
    gap: 30px min(3%,30px)
}
.pic__box figcaption {
    padding: 10px;
    color: var(--gry);
    font-size: var(--ts)
}
.check__list li {
    position: relative;
    padding: min(.5%,2px) 0 min(.5%,2px) 28px;
    font-size: var(--nm);
}
.check__list li::before {
    content: "";
    display: inline-block;
    position: absolute;
    top: 12px;
    left: 0;
    width: 12px;
    height: 6px;
    border-bottom: 3px solid var(--nvy);
    border-left: 3px solid var(--nvy);
    transform: translate(3px,-4px) rotate(-45deg)
}
.check__list.wine li::before {
    border-bottom: 3px solid var(--wine);
    border-left: 3px solid var(--wine);
}
.check__list.grn li::before {
    border-bottom: 3px solid var(--grn);
    border-left: 3px solid var(--grn);
}
.check__list.gld li::before {
    border-bottom: 3px solid var(--gld);
    border-left: 3px solid var(--gld);
}
.check__list.nvy li::before {
    border-bottom: 3px solid var(--nvy);
    border-left: 3px solid var(--nvy);
}
.more__body {
    display: none
}
.cmn-table {
    border-collapse: collapse
}
.cmn-table th,
.cmn-table td {
    border: 1px solid var(--lgry);
    line-height: 1.5
}
.cmn-table.chart thead th {
    font-size: clamp(10px, 2.8vw, 13px);
    font-weight: 700;
    text-align: center
}
.cmn-table.chart thead th,
.cmn-table.chart thead td {
    padding: 2% 1.5%
}
.cmn-table.chart tbody th {
    text-align: left
}
.cmn-table.chart tbody th,
.cmn-table.chart tbody td {
    padding: 2% 1.5%;
    background-color: var(--wht);
    font-size: clamp(10px, 2.8vw, 13px);
}
.cmn-table.chart td {
    width: 18%;
    text-align: center
}
.cmn-table.chart .ic-next {
    display: inline-block;
    margin-left: 3px;
    transform: translateY(3px) rotate(90deg);
    color: var(--nvy);
    font-size: 16px;
    font-weight: 700
}
.cmn-table.chart .more__body th,
.cmn-table.chart .more__body td {
    background-color: #fcf8de;
    text-align: left
}
.cmn-table.chart tbody tr:nth-child(4n + 3) th,
.cmn-table.chart tbody tr:nth-child(4n + 3) td {
    background-color: var(--pgry)
}

/*=====================================
アンカーリンク
=====================================*/
.anchor-link__list {
    display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

.anchor-link__item:not(:first-child) {
    margin-left: 20px;
}

.anchor-link__item a {
    position: relative;
    display: inline-block;
    padding-right: 20px;
    color: #333;
    text-decoration: none;
    font-size: clamp(13px, 1.26vw, 19px);
}

.anchor-link__item a:after {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-bottom: solid 2px #333;
    border-right: solid 2px #333;
    position: absolute;
    top: 50%;
    right: 0;
    margin-top: -6px;
    transform: rotate(45deg);
}

/*=====================================
会社概要
=====================================*/
.overview__items {
    margin-top: 60px;
}

.overview-item {
    display: flex;
    border-bottom: 1px solid #c9c9cd;
    padding: 20px 0;
}

.overview-item__title {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: #1d1d1e;
    width: 40%;
    margin-left: 10px;
}

.overview-item__text {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.5;
    letter-spacing: 0.025em;
    color: #1d1d1e;
    width: 57%;
    margin-left: 3%;
}

/*=====================================
アクセスマップ
=====================================*/
.accessmap {
    margin-top: 60px;
}

.accessmap__img img {
    width: 100%;
    height: auto;
    aspect-ratio: 950 / 585;
    object-fit: cover;
}

.factory-access {
    margin-top: 60px;
}

.company-place-list__item:not(:first-child) {
    margin-top: 40px;
}

.cmn-section__container {
    display: block;
}

.cmn-section__img {
    width: 100%;;
}

.cmn-section__img img {
    width: 100%;
    height: auto;
    aspect-ratio: 400 / 300;
    object-fit: cover;
}

.cmn-section__contents {
    margin-top: 40px;
}

.cmn-section__title {
    font-size: 23px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.025em;
    color: #243A66;
}

.cmn-section__text {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.5;
    letter-spacing: 0.025em;
    color: #1D1D1E;
    margin-top: 20px;
}

.cmn-section iframe {
    margin-top: 35px;
    width: 100%;
}

/*=====================================
当社の特長
=====================================*/


.cmn-box__container {
    display: block;
}

.cmn-box__container--store .cmn-box__text {
    flex-basis: 52%;
}

.cmn-box__container--store .cmn-box-card {
    flex-basis: 42%;
    width: 100%;
}

.cmn-box__container--store .cmn-box-card__img img {
    aspect-ratio: 400 / 300;
}


.cmn-box__text {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: var(--blk);
}

.cmn-box__img-container {
    display: block;
}

.cmn-box__img-container.cmn-box__img-container--feature {
    margin-top: 35px;
}

.cmn-box-card:not(:first-child) {
    margin-top: 25px;
}

.cmn-box-card__img img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.cmn-box__img-container--feature .cmn-box-card__img:first-child  {
    aspect-ratio: 492 / 260;
}

.cmn-box__img-container--feature .cmn-box-card__img:not(:first-child)  {
    aspect-ratio: 183 / 260;
}

.cmn-box-card__text {
    margin-top: 10px;
    font-size: 13px;
    font-size: none;
    line-height: 1.75;
    color: #8e8e8e;
    text-align: center;
}

.frame__box-container {
    display: block;
}

.frame__box-container.frame__box-container--domain {
    margin-top: 50px;
}

.frame__box-container.frame__box-container--shamaison {
    margin-top: 50px;
    justify-content: space-between;
}

.frame__box-container.frame__box-container--shamaison  .frame__box-text-contents {
    width: 100%;
}

.frame__box-container.frame__box-container--shamaison  .frame__box-img {
    width: 100%;
}

.frame__box-title {
    font-size: 19px;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
}

.frame__box-text {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: var(--blk);
}

.frame__box-text  a {
    color: var(--red);
}

.frame__box-container--domain .frame__box-title:not(:first-child) {
    margin-top: 35px;
}

.frame__box-container--domain .frame__box-text {
    margin-top: 30px;
}

.frame__box-img {
    margin-top: 25px;
}

.frame__box-img img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.frame__box-img-domain img {
    aspect-ratio: 378 / 344;
}

.cmn-box__img-container.cmn-box__img-container--store {
    margin-top: 35px;
}

.cmn-box__img-container--store .cmn-box-card__img  {
    width: 100%;
}

.cmn-box__img-container--store .cmn-box-card__img img {
    aspect-ratio: 330 / 240;
}

.cmn-box iframe {
    width: 100%;
}

.sp-none {
    display: none;
}

/*=====================================
トップメッセージ
=====================================*/
.topmessage-img,.philosophy-innner {
    width: 100%;
 margin-top: min(4.34%, 50px);
    font-size: var(--tl);
    font-weight: 700;
	font-family: 游明朝, YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	text-align:center;
	line-height:1.4;
}
.topmessage-container {
margin-top: min(4.34%, 50px);
}

.topmessage-container__text {
    font-size: var(--nm);
    font-weight: normal;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: var(--blk);
}
.topmessage-container p {
	    font-size: var(--nm);
    font-weight: normal;
    line-height: 1.8!important;
    letter-spacing: 0.05em;
    color: var(--blk);
		margin-bottom:1em!important;
}

.topmessage-container__img {
	padding:1em 0 2em;
	text-align:center;
}
	.topmessage-container__img img {
    width: 100%;
	text-align:center;
}
	

.topmessage-container__img {
    width: 100%;
    margin-top: 20px;
}


.topmessage-image--Management-philosophy {
    margin-top: 40px;
	background-image:url("/app/uploads/sites/1105/2023/10/besthomes-5049-scaled.webp");
	background-repeat:no-repeat;
	background-position: center center;
    background-repeat: no-repeat;
	background-size:cover;
	padding:10px;
}
	.topmessage-image--Management-philosophy .philosophy-innner  {
	background-color: rgba(255,255,255,0.8);
		width:98%;
		max-width:600px;
		margin:0 auto;
		padding:1em 0;
}
		.topmessage-image--Management-philosophy .philosophy-innner h3 {
font-size: var(--nm)!important;
			text-align:center;
			padding:0 0 1em;
			margin:0!important;
			font-weight: 700;
}

.officer-introduction-container__card-img {
    width: 100%;
}

.officer-introduction-container__card-img img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 300 / 300;
}

.officer-introduction-container__card-text {
    font-size: 19px;
    font-weight: normal;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
    text-align: center;
    margin-top: 20px;
}

.officer-introduction-container__text {
    font-size: var(--nm);
    font-weight: normal;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: var(--blk);
    margin-top: 60px;
}

/*=====================================
沿革
=====================================*/

.history-item__timeline {
    color: var(--nvy);
    font-size: var(--tm);
    line-height: 1.75;
    font-weight: 700;
    width: 100%;
}

.history-item__border {
    width: 12.5%;
    border-top: 1px solid #243a66;
    margin-left: 20px;
    margin-top: 30px;
    display: none;
}

.history-item__text {
    position: relative;
    font-size: clamp(12px, 1vw, 15px);
    line-height: 1.75;
    font-weight: normal;
    border-left: 1px solid #d2d2d2;
    padding-left: 23px;
    padding-top: 24px;
    padding-bottom: 24px;
    width: 80%;
}

.history-item__text::before {
    position: absolute;
    content: "";
    background-color: var(--nvy);
    border-radius: 50%;
    top: 27px;
    left: -7px;
    width: 12px;
    height: 12px;
}


/*=====================================
淑徳大学指定店
=====================================*/
.shinnyusei__frame {
    margin-top: 50px;
}

.frame__box-img-contents {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-top: 20px;
}

.frame__box-container.frame__box-container--shinnyusei {
    margin-top: 30px;
}

.frame__box-container.frame__box-container--shinnyusei  .frame__box-img {
    max-width: 185px;
    width: 100%;
    margin-top: 0;
}

.frame__box-container.frame__box-container--shinnyusei  .frame__box-img:not(:first-child) {
    margin-left: 20px;
}

.frame__box-container.frame__box-container--shinnyusei img {
    aspect-ratio: 185 / 260;
}

.cmn-section__container.cmn-section__container--reverse {
    flex-direction: row-reverse;
    margin-top: 35px;
}

.cmn-section__container.cmn-section__container--real-estate  .cmn-section__text:last-child {
    margin-top: 15px;
}

.cmn-section__text-list {
    margin-top: 10px;
}

.cmn-section__text-list li {
    margin-top: 10px;
    font-size: 16px;
    font-weight: normal;
    line-height: 1.5;
    letter-spacing: 0.025em;
    color: var(--blk);
    text-indent: -1em;
    padding-left: 1em;
}

.cmn-section__container.cmn-section__container--consulting  .cmn-section__text:last-child {
    margin-top: 15px;
}

/* 当社管理物件例 */
.property-example {
    margin-top: 50px;
}

.property-example__list {
    display: block;
    margin-top: 40px;
}

.property-example__item:not(:first-child) {
    margin-top: 50px;
}

.property-example-card {
    max-width: 550px;
    width: 100%;
    margin: 0 auto;
}

.property-example-card__img-area {
    display: flex;
}

.property-example-card__img {
    width: 50%;
}

.property-example-card__img img {
    width: 100%;
    height: auto;
    aspect-ratio: 275 / 205;
    object-fit: cover;
}

.property-example-card__text-area {
    background-color: var(--wht);
    padding: min(5%, 20px) min(7%, 30px);
}

.property-example-card__title {
    line-height: 1.75;
    letter-spacing: 0.025em;
    font-weight: 700;
    color: #000;
}


.property-example-card-description-list {
    margin-top: 30px;
}

.property-example-card-description-item {
    display: flex;
}

.property-example__button {
    text-align: center;
    text-align: -webkit-center;
}

.property-example-card-description-item__title, .property-example-card-description-item__text {
    font-size: clamp(15px, 1.26vw, 19px);
    line-height: 1.5;
    letter-spacing: 0.025em;
    font-weight: normal;
    color: #000;
}

.property-example-card-description-item__title {
    width: 25%;
}

.property-example-card-description-item__text {
    width: 80%;
}

/* お部屋のご内見のポイント */
.frame__box-container.frame__box-container--preview {
    flex-direction: row-reverse;
    justify-content: space-between;
}

.frame__box-container.frame__box-container--preview:not(:first-child) {
    margin-top: 30px;
}

.frame__box-container.frame__box-container--preview .frame__box-img {
    width: 100%;
}

.frame__box-container.frame__box-container--preview img {
    aspect-ratio: 240 / 183;
}

.frame__box-container.frame__box-container--preview .frame__box-text {
    margin-top: 30px;
}

.preview-point__button {
    margin-top: 50px;
    text-align: center;
    text-align: -webkit-center;
}

/* 気にいったお部屋が見つかったら・・・ */
.cmn-box__container--favorite .cmn-box-card {
    width: 100%;
}

.cmn-box__container--favorite .cmn-box-card__img img {
    aspect-ratio: 400 / 269;
}

.check__list-title {
    font-size: var(--tl);
}

.check__list-text {
    font-size: var(--tm);
}

/* 契約時にかかる費用は？ 電気・ガス・水道について（共通） */
.contract-price-contents__item:not(:first-child) {
    margin-top: 50px;
}

.contract-cost-contents__item:not(:first-child) {
    margin-top: 50px;
}

.description-item__label {
    font-size: clamp(15px, 1.26vw, 19px);
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
    padding: 20px;
}

.description-item__text {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: var(--blk);
    margin-top: 25px;
    margin-left: 10px;
}

.contract-price__button {
    margin-top: 50px;
    text-align: center;
    text-align: -webkit-center;
}



/* 在校生の方へ */
.cmn-section__container.cmn-section__container--zaikousei .check__list {
    margin-top: 30px;
}

.cmn-section__container.cmn-section__container--zaikousei .cmn-section__text {
    margin-top: 30px;
}

.zaikousei__container {
    margin-top: 50px;
}

.zaikousei__button {
    margin-top: 50px;
    text-align: center;
    text-align: -webkit-center;
}

/*=====================================
共通ボタン
=====================================*/
.button {
    max-width: 420px;
    width: 100%;
    padding: 29px 20px;
    border: 1px solid #d2d2d2;
    background-color: var(--wht);
    display: block;
    color: var(--blk);
    position: relative;
    text-align: left;
    text-decoration: none;
    font-size: clamp(13px, 1.26vw, 19px);
    font-weight: normal;
    line-height: 1.75;
    letter-spacing: 0.025em;
    box-shadow: 0 2px #E2E2E2;
    transition: .3s;
}

.button:hover {
    color: var(--gry);
    box-shadow: none;
}

.button:hover::before {
    background-color: var(--gry);
}

.button::before {
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 20px;
    width: 21.5px;
    height: 21.5px;
    background: var(--blk);
    transition: .3s;
}

.button::after {
    content: "";
    position: absolute;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 29px;
    width: 4px;
    height: 4px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(45deg);
}

/*=====================================
お部屋探しのポイント
=====================================*/

.frame__box-wrapper.frame__box-wrapper--point {
    margin-top: 50px;
}

.frame__box-wrapper--point .frame__box {
    width: 100%;
    padding: 40px 30px;
}

.frame__box-wrapper--point .frame__box:not(:first-child) {
    margin-top: 30px;
}

/*=====================================
住まい探しの流れ
=====================================*/
.cmn-box__img-container.cmn-box__img-container--flow {
    justify-content: center;
}


.cmn-box__img-container--flow .cmn-box-card {
    width: 100%;
}

.flow-contents__items {
    margin-top: 50px;
}

/*=====================================
入居者様へのご案内
=====================================*/
.guidance {
    margin-top: 70px;
}


.guidance__list {
    margin-top: 56px;
}

.guidance__item:not(:first-child) {
    margin-top: 90px;
}

.guidance__item .cmn-box__text {
    margin-top: 40px;
}

.guidance__item .frame__box {
    margin-top: 35px;
}

.guidance__item .cv__bnr {
    background-color: var(--nvy);
    aspect-ratio: 480 / 90;
    border-radius: 8px;
}


.guidance__item .ic-mail {
    color: var(--wht);
}

.guidance__item .cv__bnr.tel {
    background-color: var(--wht);
}

.live-qa__items {
    margin-top: 50px;
}

.live-qa__item:not(:first-child) {
    margin-top: 50px;
}

.live-qa__item .description-item__label  {
    display: flex;
    align-items: center;
}

.live-qa__item .description-item__label span {
    font-size: 23px;
    color: var(--wht);
    font-weight: 700;
    text-transform: uppercase;
    background-color: var(--grn);
    border-radius: 50%;
    padding: 6px 15px;
    max-width: 48px;
    width: 100%;
}

.live-qa__item .description-item__label p {
   margin-left: 20px;
   font-size: clamp(15px, 1.26vw, 19px);
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
}


.live-qa__item .description-item__text  {
    display: flex;
    align-items: center;
    margin-left: 20px;
}

.live-qa__item .description-item__text span {
    font-size: 23px;
    color: var(--wht);
    font-weight: 700;
    text-transform: uppercase;
    background-color: var(--nvy);
    border-radius: 50%;
    padding: 5px 16px;
}

.live-qa__item .description-item__text p {
    margin-left: 20px;
    font-size: 16px;
    font-weight: normal;
    line-height: 1.8;
    letter-spacing: 0.05em;
    color: var(--blk);
}


.guidance__button-container {
    margin-top: 20px;
}

.guidance__button {
    width: 100%;
    text-align: center;
    text-align: -webkit-center;
}

.button.button--guidance {
    display: flex;
    flex-shrink: 0;
}

.button__img {
    max-width: 46px;
    width: 100%;
}

.button__img  img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 46 / 56;
}

.button__text {
    margin-left: 20px;
    font-size: clamp(15px, 1.26vw, 19px);
    letter-spacing: 0.025em;
}

.button__text span {
    font-size: clamp(21px, 1.87vw, 28px);
    line-height: 1.4;
    letter-spacing: 0.025em;
    font-weight: 700;
}

.guidance__button:not(:first-child) {
    margin-top: 30px;
}

.guidance__text-small {
    margin-top: 18px;
    display: block;
    text-align: center;
}

.guidance-container {
    margin-top: 44px;
}

.cmn-section__container.cmn-section__container--guidance .cmn-section__img {
    width: 100%;
}

.cmn-section__container.cmn-section__container--guidance img {
    aspect-ratio: 382 / 45;
}

.cmn-section__container.cmn-section__container--guidance .cmn-section__text {
    margin-top: 0;
}

.cmn-section__container.cmn-section__container--guidance:not(:first-child) {
    margin-top: 48px;
}

/*=====================================
賃貸管理・賃貸仲介サービス
=====================================*/

.renntal {
    margin-top: 70px;
}

.customer-opinion {
    margin-top: 60px;
    padding-top: 30px;
    padding-bottom: 0;
}

.customer-opinion_list {
    margin-top: 40px;
}

.customer-opinion-box-items {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
}

.customer-opinion__img {
    max-width: 342px;
    width: 100%;
    margin: 0 auto;
}

.customer-opinion__img img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 320 / 143;
}

.besthomes-answer__frame {
    margin-top: 75px;
}

.frame__box-container.frame__box-container--besthomes-answer img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 1035 / 560;
}



/*=====================================
共通パーツ
=====================================*/

.customer-opinion-box-item {
    padding: 32px;
    background-color: var(--wht);
    z-index: 0;
}

.customer-opinion-box-item__text {
    font-size: 19px;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
    text-align: center;
}

.triangle__img {
    max-width: 143px;
    width: 100%;
    margin: 0 auto;
}

.triangle__img  img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 270 / 90;
}

.flow-box-item {
    padding: 50px 30px;
    background-color: var(--wht);
    position: relative;
}

.flow-box-item:not(:last-child)::after {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    border-right: 4px solid #D0D0D0;
    border-top: 4px solid #D0D0D0;
    display: inline-block;
    bottom: -45px;
    right: 50%;
    transform: rotate(135deg);
}

.point__num.point__num--flow {
    position: absolute;
    content: "";
    top: 0;
    left: -25px;
    width: 80px;
    height: 80px;
    font-size: 14px;
    line-height: 1.28;
}

.flow-box-item__title.ttl-nvy {
    margin-top: 0;
}

.flow-box-item__container-title, .flow-box-item__container-text , .flow-box-item__text  {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.8;
    letter-spacing: 0.025em;
    color: var(--blk);
}

.flow-box-item__container-title {
    font-weight: 700;
}

.flow-box-item__container-text-wrapper {
    margin-top: 20px;
}

.flow-box-item__container-text {
    text-indent: -1em;
    padding-left: 1em;
}

.flow-box-item__text {
    margin-top: 25px;
}

.flow-box-item__container {
    margin-top: 15px;
    display: block;
}

.flow-box-item__container.flow-box-item__container--sell {
    text-align: center;
    text-align: -webkit-center;
}

.flow-box-item__img:not(:first-child) {
    margin-top: 17px;
}

.flow-box-item__img.flow-box-item__img--homes {
    max-width: 127px;
    width: 100%;
}

.flow-box-item__img.flow-box-item__img--homes img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 127 / 38;
}
.flow-box-item__img.flow-box-item__img--athome {
    max-width: 120px;
    width: 100%;
}

.flow-box-item__img.flow-box-item__img--athome img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 120 / 26;
}
.flow-box-item__img.flow-box-item__img--sumo {
    max-width: 129px;
    width: 100%;
}

.flow-box-item__img.flow-box-item__img--sumo img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 129 / 49;
}
.flow-box-item__img.flow-box-item__img--yahoo {
    max-width: 120px;
    width: 100%;
}

.flow-box-item__img.flow-box-item__img--yahoo img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 120 / 30;
}

.flow-box-item__container-item {
    width: 100%;
}

.flow-box-item__container-item:not(:first-child) {
    margin-top: 30px;
}

.besthomes-partner-item__title {
    font-size: 23px;
    line-height: 1.75;
    font-weight: 700;
    letter-spacing: 0.025em;
    color: var(--blk);
}

.besthomes-partner-item__container {
    display: block;
    margin-top: 30px;
}

.besthomes-partner-item__img {
    width: 100%;
    border: 1px solid #e8e8e8;
}

.besthomes-partner-item__img  img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 234 / 127;
}

.besthomes-partner-item__text {
    width: 100%;
    font-size: 16px;
    line-height: 1.8;
    letter-spacing: 0.05em;
    font-weight: normal;
    color: var(--blk);
    margin-top: 29px;
}

.rental-manage-plan-cards {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
}

.rental-manage-plan-card {
    background-color: var(--wht);
}

.rental-manage-plan-card__title-img {
    width: 100%;
    padding: 18px 20px;
    aspect-ratio: 320 / 52;
}

.rental-manage-plan-card__title-img img {
    width: 100%;
    height: auto;
    object-fit: cover;

}

.rental-manage-plan-card__img {
    width: 100%;

}

.rental-manage-plan-card__img img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.rental-manage-plan-card__contents {
    padding: 24px;
}

.rental-manage-plan-card__title {
    font-size: clamp(18px, 1.26vw, 21px);
    line-height: 1.75;
    letter-spacing: 0.025em;
    font-weight: 700;
    text-align: center;
}

.rental-manage-plan-card__text {
    font-size: clamp(15px, 1.07vw, 16px);
    line-height: 1.8;
    letter-spacing: 0.05em;
    font-weight: normal;
    color: var(--blk);
    margin-top: 10px;
}

.triangle__img.triangle__img--induct {
    max-width: 143px;
    width: 100%;
    margin-top: 40px;
}

.triangle__img.triangle__img--induct  img {
    width: 100%;
    height: auto;
    object-fit: cover;
}


.real-estate-sell-items {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
}

.real-estate-sell-item {
    width: 100%;
    padding: 44px 30px;
    background-color:var(--wht);
}

.real-estate-sell-item__content:not(:first-child) {
    margin-top: 6px;
}

.real-estate-sell-item__title {
    font-size: clamp(15px, 1.26vw, 19px);
}

.real-estate-sell-item__tag, .real-estate-sell-item__text {
    display: inline-block;
    font-size: 12px;
    line-height: 1.8;
    letter-spacing: 0.05em;
    font-weight: normal;
    color: var(--blk);
}

.real-estate-sell-item__tag {
    padding: 7px 5px;
    background-color: var(--pgry);

}

.real-estate-sell-item__text {
    margin-left: 12px;
}

.real-estate-sell-item__text.txt-wine {
    font-size: var(--tm);
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
}

.real-estate-sell-item__text.txt-wine span {
    font-size: 28px;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
}

.form-button {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 600px;
    width: 100%;
    background-color: var(--gld);
    text-decoration: none;
    padding: 35px;
    border-radius: 10px;
}

.form-button__img {
    max-width: 30px;
    width: 100%;
}

.form-button__img img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 36 / 36;
}

.form-button__text {
    font-size: var(--tl);
    line-height: 1.75;
    font-weight: 700;
    letter-spacing: 0.025em;
    color: var(--wht);
    margin-left: 15px;
}

/* 賃貸管理委託契約の流れ */

.rental-flow__items {
    margin-top: 70px;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 75px;
}


/* 信頼の証・パートナー事業 */

.besthomes-partner__items {
    margin-top: 67px;
    display: block;
}

.besthomes-partner__item:not(:first-child) {
    margin-top: 30px;
}

/* オーナー様のご要望にあわせて選べる３つの賃貸管理プラン */

.rental-manage-plan__cards {
    margin-top: 62px;
}

.rental-manage-plan__button {
    margin-top: 63px;
    text-align: center;
    text-align: -webkit-center;
}

/*=====================================
不動産購入・売却
=====================================*/

.besthomes-answer .ttl-nvy {
    font-size: clamp(21px, 1.87vw, 28px);
    margin-top: 50px;
}

.real-estate {
    margin-top: 70px;
}

.real-estate .lead {
    margin-top: 60px;
}

.real-estate-sell__items {
    margin-top: 60px;
}

.real-estate-sell-item__contents {
    margin-top: 15px;
}

.real-estate-sell-item__content {
    max-width: 300px;
    margin: 0 auto;
    width: 100%;
    text-align: left;
}

.induction-assessment__form-button {
    margin-top: 35px;
    text-align: center;
    text-align: -webkit-center;
}

.sell-flow__items {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 65px;
}

.sell-flow__text {
    margin-top: 35px;
    font-size: 13px;
    line-height: 1.75;
    color: var(--blk);
}

.induction-contact .frame__box {
    margin-top: 45px;
}

.induction-assessment .txt-nvy {
    text-align: center;
}

.induction-contact .txt-nvy {
    text-align: center;
}

/*=====================================
リフォーム
=====================================*/

.reform {
    margin-top: 70px;
}

.reform-todo__list {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 40px;
    margin: 0 auto;
    margin-top: 40px;
	    width: 100%;
    display: flex;
    flex-wrap: wrap;
}

.reform-todo-box-item {
    width: 44%;
    height: 100%;
    background-color: var(--wht);
    padding: 40px 33px;
}

.reform-todo-box-item__img {
    max-width: 78px;
    width: 100%;
    margin: 0 auto
}

.reform-todo-box-item__img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 78 / 78;
}

.reform-todo-box-item__text {
    margin-top: 20px;
    font-size: 17px;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
    font-weight: 700;
    text-align: center;
}

.reform-todo__list.reform-todo__list--trouble {
    margin-top: 40px;
    margin-right: auto;
    margin-left: auto;
    grid-template-columns: repeat(1, 1fr);
    width: 100%;
}

.reform-up .lead {
    margin-top: 50px;
}

.reform-up__container {
    margin-top: 48px;
    width: 100%;
    margin-right: auto;
    margin-left: auto;
}

.reform-up__text {
    font-size: 19px;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
    font-weight: 700;
    text-align: center;
}

.reform-up__items {
    margin-top: 28px;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 84px;
}

.reform-up-item {
    padding: 27px;
    font-size: var(--tm);
    position: relative;
}

.reform-up-item:last-child {
    display: flex;
    align-items: center;
    justify-content: space-around;
}

.reform-up-item:not(:last-child)::after {
    content: "";
    position: absolute;
    width: 20px;
    height: 20px;
    border-right: 4px solid #D0D0D0;
    border-top: 4px solid #D0D0D0;
    display: inline-block;
    bottom: -45px;
    right: 50%;
    transform: rotate(135deg);
}

.reform-up-item__img {
    max-width: 123px;
    width: 100%;
    margin-left: 15px;
}

.reform-up-item__img img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 123 / 106;
}

.customer-opinion.customer-opinion--card {
    margin-top: 0;
    padding: 100px 0;
}

.customer-opinion-box-item__container {
    margin-top: 35px;
}

.customer-opinion-box-item__img {
    max-width: 200px;
    width: 100%;
    border-radius: 50%;
    position: relative;
    margin: 0 auto;
    margin-top: 20px;
}

.customer-opinion-box-item__img::after {
    content: "";
    position: absolute;
    background-color: var(--pgry);
    width: 220px;
    height: 220px;
    border-radius: 50%;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
}

.customer-opinion-box-item__img img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 140 / 140;
    border-radius: 50%;
}

.customer-opinion-box-item__description {
    width: 100%;
    font-size: 16px;
    line-height: 1.8;
    font-weight: normal;
    letter-spacing: 0.05em;
    color: var(--blk);
    margin-top: 25px;
}
/*リノベーション事例  */
.renovation-case-item {
    position: relative;
}

.renovation-case__item:not(:first-child) {
    margin-top: 60px;
}

.renovation-case-item__title-wrapper {
    padding-bottom: min(1.667%,25px);
    border-bottom:  1px solid var(--lgry);
}

.point__num.point__num--renovation {
    position: absolute;
    content: "";
    top: 30px;
    left: 0;
    width: 80px;
    height: 80px;
    font-size: 14px;
    line-height: 1.28;
    padding-top: 0;
}


.renovation-case-item__title.ttl-nvy {
    line-height: 1;
    font-size: 24px;
    padding-left: 100px;
    text-align: left;
}

.renovation-case-item__title span {
    font-size: 23px;
    line-height: 1.75;
    font-weight: normal;
    letter-spacing: 0.05em;
    text-transform: capitalize;
}

.renovation-case-item__title .no-capitalize {
    text-transform: none;
}

.renovation-case-item__container {
    margin-top: 40px;
}

.renovation-case-item__img.renovation-case-item__img--horizontal {
    width: 100%;
    position: relative;
}

.renovation-case-item__img.renovation-case-item__img--horizontal img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 400 / 300;
}

.renovation-case-item__img.renovation-case-item__img--vertical {
    width: 100%;
    position: relative;
	}
	
	
	
	.besthomes-answer .frame__box {
    margin-top: 60px;
}

.cv.cv--reform {
    background-color: #3D789F;
}

.cv--reform .bh-logo {
    display: block;
    margin: 0 auto 25px;
}

.cv-container-img-list {
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
}

.cv-container-img-list iframe {
    max-width: 400px;
    width: 100%;
    margin-top: 25px;
}

.cv-container-overview-list {
    width: 100%;
    margin-top: 50px;
}

.overview-item--cv .overview-item__title {
    color: var(--wht);
}

.overview-item--cv .overview-item__text {
    color: var(--wht);
}

/*=====================================
土地・不動産活用コンサルティング
=====================================*/

.consulting {
    margin-top: 70px;
}

.besthomes-answer__img-container {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 50px;
}

.besthomes-answer__container-img {
    width: 100%;
}

.besthomes-answer__container-img img {
    width: 100%;
    height: auto;
    object-fit: contain;
    aspect-ratio: 338 / 254;
}



.besthomes-answer__frame-container {
    margin-top: 55px;
}

.besthomes-answer__frame-container .ttl-cmn {
    font-size: var(--tm);
    text-align: center;
}

.besthomes-answer__frame-container .frame__box {
    padding: 43px 22px;
}

.besthomes-answer__frame-container .frame__box:not(:first-child) {
    margin-top: 35px;
}

.consulting-todo__list {
    margin-top: 60px;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 48px;
}

.consulting-todo-box-item {
    padding: 37px 30px;
    background-color: var(--wht);
    position: relative;
    z-index: 0;
}

.consulting-todo-box-item__wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
}


.consulting-todo-box-item__img {
    max-width: 40px;
    width: 100%;
    border-radius: 50%;
    position: relative;
}

.consulting-todo-box-item__img::after {
    content: "";
    position: absolute;
    background-color: var(--pgry);
    width: 64.41px;
    height: 63.41px;
    border-radius: 50%;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
}

.consulting-todo-box-item__img img {
    width: 100%;
    height: auto;
    object-fit: contain;
    aspect-ratio: 35 / 25;
}

.consulting-todo-box-item__title {
    font-size: 23px;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.025em;
    color: var(--blk);
    margin-left: 18px;
}

.consulting-todo-box-item__text {
    font-size: 16px;
    line-height: 2.4;
    font-weight: normal;
    letter-spacing: 0.05em;
    color: var(--blk);
    margin-top: 18px;
}

.customer-opinion.customer-opinion--consulting {
    padding-bottom: 30px;
}

.customer-opinion--consulting .customer-opinion_list {
    margin-bottom: 70px;
}

/*物件*/
.es_result_block .main_column, .es_result_block .sidebar {
    width: 96%;
    margin: 0 auto;
}
.es-normal-title-enabled #page header {
    width: 96%!important;
}
	
	/*サイトマップ*/
.entry-content #original .sitemap .ttl-nvy,
.entry-content #original .privacy .ttl-nvy{
		padding-bottom:10px;
	}
	
.entry-content #original .sitemap ul {
		border-top:solid 1px #ccc;
		line-height:1.8;
	}
.entry-content #original .sitemap ul li{
		border-bottom:solid 1px #ccc;
		padding:0.5em;
	}
.entry-content #original .sitemap ul li a {
		position: relative;
	padding-left:30px;
	display:block;
	}
.entry-content #original .sitemap ul li a::before {
content: "\e315";
position: absolute;
top: calc(50% - 11px);
left : 5px;
font-size: 22px;
line-height: 1;
font-family: 'Material Symbols Outlined';
font-weight: normal;
color: var(--dgry);
transition: .2s
}
}