@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200');
@font-face {
  font-family: 'LINESeedJP';
  src: url('../font/LINESeedJP_OTF_Rg.woff') format('woff'),
       url('../font/LINESeedJP_OTF_Rg.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'LINESeedJP';
  src: url('../font/LINESeedJP_OTF_Bd.woff') format('woff'),
       url('../font/LINESeedJP_OTF_Bd.woff2') format('woff2');
  font-weight: bold;
  font-style: normal;
}

/*---------------------------
リセット
---------------------------*/
*,
*::before,
*::after {
box-sizing: border-box;
}
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
margin:0;
padding:0; 
border:0;
outline:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
html{
font-family: 'LINESeedJP', sans-serif;
font-feature-settings: "palt";
/*letter-spacing: -1px;*/
}
body {
line-height: 1;
color:#233237;
font-size:16px;
}
/*html, body {
overflow-x: hidden;
}*/
main {
overflow-x: hidden;
}
footer address{
font-style:normal;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
display:block;
}
nav ul {
list-style:none;
}
blockquote, q {
quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content:'';
content:none;
}
a {
margin:0;
padding:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
text-decoration: none;
}
li{
list-style:none;
}
ins {
background-color:#ff9;
color:#000;
text-decoration:none;
}
mark {
background-color:#ff9;
color:#000; 
font-style:italic;
font-weight:bold;
}
del {
text-decoration: line-through;
}
abbr[title], dfn[title] {
border-bottom:1px dotted;
cursor:help;
}
table {
border-collapse:collapse;
border-spacing:0;
}
hr {
display:block;
height:1px;
border:0;   
border-top:1px solid #cccccc;
margin:1em 0;
padding:0;
}
input, select {
vertical-align:middle;
}
p{
line-height: 1.6;
}
img{
width: 100%;
max-width: 100%;
vertical-align: bottom;
}
.sp{
display: block;
}
.pc {
display: none;
}
@media screen and (min-width: 768px) {
.sp{
display: none;
}
.pc {
display: block;
}
}

/*header*/
header {
    padding: 20px 3%;
}
header .header-logo {
    display: flex;
    align-items: center;
    gap: 3.7%;
}
header .header-logo .logo {
    width: 50%;
    max-width: 208px;
}
header .header-logo p {
    color: #cccccc;
    font-size: 12px;
    line-height: 1.75;
}
header .header-logo p span {
    display: block;
}

@media screen and (min-width: 768px) {
header {
    display: flex;
    justify-content: space-between;
    padding: 20px 36px 20px 50px;
}
header .header-logo {
    gap: 8.4%
}
header .header-logo .logo {
    width: auto;
}

header .header-logo .logo,
header .header-logo p,
header .header-contact .header-gototel,
header .header-contact .header-gotoform {
    flex-shrink: 0;
}
header .header-logo p {
    font-size: 16px;
    line-height: 1;
}
header .header-logo p span {
    display: block;
    margin-top: 5px;
    font-size: 21px;
}
header .header-contact {
    display: flex;
    align-items: center;
    gap: 25px;
}
header .header-contact .header-gototel {
    width: 295px;
    font-size: 13px;
    color: #65bdc4;
}
header .header-contact .header-gotoform {
    background-color: #65bdc4;
    padding: 19px 52px;
    border-radius: 27px;
}
header .header-contact .header-gotoform a {
    display: block;
    color: #ffffff;
    font-weight: bold;
}
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
.header-gototel {
    display: none;
}
}

/*footer*/
#company {
    background-color: #65bdc4;
    color: #ffffff;
    padding: 0 3%;
}
#company .company-container {
    max-width: 1095px;
    margin: 0 auto;
}
.footer-logo {
    width: 223px;
    margin: 0px auto;
    padding: 50px 0;
}
#company .company-flex {
    display: flex;
    flex-direction: column;
    gap: 0px;
}
#company h2 {
    margin-bottom: 30px;
    padding-left: 13px;
    font-size: 24px;
    font-weight: bold;
}
#company dl {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 26px;
    font-size: 15px;
}
#company dt:first-child,
#company dt:first-child + dd {
    border-top: 1px solid #f5f6fb;
}
#company dt {
    width: 20%;
    padding: 18px 0 18px 13px;
    border-bottom: 1px solid #f5f6fb;
}
#company dd {
    width: 80%;
    padding: 18px 0;
    border-bottom: 1px solid #f5f6fb;
}
#company .footer-tel {
    width: fit-content;
    margin: 0 auto 40px;
}
#company .footer-tel .footer-tel-img {
    max-width: 390px;
    margin: 0 0 10px;
}
#company .footer-tel .footer-tel-text {
    font-size: 17px;
}
#company .map {
    margin-bottom: 10px;
}
#company .map iframe {
    border-radius: 25px;
}
#company .tse-flex {
    display: flex;
    gap: 20px;
    align-items: center;
    margin-bottom: 34px;
}
#company .tse-flex p {
    font-size: 15px;
}
#company .tse-logo {
    width: 59px;
    flex-shrink: 0;
}
.copy {
    padding: 25px 0;
    color: #ffffff;
    background-color: #233237;
    text-align: center;
    font-size: 13px;
}
.sticky {
    position: sticky;
    bottom: 0;
    z-index: 2;
    padding: 12px 3%;
    background-color: #f5f6fb;
}
.sticky .sticky-flex {
    display: flex;
    gap: 3%;
}
.sticky .sticky-item-tel {
    width: 50%;
    font-size: 17px;
font-size: 12px;
    background-color: #65bdc4;
    border-radius: 7px;
}
.sticky .sticky-item-tel .sticky-item-tel-icon {
    width: 23px;
}
.sticky .sticky-item-tel span {
    display: block;
    font-size: 12px;
font-size: 10px;
    padding-top: 5px;
}
.sticky .sticky-item-contact {
    width: 50%;
    font-size: 18px;
    background-color: #eb5583;
    border-radius: 7px;
    display: flex;
    align-items: center;
}
.sticky .sticky-item-contact .sticky-item-contact-icon {
    width: 33px;
}
.sticky .sticky-item-tel a,
.sticky .sticky-item-contact a {
    color: #ffffff;
    display: flex;
    align-items: center;
}
.sticky .sticky-item-tel a div,
.sticky .sticky-item-contact a div {
    flex-shrink: 0;
}
.sticky .sticky-item-tel a,
.sticky .sticky-item-contact a  {
    gap: 5%;
    padding: 12px 0 12px 4%;
}
.sticky .sticky-item-contact a {
    gap: 5%;
    padding: 12px 0 12px 13px;
    padding: 12px 0 12px 5%;
}
@media screen and (min-width: 768px) {
#company .company-flex {
    flex-direction: row;
    gap: 5.5%;
}
#company .company-1 {
    width: 52%;
}
#company .company-2 {
    width: 43%;
}
#company h2 {
    font-size: 25px;
}
#company dl {
    font-size: 16px;
}
#company .footer-tel {
    width: auto;
    margin: 0 0 40px;
    padding-left: 13px;
}
#company .map {
    margin-bottom: 30px;
}
#company .tse-flex p {
    font-size: 16px;
}
}

/* #fv */
#fv .fv-bg {
    position: relative;
    background-image: url(../images/header-bg.jpg);
    background-size: cover;
    height: 621px;
}
#fv .fv-catch-container {
    padding: 27px 3% 0;
}
#fv .fv-catch-container h1 {
    display: flex;
    font-size: 32px;
    color: #ffffff;
    background-image: url("../images/header-image2-sp.svg");
    background-repeat: no-repeat;
    background-size: contain;
    padding: 35px 95px 44px 9px;
}
#fv .fv-catch-container h1::before {
    content: '';
    display: block;
    background-image: url("../images/header-image3.svg");
    background-repeat: no-repeat;
    background-size: contain;
    width: 42px;
    height: 56px;
    margin: -10px 19px 0 0;
}
#fv .fv-catch-container h1 .h1-flex {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
#fv .fv-catch-container h1 span {
    display: block;
}
#fv .fv-catch-container h1 .em-color {
    color: #ffff88;
}
#fv .fv-point {
    position: absolute;
    left: 0;
    bottom: 46px;
    width: 100%;
    padding: 0 2%;
    display: flex;
    justify-content: space-between;
}
#fv .fv-point p {
    width: 31vw;
    height: 31vw;
    display: flex;
    flex-direction: column;
    justify-content:center;
    background-color: #ffffff;
    border: solid #eb5583 5px;
    border-radius: 50%;
    box-shadow: 8px 8px 0 rgba(102,102,142,.4);
    font-size: 14px;
    line-height: 1.5;
    text-align: center;
}
#fv .fv-point p::before {
    content: url("../images/header-image5.png");
    display: block;
    margin-bottom: 5px;
}
#fv .fv-point p .em-color {
    display: block;
    color: #eb5583;
    font-size: 15px;
    font-weight: bold;
    margin-bottom: 20px;
}
#fv .fv-person {
    width: 440px;
    position: absolute;
    right: -130px;
    bottom: 0;
}
#fv form {
    width: 440px;
    position: relative;
    z-index: 1;
    margin: -22px 3% 0;
    padding: 42px 8% 48px 9%;
    background-color: #f5f6fb;
    border-radius: 62px;
    box-shadow: 8px 8px 0 rgba(102,102,142,.4);
}
#fv form h3 {
    font-size: 20px;
    text-align: center;
    margin-bottom: 42px;
}
#fv form .inquiry-item {
    display: flex;
    flex-direction: column;
    margin-bottom: 20px;
}
#fv form .inquiry-item label {
    color: #3c3a37;
    margin-bottom: 8px;
}
#fv form .inquiry-item input,
#fv form textarea {
    padding: 12px;
    border: none;
    border-radius: 8px;
    font-size: 16px;
}
#fv form textarea {
    line-height: 1.5;
}
#fv form input::placeholder,
#fv form textarea::placeholder {
    color: #c0c8dd;
    font-size: 16px;
}
#fv form input[type="submit"] {
    font-size: 23px;
    font-weight: bold;
    line-height: 1;
    margin: 8px auto 29px;
    padding: 20px 10%;
    border-radius: 32px;
    border: none;
    color: #ffffff;
    background-color: #eb5583;
}
#fv form .submit-btn,
#fv form .link-policy {
    text-align: center;
}
#fv form .link-policy a {
color: #3fa9f5;
text-decoration: underline;
}

@media only screen and (orientation:landscape) and (max-width : 813px),(orientation:portrait) and (max-width : 753px){
#fv form {
    width: 90%;
    margin: -30px auto 0 auto;
    padding: 42px 4.7% 48px 4.7%;
}

}



@media screen and (min-width: 768px) {
#fv {
    background-image: url(../images/header-bg.jpg);
    background-size: cover;
}
#fv .fv-bg {
    background-image: none;
}
#fv .fv-bg {
    height: 845px;
}
#fv .fv-catch-container {
    padding: 30px 0 0;
}
#fv .fv-catch-container h1 {
    display: flex;
    align-items: center;
    font-size: 60px;
    color: #ffffff;
    background-image: url("../images/header-image2.svg");
    background-repeat: no-repeat;
    background-size: auto;
    padding: 55px 0 124px 36px;
}
#fv .fv-catch-container h1 .h1-flex {
    flex-direction: row;
    gap: 0;
}
#fv .fv-catch-container h1::before {
    width: 68px;
    height: 91px;
    margin-right: 40px;
}
#fv .fv-catch-container .point-flex {
    display: flex;
    max-width: 880px;
}
#fv .fv-person {
    position: static;
}
#fv .fv-point {
    position: static;
    width: 55%;
    flex-wrap: wrap;
    margin-left: -87px;
    padding: 0;
}
#fv .fv-point p .em-color {
    font-size: 28px;
}
#fv .fv-point p {
    width: 220px;
    height: 220px;
    font-size: 19px;
}
#fv .fv-point p:last-child {
    margin: -150px auto 0;
}
}
@media screen and (min-width: 768px) and (max-width: 1239px) {
.fv-catch-container {
    max-width: 880px;
    margin: 0 auto;
}
}
@media screen and (min-width: 1240px) {
#fv .fv-container {
    max-width: 1320px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
}
#fv form {
    max-width: 422px;
    margin: 0;
    padding: 24px 42px 27px;
    background-color: #f5f6fb;
    border-radius: 62px;
}
#fv form .inquiry-item {
    margin-bottom: 16px;
}
#fv form .inquiry-item label,
#fv form .inquiry-item input,
#fv form input::placeholder,
#fv form textarea,
#fv form textarea::placeholder {
    font-size: 14px;
}
#fv form .inquiry-item label {
    margin-bottom: 6px;
}
#fv form input[type="submit"] {
    font-size: 18px;
    margin: 2px auto 20px;
}
#fv form .submit-btn, #fv form .link-policy {
    font-size: 13px;
}
}

/*#prologue*/
#prologue h2 {
    margin-top: 98px;
    margin-bottom: 53px;
    font-size: 20px;
    font-weight: normal;
    display: flex;
    justify-content: center;
    align-items: center;
}
#prologue h2 .em-color {
    color: #eb5583;
}
#prologue h2::before,
#prologue h2::after {
    content: "";
    width: 46px;
    height: 2px;
    background-color: #eb5583;
    border-radius: 1px;
    margin: 0px 4px 4px;
}
#prologue h2::before {
    transform: rotate(65deg);
}
#prologue h2::after {
    transform: rotate(-65deg);
}
#prologue .prologue-container {
    margin-bottom: 70px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 39px;
}
#prologue .prologue-container .prologue-item {
    width: 73%;
    background-image: url(../images/img-image1.svg);
    background-repeat: no-repeat;
    background-size: contain;
}
#prologue .prologue-container .prologue-item p {
    margin-top: 85px;
    font-size: 20px;
    line-height: 1.4;
    text-align: center;
}
#prologue .prologue-container .prologue-item .prologue-img {
    width: 73%;
    margin: 0 auto;
}
#prologue .omakase {
    font-size: 30px;
    font-weight: bold;
    line-height: 1;
    width: fit-content;
    margin: 0 auto 76px;
}
#prologue .omakase .em-color {
    color: #65bdc4;
}
#prologue .omakase::after {
    content: '';
    display: block;
    height: 4px;
    background-color: #fcee21;
    border-radius: 2px;
}
@media screen and (min-width: 768px) {
#prologue h2 {
    margin-top: 70px;
    margin-bottom: 69px;
    font-size: 30px;
}
#prologue .prologue-container {
    flex-direction: row;
    max-width: 1080px;
    margin: 0 auto 96px;
    gap: 0px;
}
#prologue .prologue-container .prologue-item {
    position: relative;
    background-size: cover;
}
#prologue .prologue-container .prologue-item:not(:first-child) {
    margin-left:-15px;
}
#prologue .prologue-container .prologue-item p {
    margin-top: 75px;
    font-size: 17px;
}
#prologue .prologue-container .prologue-item .prologue-img-01,
#prologue .prologue-container .prologue-item .prologue-img-02 {
    margin-top: 20px;
}
#prologue .prologue-container .prologue-item .mokumoku-01 {
    width: 72px;
    position: absolute;
    right: 53px;
    bottom: -42px;
    z-index: -1;
}
#prologue .prologue-container .prologue-item .mokumoku-02 {
    width: 52px;
    position: absolute;
    right: 0;
    left: 0;
    margin: 0 auto;
    bottom: -62px;
    z-index: -1;
}
#prologue .prologue-container .prologue-item .mokumoku-03 {
    width: 72px;
    position: absolute;
    left: 53px;
    bottom: -42px;
    z-index: -1;
}
#prologue .omakase {
    font-size: 52px;
    margin: 0 auto 88px;
}
}

/*空室ずっと無料通電とは？　#about*/
#about {
    background-image: url("../images/about-triangle.png"), url("../images/bg-about.jpg");
    background-position: center top -10px, center top;
    background-repeat: no-repeat, no-repeat;
    background-size: auto, cover;
    padding: 104px 3% 63px;
}
#about .about-container {
    padding: 46px 8% 54px;
    background-image: url("../images/bg-grid.png");
    border-radius: 62px;
    box-shadow: 8px 8px 0 rgba(102,102,142,.4);
}
#about h2 {
    font-size: 28px;
    text-align: center;
}
#about h2::after {
    content: 'about';
    display: block;
    margin-top: 24px;
    color: #b1bbdf;
    font-size: 17px;
    font-weight: normal;
    text-align: center;
}
#about .h-border {
    width: 115px;
    height: 2px;
    margin: 14px auto 100px;
    background-color: #b1bbdf;
    border-radius: 1px;
}
#about .about-flex {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: 75px;
}
#about .about-item {
    background-color: #f5f6fb;
    border: 5px solid #b1bbdf;
    border-radius: 20px;
}
#about .about-item h3 {
    width: 266px;
    height: 64px;
    margin: -39px auto 33px;
    padding-top: 12px;
    color: #ffffff;
    background-color: #66668e;
    border-radius: 10px;
    font-size: 18px;
    line-height: 1.111;
    text-align: center;
}
#about .about-item h3::after {
    content: url("../images/about-h3-triangle.svg");
    display: block;
    margin-top: 10px;
}
#about .about-item .about-text-bg {
    background-image: url("../images/img-image5.svg");
    background-repeat: no-repeat;
    background-position: calc(50% - 10px) top;
    padding-top: 50px;
} 
#about .about-item .use {
    margin-bottom: 22px;
    line-height: 1.125;
    text-align: center;
}
#about .about-item .result {
    font-size: 18px;
    text-align: center;
    line-height: 1;
}
#about .about-item .result .em-color,
#about .about-item .result .em-color-01 {
    display: block;
    margin-top: 33px;
    color: #eb5583;
    font-size: 33px;
    font-weight: bold;
    line-height: 1.182;
}
#about .about-item .result .em-color-01 {
    margin-top: 25px;
}
#about .about-item .result .em-color-01 .em-size {
    font-size: 70px;
    line-height: 1;
}
#about .about-item .about-img {
    margin: 20px 0 25px;
}

@media only screen and (orientation:landscape) and (max-width : 813px),(orientation:portrait) and (max-width : 753px){
#about .h-border{
    margin: 14px auto 80px;
}
#about {
    padding: 80px 3% 63px;
}

#about .about-container{
    padding: 46px 4.7% 20px;
    border-radius: 30px;
}

}

@media screen and (min-width: 768px) {
#about {
    padding: 80px 0 106px;
}
#about .h-border {
    margin: 14px auto 115px;
}
#about .about-container {
    max-width: 1152px;
    margin: 0 auto;
    padding: 77px 4% 66px;
}
#about .about-flex {
    flex-direction: row;
    gap: 22px;
}
#about .about-item .result .em-color-01 {
    margin-top: 33px;
    margin-bottom: 25px;
}
#about .about-item .about-img {
    width: 94%;
    margin: 20px auto 20px;
}
}

/*ご利用イメージ　#introduce*/
#introduce {
    padding: 92px 3% 0;
}
#introduce h2 {
    font-size: 28px;
    text-align: center;
}
#introduce h2::after {
    content: 'introduce';
    display: block;
    margin-top: 24px;
    color: #b1bbdf;
    font-size: 17px;
    font-weight: normal;
    text-align: center;
}
#introduce .h-border {
    width: 115px;
    height: 2px;
    margin: 14px auto 32px;
    background-color: #b1bbdf;
    border-radius: 1px;
}
#introduce .introduce-img {
    margin-bottom: 20px;
}
#introduce .happy {
    width: 60%;
    margin: 0 auto;
}
@media screen and (min-width: 768px) {
#introduce {
    position: relative;
    padding: 82px 3% 110px;
}
#introduce .introduce-img .before {
    max-width: 1114px;
    margin: 0 auto 26px;
}
#introduce .introduce-img .before img {
    margin-left: -58px;
    margin-left: -5%;
}
#introduce .introduce-img .triangle {
    width: 45px;
    margin: 0 auto 3px ;
}
#introduce .introduce-img .after {
    max-width: 784px;
    margin: 0 auto;
}
#introduce .introduce-img .after img {
    margin-left: -7.39%;
}
}
@media screen and (min-width: 1000px) {
#introduce .happy {
    width: 346px;
    position: absolute;
    bottom: 0;
    left: calc(50% + 305px);
}
}

/*導入企業様の声　#voice*/
#voice {
    padding: 46px 0 150px;
    /*background-image: url("../images/bg-voice.jpg");*/
    background-repeat: no-repeat;
    background-position: right 40% top 0%;
    position: relative;
    z-index: 1;
}
#voice h2 {
    font-size: 28px;
    text-align: center;
}
#voice h2::after {
    content: 'voice';
    display: block;
    margin-top: 24px;
    color: #b1bbdf;
    font-size: 17px;
    font-weight: normal;
    text-align: center;
}
#voice .h-border {
    width: 115px;
    height: 2px;
    margin: 14px auto 49px;
    background-color: #b1bbdf;
    border-radius: 1px;
}

#voice .voice-container {
    max-width: 1160px;
    margin: 0 3%;
    padding: 42px 4.7% 36px;
    background-color: rgba(255,255,255,.9);
    border-radius: 63px;
}
#voice .voice-item {
    position:relative;
    margin-bottom: 50px;
    padding: 96px 30px 56px;
    background-color: #ffffff;
    border-radius: 30px;
}
#voice .voice-item:last-child {
    margin-bottom: 0;
}
#voice .voice-item .voice-img {
    position:absolute;
    top: -28px;
    left: -1px;
    width: 96px;
}
#voice .voice-item p {
    line-height: 1.5;
}


@media only screen and (orientation:landscape) and (max-width : 813px),(orientation:portrait) and (max-width : 753px){
#voice .voice-container {
    padding: 42px 4.7% 20px;
    border-radius: 40px;
}

}


@media screen and (min-width: 768px) {
#voice {
    padding: 88px 0 247px;
    background-size: cover;
    background-position: center center;
}
#voice .h-border {
    margin: 14px auto 83px;
}
#voice .voice-container {
    margin: 0 auto;
    padding: 59px 8% 149px;
}
#voice .voice-container .voice-flex {
    display: flex;
    gap: 8.8%;
}
#voice .voice-item {
    margin-bottom: 0;
    padding: 84px 48px 62px;
}
#voice .voice-item .voice-img {
    left: -37px;
}
}

/*選ばれる理由　#features*/
#features {
    margin: -97px 3% 0;
    padding:49px 30px 44px;
    padding:49px 4.7% 44px;
    background-color: #f5f6fb;
    border-radius: 65px;
    position: relative;
    z-index: 2;
}
#features h2 {
    font-size: 28px;
    text-align: center;
}
#features h2::after {
    content: 'features';
    display: block;
    margin-top: 24px;
    color: #b1bbdf;
    font-size: 17px;
    font-weight: normal;
    text-align: center;
}
#features .h-border {
    width: 115px;
    height: 2px;
    margin: 14px auto 38px;
    background-color: #b1bbdf;
    border-radius: 1px;
}
#features .features-item {
    margin-bottom: 67px;
}
#features .features-item:last-child {
    margin-bottom: 0;
}
#features .features-img {
    margin: 0 7% 0;
    border-radius: 20px;
    overflow: hidden;
}
#features .features-text {
    margin-top: -90px;
    max-width: 1140px;
    padding: 130px 17px 68px 33px;
    display: grid;
    grid-template-rows: min-content auto;
    grid-template-columns: min-content auto;
    gap: 49px 18px;
    align-items: center;
    background-color: #ffffff;
    border-radius: 30px;
}
#features .features-text .features-num {
    grid-row: 1 / 2;
	grid-column: 1 / 2;
    font-size: 69px;
}
#features .features-text .features-num::after {
    content: '';
    display: block;
    width: 30px;
    height: 2px;
    margin: 0 auto;
    border-radius: 1px;
    background-color: #65bdc4;
}
#features .features-text h3 {
    font-size: 23px;
    line-height: 1.3;
    grid-row: 1 / 2;
	grid-column: 2 / 3;
}
#features .features-text p {
    grid-row: 2 / 3;
	grid-column: 1 / 3;
}


@media only screen and (orientation:landscape) and (max-width : 813px),(orientation:portrait) and (max-width : 753px){
#features {
    margin: -50px 3% 0;
    /*padding:49px 30px 44px;*/
    padding:49px 4.7% 20px;
    background-color: #f5f6fb;
    border-radius: 40px;
    position: relative;
    z-index: 1;
}

}


@media screen and (min-width: 768px) {
#features {
    max-width: 1490px;
    margin: -186px auto 0;
    padding: 82px 0 140px 0;
}
#features .features-container {
    padding: 0 10% 0 14%;
}
#features .h-border {
    margin: 14px auto 145px;
}
#features .features-item {
    margin-bottom: 25px;
}
#features .features-img {
    width: 36%;
    margin: 0;
}
#features .features-text {
    max-width: 86.5%;
    margin-top: -216px;
    margin-left: auto;
    padding: 80px 30px 70px 28%;
    padding: 7% 30px 6% 28%;
    gap: 20px 30px;
}
#features .features-text p {
    grid-row: 2 / 3;
	grid-column: 2 / 3;
}
}





/*よくあるご質問　#faq*/
#faq {
    margin-top: -112px;
    background-image: url("../images/bg-grid.png");
    padding: 212px 3% 98px;
}
#faq h2 {
    font-size: 28px;
    text-align: center;
}
#faq h2::after {
    content: 'FAQ';
    display: block;
    margin-top: 24px;
    color: #b1bbdf;
    font-size: 17px;
    font-weight: normal;
    text-align: center;
}
#faq .h-border {
    width: 115px;
    height: 2px;
    margin: 14px auto 40px;
    background-color: #b1bbdf;
    border-radius: 1px;
}
.qa-cont {
    max-width: 880px;
    margin: 0 auto 29px;
    box-shadow: 8px 8px 0 rgba(102,102,142,.4);
    border-radius: 30px;
    background: #fff;
}
.qa-cont:last-child{
    margin-bottom: 0;
}
.qa-cont input{
    display: none;
}
.qa-cont label{
    display: block;
    position: relative;
    padding: 30px 80px 25px 98px;
    cursor: pointer;
    font-size: 22px;
    color: #65bdc4;
}
.qa-cont label:before{
    content: 'Q';
    position: absolute;
    top: 0;
    bottom:0;
    left: 30px;
    display: grid;
    place-items: center;
    width: 56px;
    height: 56px;
    margin: auto;
    font-size: 30px;
    font-weight: normal;
    color: #ffffff;
    background-color: #65bdc4;
    border-radius: 50%;
}
.qa-cont .plus{
    display: block;
    width: 20px;
    height: 20px;
    position: absolute;
    right: 26px;
    top: 0;
    bottom: 0;
    margin: auto;
}
.qa-cont .plus span{
    display: block;
    width: 100%;
    height: 100%;
}
.qa-cont .plus span:before,.qa-cont .plus span:after{
    content: '';
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 1px;
    background: #65bdc4;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}
.qa-cont .plus span:after{
    transform: rotate(90deg);
    transition:transform 0.3s;
}
.qa-cont:has(input:checked) .plus span:after{
    transform: rotate(0deg);
}
.answer-wrap{
    max-height: 0;
    overflow: hidden;
    transition:max-height 0.3s ; 
    padding: 0 19px 0 19px;
    position: relative;
}
.qa-cont:has(input:checked) .answer-wrap{
    max-height: 100vh;
}
.answer-wrap-in{
    margin-bottom: 22px;
    padding: 33px 25px 33px 22px;
    background-color: #f5f6fb;
    border-radius: 20px;
    line-height: 1.5;
}

@media only screen and (orientation:landscape) and (max-width : 813px),(orientation:portrait) and (max-width : 753px){
.qa-cont label:before{
    left: 20px;
    width: 48px;
    height: 48px;
    font-size: 28px;
}

.qa-cont label{
    padding: 30px 60px 25px 88px;
    font-size: 18px;
    line-height: 1.3;
}
}

@media screen and (min-width: 768px) {
#faq {
    margin-top: -214px;
    padding: 292px 0 96px;
}
#faq .h-border {
    margin: 14px auto 74px;
}
.qa-cont label{
    padding: 30px 80px 30px 114px;
}
.answer-wrap-in{
    margin-bottom: 20px;
    padding: 33px 77px 33px 95px;
}
}

/* お問い合わせフォーム　#inquiry*/
#inquiry {
    position: relative;
    padding: 79px 3% 208px;
    background-image: url("../images/bg-contact.png");
    background-repeat: no-repeat;
    background-position: bottom -1px center;
}
#inquiry h2 {
    font-size: 28px;
    text-align: center;
}
#inquiry h2::after {
    content: 'inquiry';
    display: block;
    margin-top: 24px;
    color: #b1bbdf;
    font-size: 17px;
    font-weight: normal;
    text-align: center;
}
#inquiry .h-border {
    width: 115px;
    height: 2px;
    margin: 14px auto 42px;
    background-color: #b1bbdf;
    border-radius: 1px;
}
#inquiry form {
    max-width: 785px;
    margin: 0 auto;
    padding: 70px 8% 48px 9%;
    background-color: #f5f6fb;
    border-radius: 62px;
}
#inquiry form .inquiry-item {
    display: flex;
    flex-direction: column;
    margin-bottom: 20px;
}
#inquiry form .inquiry-item label {
    color: #3c3a37;
    margin-bottom: 8px;
}
#inquiry form .inquiry-item input,
#inquiry form .inquiry-item textarea {
    padding: 12px;
    border: none;
    border-radius: 8px;
}
#inquiry form .inquiry-item textarea {
    line-height: 1.5;
}
#inquiry form .inquiry-item input::placeholder,
#inquiry form .inquiry-item textarea::placeholder {
    color: #c0c8dd;
    font-size: 16px;
}
#inquiry form input[type="submit"] {
    font-size: 23px;
    font-weight: bold;
    line-height: 1;
    margin: 8px auto 29px;
    padding: 20px 10%;
    border-radius: 32px;
    border: none;
    color: #ffffff;
    background-color: #eb5583;
}
#inquiry form .submit-btn,
#inquiry form .link-policy {
    text-align: center;
}
#inquiry form .link-policy a {
color: #3fa9f5;
text-decoration: underline;
}
#inquiry .guide {
    width: 217px;
    position: absolute;
    bottom: 0;
    left: -30px;
}


@media only screen and (orientation:landscape) and (max-width : 813px),(orientation:portrait) and (max-width : 753px){

#inquiry form input[type="submit"] {
    font-size: 18px;
}
}


@media screen and (min-width: 768px) {
#inquiry {
    padding: 72px 0 84px;
    background-size: 100% auto;
}
#inquiry .h-border {
    margin: 14px auto 54px;
}
#inquiry form {
    padding: 73px 35px 54px 34px;
    border-radius: 30px;
}
#inquiry form .inquiry-item {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 43px;
}
#inquiry form .inquiry-item label {
    width: 27%;
    margin-bottom: 0;
    text-align: right;
}
#inquiry form .inquiry-item input,
#inquiry form .inquiry-item textarea {
    width: 70%;
}
#inquiry form input[type="submit"] {
    margin: 4px auto 45px;
    padding: 30px 90px;
    border-radius: 42px;
}
#inquiry form .link-policy {
    font-size: 15px;
}
#inquiry #form2 .error-message {
    margin-left: 30%;
}
}
@media screen and (min-width: 1000px) {
#inquiry .guide {
    width: 297px;
    position: absolute;
    bottom: 0;
    right: calc(50% + 260px);
    left: auto;
}
}
.error-message {
    color: #e71a20;
}

/*---------------------------
サンクスページ
---------------------------*/
.thanks-wrap{
padding: 100px 0 110px;
position: relative;
background-image: url(../images/bg-contact.png);
background-repeat: no-repeat;
background-position: top 80px center;
background-size: 100%;
overflow: hidden;
}
.thanks-wrap p{
font-weight: 400;
font-size: 15px;
text-align: center;
line-height: 1.4;
margin-bottom: 40px;
}
.thanks-wrap .thanks-text {
font-size: 40px;
font-weight: 700;
line-height: 1.3;
margin-bottom: 50px;
}
.thanks-wrap .thanks-text:before{
content: '\e5ca';
font-family: 'Material Symbols Outlined';
display: block;
font-variation-settings: 'wght' 700,'GRAD' 200,'opsz' 24;
font-size: 34px;
width: 46px;
height: 46px;
line-height: 46px;
background: #EB5583;
border-radius: 50%;
color: #fff;
margin: 0 auto 25px;
}
.btn-pink{
display: block;
margin: 0 auto;
width: 226px;
height: 45px;
line-height: 45px;
background: #EB5583;
color: #fff;
font-weight: 700;
font-size: 15px;
border-radius: 50px;
text-align: center;
}
.thanks-wrap:after{
content: '';
display: block;
width: 221px;
height: 248px;
background: url(../images/img-image13.svg) no-repeat center bottom / 100%;
position: absolute;
left: calc(50% - 406px);
bottom: 0;
}

@media screen and (max-width : 1700px){
.thanks-wrap{
background-position: top 110px center;
}
}

@media screen and (max-width : 1500px){
.thanks-wrap{
background-position: top 130px center;
}
}

@media screen and (max-width : 1300px){
.thanks-wrap{
background-position: top 150px center;
}
}

@media screen and (max-width : 1200px){
.thanks-wrap{
background-position: bottom -10px center;
}
}

@media only screen and (orientation:landscape) and (max-width : 813px),(orientation:portrait) and (max-width : 753px){
.thanks-wrap{
padding: 40px 0 214px;
background-position: bottom -1px center;
background-size: 1278px;
}
.thanks-wrap .thanks-text{
font-size: 30px;
margin-bottom: 40px;
}
.thanks-wrap .thanks-text:before{
margin-bottom: 40px;
}
.thanks-wrap:after {
left: -50px;
bottom: -34px;
}
}
