@charset "UTF-8";

/* -----------------------------------------------
FileName: style.css
----------------------------------------------- */
::-webkit-scrollbar {
  width: .5rem;
}

::-webkit-scrollbar-thumb {
  background: #d3a45f;
}

.home #keyWrap {
    position: relative;
    background: url("../../images/key/key.webp") center center no-repeat;
    background-color: rgba(242, 242, 242, 1);
    background-size: cover;
    height: auto;
}

.company .keyWrap {
    background: url("../../images/company/key.webp") center center no-repeat;
    height: 40vh;
    background-size: cover;
}

.home #keyWrap #keyImg {
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 90%);
	padding: 40px 0;
}

.company .keyWrap .keyImg {
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, .4);
}

.home #keyWrap #keyImg article {
    margin: auto;
    width: 100%;
    ;
    /* width: 1156px;*/
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.company .keyWrap .keyImg article {
    justify-content: center;
    display: flex;
    align-items: center;
    height: 100%;

}

.home #keyWrap #keyImg article aside {
    margin: 0 0 0 0;
    /* margin: 0 4% 0 0; */
    width: 50%;
    /**/
    display: flex;
    /**/
    justify-content: center;
    /**/
    text-align: center;
}


.home #keyWrap #keyImg article h1 {
    font-weight: 700;
    font-size: 3.5em;
    line-height: 1.5em;
    margin: 0 0 .3em 0;
    letter-spacing: .08em;
}

.company .keyWrap .keyImg article h1 {
    font-weight: 700;
    font-size: 3em;
    line-height: 1em;
    margin: 0 0 0 0;
    letter-spacing: .08em;
}

.home #keyWrap #keyImg article figure.mock {
    position: relative;
    top: 20px;
    z-index: 40;
    /* left: 4%; */
    width: 50%;
    /**/
}

.company .home #keyWrap #keyImg article figure.mock {
    left: 0;
    width: auto;
    /**/
}

.home #keyWrap #keyImg article figure.mock img {
	width: 45vw
}

.company .home #keyWrap #keyImg article figure.mock img {
    height: auto;
}

.home #keyWrap #keyImg article .kv-merit {
    font-size: 1em;
    font-weight: 700;
    margin: 0 0 1em 0;
}

.home #keyWrap #keyImg article .fv-cta {
    margin-top: 40px;
}

.home #keyWrap #keyImg article .offer {
    color: #E04428;
    font-weight: 700;
	letter-spacing: 0;
    line-height: 1.5;
	font-size: 16px;
	margin-bottom: 2px;
}

.home #keyWrap #keyImg article .btn-request {
    width: 360px;
    text-align: center;
    margin: auto;
	position: relative;
}

.home #keyWrap #keyImg article .btn-request::after {
	content: "";
	display: block;
    position: absolute;
    width: 12px;
    height: 12px;
    right: 25px;
    top: 20px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
}

.home #keyWrap #keyImg article .btn-request a {
    width: 100%;
    color: #fff;
    font-size: 20px;
    font-weight: 400;
    padding: 0.5em 0;
    letter-spacing: .1em;
    border-radius: 30px;
    background: #E04428;
    display: block;
    text-decoration: none;
    box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
	transition: .3s;
}

.company .home #keyWrap #keyImg article .btn-request {
    width: 400px;
    text-align: center;
    margin: auto;
}

.home #keyWrap #keyImg article .microcopy {
    color: #E04428;
    font-weight: 700;
    font-size: 15px;
	letter-spacing: 0;
}

.company .home #keyWrap #keyImg article .btn-request {
    width: 400px;
    text-align: center;
    margin: auto;
}

.home #keyWrap #keyImg article .btn-request a:hover {
    opacity: .8;
}

/* 監修者プロフィール　*/
.tmm .tmm_1_columns .tmm_member {
    margin: 0 auto!important;
    width: 100%!important;
}

.tmm_1_columns .tmm_member .tmm_photo {
    display: inline-block;
    margin: 0!important;
    vertical-align: middle;
}

.tmm .tmm_member .tmm_textblock {
    display: inline-block;
    margin: 0 0 0 2%;
    vertical-align: middle;
    width: 55%;
}

.tmm .tmm_plugin_f .tmm_desc {
    color: #999;
    font-size: .7rem;
    line-height: 1.2rem;
}

.home .lpSwiper {
    margin: 20px 0 60px 0;
}

.home .fnSwiper {
    margin: 0 0 60px 0;
}

.home .swiper-slide {
    width: 370px;
}

.home #aboutArea {
    margin: 0 0 80px 0;
}

.home #brandArea {
    margin: 0 0 50px 0;
    padding: 35px 30px 70px 30px;
    box-sizing: border-box;
}

.home #brandArea ul {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.home #industryArea h3 {
    text-align: center;
    margin: 0 0 2em 0;
    font-size: 20px;
    font-weight: 500;
}

.home #industryArea article {
    display: flex;
}

.home #industryArea article dl {
    width: 33%;
    text-align: center;
    padding: 0;
}

.home #industryArea article dt {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 90px;
    margin: 0;
}

.home #industryArea article dd {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 60px;
    color: #19293a;
    font-weight: 500;
    line-height: 1.5em;
    font-size: 15px;
	letter-spacing: 0.03em;
}
.home #industryArea a {
    text-decoration: underline;
}
.home #industryArea a:hover {
    opacity: .8;
}


.home #reasonArea {
    display: flex;
    justify-content: space-between;
}

.home #reasonArea article {
    width: 345px;
}

.home #reasonArea article figure {
    margin: 0 0 25px 0;
    display: flex !important;
    height: 250px;
    align-items: center;
    justify-content: center;
}

.home #reasonArea article figure.sp {
    display: none !important;
}

.home #reasonArea article figure img {
    border-radius: 10px 0 10px 0;
    max-width: 335px;
    max-height: 250px;
    object-fit: contain;
    object-position: center center;
}

.home #reasonArea article dt {
    text-align: center;
    font-weight: 700;
    font-size: 1.45em;
    margin: 0 0 1em 0;
}

.home #reasonArea article dd {
    color: #424242;
	line-height: 1.8;
}

.column a[href*="case"] figure:after {
    background: #c0934e;
    border-radius: 7px 0 0 0;
    bottom: 0;
    color: #fff;
    content: 'リザービア導入事例';
    display: inline-block;
    padding: .1rem .5rem;
    position: absolute;
    right: 0;
    text-align: center;
    z-index: 1;
}

.caseArea {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    margin: 0 0 16px 0;
}

.case .caseArea {
    justify-content: space-between;
}

.caseArea a {
    display: flex;
    flex-direction: column;
    margin: 0 0 40px 0;
    text-decoration: none;
    width: 48%;
}

.caseArea a figure {
    margin: 0 0 0 0;
    overflow: hidden;
    border-radius: 10px 0 0 0;
}

.caseArea a figure img {
    border-radius: 10px 0 0 0;
    width: 100%;
    height: 214px;
    object-fit: cover;
    object-position: 50% 0;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;
}

.caseArea a:hover figure img {
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}

.caseArea h3 {
    display: block;
    font-size: 1.3rem;
    font-weight: 700;
    margin: 0 0 .5rem;
    width: 100%;
}

.caseArea a aside {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 20px 20px 20px 20px;
    box-sizing: border-box;
    background: #fff;
    flex-grow: 1;
}

.caseArea a aside h3 {
	font-size: 1rem;
	height: 4.8rem;
	line-height: 1.2rem;
	overflow: hidden;
}
.caseArea h4 {
	font-size: 16px;
    line-height: 1.5;
	margin-top: 8px;
	letter-spacing: 0;
}
.caseArea .salon-name {
	font-size: 15px;
	color: #555;
	margin-top: 16px;
	line-height: 1.5;
	letter-spacing: 0;
}

.caseArea a aside dl {
    font-size: 13px;
    line-height: 1.8em;
    text-align: right;
}
.caseArea 

.caseArea a aside dl dt {
	height: 1.2rem;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap
}

.articleList,
.seminar .seminarList article {
    display: flex;
    flex-wrap: wrap;
    margin: 0 0 16px 0;
}

.articleList a.clink,
.seminar .seminarList article a {
    display: flex;
    flex-direction: column;
    margin: 0 30px 30px 0;
    text-decoration: none;
    width: 344px;
}
.articleList.entry h3  {
    font-size: 16px;
    line-height: 1.5;
    padding-top: 8px;
}

.articleList a.clink:nth-child(3n),
.seminar .seminarList article a:nth-child(3n) {
    margin: 0 0 30px 0;
}

.articleList a.clink figure,
.seminar .seminarList article figure {
    margin: 0 0 0 0;
    overflow: hidden;
    border-radius: 10px 0 0 0;
    position: relative;
}

.articleList a.clink figure img,
.seminar .seminarList article figure img {
    border-radius: 10px 0 0 0;
    width: 344px;
/*     height: 230px;
	height: 193px; */
    object-fit: contain;
    object-position: 50% 50%;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;
	background-color: #ddd;
}

.articleList a.clink:hover figure img {
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}

.wp-caption {
    max-width: 100%;
}

.articleList a.clink figure figcaption.ribbon19-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 85px;
    height: 85px;
    overflow: hidden;
    display: block;
}

.articleList a.clink figure figcaption.ribbon19-content .ribbon19 {
    display: inline-block;
    position: absolute;
    padding: 5px 0;
    left: -24px;
    top: 20px;
    width: 160px;
    text-align: center;
    line-height: 16px;
    background: #e94729;
    color: #fff;
    letter-spacing: 0.05em;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    box-shadow: 0 0 0 2px #e94729;
    font-size: .8em;
}

.articleList a.clink figure figcaption.ribbon19-content .ribbon19.end {
    letter-spacing: 0;
    background: #999999;
    box-shadow: 0 0 0 2px #999999;
}


.articleList a.clink aside {
    padding-top: 8px;
}

.articleList a.clink div.cat {
    margin: 0 0 8px 0;
    display: flex;
	display: none;
    flex-wrap: wrap;
}

.articleList a.clink div.cat span {
    display: inline-block;
    line-height: 1em;
    color: #fff;
    background: #282828;
    padding: .6em .8em .5em .8em;
    margin: 0 5px 5px 0;
    font-size: .75em;
    font-weight: 300;
}

/* .articleList a.clink h3, */
aside h3{
    font-size: 1em;
    letter-spacing: .03em;
    line-height: 1.5;
}

#pressArea {
    margin: 0 auto 50px;
    max-width: 90%;
}

#pressArea a {
    display: flex;
    align-items: center;
    text-decoration: none;
    background: #fff;
    border-radius: 10px 0 10px 0;
    padding: 8px 0;
    box-sizing: border-box;
    margin: 0 0 10px 0;
}

#pressArea a header {
    display: flex;
}

#pressArea a time {
    color: #424242;
    margin: 0 2.5em 0 0;
    white-space: nowrap;
    font-size: .95em;
    position: relative;
}

#pressArea a time.new:before {
    content: "NEW";
    position: absolute;
    top: -1.5em;
    left: 0;
    font-size: .8em;
    display: block;
    background: #45b1c9;
    color: #fff;
    line-height: 1em;
    padding: .4em .6em;
    letter-spacing: .2em;
}




#pressArea a .cat {
    min-width: 140px;
}

#pressArea a .cat span {
    display: block;
    color: #fff;
    background: #424242;
    line-height: 1em;
    padding: .8em 1em;
    font-size: .9em;
    border-radius: 5px 0 5px 0;
    margin: 0 0 5px 0;
}

#pressArea a .cat span:last-child {
    margin: 0;
}

#pressArea a h3 {
    line-height: 1.2rem;
    margin: 0 0 0 1rem;
    font-size: .9rem;
}

#pressArea a:hover h3 {
    text-decoration: underline;
}

#posArea {
    display: flex;
    flex-wrap: wrap;
    width: 1170px;
    margin: auto;
}

#posArea article {
    width: 530px;
    margin: 0 40px 30px 0;
}

#posArea article:nth-child(even) {
    margin: 0 0 30px 0;
}

#posArea article figure {
    margin: 0 0 25px 0;
}

#posArea article figure img {
    border-radius: 10px 0 10px 0;
}

#posArea article h3 {
    text-align: center;
    font-weight: 700;
    font-size: 1.6em;
    margin: 0 0 .8em 0;
}

#posArea article p {
    text-align: center;
    font-size: 1.1em;
    color: #19293a;
    margin: 0 0 1.5em 0;
}

/* .function 機能一覧 */
.functionIcons {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 40px;

}

#functionList h2,
.functionIcons h2 {
	display: block;
	font-size: 1.2rem;
	font-weight: 700;
	width: 100%;
}

.functionIcons a {
    text-align: center;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #999;
    width: 16.6%;
    height: 140px;
    box-shadow: 0 0 0 1px #dedede;
    color: #fff;
}

.functionIcons a:nth-child(odd) {
    background: #777;
}

.functionIcons.srv a {
    width: 16.66666%;
    height: 160px;
}
.functionIcons.srv a:nth-of-type(4) {
    display: none;
}

.functionIcons a:hover {
    background: #2847A1;
}

.functionIcons a.soon {
    background: #d7d7d7;
    cursor: default;
}

.functionIcons a.soon:hover {
    background: #d7d7d7;
}

.functionIcons a dl {
    text-align: center;
}

.functionIcons a dt {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 80px;
}

.functionIcons.srv a dt {
    height: 57px;
}

.functionIcons a dd {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    height: 2.3em;
    font-weight: 500;
    line-height: 1.6em;
    font-size: .95em;
}


.function #functionList {
    margin: 60px 0;
}



.function #functionList article {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 64px;
}

.function #functionList article:nth-child(odd) {
    flex-direction: row-reverse;
}

.function #functionList article .pict {
    width: 550px;
    position: relative;
}

.function #functionList article .pict figure.device {
    position: absolute;
    bottom: -20px;
    right: 0;
}

.function #functionList article .pict figure.thum img {
    width: 520px;
    height: auto;
}

.function #functionList article .pict figure.device img {
    max-height: 280px;
    max-width: 330px;
    width: auto;
    height: auto;
}

.function #functionList article:nth-child(even) .pict {
    text-align: right;
}

.function #functionList article:nth-child(even) .pict figure.device {
    right: auto;
    left: 0;
}

.function #functionList article aside.note {
    width: 500px;
}

.function #functionList article aside.note dl {
    display: flex;
    align-items: center;
    margin: 0;
}

.function #functionList article aside.note dl dt {
    width: 60px;
    height: 50px;
    display: flex;
    align-items: center;
}

.functionIcons figure,
.function .note figure {
	height: 100%;
}

.functionIcons figure img {
	height: auto;
	max-height: 100%;
}

.function #functionList article aside.note dl dt img {
    filter: brightness(10%);
    height: 100%;
    width: auto;
}

.function #functionList article aside.note h3 {
    font-size: 1.8em;
    font-weight: 700;
    margin: 0 0 0 .5em;
}

.function #functionList article aside.note p {
    font-size: 1em;
    color: #424242;
    margin: 0 0 16px 0;
    line-height: 2;
}

.function #functionList article aside.note p:last-child {
    margin: 0 0 0 0;
}

.function #functionList article aside.note .more-btn {
    margin: 0 0 0 0;
}

.solution #solutionArea {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    height: auto;

}

.solution #solutionArea figure {
    width: 50%;
}

.solution #solutionArea figure img {
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: 50% 50%;
    border-radius: 10px 0 0 0;
}

.solution #solutionArea article {
    width: 50%;
    background: #282828;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    text-align: center;
}

.company .solution #solutionArea article aside {
    width: 80%;
}

.solution #solutionArea article h3 {
    font-size: 2em;
    font-weight: 700;
    margin: 0 0 .8em 0;
    line-height: 1.5em;
}

.solution #solutionArea article h3:after {
    content: "";
    display: block;
    width: 100%;
    height: 7px;
    background: #ffab02;
    margin: .2em 0 0 0;
}

.solution #solutionArea article p {
    font-size: .9em;
    line-height: 1.5rem;
    margin: 0 0 1rem 0;
    text-align: left;
}

.solution #solutionArea article p.eng {
    font-family: 'Lato', sans-serif;
    font-size: 1.1em;
    letter-spacing: .2em;
}


#priceTable {
    margin: 0 0 50px 0;
    box-sizing: border-box;

}

#priceTable table {
    width: calc(100% - 1px);

}

#priceTable table thead th {
    text-align: center;
    vertical-align: middle;
    color: #fff;
    width: 25%;
    box-sizing: border-box;
    padding: 2.2em 40px;
    font-weight: 500;
}

#priceTable table thead th.light {
    background: #ffab02;
}

#priceTable table thead th.basic {
    background: #e94729;
}

#priceTable table thead th.advance {
    background: #b91017;
}

#priceTable table thead th dt {
    font-size: 2.15em;
    line-height: 1em;
    margin: 0 0 .6em 0;
}

#priceTable table thead th dd {
    line-height: 1em;
    background: #fff;
    color: #19293a;
    font-size: 1.05em;
    padding: .6em 0;
    border-radius: 7px 0 7px 00;
    font-weight: 500;
}

#priceTable table tbody th {
    text-align: center;
    vertical-align: middle;
    font-weight: 500;
    padding: .6em 1.5em;
    border: 1px solid#fff;
    background: #424242;
    color: #fff;
    font-size: 1em;
    box-sizing: border-box;
    line-height: 1.5em;
}

#priceTable table tbody td {
    text-align: center;
    vertical-align: middle;
    font-weight: 400;
    padding: .6em 2em;
    color: #424242;
    font-size: 1.1em;
    border: 1px solid #dadcde;
    box-sizing: border-box;
    line-height: 1.5em;
    background: #fff;
}



#priceTable table tbody td em {
    font-size: 1.5em;
    font-weight: 700;
    font-style: normal;
}

#priceTable table tbody td small {
    font-size: .85em;
    letter-spacing: 0em;
}

.priceOptionTable {
    margin: 0 0 50px 0;
}

.priceOptionTable table {
    width: 100%;
    background: #fff;
}

.priceOptionTable table th {
    border-bottom: 2px solid #eee;
    text-align: left;
    vertical-align: middle;
    font-weight: 400;
    padding: 1em 2.5em;
    font-size: 1.1em;
}

.priceOptionTable table th small {
    font-size: .8em;
}

.priceOptionTable table td {
    border-bottom: 2px solid #eee;
    text-align: right;
    vertical-align: middle;
    font-weight: 400;
    padding: 1em 2.5em;
}

.priceOptionTable table tr:last-child th {
    border-bottom: none;
}

.priceOptionTable table tr:last-child td {
    border-bottom: none;
}

.priceOptionTable table td em {
    font-size: 16px;
    font-weight: 700;
    font-style: normal;
}

.priceOptionTable table td em small {
    font-size: .85em;
}

.priceOptionTable table td p:not(:last-child) {
    margin: 0 0 1em 0;
}

.priceOptionTable table td p span {
    font-size: .9em;
    margin: 0 1em 0 0;
}

.priceOptionTable table .green {
    color: #2847A1;
}

.priceNote {
    text-align: center;
}

.priceNote p {
    line-height: 2;
}

.priceNote a {
    text-decoration: underline;
}

.priceNote a:hover {
    text-decoration: none;
}


/* 記事詳細 #articleDetail */
.case #articleDetail {
    margin: 0 auto 50px;
    width: 640px;
}

.release #articleDetail {
	width: 100%;
}

@media screen and (max-width: 768px) {
.case #articleDetail,
.release #articleDetail {
	width: 100%;
}   
}

.column #articleDetail h1.title {
	margin: 0 auto;
	max-width: 100%;
	width: 800px;
	text-align: left;
	line-height: 1.5;
}

.seminar #articleDetail h1.title {
	width: 100%;
	text-align: left;
	line-height: 1.5;
}


@media screen and (max-width: 768px) {
.seminar #articleDetail h1.title {
	width: 100%;
}	
}

#mainCol.post.w860 {
    padding: initial;
}

#articleDetail figure.eye-catch {
    margin: 0 0 1rem 0;
    text-align: center;
}

.case #articleDetail figure.eye-catch {
    margin: 0 0 0 0;
}

#articleDetail .end-seminar-text {
    text-align: center;
    font-size: 1.2em;
    color: #fff;
    background: #989898;
    padding: 1em 1em;
    font-weight: 700;
    border-radius: 10px;
    margin: 0 0 1em 0;
}

#articleDetail figure.eye-catch img {
    max-width: 100%;
    height: auto;
    object-fit: cover;
    object-position: 50% 50%;
    width: 100%;
}

#articleDetail .tags {
    display: flex;
    flex-wrap: wrap;
}

#articleDetail .tags li {
    margin: 0 .7rem .5rem 0;
}

#articleDetail .tags li a {
    color: #1d3994;
    display: block;
    font-size: .9rem;
    line-height: 1em;
}

#articleDetail .tags li a:hover {
    opacity: .8;
}

#articleDetail .tags li a:before {
    content: "#";
}

#articleDetail .write-date {
    color: #777;
    display: block;
    font-size: 14px;
    margin: 0 0 1rem;
    text-align: right;
}

#articleDetail .write-date dl {
    display: inline-block;
    margin: 0 .7rem 0 0;
	margin: 0;
}

#articleDetail .write-date dt:after {
	content: "：";
}

#articleDetail .write-date dt,
#articleDetail .write-date dd {
    display: inline;
}

#articleDetail .salonData {
    margin: 40px 0;
    padding: 0 0 15px 0;
	margin: 0 0 30px 0;
    border-bottom: 1px solid #dddddd;
    color: #282828;
}

#articleDetail .salonData li {
    font-size: .9em;
	line-height: 1.8;
}

.article-bn {
    margin: 0 0 70px 0;
    display: flex;
    flex-wrap: wrap;
}

.article-bn.bottom {
    margin: 70px 0 0 0;
}

.article-bn.x2 {
    margin: 0 0 0 0;
}

.article-bn figure {
    width: 48.5%;
    margin: 0 3% 0 0;
}

.article-bn figure:has(img[alt="インスタ連携予約"]) {
    display: none;
}

.article-bn figure:nth-child(even) {
    margin: 0 0 0 0;
}

.articleRelatedList .article-bn figure {
    width: 48.5%;
    margin: 0 3% 30px 0;
}

/* 2024.01.24 hirabayashi Instagram LPへのバナーを非表示 */
.articleRelatedList .article-bn figure:has(a[href="https://rsvia.co.jp/lp/instagram/"]) {
    display: none;
}

.articleRelatedList .article-bn figure:nth-child(even) {
    margin: 0 0 30px 0;
}

.article-bn figure img {
    width: 100%;
    height: auto;
}

#articleWrap {
    padding: 40px 0;
	padding: 0;
    background: #fff;
}

/* .article 記事詳細 */
article.entry {
    clear: both;
    padding: 0 0 30px 0;
}

article.post.entry {
    padding: 0 0 30px;
}

article.entry img,
article.entry a img {
    max-width: 100%;
    height: auto;
}

.column article.entry li a {
    box-sizing: border-box;
    color: #0f71d2;
    display: contents;
    font-size: 16px;
    line-height: 1.2rem;
    margin: .5rem;
    overflow: hidden;
    -webkit-box-align: center;
    -webkit-box-flex: 1;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.column article.entry li a.ez-toc-link {
    color: initial;
}

.column article.entry p a {
    color: #0f71d2;
    display: list-item;
    font-weight: 300;
    font-size: 14px;
    line-height: 1.2rem;
    list-style: disc inside;
    margin: .5rem;
    overflow: hidden;
    -webkit-box-align: center;
    -webkit-box-flex: 1;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.column article.entry p a.txt,
.column article.entry p a.text {
	display: inline;
	font-size: initial;
	list-style: initial;
	margin: initial;
}

.column article.entry p a.line-cta-btn {
	list-style: initial;
	font-size: 18px;
}

.column article.entry p a.esthetic_banner {
	list-style: initial;
}

.case article.entry p a {
    color: #0f71d2;
    text-decoration: underline;
}

.seminar .entry a {
    color: #0f71d2;
    text-decoration: underline;
}

article.entry a + br {
	display: none;
}

article.entry p a.line-cta-btn {
	margin: .5rem auto;
}

article.entry p.p-cv-btn a {
	background: #e94729;
	display: -ms-flexbox;
	display: flex;
}

.column article.entry a:before {
	/* content: "・"; --2025/2/14 */
	display: inline-block;
	text-decoration: none;
}

.column article.entry li a:before,
article.entry a.tmm_sociallink:before,
article.entry a.bms-cta-btn.sp:before,
article.entry p a:first-child:before,
article.entry .p-cv-btn a:before,
article.entry a.ez-toc-link:before,
article.entry a.line-cta-btn:before {
	content: none;
}

article.entry p {
font-size: 16px;
margin: 0 0 1.5rem;
letter-spacing: 0;
line-height: 1.8;
word-wrap: break-word;
}

article.entry a.partner_banner img {
	width: 600px!important;
	max-width: 100%;
}

article.entry p.partner_text {
	color: #777;
	margin: .5rem auto;
	max-width: 600px;
	text-align: center;
}

article.entry p.wp-caption-text {
    color: #777;
    font-size: .9rem;
    line-height: 1.5rem;
    margin: .5rem;
    text-align: center;
}

article.entry h2 {
    background: #d1a154;
    color: #fff;
    font-size: 1.4em;
    line-height: 1.5;
    margin: 3rem 0 1rem !important;
    padding: 1rem;
}

article.entry h3 {
    border-left: 5px solid #d1a154;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5;
    margin: 3rem 0 .7em;
    padding: 0 .5rem 0 1rem;
}

article.entry h4,
article.entry h5,
article.entry h6 {
    text-align: left;
    font-weight: 700;
    line-height: 1.5em;
}

article.entry h4 {
    font-size: 1.2em;
}

article.entry h5 {
    font-size: 1.1em;
    margin: 0 0 .8em 0;
}

article.entry h6 {
    font-size: 1em;
    line-height: 1.8em;
    margin: 0 0 .8em 0;
}

article.entry blockquote {
    padding: 50px;
    background: url(../images/blockquote1.png) top 20px left 20px no-repeat, url(../images/blockquote2.png) bottom 20px right 20px no-repeat;
    margin: 0 0 30px 0;
    background-color: #f2f2f2;
    box-sizing: border-box;
    border-radius: 10px;
}

/* summary */
article.entry h2.summary-title {
    border-radius: 5px 5px 0 0;
    font-size: 16px;
	font-weight: 700;
    display: inline-block;
    margin: 0!important;
    padding: 8px 16px;
}

section.answer-block {
    margin: 1.5rem auto 3rem;
}

section.answer-block ul.check_list {
    background: rgba(209,161,84,0.1);
    border: solid 2px #d1a154;
    border-radius: 0px 5px 5px 5px;
    padding: 1.5rem;
}

#articleDetail article.entry ul.check_list li {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5rem;
    list-style: none;
    margin: 1.5rem auto;
    padding-left: 1.5em;
    position: relative;
}

#articleDetail article.entry ul.check_list li:first-child {
	margin: 0 auto 1.5rem;
}

#articleDetail article.entry ul.check_list li:last-child {
	margin: 1.5rem auto 0;
}

.check_list li:before {
    content: "";
    position: absolute;
    top: .2em;
    left: .2em;
    -webkit-transform: rotate(50deg);
    -ms-transform: rotate(50deg);
    transform: rotate(50deg);
    width: 7px;
    height: 15px;
    border-right: 2px solid #d1a154;
    border-bottom: 2px solid #d1a154;
}
/* summary */

#articleDetail article.entry p + ul,
#articleDetail article.entry div + ul{
    margin: 0 0 2em;
    padding: 0 4%;
}

#articleDetail article.entry ul li {
	list-style: disc;
	list-style-position: inside;
}

#articleDetail article.entry ul ul {
	margin: 0 0 0 1rem;
}

#articleDetail article.entry ul ul li {
	font-weight: 300;
	list-style: circle;
}

#articleDetail article.entry ul li ul li.ez-toc-heading-level-3 {
    list-style-type: disc;
    list-style-position: inside;
    margin: initial;
    padding: initial;
}

#articleDetail article.entry .p-cv-btn-wrap ul li {
    font-size: .75em;
}

#articleDetail article.entry ol {
    counter-reset: number;
    list-style: none;
    margin: 0 0 2em 0;
    padding: 0 1rem;
}

#articleDetail article.entry ol li {
    list-style: decimal;
    list-style-position: inside;
}

#articleDetail article.entry ol li::marker {
	font-weight: 700;
}

article.entry .slider {
	margin: 0 auto 1.5rem;
	position: relative;
	overflow-x: auto;
	scrollbar-width: thin;
	white-space: nowrap;
}

article.entry code {
    /* background: rgb(247 246 243); --2025/2/14 */
    box-sizing: border-box;
    display: block;
    font-size: .8rem;
    line-height: 1.5rem;
    /* margin: 0 auto 1rem; --2025/2/14 */
    max-width: 100%;
    padding: 1rem;
    white-space: initial;
    word-wrap: break-word;
}

.case article.entry code {
    background: #eee;
}

#articleDetail article.entry table {
	border-collapse: collapse;
    width: 100%;
    margin: 0 0 10px 0;
}

#articleDetail article.entry table th {
    border: 1px solid #DCDCDC;
    background: #EBEBEB;
    vertical-align: middle;
    text-align: left;
    font-weight: 500;
    width: 200px;
    padding: 1em 1.5em;
}

#articleDetail article.entry table td {
    padding: 1em 1.5em;
    border: 1px solid #DCDCDC;
}

article.entry .scroll-hint {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 10px;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-weight: 700;
  line-height: 1.4;
  display: none;
  animation: scroll-hint-animation 2s infinite ease;
}

@keyframes scroll-hint-animation {
  0% {
    transform: translate(-50%, -50%);
  }
  50% {
    transform: translate(-40%, -50%);
  }
  100% {
    transform: translate(-50%, -50%);
  }
}

article.entry .scroll-hint--show {
  display: block;
}

#articleDetail article.entry .aligncenter {
    display: block;
    margin: 0 auto;
    max-width: 100%;
}

#articleDetail article.entry .alignright {
    float: right;
}

#articleDetail article.entry .alignleft {
    float: left;
}

#articleDetail article.entry .alignright,
.alignleft {
    margin: 8px;
}

.post-5403 p:has(img) {
    background: #f7f7f7;
}

.post-5403 #articleDetail article.entry img[class*="wp-image-"] {
    padding: 1rem 0;
}

#articleDetail article.entry img[class*="wp-image-"],
img[class*="attachment-"] {
    display: block;
    height: auto;
    margin: 0 auto;
    max-width: 100%;
}

/* clearfix */
#articleDetail article.entry .clearfix {
    overflow: hidden;
    zoom: 1;

    &:after {
        content: "";
        display: block;
        clear: both;
    }
}


.case h2.new-case {
    text-align: center;
    font-weight: 700;
    font-size: 1.9em;
    line-height: 1.7em;
    letter-spacing: .1em;
    margin: 0 0 .8em 0;
}


/* 関連記事 */

.articleRelatedList {
    margin: 0 0 20px 0;
}

.case .articleRelatedList {
    margin: 0 0 50px 0;
}

.articleRelatedList h2 {
    text-align: left;
    font-weight: 700;
    font-size: 24px;
    line-height: 1.7em;
    letter-spacing: .05em;
    margin-bottom: 8px;
}

.articleRelatedList h2.x2 {
    text-align: center;
}

.articleRelatedList article {
    display: flex;
    flex-wrap: wrap;
}

.articleRelatedList article a:nth-child(4n) {
    display: none;
}

.articleRelatedList article a {
    display: flex;
    flex-direction: column;
    margin: 0 24px 30px 0;
    text-decoration: none;
    width: 344px;
}

.articleRelatedList article a:nth-child(3n) {
    margin: 0 0 30px 0;
}

.articleRelatedList article a figure {
    margin: 0 0 0 0;
    overflow: hidden;
    border-radius: 10px 0 0 0;
}

.articleRelatedList article a figure img {
    border-radius: 10px 0 0 0;
    width: 344px;
    height: 12vw;
    object-fit: cover;
    object-position: 50% 50%;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;
}

.articleRelatedList article a:hover figure img {
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}

.articleRelatedList article a aside {
	margin-top: 8px;
}

.articleRelatedList article a aside h3 {
    font-size: 1em;
    line-height: 1.5;
}

.articleRelatedList article a aside p {
    font-size: .95em;
    color: #424242;
	line-height: 1.5;
}

/* 関連タグ */

.articleRelatedList .relatedTags {
    margin: 0 0 50px 0;
    display: flex;
    flex-wrap: wrap;
}

.articleRelatedList .relatedTags li {
    margin: 0 15px 15px 0;
}

.articleRelatedList .relatedTags li a {
    display: block;
    background: #fff;
    text-decoration: none;
    padding: .8em 1.2em;
}

.articleRelatedList .relatedTags li a:before {
    content: "#";
}

.articleRelatedList .relatedTags li a:hover {
    opacity: .8;
}

/* .seminar セミナー */
#floatMenu input {
    display: none;
}

.seminar-list h1.title {
	font-size: 32px;
	margin: 40px 0 0;
	text-align: center;
}

.seminar .seminarList {
    margin: 0 0 20px 0;
}

.seminar .seminarList h2 {
    font-weight: 700;
    font-size: 24px;
    margin-bottom: 8px;
}

.seminar .seminarList p {
	display: none;
}

.seminar .seminarList article a:hover figure img {
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}

.seminar .seminarList article aside {
    background: #fff;
    padding-top: 8px;
    width: 345px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.seminar .seminarList article aside p {
    font-size: .85em;
    line-height: 1.8em;
    color: #424242;
    margin: 0 0 1em 0;
}

.seminar .seminarList article aside dl {
	font-size: 13px;
    display: flex;
    font-weight: 500;
    line-height: 2;
    margin-top: 8px;
}

.seminar .seminarList article aside dt {
    white-space: nowrap;
}

.seminar .seminarList article aside dt:after {
    content: "：";
    white-space: nowrap;
}

.seminar .seminarList .cat {
    display: flex;
    justify-content: flex-end;
    font-size: .8em;
}

.seminar .seminarList .cat span {
    display: inline-block;
    line-height: 1em;
    color: #fff;
    background: #424242;
    padding: .8em 1.2em .8em 1.2em;
}

.seminar .seminarList .cat span.column {
    background: #FF4B36;
}

.seminar .seminarList .cat span.seminar {
    background: #38b483;
}

.seminar .seminarList .cat span.case {
    background: #847AC6;
}

.seminar .seminarList .cat span.post {
    background: #45b1c9;
}

.seminar .seminar-outline {
    margin: 0 0 30px 0;
}

.seminar .seminar-outline h2 {
    text-align: left;
    font-weight: 700;
    font-size: 1.9em;
    line-height: 1.7em;
    letter-spacing: .1em;
    margin: 0 0 .8em 0;
}

.seminar .seminar-outline table {
    width: 100%;
    margin: 0 0 0 0;
}

.seminar .seminar-outline table th {
    border: 1px solid #DCDCDC;
    background: #EBEBEB;
    vertical-align: middle;
    text-align: left;
    font-weight: 500;
    width: 200px;
    padding: 1em 1.5em;
}

.seminar .seminar-outline table td {
    padding: 1em 1.5em;
    border: 1px solid #DCDCDC;
}

.seminar .seminar-outline .gmap {
    margin: .5em 0 0 0;
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.seminar .seminar-outline .gmap iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}

iframe.wp-embedded-content {
    display: block;
    margin: 0 auto;
}

.seminar .seminar-outline .event-date li {
    margin: 0 0 .3em 0;
}

.seminar .seminar-outline .event-date .end span {
    text-decoration: line-through;
}

.seminar .seminar-outline .event-date .end:after {
    content: "申込締切";
    font-size: .8em;
    background: #EBEBEB;
    line-height: 1em;
    margin: 0 0 0 1em;
    padding: .5em .5em;
    border-radius: 5px;
    letter-spacing: 0;
}

.seminar .seminar-outline a.map-icon {
    display: inline-block;
    font-size: .85em;
    background: #2847A1;
    color: #fff;
    line-height: 1em;
    margin: 0 0 0 1em;
    padding: .5em .8em;
    border-radius: 5px;
    letter-spacing: 0;
    text-decoration: none;
}

.seminar .seminar-outline a.map-icon:hover {
    opacity: .8;
}

.seminar .seminar-curriculum {
    margin: 0 0 30px 0;
}


.seminar .seminar-curriculum h3 {
    text-align: left;
    font-weight: 700;
    font-size: 1.7em;
    line-height: 1.7em;
    letter-spacing: .1em;
    margin: 0 0 .8em 0;
}

.seminar .seminar-curriculum table {
    width: 100%;
    margin: 0 0 0 0;
    font-size: .8em;
}

.seminar .seminar-curriculum table th {
    background: #EBEBEB;
    border: 1px solid #dcdcdc;
    text-align: left;
    vertical-align: middle;
    font-weight: bold;
    padding: .8em 1em;
}

.seminar .seminar-curriculum table td {
    padding: .8em 1em;
    border: 1px solid #dcdcdc;
}

.seminar .seminar-curriculum table td:nth-child(1) {
    white-space: nowrap;
}

.case.single #floatMenu {
	display: flex;
}
.case.single .sidebar-case {
	display: flex;
}
.case.single .widget {
	width: 50%;
}
@media screen and (max-width: 768px) {
.case.single #floatMenu {
	display: block;
}
.case.single .widget {
	width: 100%;
}
.case.single .sidebar-case {
	display: block;
}
}

.widget {
    margin-top: 40px;
}

.widget .widget-title {
    text-align: center;
    margin: 0 0 1em 0;
    font-size: 1.35em;
    font-family: 'Lato', sans-serif;
    font-weight: 900;
    color: #2847A1;
    line-height: 1em;
}

.widget .widgetForm {
    background: #e6e6e6;
    padding: 20px 15px;
    border-radius: 10px 0 10px 0;
}

.widget .widgetForm h3 {
    text-align: center;
    font-size: 1.3em;
    font-weight: 500;
    margin: 0 0 1em 0;
}

.widget .widgetForm fieldset {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 0 20px 0;
}

.widget .widgetForm .form-set {
    margin: 0 0 35px 0;
}

.widget .widgetForm fieldset label.field-label {
    width: 125px;
    font-size: .95em;
}

.widget .widgetForm fieldset input,
.widget .widgetForm fieldset select {
    width: 100%;
}

.widget .widgetForm fieldset span.wpcf7-form-control-wrap {
    width: calc(100% - 125px);
}

.widget .widgetForm .submitBtn {
    /* color: #2847A1; */
    background: #e94729;
    width: 90%;
}

.widget .widgetForm.entry a.submitBtn {
    color: #fff;
    text-align: center;
    text-decoration: none;
    display: block;
    position: relative;
    margin: 0 auto 20px auto;

}

.widget .widgetForm.entry a.submitBtn i {
    position: absolute;
    top: 50%;
    right: 1.5em;
    margin-top: -.3em;
    font-size: .8em;
}

.widget .widgetForm.entry .end-text {
    text-align: center;
    padding: 1em 1em;
    box-sizing: border-box;
    background: #fff;
    color: #cc0000;
    font-weight: 500;
    margin: 0 0 15px 0;
    border-radius: 5px 0 5px 0;
}

.widget-ranking .widget-ranking-box {
    display: flex;
    align-items: center;
    margin: 0 0 12px 0;
    text-decoration: none;

}

.widget-ranking .widget-ranking-num {
    width: 1em;
    padding: 0 1.3em 0 .8em;
    font-family: 'Lato', sans-serif;
    font-weight: 900;
    font-size: 1.6em;
}

.widget-ranking .widget-ranking-num:after {
    counter-increment: rank_number;
    content: counter(rank_number);
}

.widget-ranking .widget-ranking-box:nth-child(1) .widget-ranking-num,
.widget-ranking .widget-ranking-box:nth-child(2) .widget-ranking-num,
.widget-ranking .widget-ranking-box:nth-child(3) .widget-ranking-num {
    color: #2847A1;
}

.widget-ranking .widget-ranking-box dl {
    width: calc(100% - 2.1em);
    background: #fff;
    padding: 20px 25px;
    border-radius: 10px 0 10px 0;
}

.widget-ranking.x2 .widget-ranking-box dl {
    width: 100%;
}

.widget-ranking .widget-ranking-box dl dt {
    font-weight: 700;
    font-size: .95em;
    line-height: 1.8em;
    margin: 0 0 .5em 0;
}

.widget-ranking .widget-ranking-box dl dd {
    font-size: .7em;
    color: #474747;
}

.widget-ranking .widget-ranking-box dl dd.date {
    text-align: right;
    line-height: 1em;
}

.widget li {
    margin: 0 0 12px 0;
}

.widget li a {
    display: block;
    text-align: center;
}

/* .company 会社概要 */
.company #messageArea {
    padding: 50px 0 0 0;
    text-align: center;
}

.company #messageArea h2 {
    font-size: 3.8em;
    font-family: 'Lato', sans-serif;
    font-weight: 900;
    margin: 0 0 1em 0;
}

.company #messageArea p {
    font-size: 1.3em;
    font-weight: 500;
    margin: 0 0 2em 0;
    line-height: 2.2em;
}

.company #messageArea p:last-child {
    margin: 0 0 0 0;
}

.company #outluneArea {
    margin: 0 0 10px 0;
}

.company #outluneArea dl {
    display: flex;
    margin: 0 0 10px 0;
    background: #fff;
    border-radius: 10px 0 10px 0;
    font-size: 1.1em;
    color: #424242;
}

.company #outluneArea dt {
    width: 260px;
    padding: 1.5em 3em;
    box-sizing: border-box;
}

.company #outluneArea dd {
    padding: 1.5em 3em;
    box-sizing: border-box;
    font-weight: 500;
}

.company .contents#release {
    padding: 0 0 55px 0;
}

.release a {
	color: #2847A1;
}

.company #moreArea article {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.company #moreArea article a {
    display: block;
    text-decoration: none;
    width: 530px;
    filter: drop-shadow(0px 0px 4px rgba(50, 50, 50, 0.2));
}

.company #moreArea article a figure {
    position: relative;
    padding-top: 56.25%;
    overflow: hidden;
    border-radius: 10px 0 0 0;
}

.company #moreArea article a figure img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;

}

.company #moreArea article a:hover figure img {
    -moz-transform: scale(1.1);
    -webkit-transform: scale(1.1);
    -ms-transform: scale(1.1);
    transform: scale(1.1);
}

.company #moreArea article a aside {
    background: #fff;
    padding: 1.1em 1em;
}

.company #moreArea article a aside h3 {
    font-weight: 500;
    font-size: 1.2em;
    text-align: center;
    position: relative;
}

.company #moreArea article a aside h3 i {
    position: absolute;
    top: 50%;
    right: 1.5em;
    margin-top: -.3em;
    font-size: .8em;
}


.company #conceptArea {
    margin: 0 0 0 0;
    text-align: center;
}

.company #conceptArea h2 {
    text-align: center;
    font-weight: 700;
    font-size: 3em;
    line-height: 1em;
    margin: 0 0 1em 0;
    letter-spacing: .08em;
}

.company #conceptArea figure {
    margin: 30px auto 40px auto;
    position: relative;
    width: 900px;

}

.company #conceptArea figure img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    object-position: 50% 50%;
}

.company #conceptArea figure figcaption {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, .3);
}

.company #conceptArea h3 {
    text-align: center;
    font-weight: 700;
    font-size: 2em;
    line-height: 1em;
    margin: 0 0 0 0;
    letter-spacing: .1em;
    color: #fff;
}



/* .request 資料請求 */
.form_t_link {
    font-size: 12px;
    line-height: 1.4;
    margin: 10px 0;
}
.request-step .form_t_link {
	margin: 0 0 1rem;
}

.form_t_link a {
    color: #0F71D2;
}

.column_form .form_t_link br {
    display: block;
}

.form-set .submitBtn,
.request .submitBtn {
    font-size: 17px;
    font-weight: 700;
    letter-spacing: .1rem;
    margin: 0 auto 1rem;
    padding: 12px 0;
}

.request #requestArea {
    margin: 0 0 50px 0;
}

.request #requestArea h1 {
    text-align: center;
    font-weight: 700;
    margin: 0 0 2rem 0;
    font-size: 24px;
}

.request #requestArea h1 em {
    color: #2847A1;
    font-style: normal;
}

.request #requestArea .point-box {
    text-align: center;
    display: block;
    margin: 0 0 2em 0;
}

.request #requestArea .point-box ol {
    text-align: left;
    display: inline-block;
}

.request #requestArea .point-box ol li {
    margin: 0 0 0 1.5em;
}

.request #requestArea fieldset {
	margin: 0;
}

.request #requestArea .form-set {
    margin: 0 0 50px 0;
}

.request #requestArea fieldset label.field-label,
article.entry .form-wrap fieldset label.field-label {
    display: inline-block;
    margin: 0 0 1em 0;
    font-size: 16px;
    font-weight: 700;
    vertical-align: middle;
    width: 30%;
}

.request #requestArea fieldset label.field-label small,
article.entry .form-wrap fieldset label.field-label small {
    font-size: .9em;
    font-weight: 400;
}

.request #requestArea fieldset .wpcf7-form-control-wrap,
article.entry .form-wrap fieldset .wpcf7-form-control-wrap {
    display: inline-block;
    vertical-align: middle;
    width: 69%;
}

span.wpcf7-form-control.wpcf7-radio {
    position: relative;
    top: -6px;
	font-size: 12px;
	letter-spacing: 0;
}

span.wpcf7-form-control.wpcf7-radio input {
    margin: 2px 0 0;
}

.wpcf7-radio .wpcf7-list-item,
.wpcf7-checkbox .wpcf7-list-item {
    display: block;
    margin: 0;
    font-size: .8rem;
	line-height: 2;
}
.hotpepper .wpcf7-list-item {
    display: inline-block;
    margin-right: 20px;
}

.wpcf7-radio .wpcf7-list-item input {
    position: relative;
    top: -2px;
}

#requestArea .wpcf7-radio .wpcf7-list-item {
    font-size: 15px;
	line-height: 1.8;
}

.request #requestArea .comp-txt {
    text-align: center;
    line-height: 2.2em;
}

.request footer.cv-foot {
    padding: 0;
}

span.notice {
	display: block;
	font-size: 12px;
	margin: 0 0 0 31%;
	line-height: 1.5;
}
.request-step span.notice {
	color: #666;
	font-size: 12px;
}

.wpcf7-form-control-wrap textarea {
    height: 7rem;
}


article.entry .form-wrap {
    background-color: rgba(242, 242, 242, 1);
    padding: 1em 1em;
}

article.entry .form-wrap fieldset {
    margin: 0 0 20px 0;
}

article.entry .form-wrap .show-btn {
    margin: 0 0 20px 0;
}


/* MW WP FORM */
.mw_wp_form fieldset {
    width: 100%;
}

.mw_wp_form input[type="text"],
.mw_wp_form input[type="number"],
.mw_wp_form input[type="email"],
.mw_wp_form input[type="tel"],
.mw_wp_form textarea{
    padding: 5px 10px;
    box-sizing: border-box;
    border: solid 1px #d1d2d2;
    background: #e5e5e5;
    display: inline-block;
    width: 69%;
    border-radius: 3px;
}

.mw_wp_form input[type="submit"] {
    background: #e94729;
    border: none;
	border-radius: 3px;
    color: #fff;
    cursor: pointer;
    display: block;
    font-size: 1em;
	font-size: 22px;
    font-weight: 500;
    line-height: 1em;
    margin: auto;
    max-width: 100%;
    padding: 1em 0;
	padding: 12px 0;
    width: 400px;
    -webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-o-transition: all .3s ease;
}

.mw_wp_form .form-set select,
.mw_wp_form .form-set textarea {
    display: inline-block;
    vertical-align: middle;
    width: 69%;
}

.column_form .mw_wp_form input[type="text"],
.column_form .mw_wp_form input[type="number"],
.column_form .mw_wp_form input[type="email"],
.column_form .mw_wp_form .form-set select,
.column_form .mw_wp_form .form-set textarea {
    width: 100%;
}

/* 規約系 */
#kiyakuArea {
    max-width: 100%;
    margin: 0 auto;
    width: 90%;
}

#kiyakuArea > div {
    margin: 0 auto -80px;
}

#kiyakuArea h1 {
    font-size: 22px;
    margin: 80px auto 30px;
    padding: 80px 0 0;
}

#kiyakuArea h2 {
    border-bottom: 1px solid #eee;
    font-size: 18px;
    margin: -20px -20px 20px;
    margin-top: 30px !important;
    padding: 15px 20px;
}

#kiyakuArea h3 {
    font-size: 16px;
    padding: 0 0 10px;
}

#kiyakuArea h4 {
    font-size: 16px;
    font-weight: 700;
    margin-top: 16px;
}

#kiyakuArea p {
    font-size: 14px;
    line-height: 1.5rem;
    margin: 0 0 1rem;
}

#kiyakuArea .t_right {
    text-align: right;
}

#kiyakuArea ul {
    margin: 0 0 1rem;
}

#kiyakuArea ol {
    font-size: 14px;
    margin: 0 0 1rem;
    margin-top: 8px !important;
    padding-left: 2rem;
}

#kiyakuArea ol ol {
    padding-left: 0;
}

#kiyakuArea ol ol li {
    list-style-type: none;
    counter-increment: cnt;
    margin: 0 0 .5rem;
}

#kiyakuArea ol ol li::before {
    content: "(" counter(cnt) ") ";
}

#kiyakuArea .info-box {
    border: 1px solid transparent;
    border-color: #ccc;
    border-radius: 3px;
    margin: 0 0 1rem;
    padding: 1rem 1.5rem 0;
}

#kiyakuArea .info-box p {
    font-size: 12px;
}

#kiyakuArea a {
    border-bottom: 1px dotted;
    color: #0F71D2;
    margin: 0 .2rem;
}

#kiyakuArea a:hover {
    text-decoration: none;
}

#endArea {
    text-align: center;
    margin: 0 0 2em 0
}

#endArea dt {
    font-weight: 600;
    font-size: 1.2em;
    margin: 0 0 .8em 0;
}

#endArea dd {
    font-size: 1em;
}


/* 目次 */

.single__index {
    margin: 30px 0;
    padding: 50px 50px;
    background: #f4f3f1;
    position: relative;
}

.index__title {
    font-size: 1.3em;
    text-align: center;
    font-weight: 600;
    letter-spacing: .15em;
    margin: 0 0 0 0;
}


ul.index__list {
    list-style: none;
    padding: 1em 0 0 0;
    margin: 1em 0 0 0 !important;
}

ul.index__list li.index__item {
    list-style: none !important;
    margin: 0 0 .8em 0 !important;
    display: flex !important;
}

ul.index__list li.index__item:last-child {
    margin: 0 0 0 0 !important;
}

ul.index__list li.index__item:before {
    content: "\f107" !important;
    font-family: "Font Awesome 5 Free" !important;
    font-weight: 900 !important;
    margin: 0 .5em 0 0 !important;
    font-size: 1.5em !important;
}

ul.index__list li.index__item a {
    color: #282828;
}

ul.index__list li.index__item:last-child {
    margin: 0 0 0 0;
}

.index__list_child {
    margin-left: 1em;
}

.index__button {
    font-size: .7em;
    cursor: pointer;
    vertical-align: middle;
    color: #fff;
    border: none;
    background: #282828;
    position: absolute;
    top: 1em;
    right: 1em;
    width: 36px;
    height: 36px;
    line-height: 30px;
    border-radius: 50%;
}

#ez-toc-container {
    background: #f7f7f7;
    border-bottom: 3px solid #d1a154;
    border-top: 3px solid #d1a154;
    margin: 0 auto 1rem;
    padding: 1.5rem;
}

article.entry .ez-toc-title-container p {
    font-weight: 700;
    margin: 0 0 1rem;
}

/* article.entry .ez-toc-title-container p:before {
    color: #d1a154;
    content: "\f03a" !important;
    font-family: "Font Awesome 5 Free" !important;
    font-size: 1.5rem;
    margin: 0 .5rem 0 0;
} */

#articleDetail article.entry ul li.ez-toc-page-1 {
    color: #d1a154;
    font-size: 14px;
    font-weight: 300;
    list-style-type: decimal;
    list-style-position: outside;
    padding: 0 0 .5rem;
    margin: 0 0 0 1.3rem;
    line-height: 1.7;
}

#articleDetail article.entry ul li.ez-toc-page-1:last-child {
    padding: initial;
}

li div {
    display: inline;
    font-size: .9rem;
}

article.entry a.ez-toc-link {
    color: #333;
}


/* 機能詳細ページの機能一覧リンク */
.single-function h2.function-list {
	text-align: center;
    font-size: 28px;
    font-weight: bold;
    margin: 64px 0 16px;
}
.single-function .function-list.contents {
	max-width: 960px;
	width: 90%;
	padding: 0;
	margin-bottom: 100px;
}
@media screen and (max-width: 768px) {
.single-function .function-list.contents {
	margin-bottom: 0;
}
}

/* column form */
.single-function .column_form {
    margin: -60px auto 80px;
    padding-top: 120px;
    width: 500px;
}

.column .column_form {
	margin: 64px auto 0;
	width: 600px
}

.column_form h2 {
	display: block;
	text-align: center;
	font-size: 24px;
	font-weight: bold;
	letter-spacing: .03em;
	margin-bottom: 16px;
}

.column_form h2 img {
    display: none;
}

.column_form br {
    display: none;
}

.column_form label.field-label {
    font-size: .9rem;
	font-size: 16px;
    font-weight: 700;
    display: block;
    line-height: 1.5rem;
}


.column_form select,
.column_form .wpcf7-text,
.column_form textarea {
    background: #e5e5e5;
    border: solid 1px #d1d2d2;
    border-radius: 3px;
    box-sizing: border-box;
    font-size: 14px;
    padding: 7px 10px;
}

.column_form .notice {
	color: #333;
	font-size: 12px;
	display: block;
	margin: 4px 0 0;
	line-height: 1.5;
}
.column_form .goal .notice {
    margin: 0 0 4px;
}
@media (min-width: 1280px) {
  .column_form .goal .notice {
    margin: 0 0 8px;
  }	
}


/* column single CTA */
@media (min-width: 1440px) {
	
	.column.single #main.ads,
	.column.single .footer-cta,
	.column.single .foot
	{
        background: initial;
        width: 100%;
        padding-right: 25vw;
        box-sizing: border-box;
    }
	
    .column.single .contents,
    .column.single footer.foot .footer,
	.case.single .contents,
	.case.single footer.foot .footer,
    .single-function .contents,
    .single-function footer.foot .footer
	{
        width: 80%;
        padding: 0px 3vw;
    }

    .column.single #pageTop {
        display: none;
    }

    .column.single .cv .contents #cvArea.x2 .btns {
        width: 100%;
    }

    .column.single .articleRelatedList article a {
        width: 31%;
    }

    .column.single .column_form,
	.case.single .column_form {
        border-left: 1px dotted #ccc;
        position: fixed;
        top: 0px;
        right: 0px;
        width: 25vw;
        height: 100vh;
        overflow: scroll;
        padding: 30px 1.5vw 120px;
    }
	.case.single .column_form {
		display: none;
    }

    .column.single .wpcf7-not-valid-tip,
    .column.single .column_form .notice
    .single-function .column_form .notice {
        font-size: 12px;
        line-height: 1.25rem;
    }

/*     .column.single .column_form fieldset.required {
        display: block;
    } */

    .column.single .column_form .submitBtn {
        margin: 1rem auto 0px auto;
    }
}

.column.single .articleRelatedList article a figure img {
    border-bottom: 1px solid rgb(204, 204, 204);
    width: 100%;
}
.column.single .articleRelatedList article a[href^="https://rsvia.co.jp/lp/instagram/"] {
    display: none;
}

/* 資料請求フォーム */
#form h1,
#form h2 {
    border: initial;
    margin: 0 auto .2rem;
}

.container.x2 {
    background: initial;
}

.form-set fieldset {
    padding: 6px 0;
}
.form-set fieldset.hotpepper {
    padding: 0.5rem 0 0;
}
@media screen and (min-width: 1221px) {
  .form-set fieldset.hotpepper {
	  margin-bottom: -8px;
  }	
}
.line .form-set fieldset.goal {
    padding: 0.5rem 0 0;
}
.google .form-set fieldset.goal {
    padding: 0.5rem 0 0;
}
.home .form-set fieldset.goal {
    padding: 0.5rem 0 0;
}

.form-set select,
.form-set .wpcf7-text,
.form-set textarea,
input.wpcf7-form-control.wpcf7-number.wpcf7-validates-as-required.wpcf7-validates-as-number {
    padding: 5px 10px;
    box-sizing: border-box;
    border: solid 1px #d1d2d2;
	background: #e5e5e5;
/*     background: url(../images/arrow_down.svg) right 1em center no-repeat #e5e5e5; */
    width: 100%;
    border-radius: 3px;
    font-size: 16px;
	letter-spacing: .03em;
}

.form-set fieldset.required label.field-label:after {
    background: #ff7e00;
	background: #d1a154;
    border-radius: 4px;
    color: #fff;
    content: "必須";
    display: inline-block;
    float: right;
    font-size: 14px;
    line-height: 1;
    padding: 4px 6px;
    position: relative;
    right: 0;
    top: 0;
}
.request .form-set fieldset.required label.field-label:after {
    top: 6px;
}

.form-set input::placeholder {
	color: #777;
	font-size: 16px;
}

/* instagram-feature-toc-20221018 */
.post-7445 #articleDetail article.entry ul li.ez-toc-heading-level-2 {
    font-weight: 700;
    list-style-type: none;
    list-style-position: outside;
    margin: initial;
}

.post-7445 #articleDetail article.entry ul.ez-toc-list-level-3 {
    margin: 0.2rem 0 1rem 1rem !important;
}

.post-7445 #articleDetail article.entry ul li.ez-toc-heading-level-3 {
    font-weight: 400;
    list-style-type: disc;
    list-style-position: inside;
    margin: initial;
    padding: initial;
}

.post-7445 #articleDetail article.entry h3 {
    margin: 2rem 0 1rem !important;
}

.post-7445 #articleDetail article.entry h4 {
    background: linear-gradient(transparent 90%, #d1a154 10%);
    display: inline-block;
    margin: 0 0 1rem;
}

.post-7445 #articleDetail article.entry table {
    background: rgba(209, 161, 84, 0.2);
    border-radius: .7rem 0 .7rem 0;
    display: block;
    padding: 1rem 1rem .5rem;
}

.post-7445 #articleDetail article.entry table th {
    background: initial !important;
    font-weight: 700;
}

.post-7445 #articleDetail article.entry table th:before {
    content: "○";
    font-size: .7rem;
    margin: 0 .2rem 0 0;
}

.post-7445 #articleDetail article.entry table th,
.post-7445 #articleDetail article.entry table td {
    border: initial;
    display: block;
    padding: 0 0 .2rem;
}

.post-7445 #articleDetail article.entry table td {
    padding: 0 0 .5rem 1rem;
}

.sp {
  display : none;
}

.download-title {
  font-size : 24px;
}

.img-box {
  text-align : center;
}

.img-box img {
  width : 800px;
}

.mokuji-heading {
  font-size : 20px;
  font-weight : bold;
  border-bottom : 1px solid rgb(230, 230, 230);
  margin-top : 24px;
  padding-bottom : 4px;
}

.mokuji-list {
  margin : 16px 0px 32px 0px;
}

.mokuji-item {
  font-size : 18px;
}

@media screen and (max-width: 768px) {
  .sp {
    display : block;
  }

  .mokuji-heading {
    font-size : 18px;
    margin-top : 16px;
  }

  .mokuji-list {
    margin : 8px 0px 32px 0px;
  }

  .mokuji-item {
    font-size : 15px;
  }
}

.m-b8 {margin-bottom: 8px !important;}
.d-n {display: none !important;}
.d-b {display: block}
@media (min-width: 769px) {
	.request .d-n {display: block !important;}
	.request .d-b {display: none}
}

/* トップページ「フォーム追加」20240207_hirabayashi */
.home .column_form {
	display: none;
}


@media (min-width: 1152px) {
	.home #main.ads,
    .home .foot {
        background: initial;
        width: 100%;
        box-sizing: border-box;
    }
	
    .home .contents,
    .home footer.foot .footer {
        width: 85%;
		max-width: 1200px;
        padding: 0;
		letter-spacing: 0;
    }
	
	.home .contents.cv {
        width: 100%;
    }
	
    .home #pageTop {
        display: none;
    }
	
    .home .cv .contents #cvArea.x2 .btns {
        width: 100%;
    }

    .home .column_form {
        border-left: 1px dotted #ccc;
		display: block;
        position: fixed;
        top: 0px;
        right: 0px;
        width: 25vw;
        height: 100vh;
        overflow: scroll;
        padding: 80px 1.5vw 0;
    }
	
    .home .wpcf7-not-valid-tip,
    .home .column_form .notice {
        font-size: 12px;
        line-height: 1.25rem;
    }
	
    .home .column_form .submitBtn {
        margin: 1rem auto 0px auto;
    }
	
	.home #keyWrap #keyImg article h1 {
		font-size: 40px;
		line-height: 1.4;
		letter-spacing: .05em;
	}
	
	.home #keyWrap #keyImg article figure.mock {
		width: 42%;
	}
	
	.home .swiper-slide {
		width: 320px;
	}
	
	.home .lpSwiper {
		margin: 0 0 64px 0;
	}
	
	.home h2.title {
		font-size: 32px;
		line-height: 1.4;
		letter-spacing: .05em;
		margin-bottom: 16px;
	}
	
	.home #brandArea ul {
		align-items: center;
	}
	
	.home #brandArea {
		margin: 64px 200px;
		padding: 0;
	}
	
	.home #reasonArea article {
		width: 30%;
	}
	
	.home #reasonArea article figure {
		margin: 0 0 16px 0;
		height: auto;
	
	}
	
	.home #reasonArea article dt {
		font-size: 18px;
		margin: 0 0 8px 0;
	}
	
	.home #reasonArea article dd {
		font-size: 15px;
		line-height: 1.7;
	}
	
	.home #reasonArea article figure img {
		border-radius: 0;
		max-width: 100%;
	}
	
	.caseArea {
		justify-content: space-between;
		margin: 0;
	}
	
	.home .caseArea a {
		width: 31%;
	}
	
	.home .caseArea a figure img {
		width: 100%;
		height: 12.5vw;
		height: 16vw;
		max-height: 215px;
	}
	
	.articleList, .seminar .seminarList article {
		justify-content: flex-start;
	}
	
	.articleList a.clink,
	.seminar .seminarList article a {
		width: 31%;
	}
	
	.home .articleList a.clink figure img, .seminar .seminarList article figure img {
		width: 100%;
/* 		height: 14vw; */
/* 		max-height: 197px; */
	}
	
	#posArea {
		justify-content: space-between;
		width: 100%;
	}
	
	#posArea article {
		width: 48%;
		margin: 0;
	}
}
/* トップページ「フォーム追加」20240207_hirabayashi */

/* フォーム導入実績追加_20240207 */
.color-main {
  color: #05C756;
}
#articleDetail .works {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
.works-top {
  display: none;
  padding: 24px 0 40px;
}
#articleDetail .works-heading {
  font-size: 16px;
  margin-bottom: 24px;
}
#articleDetail .works-logo {
  margin: 0 auto;
  max-width: 640px;
  width: 100%;
}
#articleDetail .works-note {
  margin-top: 24px;
  letter-spacing: 0;
}
#articleDetail .works-number {
  font-size: 28px;
}
@media (max-width: 768px) {
	#articleDetail .works-top {
		display: block;
	}
  #articleDetail .works {
    font-size: 4vw;
    font-weight: 500;
	  margin: 32px 0 20px;
  }
  #articleDetail .works-top {
    padding: 8px 0 12px;
  }
  #articleDetail .works-inner {
	  margin: 10px auto 0;
	  background-color: #f4efe7;
	  position: relative;
	  padding-bottom: 6px;
	  width: 100%;
  }
  #articleDetail .works-heading {
	  margin-bottom: 10px;
	  position: absolute;
	  left: calc(50% - 60px);
	  top: -16px;
	  background-color: #fff;
	  color: #05c756;
	  padding: 0 20px;
	  letter-spacing: .1em;
	  border: 2px solid #05c756;
  }
  #articleDetail .works-logo {
	  width: 90%;
	  margin: 24px auto 0;
	  background-color: #fff;
	  padding: 8px;
  }
  #articleDetail .works-note {
    margin-top: 12px;
    line-height: 1.2;
    letter-spacing: 0;
  }
	#articleDetail .works-note + p {
    margin-top: -2px;
  }
  #articleDetail .works-number {
    font-size: 6vw;
  }
  #articleDetail .works-br {
    display: block !important;
  }
}
/* フォーム導入実績追加_20240207 */

/* 20240216_hirabayashi_開業時期追加 */
.open-timing, .hotpepper {
  display: none;
}
.home .column_form fieldset.required.open-timing {
  display: none;
}
@media (min-width: 1024px) {
.column.single .column_form fieldset.required.open-timing {
    display: none;
}
}
/* 20240216_hirabayashi_開業時期追加 */

/* 20240228_hirabayashi_ステップフォーム対応 */
.submitBtn {
	background: #ef6b52;
}

.form-step {
    display: none;
}
@media screen and (max-width: 768px) {
  .form-step {
      display: flex;
      margin-bottom: 12px;
  }	
}

.form-step-desc {
	font-size: 14px;
    font-weight: bold;
}
.form-step-list {
	display: flex;
}
.form-step-item {
    padding: 0;
    background: #e6e6e6;
    color: #000426;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
	margin-left: 8px;
	width: 32px;
    height: 32px;
    font-size: 15px;
}
.btn-next,.btn-prev {
	display: none;
  border: none;
  width: 400px;
  max-width: 100%;
  color: #fff;
  line-height: 1em;
  background: #ef6b52;
  border-radius: 3px;
  margin: 12px auto;
  cursor: pointer;
  -webkit-transition: all .3s ease;
  -moz-transition: all .3s ease;
  -o-transition: all .3s ease;
  font-size: 17px;
  font-weight: bold;
  letter-spacing: .05em;
  padding: 12px 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .btn-next,.btn-prev {
    display: block;
  }
}
.btn-next:hover,
.btn-prev:hover {
	opacity: .8;
}

.btn-prev {
  border: 1px solid #ef6b52;
  color: #ef6b52;
  background-color: #fff;
}
.btn-prev#prev-2 {
	margin: 10px auto 0;
}
.btn-prev#prev-2.submit {
	margin: 16px auto 0;
}

@media screen and (max-width: 768px) {
  .form-second, .form-third {
    display: none;
  }	
}

.active {
	background: #ef6b52;
    color: #fff;
}
/* 20240228_hirabayashi_ステップフォーム対応 */

/* 20240307_hirabayashi_料金表変更 */
/* .price-table {
  font-size: 20px;
  line-height: 2.5;
  margin: 0 auto 40px;
  text-align: center;
  width: 640px;
} */
.price-table {
  display: block;
  margin: 0 auto 40px;
  width: 640px;
}
.priceOptionTable {
  margin: 0 auto 40px;
  width: 640px;
}


@media screen and (max-width: 768px) {
	/* 個人情報保護方針 */
	#kiyakuArea > div {
		margin: 0 auto -50px;
	}

	#kiyakuArea h1 {
		margin: 50px auto 30px;
		padding: 50px 0 0;
	}

  .price-table {
    font-size: 15px;
    margin: 0 auto 20px;
    width: 100%;
  }
  .priceOptionTable {
    margin: 0 auto 20px;
    width: 100%;
  }
}

.price-table .initial-cost {
  background-color: #2847A1;
  color: #fff;
}
.price-table .initial-price {
  border-left: 1px solid #ccc;
  border-right: 1px solid #ccc;
}
.price-table dl {
  display: flex;
  justify-content: space-between;
}
.price-table dt {
  background-color: #2847A1;
  color: #fff;
  width: 33%;
}
.price-table dd {
  border: 1px solid #ccc;
  width: 33%;
}
.price-table .bg-color {
  background-color: #F4EFE7;
}
/* 20240307_hirabayashi_料金表変更 */

/* 20240403_hirabayashi_ホットペッパーの利用状況 */
.hotpepper br {
	display: none;
}
@media screen and (min-width: 1221px) {
    .request .hotpepper {
	    line-height: 1.5;
    }
	.request .form-set fieldset.required.hotpepper label.field-label:after {
        top: -8px;
    }
	.request .hotpepper br {
	  display: block;
  }
}
/* 20240403_hirabayashi_ホットペッパーの利用状況 */

/* 20240520_hirabayashi_導入企業ロゴ追加 */
.logo-slider {
  animation: logo-slider 75s linear infinite;
    background: url(https://rsvia.co.jp/wp-content/themes/rsvia/images/brand/salon-logo-pc.jpg) repeat-x 50%;
    background-size: auto 64px;
    height: 64px;
    width: 99vw;
    margin: 0 calc(50% - 50vw) 10px;
}
@keyframes logo-slider {
  0%{
    background-position: 0 0;
  }
  100%{
    background-position: -2386px 0;
  }
}
/* 20240520_hirabayashi_導入企業ロゴ追加 */

/* 20240611_hirabayashi_トップページFV改善 */
.home #keyWrap #keyImg article .h1 {
  font-size: 44px;
  line-height: 1.4;
}
.color-blue {
  color: #2847A1;
}
.d-sp {display: none;}
@media screen and (max-width: 768px) {
  .d-pc {display: none;}
  .d-sp {display: block;}
}
.subcatch {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.3;
  margin: 20px 0 4px;
  position: relative;
}
.subcatch::before {
  color: #2847A1;
  content: "・・・・・";
  position: absolute;
  top: -20px;
  left: calc(50% - 106px);
}
.fv_list {
  display: flex;
  margin-top: 20px;
}
.fv_item {
  align-items: center;
  justify-content: center;
  display: flex;
  background-color: #fff;
  border: 2px dashed #2847A1;
  font-size: 20px;
  font-weight: bold;
  color: #2847A1;
  border-radius: 50%;
  line-height: 1.5;
  height: 120px;
  width: 120px;
}
.fv_item:nth-of-type(2) {
  margin: 0 18px;
}
@media screen and (max-width: 768px) {
  .home #keyWrap #keyImg article .h1 {
    font-size: 36px;
    margin: 5px 0;
    line-height: 1.3;
  }
  .home #keyWrap #keyImg article figure.mock .img {
    width: 70%;
  }
  .subcatch {
    margin-top: 8px;
  }
  .fv_list {
    margin-top: 10px;
  }
  .fv_item {
    text-align: center;
    font-size: 16px;
    height: 100px;
    width: 100px;
  }
}
/* 20240611_hirabayashi_トップページFV改善 */

/* 20241002_asa_copy-btn */
.copy-text-container {
    margin: 0 auto 3rem;
    text-align: right;
}

.copy-text-content {
    background: #f7f7f7;
    line-height: 1.5rem;
    margin: 0 auto .5rem;
    padding: 1rem 1.5rem;
    text-align: left;
}

.copy-button {
    background:  #333;
    border: initial;
    border-radius: 4px;
    color: #fff;
    padding: .3rem 1rem;
}
/* 20241002_asa_copy-btn */

.swiper-button-next:after,
.swiper-button-prev:after {
	color: #333;
    font-weight: 700;
    background: #fff;
    padding: 10px;
    border-radius: 10px;
}

.td-underline {
	text-decoration: underline;
}


/* Blog Card */
.blogcard {
	margin: -1rem auto 2.5rem;
	transition: all 0.5s ease;
	background: #f7f7f7;
	border-radius: .5rem;
	padding: 0;
}

.blogcard a {
 	display: block;
 	padding: 1rem 1rem 1.5rem;
}

.blogcard-thumbnail {
 	display: none;
 	vertical-align: middle;
 	width: 20%;
}

.blogcard-thumbnail img {
 	border-radius: 5px;
 	object-fit: cover;
 	width: 100%;
}

.blogcard-texts {
 	display: inline-block;
 	vertical-align: middle;
 	width: 100%;
}

article.entry p.blogcard-title {
 	line-height: 1.5rem;
 	margin: 0 auto;
 	padding: 0.5rem 1rem 0;
}

.blogcard-url {
 	padding: 0 0 0 0.6rem;
}

p.related-articles-heading,
p.related-functions-heading {
     background-image: url(https://rsvia.co.jp/wp-content/themes/rsvia/images/icon_related_article.png);
     background-repeat: no-repeat;
     background-size: 2rem;
     background-position: 0 0;
     font-weight: 700;
     margin: -1rem 0 1.1rem 0!important;
     padding: .7rem 0 0 2.5rem;
     position: relative;
     top: 1rem;
     left: .5rem;
     width: calc( 100% - 2rem );
}

.blogcard.ex + br {
	display: none;
}

p.related-functions-heading {
     background-image: url(https://rsvia.co.jp/wp-content/themes/rsvia/images/icon_related_function.png);
}

/* 二重送信防止用コード */
input.submit-btn:disabled {
    background: #e5e5e1;
    color: #606060;
}

.consultation-note {
	margin: -8px 0 16px;
    text-align: center;
	line-height: 1.7;
}

/* 20240501_導入企業ロゴ追加 */
.works {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 500;
  text-align: center;
	padding: 56px 0 40px
}
.works-inner {
	margin: 10px auto 0;
	background-color: #F4EFE7;
	width: 100%;
	position: relative;
	padding: 40px 0 20px;
}
.works-heading {
	margin-bottom: 10px;
	position: absolute;
	left: calc(50% - 61px);
	top: -16px;
	background-color: #fff;
	color: #168352;
	padding: 0 20px;
	letter-spacing: .1em;
	border: 2px solid #168352;
}
.works-note {
	margin-top: 12px;
    line-height: 1.2;
    letter-spacing: 0;
}
.works-number {
  font-size: 28px;
}
@media (max-width: 768px) {
  .works {
    font-size: 4.2vw;
    font-weight: 500;
	padding: 60px 0 20px;
  }
  .works-heading {
    font-size: 20px;
    margin-bottom: 10px;
    left: calc(50% - 66px);
  }
  .works-note {
    margin-top: 16px;
    line-height: 1.2;
    letter-spacing: 0;
  }
  .works-number {
    font-size: 6vw;
  }
}

.pc-is {
  display: none;
}
@media (min-width: 1279px) {
  .pc-is { display: block;}
  .sp-is { display: none;}
}

.works-br {
  display: block !important;
}

@media (min-width: 1279px) {
  .works { padding: 48px 0 0;}
  .works-inner { width: 800px;}
}

.works-list {
  background-color: #fff;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto;
  padding: 12px 0;
  width: 95%;
}
.works-item {
  align-items: center;
  justify-content: center;
  display: flex;
  margin: 8px 6px;
  width: 22%;
}
@media (min-width: 1279px) {
  .works-item {
    width: 14.5%;
  }
}
@media (max-width: 768px) {
  .works-item {
    width: 28%;
  }
}
.works-item .ash { height: 28px;}
.works-item .taya { height: 36px;}
.works-item .nyny { height: 24px;}
.works-item .kingsman { width: 108px;}
.works-item .velovetica { width: 108px;}
.works-item .foot-balance { width: 108px;}
.works-item .aveda { height: 56px;}
.works-item .kaming { height: 36px;}
.works-item .motegamishi { width: 96px;}
.works-item .lavela-tokyo { height: 64px;}
.works-item .screen { width: 104px;}
.works-item .uno-pulir { width: 96px;}
.works-item .yvess { width: 96px;}
.works-item .wolfman { width: 96px;}
.works-item .toh { height: 28px;}
.works-item .brain-sleep { height: 62px;}
@media (max-width: 768px) {
  .works-item .ash { height: 26px;}
  .works-item .taya { height: 34px;}
  .works-item .nyny { height: 22px;}
  .works-item .kingsman { width: 106px;}
  .works-item .velovetica { width: 104px;}
  .works-item .foot-balance { width: 100px;}
  .works-item .aveda { height: 50px;}
  .works-item .kaming { height: 32px;}
  .works-item .motegamishi { width: 92px;}
  .works-item .lavela-tokyo { height: 60px;}
  .works-item .screen { width: 96px;}
  .works-item .uno-pulir { width: 90px;}
  .works-item .yvess { width: 84px;}
  .works-item .wolfman { width: 92px;}
  .works-item .toh { height: 24px;}
  .works-item .brain-sleep { height: 58px;}
}
/* 20240501_導入企業ロゴ追加 */

/* 20250107_フッターCTA改善 */
.footer-cta {
  display: flex;
  margin-top: 64px;
}
.footer-cta-box {
  width: calc(100% / 3);
  padding: 40px 32px;
  color: #fff;
}
.footer-cta-box.demo {
  background-color: #2847A1;
  border-left: 1px solid #fff;
  border-right: 1px solid #fff;
}
.footer-cta-box.request {
  background-color: #E04428;
}
.footer-cta-box.line {
  background-color: #D1A154;
}
.footer-cta-heading {
  font-size: 24px;
  font-weight: bold;
}
.footer-cta-text {
  font-size: 16px;
  letter-spacing: .03em;
  line-height: 1.8;
  margin: 20px 0;
}
.footer-cta-link {
  background-color: #fff;
  border-radius: 5px;
  display: block;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.05em;
  padding: 10px 0;
  position: relative;
  text-align: center;
}
.footer-cta-link:hover {
  opacity: .9;
  text-decoration: none;
}
.footer-cta-link::after {
  content: '';
  display: block;
  position: absolute;
  transform: rotate(45deg);
  top: 19px;
  right: 20px;
  height: 13px;
  width: 13px;
}
.demo .footer-cta-link {
  color: #2847A1;
}
.request .footer-cta-link {
  color: #E04428;
}
.line .footer-cta-link {
  color: #D1A154;
}
.demo .footer-cta-link::after {
  border-top: 3px solid #2847A1;
  border-right: 3px solid #2847A1;
}
.request .footer-cta-link::after {
  border-top: 3px solid #E04428;
  border-right: 3px solid #E04428;
}
.line .footer-cta-link::after {
  border-top: 3px solid #D1A154;
  border-right: 3px solid #D1A154;
}

@media screen and (max-width: 768px) {
  .footer-cta {
    display: block;
	margin-top: 64px;
  }
  .footer-cta-box {
    width: 100%;
    padding: 32px 20px;
  }
  .footer-cta-box.demo {
    border-left: 0px solid #fff;
    border-right: 0px solid #fff;
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
  }
  .footer-cta-heading {
    font-size: 21px;
    font-weight: bold;
  }
  .footer-cta-text {
    font-size: 15px;
    letter-spacing: 0;
  }
  .footer-cta-link {
    font-size: 17px;
  }
  .footer-cta-link::after {
    top: 19px;
  }
}
/* 20250107_フッターCTA改善 */

/* 20250110_トップページ選ばれる理由 */
.reason-wrapper {
  display: flex;
  justify-content: space-between;
}
.reason-box {
  width: 31%;
}
.reason-title {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0;
  margin: 10px 0;
}
.reason-text {
  line-height: 1.8;
  letter-spacing: 0;
}
.reason-link {
	text-decoration: underline;
    color: #2847A1;
    font-weight: bold;
}
.font-bold {
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .reason-wrapper {
    display: block;
  }
  .reason-box {
    margin-top: 24px;
    width: 100%;
  }
  .reason-box img {
	height: auto;
    width: 100%;
  }
  .reason-title {
    font-size: 18px;
  }
}
/* 20250110_トップページ選ばれる理由 */

.industry-name {
	display: none;
}

.case .aesthetic-fotter-banner {
	display: block;
	margin: 40px auto 0;
	max-width: 480px;
}

/* 20250520_機能ページ料金表 */
.function .price {
	margin-top: -60px;
	padding-top: 60px;
}

/* 20250611_事例ページ画像 */
.case article.entry img {
	margin-bottom: -10px !important;
}

/* 20250617_導入サロンロゴ */
.logo {
  background-color: #D2DEFF;
}
.home .logo {
  background-color: #F4EFE7;
}

.logo-inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  margin: 0 auto;
  width: 90%;
  max-width: 1100px;
  padding: 20px;
}
@media screen and (max-width: 768px) {
  .logo-inner {
    flex-wrap: wrap;
	justify-content: space-between;
    width: 100%;
	padding: 12px 20px 20px;
  }
}
.logo img {
  display: block;
  margin: 0 5px;
  width: 11%;
}
@media screen and (max-width: 768px) {
  .logo img {
    margin: 10px 0 0;
    width: 48%;
  }
}

.home .logo {
	margin: -20px 0 64px;
	padding: 40px 0;
}
.home .logo-title {
	color: #282828;
	font-size: 24px;
}
.home .logo-inner {
	flex-wrap: wrap;
	margin-top: -20px;
	padding: 0;
}
.home .logo img {
	margin-top: 20px;
	width: 13%;
}
@media screen and (max-width: 768px) {
	.home .logo {
		margin: 20px 0 40px;
		padding: 30px 0;
	}
	.home .logo .title {
	font-size: 20px;
	}
	.home .logo-title {
	font-size: 18px;
	}
	.home .logo-inner {
		margin: -16px auto 0;
		width: 90%;
	}
	.home .logo img {
		margin: 12px 0 0;
		width: 48%;
	}
}
/* 20250617_導入サロンロゴ */

/* 20250821_機能一覧リニューアル */
.function a:hover,
.outline-item a:hover {
  text-decoration: none;
  opacity: 0.6;
}

.function main {
  letter-spacing: 0;
}

.function .top {
  background: #F4EFE7;
  font-size: 18px;
  padding: 32px 0;
  text-align: center;
}
.function .top h1 {
  font-size: 32px;
}
@media screen and (max-width: 768px) {
  .function .top h1 {
    font-size: 28px;
  }
}
.function .top p {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .function .top p {
    font-size: 16px;
    line-height: 1.7;
    margin: 20px auto 0;
    text-align: left;
    width: 90%;
  }
}
.function .top a {
  background-color: #E04428;
  border-radius: 30px;
  color: #fff;
  font-size: 20px;
  display: block;
  letter-spacing: 0.03em;
  margin: 20px auto 0;
  padding: 6px 0;
  position: relative;
  width: 280px;
}
.function .top a::after {
  content: "";
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  right: 25px;
  top: 15.5px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}
.function .top a:hover {
  opacity: 0.9;
}

.outline-inner {
  display: flex;
  justify-content: space-between;
  width: 90%;
  max-width: 1200px;
  margin: 48px auto 32px;
}
.home .outline-inner {
	width: 100%;
	margin: 32px auto;
}
@media screen and (max-width: 768px) {
  .outline-inner {
    margin: 40px auto 24px;
    display: block;
  }
}
.outline-group {
  width: 23%;
}
@media screen and (max-width: 768px) {
  .outline-group {
    margin-top: 32px;
    width: 100%;
  }
}
.outline-heading {
border-bottom: 1px solid #282828;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 14px;
  position: relative;
}
.outline-heading span {
  border: 1px solid #282828;
  border-radius: 50%;
  display: block;
  position: absolute;
  right: 0;
  top: calc(50% - 9px);
  height: 18px;
  width: 18px;
}
.outline-heading span::after {
  content: "";
  display: block;
  position: absolute;
  width: 8px;
  height: 8px;
  right: 4px;
  top: calc(50% - 6px);
  border-top: 1px solid #282828;
  border-right: 1px solid #282828;
  transform: rotate(135deg);
}
.outline-item {
  margin-top: 10px;
}
.outline-item a {
  align-items: center;
  border: 1px solid #ccc;
  border-radius: 10px;
  display: flex;
  font-size: 15px;
  padding: 3px 0;
}
.outline-item img {
  display: block;
  filter: brightness(0.3);
  margin: 0 8px;
  width: 32px;
}
.outline-item img.app,
.outline-item.black img {
filter: brightness(1);
}

.detail {
  padding-bottom: 64px;
}
@media screen and (max-width: 768px) {
  .detail {
    padding-bottom: 40px;
  }
}
.detail-inner {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
}
.detail-heading {
  color: #D1A154;
  font-size: 28px;
  font-weight: bold;
  margin-top: -40px;
  padding-top: 104px;
}
@media screen and (max-width: 768px) {
  .detail-heading {
    font-size: 24px;
    margin: -20px 0 -6px;
    padding-top: 72px;
  }
}
.detail-wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .detail-wrapper {
    display: block;
  }
}

@media screen and (min-width: 769px) {
.detail-wrapper.other:after {
    content: "";
    display: block;
    width: 32%;
    height: 0;
}
}

.detail-box {
  background-color: #F4EFE7;
  border-radius: 15px;
  margin-top: 20px;
  padding: 20px 20px 64px;
  position: relative;
  width: 32%;
}
@media screen and (max-width: 768px) {
  .detail-box {
    width: 100%;
  }
}
.detail-box h3 {
  font-size: 20px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .detail-box h3 {
    font-size: 18px;
  }
}
.detail-box h3 img {
  display: inline-block;
  filter: brightness(0.3);
  margin: 0 8px 0 -4px;
  width: 32px;
}
.detail-box.black h3 img {
  filter: brightness(1);
}
.detail-box p {
  line-height: 1.8;
  margin-top: 8px;
}
@media screen and (max-width: 768px) {
  .detail-box p {
    font-size: 15px;
    line-height: 1.7;
  }
}
.detail-box .highlight {
  color: #2847A1;
  font-weight: bold;
}
.detail-box a {
  color: #282828;
  font-size: 18px;
  position: absolute;
  bottom: 20px;
  right: 50px;
}
.detail-box a::after {
  content: "";
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  right: -20px;
  bottom: 10px;
  border-top: 2px solid #282828;
  border-right: 2px solid #282828;
  transform: rotate(45deg);
}

/* 20250821_機能一覧リニューアル */

/* 20250836_トップFV改善 */
.home .subcatch::before {
  left: calc(50% - 100px);
}

.home .cv-btns {
  margin: 32px 0 10px;
}

.home .fv {
  letter-spacing: 0;
  line-height: 1.5;
  overflow-x: hidden;
  padding-bottom: 16px;
}
@media screen and (max-width: 768px) {
  .home .fv {
    padding-bottom: 0;
    margin-bottom: -10px;
  }
}
.home .fv a:hover {
  text-decoration: none;
  opacity: 0.8;
}
.home .fv-inner {
  margin: 0 auto;
  width: 1100px;
}
@media screen and (max-width: 768px) {
  .home .fv-inner {
    width: 100%;
  }
}
.home .fv-top {
  align-items: center;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .home .fv-top {
    display: block;
    margin-top: 40px;
  }
}
.home .fv-first {
  margin-right: 80px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .home .fv-first {
    margin-right: 0;
  }
}
.home .fv-copy {
  color: #2847A1;
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.3;
}
@media screen and (max-width: 768px) {
  .home .fv-copy {
    font-size: 36px;
  }
}
.home .fv-offer {
  color: #E04428;
  font-weight: 700;
  font-size: 16px;
  margin: 32px 0 2px;
}
.home .fv-btn {
  background: #E04428;
  border-radius: 30px;
  box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
  color: #fff;
  display: block;
  font-size: 20px;
  letter-spacing: 0.1em;
  padding: 10px 0;
  position: relative;
  text-align: center;
  transition: 0.3s;
  width: 360px;
}
.home .fv-btn::after {
  content: "";
  display: block;
  position: absolute;
  width: 12px;
  height: 12px;
  right: 25px;
  top: 20px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}
.home .fv-slider img {
  margin: 10px 6px -10px;
  width: 50vw;
}
.home .fv-second {
  display: flex;
  justify-content: space-between;
  width: 48%;
}
@media screen and (max-width: 768px) {
  .home .fv-second {
    margin: 20px auto -40px;
    width: 94%;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  .home .fv-second {
    margin: 24px 1.5vw 0 auto;
  }
}
.home .fv-second-box {
  width: 49%;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .home .fv-second-box {
    width: 48%;
  }
}
.home .fv-second-box img {
  height: auto;
  margin-bottom: -22px;
}
@media screen and (max-width: 768px) {
  .home .fv-second-box img {
    margin-bottom: -10px;
  }
}
.home .fv-second-box span {
  color: #2847A1;
  display: inline-block;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.03em;
  margin-left: 44px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .home .fv-second-box span {
    display: block;
    font-size: 18px;
    left: -14px;
    margin: 0 auto;
    width: -moz-fit-content;
    width: fit-content;
  }
}
.home .fv-second-box span::after {
  content: "";
  display: block;
  position: absolute;
  width: 10px;
  height: 10px;
  right: -15px;
  top: 8px;
  border-top: 2px solid #2847A1;
  border-right: 2px solid #2847A1;
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .home .fv-second-box span::after {
    top: 9px;
  }
}
.home .fv-case {
  display: flex;
  justify-content: space-between;
  margin-top: 32px;
}
.home .fv-case a {
  display: block;
  width: 19%;
}
/* 20250836_トップFV改善 */

/* 20251002 事例レイアウト調整 */
.case .wrapper {
	margin-top: 20px;
}
/* 20251002 事例レイアウト調整 */

/* 20251011 事例の成果 */
.results {
	background-color: #F4EFE7;
    border-radius: 10px;
    padding: 15px;
	margin-bottom: 24px;
}
article .results p {
	margin: 0 ;
}
/* 20251011 事例の成果 */

/* 20260202 記事内バナー */
.entry-cta {
  display: block;
  margin: 20px auto 40px;
  width: 400px;
}
@media screen and (max-width: 768px) {
.entry-cta {
  width: 100%;
}
}
/* 20260202 記事内バナー */