/* 
    GoriWatch front.css
    
    基本的な設計は「SMACSS」を採用

*/


/* -------------- */
/* --Base Layer-- */
/* -------------- */

html{
    color: #454545;
    line-height: 1.5;
    font-family: sans-serif;
}

a{
    text-decoration: none;
    color: inherit;
}

button{
    background-color: transparent;
    border: none;
}


/* ---------------- */
/* --Layout Layer-- */
/* ---------------- */

.l-contents{
    padding: 3rem 0 5rem;  
}

.l-contents-full{
    width: 100%;
    margin: 0 auto;
}

.l-contents-wide{
    
}

.l-contents-base{
    width: 100%;
    max-width: 1025px;
    margin: 0 auto;
}
@media screen and (max-width: 1050px){
    .l-contents-base{
        width: calc( 100% - 4rem );
    }
}


/* ---------------- */
/* --Module Layer-- */
/* ---------------- */


/* 【共通部品】 START */

/* コンテナ */
.container--img img{
    object-fit: cover;
    width: 100%;
    margin: 0 auto;
}

.container--resimg{
    position: relative;
}

.container--resimg img{
    object-fit: cover;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
}

/* アラート */

/* インプット */

/* アイコン */

.icon:before{
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
}

.icon--check:before{
    content: '\f00c';
}

/* 見出し */

.container--page-title{
    text-align: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    margin: 0 auto 1.5rem;
    padding: 3rem 0;
}

.page-titile--inquiry{
    background-image: url('../img/inquiry.jpg');
}

.page-titile--company{
    background-image: url('../img/company.jpg');
}

.page-titile--service{
    background-image: url('../img/terms_service.jpg');
}

.page-titile--privacy{
    background-image: url('../img/terms_privacy.jpg');
}

.title--h1{
    font-size: 2rem;
    color: #ffffff;
    font-weight: 700;
    text-shadow: 0px 5px 5px rgb(0 0 0 / 50%);
}
@media screen and ( max-width:768px){
    .title--h1{
        font-size: 1.5rem;
    }
}

.title--h2{
    font-size: 1.5rem;
    color: #f78fbf;
    font-weight: 700;
}
@media screen and ( max-width:768px){
    .title--h2{
        font-size: 1.25rem;
    }
}

.title--h2-border{
    border-bottom: solid 3px #f78fbf;
    margin-bottom: 1rem;
}

/* ボタン */
.btn{
    cursor: pointer;
    text-decoration: none;
    border: none;
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

.btn:hover,
.href:hover{
    opacity: 0.5;
    transition: .25s ;
}

.btn a{
    display: block;
    width: 100%;
}

.href{
    cursor: pointer;
    color: #0a00ff;
}

.btn--submit{
    border: solid 1px #454545;
    color: #fff;
    background-color: #454545;
    padding: 1rem 1.5rem;
    font-weight: 700;
    box-shadow: 0px 2px 2px 2px rgb(37 27 27 / 20%);
    width: 100%;
    text-align: center;
    font-size: 1.2rem;
}

/* 表 */

/* 入力フォーム */

.table--form{
    width: 100%;
}

.table--form tr{
    border-top: solid 1px #454545;
}

.table--form tr:last-child{
    border-bottom: solid 1px #454545;
}

.table--form th{
    padding: 1.5rem 1rem;
    vertical-align: top;
    width: 30%;
    line-height: 1.5;
    font-weight: 700;
    background-color: #f0eded;
    border-left: solid 1px #454545;
    border-right: solid 1px #454545;
    box-sizing: border-box;
}
@media screen and ( max-width:768px) {
    .table--form th{
        display: block;
        width: 100%;
        padding: 1rem;
        border-bottom: solid 1px #454545;
    }
}

.table--form th .label--item{
    font-size: 1.2rem;
    text-align: left;
}

.table--form th .label--require{
    font-size: 1rem;
    color: #fff;
    font-weight: 700;
    background-color: #f9a2cc;
    border-radius: 15px;
    padding: 0.25rem 0.5rem;
    min-width: 48px;
}

.table--form td{
    padding: 1.25rem 1rem;
    font-size: 1.2rem;
    vertical-align: top;
    width: 70%;
    border-left: solid 1px #454545;
    border-right: solid 1px #454545;
    box-sizing: border-box;
}
@media screen and ( max-width:768px) {
    .table--form td{
        display: block;
        width: 100%;
        padding: 1rem;
    }
}

.table--form .wrap--label{
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: nowrap;
}

.table--form .wrap--input{
    box-sizing: border-box;
}

.table--form .wrap--input:nth-child(n + 2){
    margin-top: .75rem;
}

.table--form select{
    padding: .5rem;
}

.table--form .input{
    font-size: 1rem;
    padding: .75rem;
    border: solid 1px #454545;
    box-sizing: border-box;
}

.table--form .confirm{
    padding: .5rem;
    display: inline-block;
    word-break: break-all;
}

.table--form .label{
    display: block;
    font-size: 1.1rem;
    margin-bottom: 0;
    font-weight: 700;
    padding: .5rem 0;
    color: #654545;
}

.table--form .label-child{
    display: block;
    font-size: .95rem;
    margin-bottom: -0.25rem;
    font-weight: 700;
    padding: .5rem 0;
}

.table--form .label-child:nth-of-type(n + 2){
    margin-top: .25rem;
}

.table--form .label-description{
    display: block;
    font-size: .95rem;
}

.table--form .checkbox{
    display: none;
}

.table--form .checkbox:checked + .label-checkbox:before{
    content: '\f00c';
    position: absolute;
    display: block;
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
    color: #C46A6A;
    top: 7px;
    left: 2px;
}

.table--form .label-checkbox{
    position: relative;
    display: inline-block;
    padding: .5rem 0 .5rem 2rem;
}

.table--form .label-checkbox:nth-of-type(n + 2){
    margin-right: 1rem;
}

.table--form .label-checkbox:after{
    content: "";
    position: absolute;
    display: block;
    width: 24px;
    height: 24px;
    border: solid 1px #A5A5A5;
    top: 9px;
    left: 0;
}

.table--form .is-confirm:after{ /* .table--form .label-checkbox:afterを打消し */
    border: none;
}
@media screen and (min-width: 501px) and ( max-width:1000px) {
    .table--form .name{
        display: block;
        width: 100%;
        min-width: 260px;
    }
}
@media screen and ( max-width:500px) {
    .table--form .name{
        display: block;
        width: 100%;
    }
}


.table--form .name:nth-of-type(n + 2){
    margin-left: 1rem;
}
@media screen and ( max-width:1000px) {
    .table--form .name:nth-of-type(n + 2){
        margin-top: 1rem;
        margin-left: 0;
    }
}

.table--form .name-full{
    width: 100%;
}

.table--form .mail{
    width: 100%;
}

.table--form .postal-code-1{
    width: 55px;
    margin-right: .5rem;
}

.table--form .postal-code-2{
    width: 65px;
    margin-left: .5rem;
}

.table--form .address{
    width: 100%;
}

.table--form .tel{
    width: 4.063rem;
    margin-right: .5rem;
}

.table--form .textarea{
    width: 100%;
}

.table--form .confirm-tel{
    width: auto !important;
}

.table--form .tel{
    margin-right: .5rem;
    margin-left: .5rem;
}
@media screen and ( max-width:500px) {
    .table--form .tel{
        width: 3.2rem;
        font-size: .875rem;
        margin-right: .3rem;
        margin-left: .3rem;
        padding: .5rem;
    }
}

.table--form .tel:first-child{
    margin-left: 0;
}

.table--form .tel:last-child{
    margin-right: 0;
}

.table--form .radio{
    margin-right: .25rem;
}

.table--form .radio:nth-of-type( n + 2 ){
    margin-left: 1rem;
}

.table--form .email{
    width: 100%;
}

.table--form .sex + label{
    margin-right: 1rem;
}

.table--form .password{
    width: 100%;
}

.table--form .wrap--block{
    padding: 0 1.5rem 1.5rem;
}

.table--form .wrap--block-border{
    border-bottom: solid 1px #454545;
}

.table--form .wrap--block-padding{
    padding-top: 1.5rem;
}

.table--form .container--error{
    background-color: #ffd6c9;
}

.table--form .wrap--input--password{
    position: relative;
}

.table--form .wrap--input--password .btn--password{
    position: absolute;
    top: 13px;
    right: 15px;
}

.table--plan{
    text-align: center;
    border-collapse: separate;
    border-spacing: 3px 3px;
}
@media screen and ( max-width:768px){
    .table--plan{
        border-collapse: collapse;
    }
}

.table--plan thead td{
    width: 200px;
}

.table--plan .plan-name{
    padding: .5rem .5rem;
    color: #fff;
    font-weight: 700;
    width: 100%;
    margin: 0 auto 1rem;
    box-sizing: border-box;
}

.table--plan .plan-name--free{
    background-color: #2AC705;
}

.table--plan .plan-name--standard{
    background-color: #12A6D5;
}

.table--plan .plan-name--business{
    background-color: #B012D5;
}

.table--plan tbody th{
    font-weight: 700;
    padding: .25rem .5rem;
    box-sizing: border-box;
}
@media screen and ( max-width:768px){
    .table--plan tbody th{
        display: block;
        width: 100%;
    }
}

.table--plan tbody td{
    padding: .25rem .5rem;
    box-sizing: border-box;
}
@media screen and ( max-width:768px){
    .table--plan tbody td{
        display: block;
        width: 100%;
    }
}

.table--plan tbody tr:nth-child(odd) td{
    background-color: rgba( 0 , 0 , 0 , .04 );
}
@media screen and ( max-width:768px){
    .table--plan tbody tr:nth-child(odd) td,
    .table--plan tbody tr:nth-child(even) td{
        background-color: #fff;
    }
}

.table--plan tbody tr:nth-child(odd) th{
    background-color: rgba( 255 , 157 , 150 , .2 );
}

.table--plan tbody tr:nth-child(even) th{
    background-color: rgba( 255 , 157 , 150 , .1 );
}
@media screen and ( max-width:768px){
    .table--plan tbody tr:nth-child(even) th{
        background-color: rgba( 255 , 157 , 150 , .2 );
    }
}

.table--front{
    width: 100%;
}

.table--front tr{
    width: 100%;
    height: 5rem;
    border-top: solid 2px #fad5e7;
}

.table--front tr:last-child{
    border-bottom: solid 2px #fad5e7;
}

.table--front th{
    width: calc( 15% );
    padding: 1rem;
    font-weight: 700;
    vertical-align: middle;
    box-sizing: border-box;
}
@media screen and ( max-width:768px){
    .table--front th{
        display: block;
        width: 100%;
        text-align: center;
        padding-top: 1rem;
        padding-bottom: .5rem;
    }
}

.table--front td{
    width: calc( 85% );
    padding: 1rem;
    vertical-align: middle;
    box-sizing: border-box;
}
@media screen and ( max-width:768px){
    .table--front td{
        display: block;
        width: 100%;
        text-align: center;
        padding-top: 0;
        padding-bottom: 1rem;
    }
}

/* リスト */
.list--large{
    list-style: decimal;
    padding: 0 0 0 1.5rem;
    margin-right: 0;
}

.list--large li{
    margin-bottom: .5rem;
}

.list--medium{
    padding: 0 0 0 .5rem;
    margin-right: 0;
}

.list--medium li{
    list-style-type: none;
	counter-increment: cnt;
    text-indent: -1.8rem;;
    padding-left: 1.25rem;
    margin-bottom: .5rem;
}

.list--medium li::before {
	content: "(" counter(cnt) ") ";
}


/* モーダルウィンドウ */


/* 【共通部品】 END */


/* 【共通エレメント】 START */

/* 全ページ共通 */

/* ヘッダー */
.header--front{
    width: 100%;
    background-color: #454545;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
}

@media screen and ( max-width:768px){
    .header--front{
        height: auto;
    }
}

.header--front .wrap--header{
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .5rem 2rem;
}
@media screen and ( max-width:768px){
    .header--front .wrap--header{
        flex-wrap: wrap;
        justify-content: space-around;
    }
}

@media screen and ( max-width:768px){
    .header--front .wrap--logo{
        width: calc( 100% - 3.75rem );
        margin-right: 1rem;
    }
}

@media screen and ( max-width:768px){
    .header--front .wrap--icon{
        width: 1.75rem;
        margin-left: 1rem;
        text-align: right;
    }
}

.header--front .logo{
    font-size: 2rem;
    color: #fff;
    font-weight: 700;
}

.header--front .wrap--menu{
    display: flex;
    margin-left: auto;
    margin-right: 1rem;
}
@media screen and ( max-width:768px){
    .header--front .wrap--menu{
        display: none;
        width: 100%;
        margin-top: 1rem;
        margin-right: 0;
    }
}

.header--front .wrap--menu .wrap--button{
    margin: auto 1rem;
    text-align: center;
}

@media screen and ( max-width:768px){
    .header--front .wrap--menu .wrap--button{
        border-top: solid 1px #fff;
        padding: 1rem;
        margin: auto 0;
    }
}

.header--front .wrap--menu .btn{
    color: #fff;
    font-weight: 700;
    font-size: 1rem;
}

@media screen and ( max-width:768px){
    .header--front .wrap--login{
        display: none;
        width: 100%;
        border-top: solid 1px #fff;
        text-align: center;
    }
}

@media screen and ( max-width:768px){
    .header--front .wrap--button{
        padding: 0.25rem 1rem;
    }
}

.header--front .wrap--login .btn{
    border: solid 2px #fff;
    color: #fff;
    font-weight: 700;
    font-size: 1rem;
}
@media screen and ( max-width:768px){
    .header--front .wrap--login .btn{
        border: none;
    }
}

.header--front .wrap--login .btn a{
    padding: 0.5rem 1rem;
    box-sizing: border-box;
}

.header--front .wrap--icon{
    display: none;
    color: #ffffff;
}

@media screen and ( max-width:768px){
    .header--front .wrap--icon{
        display: flex;
        justify-content: right;
        align-items: center;
    }
}

@media screen and ( max-width:768px){
    .header--front .wrap--icon div{
        display: flex;
        justify-content: center;
        align-items: center;
    }
}

@media screen and ( max-width:768px){
    .header--front .icon--bars{
        font-size: 2rem;
    }
}

@media screen and ( max-width:768px){
    .header--front .icon--xmark{
        font-size: 2.5rem;
    }
}



/* フッター */
.footer--front{
    width: 100%;
    background-color: #454545;
    color: #ffffff;
    font-weight: 700;
    padding: 1.75rem 0 7rem;
}

.footer--front .wrap--footer{
    padding: 0 1rem;
}

.footer--front .logo{
    font-size: 2rem;
    text-align: center;
    margin-bottom: .25rem;
}

.footer--front .wrap--memu ul{
    margin: 0 auto 1.5rem;
    display: flex;
    justify-content: center;
    font-size: .875rem;
}
@media screen and ( max-width:768px){
    .footer--front .wrap--memu ul{
        flex-wrap: wrap;
    }
}

.footer--front .wrap--memu li{
    padding: 0 .75rem;
    border-right: solid 2px #ffffff;
    line-height: 1;
}
@media screen and ( max-width:768px){
    .footer--front .wrap--memu li{
        border-right: none;
        width: 100%;
        text-align: center;
        margin-top: .25rem;
    }
}

.footer--front .wrap--memu li:last-child{
    border-right: none;
}

.footer--front .copy{
    text-align: center;
}

/* チャート */

.chart{
    margin: 4rem auto;
}

.chart ul{
    display: flex;
    justify-content: center;
}

.chart li{
    padding: .75rem 2.5rem;
    color: #454545;
    background-color: #eeeeee;
    font-weight: 700;
    font-size: 1.25rem;
    margin: 0 2rem;
    line-height: 1.5rem;
    border: solid 2px #454545;
}
@media screen and (min-width:451px) and (max-width:768px){
    .chart li{
        margin: 1rem;
        padding: 0.75rem 1.5rem;
    }
}
@media screen and (max-width:450px){
    .chart li{
        margin: .5rem;
        padding: .75rem;
    }
}

.chart .is-active{
    color: #fff;
    background-color: #654545;
}

/* ディスクリプション */

.wrap--description .description{
    text-align: center;
    line-height: 1.5;
}
@media screen and (max-width: 768px) {
    .wrap--description .description{
        text-align: left;
    } 
}

/* サブミット */
.submit .wrap--buttun{
    width: 400px;
    margin: 0 auto;
}
@media screen and (max-width: 450px) {
    .submit .wrap--buttun{
        width: 280px;
    }
}

.submit .wrap--buttun .btn:nth-of-type( n + 2 ){
    margin-top: 2rem;
}

.submit .icon--chevron-left{
    position: relative;
}

.submit .icon--chevron-left:before{
    position: absolute;
    top: 16px;
    left: 16px;
}

.submit .icon--chevron-right{
    position: relative;
}

.submit .icon--chevron-right:before{
    position: absolute;
    top: 16px;
    right: 16px;
}

/* オーバーレイ */
.overlay{
    width: 100%;   
    padding: .75rem;
    box-sizing: border-box;
}

.front-index .overlay{
    background-color: rgba( 255 , 255 , 255 , 0 );
}

.footer--front .overlay{
    position: fixed;
    bottom: 0;
    background-color: #fad5e7;
}

.footer--front .overlay{
    position: fixed;
    bottom: 0;
    background-color: #fad5e7;
}

.overlay .wrap--content{
    width: 400px;
    margin: 0 auto;
    text-align: center;
}
@media screen and ( max-width:768px){
    .overlay .wrap--content{
        width: 100%;
    }
}

.overlay .wrap--content .catchphrase{
    font-size: .8rem;
    font-weight: 700;
    color: #454545;
    margin-bottom: .25rem;
}

.overlay .wrap--content .wrap--button .btn{
    font-size: .9rem;
    color: #fff;
    font-weight: 700;
    background-color: #454545;
    padding: .5rem 1.5rem;
    border-radius: 30px;
    width: 380px;
}
@media screen and ( max-width:768px){
    .overlay .wrap--content .wrap--button .btn{
        width: auto;
    }
}



/* 【共通エレメント】 END */


/* 【個別ページ】 START */

/* TOPページ */
.front-index .front-index__eyecatch{
    background-image: url("../img/index-keyvisual.jpg");
    background-repeat: no-repeat;
    background-position: center;
    height: auto;
}

.front-index__eyecatch .wrap--site-title{
    padding-top: 3rem;
    text-align: center;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .wrap--site-title{
        padding: 1.5rem 1rem 0;
    }
}

.front-index__eyecatch .catchphrase{
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: .5rem;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .catchphrase{
        font-size: 1.4rem;
    }
}

.front-index__eyecatch .site-title{
    font-size: 3.2rem;
    font-weight: 700;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .site-title{
        font-size: 2.6rem;
    }
}

.front-index__eyecatch .wrap--lead{
    padding: 2rem;
    margin: 0 auto 3rem;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .wrap--lead{
        margin-bottom: 0;
    }
}

.front-index__eyecatch .wrap--lead ul{
    display: flex;
    flex-wrap: wrap;
    width: 650px;
    margin: 0 auto;
    background-color: #E2E6E9;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .wrap--lead ul{
        display: block;
        width: 100%;
        text-align: center;
    }
}

.front-index__eyecatch .wrap--lead li{
    width: calc( 50% - 4rem );
    margin: 2rem;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .wrap--lead li{
        width: 100%;
        margin: 0 0 1rem;
    }
}

.front-index__eyecatch .lead-title{
    font-size: 1.3rem;
    font-weight: 700;
    color: #f78fbf;
    margin-bottom: .75rem;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .lead-title{
        font-size: 1.2rem;
        margin-bottom: .5rem;
    }
}

.front-index__eyecatch .lead-title:before{
    color: #004BB1;
    font-size: 1.5rem;
}

.front-index__eyecatch .lead-sentence{
    font-size: 1rem;
    font-weight: 700;
}
@media screen and ( max-width:768px){
    .front-index__eyecatch .lead-sentence{
        font-size: .9rem;
    }
}

.front-index__feature{
    padding: 3rem 0;
}
@media screen and ( max-width:768px){
    .front-index__feature{
        padding: 3rem 0 1rem;
    }
}

.front-index__feature .feature{
    display: flex;
    margin-bottom: 2.5rem;
}
@media screen and ( max-width:768px){
    .front-index__feature .feature{
        flex-wrap: wrap;
    }
}
@media screen and ( max-width:768px){
    .front-index__feature .feature:nth-child(2){
        display: flex;
        flex-direction: column-reverse;
    }
}

.front-index__feature .feature .title{
    font-size: 1.7rem;
    color: #f78fbf;
    font-weight: 700;
    margin-bottom: .5rem;
}
@media screen and ( max-width:768px){
    .front-index__feature .feature .title{
        text-align: center;
        font-size: 1.35rem;
    }
}

.front-index__feature .feature-sentence{
    width: calc( 50% - 1rem );
    margin-right: 1rem;
}
@media screen and ( max-width:768px){
    .front-index__feature .feature-sentence{
        width: calc( 100% );
        margin: 0 0 1.5rem;
    }
}

.front-index__feature .feature-sentence-reverce{ /* 「.feature-sentence」を上書き */
    margin-right: 0;
    margin-left: 1rem;
}

.front-index__feature .feature-img{
    width: calc( 50% - 1rem );
    margin-left: 1rem;
}
@media screen and ( max-width:768px){
    .front-index__feature .feature-img{
        width: calc( 100% );
        margin-left: 0;
    }
}

.front-index__feature .feature-img-reverce{ /* 「.feature-img」を上書き */
    margin-left: 0;
    margin-right: 1rem;
}

.front-index__plan{
    padding: 3rem 0;
    background-color: rgba( 219 , 192 , 166 , 0.2 );
}

.front-index__plan .wrap--title{
    text-align: center;
}

.front-index__plan .title--h2{
    margin-bottom: 1rem;
}

.front-index__plan .description{
    margin-bottom: 1.5rem;
}

.front-index__plan .wrap--plan-table{
    background-color: #fff;
    border: solid 1px #cccccc;
    margin-bottom: 2rem;
}

.front-index__plan .table--plan{
    width: calc( 100% - 2rem );
    margin: 1rem;
}

.front-index__plan .supplement{
    text-align: left;
    font-size: .875rem;
    margin-bottom: 1rem;
    padding-left: 1rem;
}


/* お問い合わせ */

.front-inquiry{

}

.front-inquiry .wrap--front-title{
    text-align: center;
    margin: 3rem 0 2rem;
}

.front-inquiry .submit{
    margin: 4rem 0 6rem;
}

/* 利用規約、プライバシーポリシー */
.terms-privacy {

}

.terms_service__title{
    margin-bottom: 3rem;
}

.terms_service__title .title--h2{
    margin-bottom: 1rem;
}

.terms_service__body .wrap--terms{
    margin-bottom: 2rem;
}
@media screen and ( max-width:1048px){
    .terms_service__body .wrap--terms{
        
    }
}

.terms_service__body .wrap--term:first-child{
    margin-bottom: 2rem;
}

.terms_service__body .wrap--term{
    margin-bottom: 1.5rem;
}

.terms_service__body .wrap--detail{
    padding: 0;
}
@media screen and ( min-width:401px) and (max-width:768px){
    .terms_service__body .wrap--detail{
        
    }
}
@media screen and (max-width:400px){
    .terms_service__body .wrap--detail{
        padding: 0;
    }
}

.terms_service__body .wrap--detail p{
    margin-bottom: .5rem;
}

.terms_service__body .by-law{
    padding: 0;
}

.terms_service__body .by-law p{
    margin-bottom: .5rem;
}
@media screen and (max-width:768px){
    .terms_service__body .by-law p{
        margin-bottom: .25rem;
    }
}

/* 運営会社 */
.company .table--front{
    margin-top: 4rem;
}  

/* サンクスページ */
.wrap--description{
    margin-bottom: 3rem;
}


/* 【個別ページ】 END */

/* ----------------- */
/* -- State Layer -- */
/* ----------------- */



/* ------------- */
/* -- Utility -- */
/* ------------- */

.u-display-block{
    display: block !important;
}

.u-display-inlineblock{
    display: inline-block !important;
}

.u-display-flex{
    display: flex !important;
}

.u-display-none{
    display: none !important;
}

.u-display-table-pc{
    display: table !important;
}
@media screen and ( max-width:768px){
    .u-display-table-pc{
        display: none !important;
    }
}

.u-display-table-sp{
    display: none !important;
}
@media screen and ( max-width:768px){
    .u-display-table-sp{
        display: table !important;
    }
}