@charset "utf-8";
/* CSS Document */

body {
margin: 0;
font-family: "Helvetica Neue", Arial, sans-serif;
background-color: #fff;
color: #333;
}

a{
transition: .6s;
text-decoration: none;
}
a:hover{
transition: .6s;
}

/***ブラウザクリア***/
h1 {
display: block;
margin-block-start: 0em;
margin-block-end: 0em;
margin-inline-start: 0px;
margin-inline-end: 0px;
font-weight: bold;
unicode-bidi: isolate;
}
h2 {
display: block;
margin-block-start: 0em;
margin-block-end: 0em;
margin-inline-start: 0px;
margin-inline-end: 0px;
font-weight: bold;
unicode-bidi: isolate;
}
h3 {
display: block;
font-size: 0em;
margin-block-start: 0em;
margin-block-end: 0em;
margin-inline-start: 0px;
margin-inline-end: 0px;
font-weight: bold;
unicode-bidi: isolate;
}
ul {
display: block;
list-style-type: none;
margin-block-start: 0;
margin-block-end: 0;
padding-inline-start: 0px;
unicode-bidi: isolate;
}
p {
display: block;
margin-block-start: 0em;
margin-block-end: 0em;
margin-inline-start: 0px;
margin-inline-end: 0px;
unicode-bidi: isolate;
}

/* レイアウト全体を横並び */
.layout {
display: flex;
min-height: 100vh;
}
/***************************
　サイドバー
****************************/
#header_sp{
display: none;
}

#header.site-header{
position: fixed;
left: 0;
top: 0;
min-width: 300px;
max-width: 16vw;
height: 100vh;
display: flex;
justify-content: flex-start;
align-items: center;
flex-direction: column;
background-color: #fff;
color: white;
padding-top: 48px;
}

#header .header-inner {
width: 90%;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
#header .header-contents{
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
flex-grow: 1;
text-align: center;
border-radius: 20px;
box-shadow: 1px 1px 4px 4px rgba(0, 0, 0, 0.08);
padding-bottom: 12px;
}
#header h1.site-title{
position: relative;
padding: 2vh 0;
margin: 0;
display: flex;
justify-content: center;
}
#header .site-title::after {
content: "";
position: absolute;
bottom: 0;
left: 50%;
transform: translateX(-50%);
width: 90%;
height: 2px;
background-color: #EC6B19;
}
#header .site-title a:hover{
opacity: .6;
}
#header .site-title img.logo {
width: 90%;
max-width: 80%;
height: auto;
display: block;
margin: 0 auto;
}
#header .global-nav{
width: 90%;
}
#header .global-nav ul {
list-style: none;
padding: 0;
margin: 0;
width: 100%;
display: flex;
flex-direction: column;
gap: .5rem;
}
#header .global-nav ul li {
border-bottom: 1px solid #EC6B19;
padding-bottom: 0.5rem;
}
#header .global-nav ul li:last-child {
border-bottom: none;
margin-bottom: 0;
}
#header .global-nav li a {
color: #000;
font-size: 1.8vh;
text-decoration: none;
font-weight: bold;
text-align: left;
display: block;
padding: 0.5rem 0;
}

#header .global-nav li a span{
font-size: 80%;
font-weight: normal;
color: #666;
transition: .6s;
}
#header .global-nav li a:hover {
color: #EC6B19;
border-radius: 5px;
transition: .6s;
}
#header .global-nav li a:hover span{
color: #EC6B19;
transition: .6s;
}

#header .header-btn_wrap {
display: block;
width: 100%;
margin: 0 auto;
margin-top: auto;
padding-top: 2vh;
display: flex;
flex-direction: column;
gap: 1.2vh;
}

#header a.header-btn{
display: flex;
align-items: center;
font-size: 1.8vh;
text-align: center;
color: #fff;
font-weight: bold;
text-decoration: none;
padding: 2vh 24px;
border-radius: 50px;
box-sizing: border-box;
transition: .6s;
box-shadow: 0px 0px 2px 2px rgba(0, 0, 0, 0.1);
}

#header a.header-btn::before{
content: "";
display: inline-block;
background: url(./img/icon-doc.png) no-repeat;
background-size: contain;
width: 1.5rem;
height: 1.5rem;
margin-right: 12px;
}

#header a.header-btn.cont::before{
content: "";
display: inline-block;
background: url(./img/icon-contact.png) no-repeat;
background-size: contain;
}

#header a.header-btn.info{
background-color: #1393D2;
}
#header a.header-btn.cont{
background-color: #EC6B19;
}
#header a.header-btn:hover {
opacity: .6;
transition: .6s;
}

#header .sidebar-btn img {
width: 20px;
height: 20px;
object-fit: contain;
}
/***************************
　サイドバー
****************************/

/***************************
　フロートボタン
****************************/
.float_btn{
display: none;
}


/***************************
　フロートボタン
****************************/



/***************************
　コンテナ
****************************/
#container{
display: flex;
flex-wrap: wrap;
width: 100%;
gap: 0;
}

#container .side{
min-width: 300px;
max-width: 16vw;
height: 100vh;
}

/***************************
　コンテンツ
****************************/
.contents {
display: block;
width: auto;
background-color: #fff;
padding: 48px 24px 0;
box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
flex: 1;
}

/* コンテンツ領域 */
.content_inner{
width: 100%;
max-width: 1200px;
margin: 0 auto;
}

/* メインビジュアル */
#mainvisual.main{
position: relative;
width: 100%;
background-color: #ffc77d;
height: 60vh;
border-radius: 20PX;
margin: 0px auto 48px;
}

#mainvisual.main .mv-contain{
position: absolute;
width: 33vw;
top: 50%;
left: 5%;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-ms-transform: translateY(-50%);
}

#mainvisual.main img.sitetitle{
width: 90%;
}
#mainvisual.main p.main_text{
font-size: 1.1vw;
text-align: justify;
margin: 40px 0 0 0;
}
#mainvisual.main img.mainvisual{
position: absolute;
width: auto;
height:100%;
right: 5%;
top: 0;
bottom: 0;
margin: auto 0;
}

@media screen and (max-width: 1400px){
#mainvisual.main img.mainvisual{
width: 40%;
height:auto;
}
}

/***************************
　検索・タグ
****************************/
#search.search-section {
display: flex;
gap: 3rem;
justify-content: space-between;
align-items: flex-start;
flex-wrap: wrap;
margin: 3rem  auto;
}

#search .search-wrap,
.tag-wrap {
flex: 1;
min-width: 280px;
}

#search h3{
display: flex;
align-items: center;
font-size: 1rem;
margin-bottom: 1rem;
font-weight: 400;
}
#search h3::before{
content: "";
display: inline-block;
background: url(./img/icon-serch.png) no-repeat;
background-size: contain;
width: 1.5rem;
height: 1.5rem;
margin-right: 12px;
}

#search h3 strong{
font-size: 120%;
font-weight: bold;
}

#search .search-form {
display: flex;
gap: 1rem;
}

#search .search-form input {
flex: 1;
padding: 1rem;
border: 2px solid #EC6B19;
border-radius: 10px;
font-size: 1rem;
}

#search .search-form button {
background-color: #EC6B19;
color: white;
border: none;
padding: 1rem 2rem;
border-radius: 10px;
font-weight: bold;
cursor: pointer;
transition: .6s;
}

#search .search-form button:hover {
opacity: 0.6;
transition: .6s;
}

#search .keyword-list {
display: flex;
flex-wrap: wrap;
grid-template-columns: repeat(3, 1fr);
align-items: stretch;
gap: 1rem;
padding: 0;
margin: 0;
list-style: none;
}

#search .keyword-list li.tag{
padding: 12px 18px;
display: block;
border: 1px solid #EC6B19;
border-radius: 12px;
transition: .6s;
}

#search .keyword-list li a {
font-size: 90%;
display: block;
text-align: center;
text-decoration: none;
color: #333;
font-weight: 500;
}

#search .keyword-list li:hover {
background-color: #EC6B19;
}
#search .keyword-list li:hover a{
color: #fff;
transition: .6s;
}

#search .icon {
width: 20px;
height: 20px;
object-fit: contain;
}

/***************************
　記事コンテンツ
****************************/
#post-list .section-title {
text-align: center;
margin-bottom: 3rem;
}

#post-list .section-title h2{
font-size: 2.4rem;
font-weight: bold;
margin-bottom: 4px;
}

#post-list .title-line-wrap {
display: flex;
align-items: center;
justify-content: center;
gap: 1rem;
}
#post-list .title-line-wrap .line {
flex: 1;
height: 1px;
background-color: #EC6B19;
}
#post-list .title-line-wrap .en {
color: #EC6B19;
font-weight: bold;
font-size: 140%;
letter-spacing: .1rem;
margin: 0 40px;
white-space: nowrap;
}

#post-list .case-list {
display: flex;
justify-content: center;
flex-wrap: wrap;
gap: 2rem;
/* margin-bottom: 3rem; */
margin-bottom: 1.5rem;
}

#post-list .case-item {
background-color: #fff;
border-radius: 20px;
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
overflow: hidden;
display: flex;
flex-wrap: wrap;
/* width: 480px; */
width: 100%;
height: auto;
text-align: left;
align-items: center;
}

#post-list .case-thumbnail {
/* width: 100%; */
width: 40%;
aspect-ratio: 1.91 / 1;
background: url(./img/no-image.jpg) no-repeat;
background-size: cover;
background-position: center;
display: block;
}

#post-list .case-text {
/* width: 100%; */
width: 60%;
padding: 24px;
box-sizing: border-box;
}

#post-list .case-text h3 {
font-size: 1.2rem;
margin-bottom: 1.5rem;
font-weight: bold;
overflow: hidden;
display: -webkit-box;
text-overflow: ellipsis;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
}

#post-list .case-text p {
display: inline-block;
font-size: .9rem;
line-height: 1.6;
color: #999;
overflow: hidden;
display: -webkit-box;
text-overflow: ellipsis;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
}


#post-list .button_more {
text-align: center;
letter-spacing: .1em;
}
#post-list .button_more .btn-outline{
display: inline-block;
width: 90%;
max-width: 300px;
border: 1px solid #EC6B19;
color: #EC6B19;
padding: 16px;
border-radius: 30px;
text-decoration: none;
transition: .6s;
}

#post-list .button_more a{
position: relative;
}
#post-list .button_more a::after{
content: "";
position: absolute;
top: 0;
bottom: 0;
right: 27px;
width: 9px;
height: 9px;
margin: auto;
border-top: 2px solid #EC6B19;
border-right: 2px solid #EC6B19;
transform: rotate(45deg);
box-sizing: border-box;
}

#post-list .button_more .btn-outline:hover {
background-color: #EC6B19;
color: #fff;
transition: .6s;
}
#post-list .button_more .btn-outline:hover::after{
content: "";
border-top: 2px solid #fff;
border-right: 2px solid #fff;
transition: .6s;
}

/* 最新記事 */
#post-list .news-container {
padding: 4rem 2rem;
}

#post-list .news-grid {
display: flex;
gap: 2rem;
margin-bottom: 3rem;
}

#post-list .main-news {
width: 40%;
}

#post-list .main-news .thumnail-wrap {
background: #ccc;
border-radius: 16px;
height: auto;
position: relative;
}

#post-list .main-news .thumnail-wrap,
#post-list .news-item .thumnail-wrap {
background-color: #ccc;
aspect-ratio: 16 / 9;
border-radius: 16px;
overflow: hidden;
position: relative;
width: 100%;
}

#post-list .main-news .thumnail-wrap img.thum-image,
#post-list .side-news .thumnail-wrap img.thum-image
{
object-fit: cover;
width: 100%;
height: 100%;
aspect-ratio: 16/9;
display: block;
}

#post-list .icon_new {
position: absolute;
top: 16px;
left: 16px;
background: #EC6B19;
color: white;
aspect-ratio: 1/1;
font-size: 80%;
border-radius: 50%;
width: 48px;
display: flex;
align-items: center;
justify-content: center;
}

#post-list .main-news .meta {
margin-top: 16px;
}

#post-list .meta span.category {
border: 1px solid #EC6B19;
padding: 6px 24px;
font-size: 90%;
border-radius: 10px;
margin-bottom: 12px;
display: inline-block;
color: #EC6B19;
}

#post-list .meta .date {
display: block;
font-size: 90%;
color: #999;
}

#post-list h3 {
font-size: 1.2rem;
margin-top: 8px;
font-weight: bold;
color: #333;
}

#post-list .side-news {
width: 60%;
display: flex;
flex-wrap: wrap;
gap: 24px;
}
#post-list .news-item {
display: flex;
gap: 16px;
}

/***************************
　CTA
****************************/
#cta.cta-container {
background: url(./img/cta_bg.jpg) no-repeat;
background-size: cover;
padding: 0;
text-align: center;
border-radius: 10px;
}

#cta h2 {
font-size: 1.8rem;
margin: 0 auto;
padding: 24px 0;
}
#cta h2 span {
font-size: 130%;
color: #EC6B19;
font-weight: bold;
}

#cta .cta-inner {
display: flex;
width: 85%;
margin: 0 auto;
background: #feeaca;
border-radius: 12px;
padding: 40px 40px;
flex-wrap: wrap;
margin-bottom: 24px;
}
#cta .cta-inner p.lead {
font-size: 1.6rem;
font-weight: bold;
text-align: center;
margin: 0 auto 40px;
}

#cta .cta-inner .flex_box{
display: flex;
justify-content: space-between;
width: 100%;
margin: 0 auto;
gap: 5%;
}

/* お悩みリスト */
#cta .problem-list {
width: 50%;
display: flex;
flex-wrap: wrap;
gap: 16px;
border-radius: 10px;
}

#cta p.problem {
display: block;
width: 100%;
font-size: 110%;
line-height: 1.6;
background: #ff8828;
color: #fff;
padding: 16px 0;
border-radius: 8px;
margin: 0;
}

/* プロフィール */
#cta .profile-box {
width: 50%;
background: #fff8ee;
padding: 24px 40px 16px 40px;
border-radius: 16px;
position: relative;
font-size: 90%;
line-height: 1.8;
color: #333;
text-align: left;
display: flex;
flex-direction: column;
align-items: flex-end;
justify-content: flex-end;
gap: 0;
}

/* 吹き出しラベル */
#cta .profile-box .label {
position: absolute;
top: -24px;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
background: #f8cd3c;
color: #333;
font-size: 80%;
font-weight: bold;
padding: 8px;
width: 50%;
text-align: center;
border-radius: 20px;
}

#cta .profile-box .label::after {
content: "";
position: absolute;
bottom: -12px;
right: 0;
left: 0;
margin: 0 auto;
width: 0;
height: 0;
border: 6px solid transparent;
border-top-color: #f8cd3c;
}

#cta .profile-box p.name{
width: 100%;
margin-bottom: 16px;
line-height: 1.4;
}
#cta .profile-box p.name span{
font-size: 120%;
font-weight: bold;
display: block;
}

#cta .profile-box p.bio {
text-align: justify;
font-size: 80%;
line-height: 1.6;
}
#cta .profile-box p.bio span{
font-weight: bold;
display: block;
font-size: 120%;
color: #EC6B19;
}

/* CTAボタン */
#cta .button_cta {
width: 100%;
}
#cta .button_cta a{
display: block;
width: 100%;
max-width: 100%;
background: #EC6B19;
color: #fff;
padding: 24px 0;
font-size: 140%;
font-weight: bold;
border-radius: 0 0 12px 12px;
text-align: center;
text-decoration: none;
box-sizing: border-box;
}
#cta .button_cta a span{
position: relative;
letter-spacing: .1rem;
}
#cta .button_cta a span::after{
content: "";
position: absolute;
top: 0;
bottom: 0;
right: -24px;
width: 9px;
height: 9px;
margin: auto;
border-top: 2px solid #fff;
border-right: 2px solid #fff;
transform: rotate(45deg);
box-sizing: border-box;
}

#cta .button_cta a:hover {
opacity: .6;
}
/***************************
　コンテンツ
****************************/

/***************************
　フッター
****************************/
#footer{
margin-top: 64px;
}
#footer.site-footer {
background: #EC6B19;
color: #fff;
padding: 80px 0px 40px;
border-radius: 20px 20px 0px 0px;
font-size: 80%;
}

#footer h2{
font-size: 2rem;
display: flex;
align-items: center;
justify-content: center;
width: 100%;
gap:24px;
text-align: center;
}
#footer h2::before,
#footer h2::after{
content: "";
background: #fff;
flex: 1;
height: 1px;
display: block;
}
#footer h2 span{
display: block;
font-size: 80%;
width: 100%;
font-weight: 400;
text-align: center;
margin-top: 8px;
}

#footer .footer-content {
width: 90%;
max-width: 1200px;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
gap: 2rem;
margin: 64px auto;
}

#footer .footer-info {
flex: 1;
min-width: 240px;
}
#footer .footer-info h3{
font-size: 1.4rem;
font-weight: 400;
line-height: 2;
}
#footer .footer-info p.add{
font-size: 100%;
}

#footer .footer-links {
display: flex;
flex-wrap: wrap;
gap: 16px;
list-style: none;
padding: 0;
margin: 0;
color: #fff;
}
#footer .footer-links li{
width: 30%;
font-size: 80%rem;
}
#footer .footer-links li a {
color: #fff;
text-decoration: none;
transition: .3s;
}
#footer .footer-links li a:hover {
opacity: .6;
transition: .3s;
}

#footer .copy {
border-top: solid 1px #fff;
padding-top: 48px;
}
#footer .copy .copy-container{
width: 90%;
max-width: 1200px;
margin: 0 auto;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}
#footer p.copyright{
font-size: 90%;
width: 50%;
}
#footer .copy ul.bottom-link {
width: 50%;
list-style: none;
display: flex;
justify-content: flex-end;
gap: 10%;
margin: 0;
padding: 0;
}
#footer .copy ul.bottom-link li{
}
#footer .copy ul.bottom-link a {
display: block;
color: #fff;
text-decoration: none;
transition: .3s;
}
#footer .copy .bottom-link a:hover {
opacity: .6;
transition: .3s;
}



/******************************************************
　記事ページ
*******************************************************/
.contents.post{
background: #fff;/**記事表示時背景色**/
}
.breadcrumbs{
width: 90%;
margin: 0 auto 40px;
background: #EC6B19;
border-radius: 50px;
padding: 16px 24px;
}
.breadcrumbs ul{
display: flex;
align-items: center;
gap:12px;
}
.breadcrumbs ul li{
font-size: 80%;
}
.breadcrumbs ul li::after{
content: ">";
color: #fff;
margin-left: 12px;
}
.breadcrumbs ul li a{
color: #fff;
text-decoration: underline;
}
.breadcrumbs ul li:last-child a{
text-decoration: none;
font-weight: bold;
}
.breadcrumbs ul li a:hover{
opacity: .6;
}
.breadcrumbs ul li:last-child::after{
display: none;
}
.breadcrumbs ul li:first-child::before{
content: "⚫︎";
color: #fff;
margin-right: 8px;
}



#post {
max-width: 960px;
margin: 0px auto 64px;
padding: 40px 20px;
font-family: sans-serif;
box-shadow: 1px 1px 8px 4px rgba(0, 0, 0, 0.08);
border-radius: 20px;
}
#post .post_inner{
width: 90%;
margin: 0 auto;
}
#post .post-header {
width: 100%;
height: auto;
}
#post .post-title {
font-size: 2rem;
font-weight: bold;
margin-bottom: 16px;
}

#post .meta {
display: flex;
align-items: center;
justify-content: flex-start;
margin-bottom: 16px;
gap: 12px;
}
#post .meta .date {
display: block;
font-size: 90%;
color: #999;
line-height: 0.5;
}
#post .meta .date::after{
content: "|";
flex-grow: 1;
display: inline-block;
margin-left: 16px;
margin-right: 8px;
}
#post ul.tag{
display: flex;
gap: 12px;
}
#post .tag li {
padding: 1px 14px 2px;
display: block;
border: 1px solid #EC6B19;
border-radius: 12px;
transition: .6s;
}
#post .tag li a{
color: #333;
font-size: 80%;
}
#post .tag li:hover{
background: #EC6B19;
}
#post .tag li:hover a{
color: #fff;
}


#post .author {
display: flex;
align-items: center;
margin: 40px 0;
}
#post .author .image {
width: 60px;
aspect-ratio: 1/1;
border-radius: 50%;
margin-right: 16px;
object-fit: cover;
}
#post .author .info {
display: block;
}
#post .author .company {
font-size: 80%;
color: rgba(0, 0, 0, 0.5);
}
#post .author .author-name {
font-size: 1rem;
}

#post .post-thumbnail {
width: 100%;
aspect-ratio: 16/9;
background: #ccc;
margin-bottom: 32px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 16px;
}
#post .post-thumbnail img {
width: 100%;
height: 100%;
object-fit: cover;
border-radius: 8px;
}

#post .post-section {
width: 100%;
margin: 60px auto;
}

#post h2.post-heading {
font-size: 1.8rem;
font-weight: bold;
border-bottom: 2px solid #ec6b19;
padding-bottom: 8px;
margin-bottom: 32px;
}
#post h3.post-heading {
font-size: 1.4rem;
font-weight: bold;
border-left: solid 6px #EC6B19;
margin: 0 auto 32px;
padding: 4px 0 4px 16px;
}
#post h4.post-heading {
font-size: 1.2rem;
font-weight: bold;
color: #EC6B19;
margin: 0 auto 32px;
}

#post p.text {
font-size: .95rem;
line-height: 1.8;
margin: 0 auto 24px;
padding: 0 16px;
}
#post p.text a{
color: #ec6b19;
text-decoration: underline;
}

#post .post-image {
width: 100%;
height: auto;
background: #ccc;
border-radius: 12px;
margin: 24px 0;
object-fit: cover;
}

.pc { display: block !important; }
.sp { display: none !important; }
@media only screen and (max-width: 1024px) {
.pc { display: none !important; }
.sp { display: block !important; }
}


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

#header.site-header{
display: none!important;
}
#container .side{
display: none;
}
.contents{
margin-top: 80px;
padding: 0px 0px 0;
box-sizing: border-box;
}

/***************************
　ヘッダー
****************************/
#header_sp{
position: fixed;
display: flex;
align-items: center;
justify-content: space-between;
background: #fff;
width: 100%;
height: 80px;
z-index: 999;
overflow: hidden;
box-shadow: 1px 1px 4px 4px rgba(0, 0, 0, 0.08);
}
#header_sp h1.site-title{
position: relative;
padding: 0;
margin: 0;
display: flex;
align-items: center;
justify-content: center;
margin-left: 20px;
height: 100%;
}
#header_sp .site-title a:hover{
opacity: .6;
}
#header_sp .site-title img.logo {
width: auto;
height: 48px;
display: block;
}
#header_sp .hamburger-morph {
position: fixed;
top: 16px;
right: 20px;
z-index: 1000;
width: 48px;
height: 48px;
padding: 0;
border: none;
background: transparent;
cursor: pointer;
}
#header_sp .hamburger-morph__icon {
width: 100%;
height: 100%;
}
#header_sp .hamburger-morph__line {
fill: none;
stroke: #EC6B19;
stroke-width: 6;
transition: stroke-dasharray 600ms cubic-bezier(0.4, 0, 0.2, 1),
stroke-dashoffset 600ms cubic-bezier(0.4, 0, 0.2, 1);
}
#header_sp .hamburger-morph.active .hamburger-morph__line {
stroke: #fff;
}
#header_sp .hamburger-morph__line:nth-child(1) {
stroke-dasharray: 60 207;
}
#header_sp .hamburger-morph__line:nth-child(2) {
stroke-dasharray: 60 60;
}

#header_sp .hamburger-morph__line:nth-child(3) {
stroke-dasharray: 60 207;
}

#header_sp .hamburger-morph.active .hamburger-morph__line:nth-child(1) {
stroke-dasharray: 90 207;
stroke-dashoffset: -134;
}

#header_sp .hamburger-morph.active .hamburger-morph__line:nth-child(2) {
stroke-dasharray: 1 60;
stroke-dashoffset: -30;
}

#header_sp .hamburger-morph.active .hamburger-morph__line:nth-child(3) {
stroke-dasharray: 90 207;
stroke-dashoffset: -134;
}

#header_sp .nav-morph {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100vh;
background: #EC6B19;
clip-path: circle(0% at 50% 50%);
transition: clip-path 0.7s cubic-bezier(0.4, 0, 0.2, 1);
z-index: 900;
}

#header_sp .nav-morph.active {
clip-path: circle(200% at 50% 50%);
}

#header_sp .nav-morph__wrapper {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
height: 100%;
}

#header_sp .nav-morph__list {
width: 90%;
margin: 0;
padding: 0;
list-style: none;
text-align: center;
}

#header_sp .nav-morph__item {
opacity: 0;
transform: translateY(30px);
transition: opacity 0.4s ease, transform 0.4s ease;
}

#header_sp .nav-morph.active .nav-morph__item {
opacity: 1;
transform: translateY(0);
}
.nav-morph.active .nav-morph__item:nth-child(1) { transition-delay: 0.3s; }
.nav-morph.active .nav-morph__item:nth-child(2) { transition-delay: 0.4s; }
.nav-morph.active .nav-morph__item:nth-child(3) { transition-delay: 0.5s; }
.nav-morph.active .nav-morph__item:nth-child(4) { transition-delay: 0.6s; }

#header_sp .nav-morph__item.head_button{
background: #1393D2;
border-radius: 8px;
width: 100%;
display: flex;
align-items: center;
justify-content: center;
padding: 4px 0;
}
#header_sp .nav-morph__item.head_button.doc{
margin-bottom: 8px;
}
#header_sp .nav-morph__item.head_button.cont{
background: #ba5313;
}
#header_sp .nav-morph__item.head_button::before{
content: "";
display: inline-block;
background: url(./img/icon-doc.png) no-repeat;
background-size: contain;
width: 1rem;
height: 1rem;
margin-right: 8px;
}

#header_sp .nav-morph__item.head_button.cont::before{
content: "";
display: inline-block;
background: url(./img/icon-contact.png) no-repeat;
background-size: contain;
}
#header_sp .nav-morph__link {
position: relative;
display: inline-block;
padding: 12px;
font-size: 1rem;
color: #fff;
text-decoration: none;
overflow: hidden;
}
#header_sp .nav-morph__link span.en{
display: block;
font-size: 70%;
opacity: .5;
margin-top: 4px;
}
#header_sp .nav-morph__text,
#header_sp .nav-morph__hover {
display: block;
transition: transform 0.3s ease;
}

/***************************
　フロートボタン
****************************/
.float_btn{
display: flex;
width: 100%;
position: fixed;
margin: 0 auto;
bottom: 0;
z-index: 99;
}

.float_btn a{
color: #fff;
display: block;
width: 50%;
margin: 0 auto;
align-items: center;
justify-content: center;
text-align: center;
padding: 20px 0;
text-decoration: none;
font-size: 3vw;
}

.float_btn a.info{
background-color: #1393D2;
}
.float_btn a.cont{
background: #EC6B19;
}



@media screen and (max-width: 740px){
.float_btn a{
font-size: 3.4vw;
}
}
/***************************
　フロートボタン
****************************/


/***************************
　メインビジュアル
****************************/
#mainvisual.main{
width: 100%;
height: auto;
border-radius: 0px;
margin: 0px auto 48px;
padding: 40px 0;
}
#mainvisual.main .mv-contain{
position: relative;
width: 80%;
top: 0;
left: 0;
transform: translateY(-0%);
-webkit-transform: translateY(-0%);
-ms-transform: translateY(-0%);
margin: 0 auto;
}
#mainvisual.main img.sitetitle{
width: 90%;
max-width: 240px;
}
#mainvisual.main p.main_text{
font-size: .9rem;
margin: 24px 0 0 0;
}
#mainvisual.main img.mainvisual{
position: relative;
display: block;
width: 80%;
height:auto;
right: 0;
margin: 0 auto;
}

/***************************
　コンテンツ
****************************/
.content_inner{
width: 100%;
margin: 0 auto;
padding: 0 24px;
box-sizing: border-box;
}
/***************************
　検索・タグ
****************************/
#search.search-section {
gap: 40px;
margin: 0 auto;
}
#search .search-wrap,
.tag-wrap {
flex: 1;
min-width: 100%;
}
#search h3{
font-size: .9rem;
margin-bottom: 8px;
}
#search h3::before{
content: "";
width: 1.2rem;
height: 1.2rem;
margin-right: 10px;
}
#search .search-form {
display: flex;
gap: 10px;
}
#search .search-form input {
width: calc(100% - 90px);
padding: 4px 16px;
font-size: .9rem;
flex: auto;
}
#search .search-form button {
width: 80px;
padding: 16px 0;
}
#search .keyword-list {
grid-template-columns: repeat(3, 1fr);
align-items: stretch;
gap: 8px;
}
#search .keyword-list li.tag{
padding: 8px 16px;
}
#search .keyword-list li a {
font-size: 80%;
}

/***************************
　記事コンテンツ
****************************/
#post-list{
margin-top: 40px;
}
#post-list .section-title {
margin-bottom: 24px;
}
#post-list .section-title h2{
font-size: 1.6rem;
margin-bottom: 4px;
}
#post-list .title-line-wrap {
gap: 24px;
}
#post-list .title-line-wrap .en {
font-size: 120%;
margin: 0 0px;
}

#post-list .case-list {
gap: 24px;
/* margin-bottom: 24px; */
margin-bottom: 1.5rem;
}
#post-list .case-item {
width: 100%;
height: auto;
text-align: left;
flex-wrap: wrap;
}
#post-list .case-thumbnail {
/* width: 100%; */
width: 40%;
height: auto;
aspect-ratio: 16/9;
}
#post-list .case-text {
/* width: 100%; */
width: 60%;
padding: 16px;
}
#post-list .case-text h3 {
font-size: 1rem;
margin-bottom: 8px;
}
#post-list .case-text p {
font-size: 80%;
-webkit-line-clamp: 3;
}

#post-list .button_more .btn-outline{
width: 90%;
max-width: 200px;
padding: 16px;
font-size: 80%;
}


/* 最新記事 */
#post-list .news-container {
padding: 0;
margin: 40px 0;
}
#post-list .news-grid {
display: flex;
flex-wrap: wrap;
gap: 24px;
margin-bottom: 24px;
}
#post-list .main-news {
width: 100%;
}
#post-list .icon_new {
font-size: 70%;
}
#post-list .meta {
width: 95%;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
margin: 0px auto 0;
gap: 8px;
}
#post-list .main-news .meta{
margin-top: 8px;
}
#post-list .meta span.category {
padding: 6px 24px;
font-size: 90%;
margin-bottom: 0px;
}
#post-list .meta .date {
display: block;
font-size: 80%;
color: #999;
}
#post-list h3 {
width: 100%;
font-size: 1rem;
margin-top: 0px;
}
#post-list .side-news {
width: 100%;
display: flex;
flex-wrap: wrap;
gap: 24px;
}
#post-list .news-item {
flex-wrap: wrap;
gap: 8px;
}

/***************************
　CTA
****************************/
#cta h2 {
font-size: 1rem;
}
#cta h2 span {
display: block;
}

#cta .cta-inner {
width: 90%;
padding: 24px 16px;
margin-bottom: 24px;
box-sizing: border-box;
}
#cta .cta-inner p.lead {
font-size: 1.2rem;
margin: 0 auto 24px;
}
#cta .cta-inner .flex_box{
flex-wrap: wrap;
width: 100%;
gap: 24px;
}

/* お悩みリスト */
#cta .problem-list {
width: 100%;
gap: 16px;
}
#cta p.problem {
font-size: 90%;
padding: 16px;
}

/* プロフィール */
#cta .profile-box {
width: 100%;
padding: 32px 16px 16px 16px;
font-size: 90%;
margin-top: 24px;
}

/* 吹き出しラベル */
#cta .profile-box .label {
font-size: 80%;
width: 60%;
}
#cta .profile-box p.name{
width: 100%;
font-size: .8rem;
}
#cta .profile-box p.name span{
font-size: 120%;
}
#cta .profile-box p.bio {
font-size: 80%;
}
#cta .profile-box p.bio span{
font-size: 120%;
margin-bottom: 4px;
}

/* CTAボタン */
#cta .button_cta a{
font-size: 100%;
}
/***************************
　コンテンツ
****************************/

/***************************
　フッター
****************************/
#footer{
margin-top: 64px;
}
#footer.site-footer {
padding: 64px 0px 24px;
font-size: 80%;
}

#footer h2{
font-size: 1.2rem;
gap:14px;
}
#footer h2 span{
font-size: 80%;
margin-top: 8px;
}

#footer .footer-content {
gap: 24px;
margin: 40px auto;
}
#footer .footer-info h3{
font-size: .9rem;
}
#footer .footer-info p.add{
font-size: 90%;
}
#footer .footer-links {
gap: 16px;
margin-top: 24px;
}
#footer .footer-links li{
width: 100%;
font-size: 100%;
}

#footer .copy {
padding-top: 24px;
}
#footer p.copyright{
order: 2;
font-size: 80%;
width: 100%;
text-align: center;
}
#footer .copy ul.bottom-link {
order: 1;
width: 100%;
gap: 16px;
margin-bottom: 32px;
align-items: center;
justify-content: center;
}


/******************************************************
　記事ページ
*******************************************************/
.breadcrumbs{
width: 100%;
margin: 0 auto 40px;
border-radius: 0px;
padding: 16px 24px;
box-sizing: border-box;
}

#post {
width: 100%;
margin: 0px auto 64px;
padding: 24px 20px;
box-sizing: border-box;
}
#post .post_inner{
width: 100%;
}
#post .post-title {
font-size: 1.6rem;
margin-bottom: 16px;
}
#post .meta {
flex-wrap: wrap;
margin-bottom: 16px;
gap: 12px;
}
#post .meta .date {
font-size: 80%;
}
#post .meta .date::after{
display: none;
}
#post ul.tag{
gap: 8px;
}

#post .author {
flex-wrap: wrap;
margin: 24px 0;
}
#post .author .image {
margin-bottom: 4px;
}
#post .author .name {
font-size: .9rem;
}

#post .post-thumbnail {
margin-bottom: 32px;
}
#post .post-section {
margin: 60px auto;
}
#post h2.post-heading {
font-size: 1.2rem;
}
#post h3.post-heading {
font-size: 1.1rem;
margin: 0 auto 32px;
padding: 4px 0 4px 16px;
}
#post h4.post-heading {
font-size: 1rem;
margin: 0 auto 32px;
}
#post p.text {
font-size: .9rem;
margin: 0 auto 24px;
padding: 0 8px;
}

}