@charset "utf-8";
@media screen and (max-width:1024px) {
.banner {
    max-width: 200px;
}
.plan_card {
    padding: 35px 15px;
}
.plan_card>p {
    font-size: 16px;
}
.flow_wrapper_text {
    max-width: 550px;
}
.flow_number {
    width: 55px;
    height: 55px;
    line-height: 55px;
    top: -25px;
    left: -10px;
}
#RULE:after {
    width: 90vw;
}
  
}

@media screen and (max-width: 768px) {
h2 {
    font-size: 35px;
}
.pc-only {
    display: none;
}
.less-ipad {
    display: block;
}
.Column2 {
    flex: 0 0 100%;
    max-width: 100%;
}
.row {
    display: block;
}
.inner {
    padding: 60px 20px;
}
.Column3_1 {
    flex: 0 0 100%;
    max-width: 100%;
}
#MAINIMG {
    margin-top: 70px;
    padding: 50px 0 30px;
}
#MAINIMG .inner {
    flex-direction: column;
}
#MAINIMG img.fv-logo {
    max-width: 470px;
    display: block;
    margin: 0 auto 35px;
}
#MAINIMG p {
    font-size: 18px;
}
#MAINIMG img.fv-illust {
    max-width: 350px;
    margin: 0 auto 10px;
}
.omakase p {
    font-size: 35px;
}
#POINT h3 {
    margin: 0 auto 15px;
}
#POINT h2 img {
    max-width: 315px;
}
#POINT .Column3 {
    max-width: 490px;
    margin: 0 auto 30px;
}
#SERVICE:before {
    top: -40px;
}
.service_wrapper {
    padding: 30px;
    max-width: 650px;
}
.service {
    grid-template-columns: repeat(2, 1fr);
}
.service_wrapper {
    padding: 40px;
    max-width: 680px;
}
.service_card img {
    max-width: 100px;
}
.modalWrapper {
    max-width: 90vw;
}
.modal_service {
    grid-template-columns: repeat(2, 1fr);
}
#PLAN .Column3 {
    flex: unset;
    max-width: 70vw;
    margin: 0 auto;
}
.service_wrapper h3 {
    font-size: 45px;
    margin-bottom: 25px;
}
.plan_card .price span.number, .plan_card .period span, .plan_card .revision span {
    font-size: 35px;
}
.flow_wrapper_text h3 {
    font-size: 20px;
}
.flow_number {
    width: 50px;
    height: 50px;
    line-height: 50px;
    top: -20px;
    font-size: 25px;
}
.flow_wrapper img {
    max-width: 250px;
}
#RULE:before {
    top: -40px;
}
#RULE .Column3 {
    flex: unset;
    max-width: 100%;
}
.rule_box {
    border: 4px solid #ded9c9;
    max-width: 600px;
}
#RULE:after {
    width: 96vw;
    height: 70%;
    top: 21%;
}
#CONTACT .inner>p {
    max-width: 610px;
}
.contact-form th {
    width: 35%;
}
.contact-form td {
    width: 65%;
}
.banner {
    display: none;
}    
footer .Column2 {
    flex: 0 0 50%;
    max-width: 50%;
}
  
}

@media screen and (max-width: 480px) {
.for-pc {
    display: none!important;
}
.for-sp {
    display: block!important;
}
.sp-menu-wrapper {
    padding: 30px 30px;
    border-radius: 10px;
    width: 85vw;
}
h2 {
    font-size: 25px;
}
p {
    font-size: 15px;
}
.sp-nav_contact a.sp-nav_contact-btn {
    display: none;
}
.sp-nav__wrapper h1 img {
    max-width: 180px;
    margin-top: -3px;
    display: block;
}
.sp-nav__wrapper h1 span {
    font-size: 12px;
    line-height: 1.3;
}
#PAGE-TOP {
    bottom: 20px;
    right: 20px;
}
#MAINIMG {
    padding: 40px 0 20px;
}
#MAINIMG .inner {
    padding: 0 10px 20px;
}
#MAINIMG p {
    font-size: 15px;
    margin-bottom: 20px;
}
#MAINIMG img.fv-illust {
    max-width: 220px;
    margin: 0 auto 10px;
}
#MAINIMG img.fv-logo {
    margin: 0 auto 25px;
}
.card_tate {
    max-width: 80px;
    margin-right: 30px;
}
.card_pc {
    max-width: 150px;
    margin-right: 20px;
}
.card_yoko {
    max-width: 120px;
    margin-right: 20px;
}
.worries_wrapper {
    padding: 20px 25px;
}
.worries_wrapper .blline {
    font-size: 16px;
}
.worries_wrapper .worries_text {
    max-width: 173px;
}
.worries_wrapper .worries_text {
    margin: 15px auto 20px;
}
.worries_illust {
    width: 60px;
    height: 85px;
    left: 10px;
    top: 50px;
}
.worries li:before {
    width: 14px;
    height: 14px;
}
.worries li {
    font-size: 15px;
    font-weight: 500;
}
/*.worries_wrapper:after {
    bottom: -60px;
    border-width: 60px 72.5px 0 72.5px;
}*/
.worries_wrapper:before {
    position: absolute;
    content: '';
    left: 50%;
    transform: translate(-50%, 0);
    bottom: -27px;
    width: 100px;
    height: 30px;
    background: #fff
}
.worries_wrapper:after {
    bottom: -60px;
    border-width: 40px 70px 0 70px;
}
.omakase p {
    font-size: 25px;
}
.omakase p span {
    font-size: 20px;
}
.omakase {
    padding: 25px 0;
}
#POINT h2 img {
    max-width: 255px;
}
#POINT h3 {
    font-size: 20px;
}
#POINT .Column3 img {
    max-width: 240px;
}
#POINT .Column3:nth-of-type(3) {
    margin: 0 auto;
}
#SERVICE:before {
    top: -20px;
}
.service_wrapper {
    margin: 0 auto 30px;
}
.service_wrapper:last-child {
    margin: 0 auto;
}
.service_wrapper h3 {
    font-size: 35px;
}
.service_wrapper h3 span {
    font-size: 14px;
}
.service {
    display: flex;
    flex-direction: column;
}
.service_card img {
    max-width: 80px;
}
.service_wrapper {
    padding: 30px 25px;
}
.service_card {
    margin-bottom: 13px;
}
.service_card {
    margin-bottom: 13px;
}
.service_card:last-child {
    margin-bottom: 0;
}
.service_card_text h4 {
    font-size: 15px;
}
.service_card_text p {
    font-size: 13px;
}
.service_wrapper>p {
    margin: 20px auto 0;
}
#PLAN .Column3 {
    max-width: 90vw;
}
.plan_card h3 img {
    max-width: 220px;
}
.plan_card h4 {
    font-size: 18px;
}
.plan_card .price span.number, .plan_card .period span, .plan_card .revision span {
    font-size: 30px;
}
.initial {
    font-size: 14px;
}
.initial span {
    font-size: 18px;
}
.plan_card .price span:nth-of-type(2) {
    font-size: 14px;
}
.plan_card .price {
    padding: 20px 0;
}
.plan_card .period {
    padding: 20px 0 10px;
}
.plan_card .revision {
    padding: 20px 0 15px;
}
.openModal {
    font-size: 15px;
}
.modalWrapper {
    max-height: 80vh;
}
.modal_service {
    display: flex;
    flex-direction: column;
}
.modal_contents>p {
    font-size: 16px;
}
.modal_service_card {
    margin: 10px 0 0;
}
.modal_service_card h5 {
    font-size: 15px;
}
.modal_service_card img {
    max-width: 70px;
}
.flow_wrapper {
    flex-direction: column;
    margin-bottom: 40px;
}
.flow_wrapper_text {
    margin-right: 0;
    margin-bottom: 15px;
}
.flow_wrapper_text h3 {
    font-size: 17px;
    padding: 3px 1em;
    margin: 0 auto 15px;
}
.flow_wrapper_text h3::after {
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    bottom: -13px;
    top: unset;
    border-width: 8px 0 8px 12px;
    transform: rotate(90deg);
}
.flow_wrapper img {
    max-width: 230px;
    display: block;
    margin: 0 auto;
}
.flow_number {
    width: 45px;
    height: 45px;
    line-height: 45px;
    font-size: 18px;
}
#RULE:before {
    top: -20px;
}
.rule_box {
    background: #fff;
    border: 2px solid #ded9c9;
    border-radius: 20px;
    padding: 15px 10px;
}
.rule_box img {
    max-width: 140px;
}
#RULE .inner {
    padding: 60px 20px 0;
}
#RULE:after {
    width: 96vw;
    height: 63%;
    top: 25%;
}
.faq_wrapper h3 {
    font-size: 20px;
}
#FAQ .question {
    padding: 15px 35px 15px 55px;
    font-size: 15px;
}
.faq_wrapper {
    padding: 30px 20px;
}
#FAQ .question:before {
    font-size: 20px;
}
#FAQ .question:before {
    left: 10px;
}
#FAQ .answer {
    padding: 0 20px 15px 55px;
    font-size: 14px;
}
.agreement_wrapper {
    width: 100%;
    height: 100%;
    background: unset;
}
.agreement_card {
    padding: 0;
    height: unset;
}
.slick-slide {
    min-height: unset;
}
.slick-prev {
    left: 0;
}
.slick-next {
    right: -10px;
}
#AGREEMENT .slick-next:before {
    right: 0;
}
#AGREEMENT .slick-arrow:before {
    width: 30px!important;
    height: 30px!important;
}
#AGREEMENT .slick-next:before {
    right: 0;
}
#AGREEMENT .slick-prev:before {
    left: -10px;
}
.contact_wrapper {
    padding: 20px;
}
.contact-form th, .contact-form td {
    display: block;
    width: 100%;
    font-size: 14px;
}
.contact-form th {
    padding-bottom: 0;
}
.submit button {
    font-size: 15px;
}
#PRIVACY h3 {
    font-size: 15px;
}
#PRIVACY p {
    font-size: 13px;
}
#PRIVACY {
    padding: 15px;
}
footer .inner {
    padding: 20px 0;
}
footer .inner>p {
    font-size: 20px;
}
footer .Column2 {
    flex: 0 0 100%;
    max-width: 100%;
}
.footer_company {
    flex-direction: column;
}
.footer_company img {
    max-width: 170px;
    margin-right: 0;
}
.footer-right p {
    font-size: 13px;
}
footer address {
    font-size: 11px;
}
}

@media screen and (max-width: 350px) {
#MAINIMG img.fv-logo {
    margin: 0 auto 20px;
}
.worries_wrapper .worries_text {
    max-width: 155px;
}
.worries_illust {
    width: 48px;
    height: 68px;
    left: 20px;
    top: 55px;
}
.flow_wrapper {
    padding: 20px 15px;
}
#FAQ .question:after {
    right: 10px;
}
  
}