@charset "utf-8";

/*********************
Last update:
**********************/
/* ====================================================================
Spacing
======================================================================*/
.row {
    margin: 0 !important;
}

.nonepadding {
    padding: 0 !important;
}

.panelcontens {
    position: relative;
    padding: 0;
}

.commonsp_s {
    padding-left: 10px;
    padding-right: 10px;
}

.commonsp {
    padding-left: 20px;
    padding-right: 20px;
}

.commonsp_b {
    padding-left: 100px;
    padding-right: 100px;
}

.commonsp_0 {
    padding-left: 20px;
    padding-right: 20px;
}


/*padding top bottom */
.sp-top-bottom120 {
    padding-top: 120px !important;
    padding-bottom: 120px !important;
}

.sp-top-bottom110 {
    padding-top: 110px !important;
    padding-bottom: 110px !important;
}

.sp-top-bottom100 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
}

.sp-top-bottom90 {
    padding-top: 90px !important;
    padding-bottom: 90px !important;
}

.sp-top-bottom80 {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
}

.sp-top-bottom70 {
    padding-top: 70px !important;
    padding-bottom: 70px !important;
}

.sp-top-bottom60 {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
}

.sp-top-bottom50 {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
}

.sp-top-bottom40 {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
}

.sp-top-bottom30 {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
}

.sp-top-bottom20 {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
}

.sp-top-bottom10 {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}

.sp-top-bottom5 {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
}

/*padding top */
.sp-top120 {
    padding-top: 120px !important;
}

.sp-top110 {
    padding-top: 110px !important;
}

.sp-top100 {
    padding-top: 100px !important;
}

.sp-top90 {
    padding-top: 90px !important;
}

.sp-top80 {
    padding-top: 80px !important;
}

.sp-top70 {
    padding-top: 70px !important;
}

.sp-top60 {
    padding-top: 60px !important;
}

.sp-top50 {
    padding-top: 50px !important;
}

.sp-top40 {
    padding-top: 40px !important;
}

.sp-top30 {
    padding-top: 30px !important;
}

.sp-top20 {
    padding-top: 20px !important;
}

.sp-top10 {
    padding-top: 10px !important;
}

.sp-top5 {
    padding-top: 5px !important;
}

/*padding bottom */
.sp-bottom120 {
    padding-bottom: 120px !important;
}

.sp-bottom110 {
    padding-bottom: 110px !important;
}

.sp-bottom100 {
    padding-bottom: 100px !important;
}

.sp-bottom90 {
    padding-bottom: 90px !important;
}

.sp-bottom80 {
    padding-bottom: 80px !important;
}

.sp-bottom70 {
    padding-bottom: 70px !important;
}

.sp-bottom60 {
    padding-bottom: 60px !important;
}

.sp-bottom50 {
    padding-bottom: 50px !important;
}

.sp-bottom40 {
    padding-bottom: 40px !important;
}

.sp-bottom30 {
    padding-bottom: 30px !important;
}

.sp-bottom20 {
    padding-bottom: 20px !important;
}

.sp-bottom10 {
    padding-bottom: 10px !important;
}

.sp-bottom5 {
    padding-bottom: 5px !important;
}

/*margin top bottom */
.sm-top-bottom120 {
    margin-top: 120px !important;
    margin-bottom: 120px !important;
}

.sm-top-bottom110 {
    margin-top: 110px !important;
    margin-bottom: 110px !important;
}

.sm-top-bottom100 {
    margin-top: 100px !important;
    margin-bottom: 100px !important;
}

.sm-top-bottom90 {
    margin-top: 90px !important;
    margin-bottom: 90px !important;
}

.sm-top-bottom80 {
    margin-top: 80px !important;
    margin-bottom: 80px !important;
}

.sm-top-bottom70 {
    margin-top: 70px !important;
    margin-bottom: 70px !important;
}

.sm-top-bottom60 {
    margin-top: 60px !important;
    margin-bottom: 60px !important;
}

.sm-top-bottom50 {
    margin-top: 50px !important;
    margin-bottom: 50px !important;
}

.sm-top-bottom40 {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
}

.sm-top-bottom30 {
    margin-top: 30px !important;
    margin-bottom: 30px !important;
}

.sm-top-bottom20 {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
}

.sm-top-bottom10 {
    margin-top: 10px !important;
    margin-bottom: 10px !important;
}

.sm-top-bottom5 {
    margin-top: 5px !important;
    margin-bottom: 5px !important;
}

/*margin top */
.sm-top120 {
    margin-top: 120px !important;
}

.sm-top110 {
    margin-top: 110px !important;
}

.sm-top100 {
    margin-top: 100px !important;
}

.sm-top90 {
    margin-top: 90px !important;
}

.sm-top80 {
    margin-top: 80px !important;
}

.sm-top70 {
    margin-top: 70px !important;
}

.sm-top60 {
    margin-top: 60px !important;
}

.sm-top50 {
    margin-top: 50px !important;
}

.sm-top40 {
    margin-top: 40px !important;
}

.sm-top30 {
    margin-top: 30px !important;
}

.sm-top20 {
    margin-top: 20px !important;
}

.sm-top10 {
    margin-top: 10px !important;
}

.sm-top5 {
    margin-top: 5px !important;
}

/*margin bottom */
.sm-bottom120 {
    margin-bottom: 120px !important;
}

.sm-bottom110 {
    margin-bottom: 110px !important;
}

.sm-bottom100 {
    margin-bottom: 100px !important;
}

.sm-bottom90 {
    margin-bottom: 90px !important;
}

.sm-bottom80 {
    margin-bottom: 80px !important;
}

.sm-bottom70 {
    margin-bottom: 70px !important;
}

.sm-bottom60 {
    margin-bottom: 60px !important;
}

.sm-bottom50 {
    margin-bottom: 50px !important;
}

.sm-bottom40 {
    margin-bottom: 40px !important;
}

.sm-bottom30 {
    margin-bottom: 30px !important;
}

.sm-bottom20 {
    margin-bottom: 20px !important;
}

.sm-bottom10 {
    margin-bottom: 10px !important;
}

.sm-bottom5 {
    margin-bottom: 5px !important;
}

/* ====================================================================
かけ線
======================================================================*/
.op_01 {
    opacity: 0.1 !important;
}

.op_02 {
    opacity: 0.2 !important;
}

.op_03 {
    opacity: 0.3 !important;
}

.op_06 {
    opacity: 0.6 !important;
}

.op_10 {
    opacity: 1 !important;
}

/* ====================================================================
loop TXT
======================================================================*/

.loop_top {
    position: relative;
    z-index: -1;
    margin-top: -120px;
}

.loop {
    overflow: hidden;
    position: relative;
    width: 100%;
}

.loop__box {
    display: flex;
    width: 100vw;
}

.loop__item,
.loop__item_l {
    flex: 0 0 auto;
    white-space: nowrap;
    line-height: 1;
    font-family: 'SF PRO';
}

.loop__item {
    text-align: left;
}

.loop__item_l {
    text-align: right;
}

.loop__item:nth-child(odd) {
    animation: R-loop 200s -100s linear infinite;
}

.loop__item:nth-child(even) {
    animation: R-loop2 200s linear infinite;
}

.loop__item_l:nth-child(odd) {
    animation: L-loop 200s linear infinite;
}

.loop__item_l:nth-child(even) {
    animation: L-loop2 200s -100s linear infinite;
}

/*流れる文字*/
@keyframes R-loop {
    0% {
        transform: translateX(100%);
    }

    to {
        transform: translateX(-100%);
    }
}

@keyframes R-loop2 {
    0% {
        transform: translateX(0);
    }

    to {
        transform: translateX(-200%);
    }
}

@keyframes L-loop {
    0% {
        transform: translateX(-100%);
    }

    to {
        transform: translateX(100%);
    }
}

@keyframes L-loop2 {
    0% {
        transform: translateX(-200%);
    }

    to {
        transform: translateX(0);
    }
}

/* ====================================================================
ribbon
======================================================================*/
.ribbonbox{text-align: center;}
.ribbon_1 {
  display: inline-block;
  position: relative;
  height: 45px;
  text-align: center;
  box-sizing: border-box;
    margin: 0 auto;
    z-index: 1;
}
.ribbon_1:before {/*左側のリボン端*/
  content: '';
  position: absolute;
  width: 10px;
  bottom: -10px;
  left: -25px;
  z-index: -2;
  border: 20px solid #ffbeab;
  border-left-color: transparent;/*山形に切り抜き*/
}

.ribbon_1:after {/*右側のリボン端*/
  content: '';
  position: absolute;
  width: 10px;
  bottom: -10px;
  right: -25px;
  z-index: -2;
  border: 20px solid #ffbeab;
  border-right-color: transparent;/*山形に切り抜き*/
}

.ribbon_1 h2 {
  display: inline-block;
  position: relative;
  margin: 0;
  padding: 0 20px;
  line-height: 45px;
  font-size: 1.4rem;
    font-weight: 700;
  color: #FFF;
  background: #fda186;/*真ん中の背景色*/
}
.ribbon_1 h2:before {
  position: absolute;
  content: '';
  top: 100%;
  left: 0;
  border: none;
  border-bottom: solid 10px transparent;
  border-right: solid 15px #c66b54;/*左の折り返し部分*/
}
.ribbon_1 h2:after {
  position: absolute;
  content: '';
  top: 100%;
  right: 0;
  border: none;
  border-bottom: solid 10px transparent;
  border-left: solid 15px #c66b54;/*右の折り返し部分*/
}
.arrow_box{
    position:relative;
    width:100%;
    background:#000;
    padding:10px;
    text-align:left;
    color:#FFFFFF;
    border-radius:5px;
    -webkit-border-radius:5px;
    -moz-border-radius:5px;
    font-size: 0.8rem;
}
.arrow_box:after{
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;

    border-top-width:10px;
    border-bottom-width:10px;
    border-left-width:10px;
    border-right-width:10px;
    margin-left: -10px;
    border-top-color:#000;
    top:100%;
    left:10%;
}

/* ====================================================================
Line
======================================================================*/
.line20 {
    width: 100%;
    margin-top: 18px;
    padding-bottom: 20px;
    clear: both;
    display: block;
    border-bottom: 1px solid rgba(210, 210, 210, 1);
}

.line40 {
    width: 100%;
    margin-top: 38px;
    padding-bottom: 40px;
    clear: both;
    display: block;
    border-bottom: 1px solid rgba(210, 210, 210, 1);
}

.linesp01 {
    height: 4px;
    width: 20px;
    background-color: #e50099;
    display: block;
}

/* ====================================================================
かけ線
======================================================================*/
.heart_hr {
    position: relative;
    overflow: visible;
    text-align: center;
    color: #f06292;
    border-width: 1px 0 0 0;
    border-style: dashed;
    border-color: #f06292;
    margin: 25px 0;
}

.heart_hr::after {
    position: absolute;
    transform: translate(-50%, -50%);
    display: inline-block;
    content: '♥';
    background: #ffffff;
}

.boxed {
    overflow: hidden;
    text-align: center;
}

.boxed > span {
    border: 1px solid #cccccc;
    display: inline-block;
    padding: 0.25em 0.7em;
    position: relative;
    border-radius: 100px;
}

.boxed > span:before,
.boxed > span:after {
    border-bottom: 1px solid #cccccc;
    content: '';
    margin: 0 3px;
    position: absolute;
    top: 50%;
    width: 100%;
    /* Line-length. 100% width is equal to width of boxed-area. */
}

.boxed > span:before {
    right: 100%;
}

.boxed > span:after {
    left: 100%;
}

/* ====================================================================
Icon position
======================================================================*/
.eyecatch {
    display: inline-flex;
}

.normal {
    vertical-align: -0.3em;
}

.normal img {
    width: 20px;
    height: 20px;
}

.small_ss {
    vertical-align: -0.15em;
    /*調整中*/
}

.small_ss img {
    width: 14px;
    height: 14px;
}

.bannerlinks {
    opacity: 1;
    transition: all 0.15s ease;
}

.bannerlinks:hover {
    opacity: 0.7;
}

.iconsp_r {
    padding-right: 6px !important;
}

.iconsp_l {
    padding-left: 6px !important;
}

.iconsp_c {
    padding-right: 6px !important;
    padding-left: 6px !important;
}

.iconsp_r_b {
    padding-right: 12px !important;
}

.iconsp_l_b {
    padding-left: 12px !important;
}

.iconsp_c_b {
    padding-right: 12px !important;
    padding-left: 12px !important;
}

/* ====================================================================
グーグルマップレスポンシブル
======================================================================*/
.gmap {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;
    /*16:9の比率にしたい場合、9/16=56.25%*/
}

.gmap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* ====================================================================
画像・動画等のレスポンシブ
======================================================================*/

.resimg {
    width: 100%;
    height: auto;
}

.postcontents .imgmax,
.embedmedia-container {
    margin-top: 70px;
    margin-bottom: 60px;
}

.postcontents .imgmax {
    max-width: calc(100% + 8vw);
    height: auto;
    margin-left: -4vw;
    border-radius: 4px;
}

.embedmedia-container {
    position: relative;
    padding-top: 76%;
    overflow: hidden;
    width: calc(100% + 8vw);
    height: auto;
    margin-left: -4vw;
}

.embedmedia-container iframe,
.embedmedia-container object,
.embedmedia-container embed {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

/* ====================================================================
角丸
======================================================================*/
.radius_3 {
    border-radius: 3px !important;
}

.radius_4 {
    border-radius: 4px !important;
}

.radius_5 {
    border-radius: 5px !important;
}


.border_line {
    margin-top: 20px;
    padding-bottom: 20px;
    border-top: 1px solid #494a58;
}

.border_line_g {
    margin-top: 20px;
    padding-bottom: 20px;
    border-top: 1px solid #ccc;
}

.border_line_d {
    margin-top: 20px;
    padding-bottom: 20px;
    border-top: 1px dashed #494a58;
}

.border_line_d_g {
    margin-top: 20px;
    padding-bottom: 20px;
    border-top: 1px dashed #ccc;
}

/* ====================================================================
アニメーション
======================================================================*/
.fade-in {
    -webkit-animation-name: fade-in;
    animation-name: fade-in;
}

.fade-out {
    -webkit-animation-name: fade-out;
    animation-name: fade-out;
}

.blink {
    -webkit-animation: blink .5s ease-in-out infinite alternate;
    animation: blink .5s ease-in-out infinite alternate;
}

/*.lightning{display: flex;}*/



/* ====================================================================
UL INDENT
======================================================================*/
ul.indent01 {
    padding: 0;
    list-style: none;
    margin-block-start: 20px;
    margin-block-end: 0;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    padding-inline-start: 0;
}

ul.indent01 li {
    margin: 0 0 20px 0;
    padding-left: 1em;
    text-indent: -1em;
}

/* ====================================================================
Display
======================================================================*/
.mediaPC {
    display: block !important;
}

.mediaPC-inlineBlock {
    display: inline-block !important;
}

.mediaSP {
    display: none !important;
}

.mediaSP-inlineBlock {
    display: none !important;
}
.pointer{cursor: pointer !important;}
/* ====================================================================
Background
======================================================================*/
.gldbg {
    position: relative;
    background-image: url(../images/hedline_bg.png);
    background-size: 4px 4px;
    background-repeat: repeat;
    text-shadow: 00px 0px 6px rgba(0, 0, 0, 0.5);
}

.gldbg::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    width: 2px;
    height: 15px;
    display: block;
    background-color: rgba(255, 255, 255, 1);
}

.gldbg::before {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    width: 15px;
    height: 2px;
    display: block;
    background-color: rgba(255, 255, 255, 1);
}

/* ====================================================================
box
======================================================================*/
.m_formbox {
    max-width: 750px;
    margin-left: auto;
    margin-right: auto;
}

.prpx {
    border: 4px solid rgba(210, 210, 210, 0.5);
    padding: 40px;
    margin: 40px 0;
}

.pc_linebox {
    border: 3px solid rgba(0, 185, 0, 0.2);
    padding: 10px;
}
/***/

.box20 {
    position: relative;
    padding: 0.25em 1em;
    margin: 2em 0;
    top: 0;

}
.box20:before, .box20:after{ 
    position: absolute;
    top: 0;
    content:'';
    width: 10px;
    height: 100%;
    display: inline-block;
    box-sizing: border-box;
}
.box20:before{
    border-left: dotted 2px #333;
    border-top: dotted 2px #333;
    border-bottom: dotted 2px #333;
    left: 0;
}
.box20:after{
    border-top: dotted 2px #333;
    border-right: dotted 2px #333;
    border-bottom: dotted 2px #333;
    right: 0;
}
.box20 p {
    margin: 0; 
    padding: 0;
}

/* ====================================================================
Font-family
======================================================================*/


/* ====================================================================
Font size
======================================================================*/
/*デフォルト*/
.fc_333333 {
    color: #333333 !important;
}

/*ライトグレー*/
.fc_cccccc {
    color: #cccccc !important;
}

/*グレー*/
.fc_cccccc {
    color: #666666 !important;
}

/*赤*/
.fc_ff0000 {
    color: #ff0000 !important;
}

/*黒*/
.fc_000000 {
    color: #000000 !important;
}

/*ピンク*/

.fc_d16187 {
    color: #d16187;
}

/*グリーン*/
.fc_6bc1b6 {
    color: #6bc1b6;
}

/*LINK*/

.fc_ff9374 {
    color: #ff9374;
}

/* ====================================================================
Font weight
======================================================================*/
.fw400 {
    font-weight: 400 !important;
}

.fw700 {
    font-weight: 700 !important;
}

/* ====================================================================
Letter spacing
======================================================================*/
.lp0 {
    letter-spacing: 0px !important;
}

.lpD {
    letter-spacing: 0.07em !important;
}

.lp1 {
    letter-spacing: 0.1em !important;
}

.lp15 {
    letter-spacing: 0.15em !important;
}

.lp2 {
    letter-spacing: 0.2em !important;
}

/* ====================================================================
Font size
======================================================================*/
.font_ss {
    font-size: 0.6rem;
}

.font_s {
    font-size: 0.8rem;
}

.font_n {
    font-size: 1rem;
}

.font_l {
    font-size: 1.2rem;
}

.font_ll {
    font-size: 1.4rem;
}

.font_xl {
    font-size: 2rem;
}

.font_xll {
    font-size: 2.4rem;
}

.big_font {
    font-size: 200px;
}

/* ====================================================================
Font position
======================================================================*/
.text-center {
    text-align: center !important;
}

.text-right {
    text-align: right !important;
    ;
}

.text-left {
    text-align: left !important;
}

/* ====================================================================
Fonts Outline
======================================================================*/
.outline {
    color: #ffffff;
    text-shadow:
        1px 1px 0px #dddddd,
        -1px 1px 0px #dddddd,
        1px -1px 0px #dddddd,
        -1px -1px 0px #dddddd,
        1px 0px 0px #dddddd,
        0px 1px 0px #dddddd,
        -1px 0px 0px #dddddd,
        0px -1px 0px #dddddd;
}

/* ====================================================================
Background-clip
======================================================================*/
.bgclip {
    flex: 1;
    position: relative;
    -webkit-text-fill-color: transparent;
    background-size: cover;
    -webkit-background-clip: text;
    background-clip: text;
    background-repeat: no-repeat;
}

.clip01 {
    background-image: url("../images/backgroundclip/clip01.gif");
}

.clip02 {
    background-image: url("../images/backgroundclip/clip02.gif");
}

.clip03 {
    background-image: url("../images/backgroundclip/clip03.gif");
}

.clip04 {
    background-image: url("../images/backgroundclip/clip04.gif");
}

.clip05 {
    background-image: url("../images/backgroundclip/clip05.gif");
}

.clip06 {
    background-image: url("../images/backgroundclip/clip06.gif");
}

.clip07 {
    background-image: url("../images/backgroundclip/clip07.gif");
}

.clip08 {
    background-image: url("../images/backgroundclip/clip08.gif");
}

.clip09 {
    background-image: url("../images/backgroundclip/clip09.gif");
}

/* ====================================================================
Position
======================================================================*/
.textline {
    color: #fff;
    text-shadow:
        3px 3px 0 #000,
        -3px 3px 0 #000,
        -3px -3px 0 #000,
        3px -3px 0 #000;
}

/* ====================================================================
Position
======================================================================*/
.ps_relative {
    position: relative;
}

.no_overflow {
    overflow: visible;
}

.stickynav {
    /*stickyで固定*/
    position: -webkit-sticky;
    /*Safari*/
    position: sticky;
    /*固定したい位置*/
    top: 0;
    /*ナビゲーションの形状*/
    width: 100% !important;
    display: block;
}

.optionBox {
    display: none;
}

.optionbt {
    cursor: pointer;
}

.stripe {
    background-image: linear-gradient(-45deg, #fff 25%, #80b9ba 25%, #80b9ba 50%, #fff 50%, #fff 75%, #80b9ba 75%, #80b9ba);
    background-size: 4px 4px;
    height: 10px;
    display: block;
}

@media only screen and (max-width: 1199px) {}

@media only screen and (max-width: 991px) {
    .commonsp_b {
        padding-left: 50px;
        padding-right: 50px;
    }
}

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


    .loop_top {
        margin-top: -80px;
    }

    /* ====================================================================
Spacing
======================================================================*/
    .panelcontens {
        padding: 0;
    }

    .commonsp_b {
        padding-left: 40px;
        padding-right: 40px;
    }

    .commonsp_0 {
        padding-left: 0px;
        padding-right: 0px;
    }

    /*padding top bottom */
    .sp-top-bottom120,
    .sp-top-bottom110,
    .sp-top-bottom100,
    .sp-top-bottom90 {
        padding-top: 60px !important;
        padding-bottom: 60px !important;
    }

    .sp-top-bottom80,
    .sp-top-bottom70,
    .sp-top-bottom60,
    .sp-top-bottom50 {
        padding-top: 40px !important;
        padding-bottom: 40px !important;
    }

    .sp-top-bottom40,
    .sp-top-bottom30 {
        padding-top: 20px !important;
        padding-bottom: 20px !important;
    }

    /*padding top */
    .sp-top120,
    .sp-top110,
    .sp-top100,
    .sp-top90 {
        padding-top: 60px !important;
    }

    .sp-top80,
    .sp-top70,
    .sp-top60,
    .sp-top50 {
        padding-top: 40px !important;
    }

    .sp-top40,
    .sp-top30 {
        padding-top: 20px !important;
    }


    /*padding bottom */
    .sp-bottom120,
    .sp-bottom110,
    .sp-bottom100,
    .sp-bottom90 {
        padding-bottom: 60px !important;
    }

    .sp-bottom80,
    .sp-bottom70,
    .sp-bottom60,
    .sp-bottom50 {
        padding-bottom: 40px !important;
    }

    .sp-bottom40,
    .sp-bottom30 {
        padding-bottom: 20px !important;
    }

    /*margin top bottom */
    .sm-top-bottom120,
    .sm-top-bottom110,
    .sm-top-bottom100,
    .sm-top-bottom90 {
        margin-top: 60px !important;
        margin-bottom: 60px !important;
    }

    .sm-top-bottom80,
    .sm-top-bottom70,
    .sm-top-bottom60,
    .sm-top-bottom50 {
        margin-top: 40px !important;
        margin-bottom: 40px !important;
    }

    .sm-top-bottom40,
    .sm-top-bottom30 {
        margin-top: 20px !important;
        margin-bottom: 20px !important;
    }

    /*margin top */
    .sm-top120,
    .sm-top110,
    .sm-top100,
    .sm-top90 {
        margin-top: 60px !important;
    }

    .sm-top80,
    .sm-top70,
    .sm-top60,
    .sm-top50 {
        margin-top: 40px !important;
    }

    .sm-top40,
    .sm-top30 {
        margin-top: 40px !important;
    }

    /*margin bottom */
    .sm-bottom120,
    .sm-bottom110,
    .sm-bottom100,
    .sm-bottom90 {
        margin-bottom: 60px !important;
    }

    .sm-bottom80,
    .sm-bottom70,
    .sm-bottom60,
    .sm-bottom50 {
        margin-bottom: 80px !important;
    }

    .sm-bottom40,
    .sm-bottom30 {
        margin-bottom: 40px !important;
    }

    .normal {
        vertical-align: -0.05em;
    }

    .normal img {
        width: 14px;
        height: 14px;
    }

    /* ====================================================================
Display
======================================================================*/
    .mediaPC {
        display: none !important;
    }

    .mediaPC-inlineBlock {
        display: none !important;
    }

    .mediaSP {
        display: block !important;
    }

    .mediaSP-inlineBlock {
        display: inline-block !important;
    }

    
    .ribbon_1 h2 {
        font-size: 1.4rem;
    }
    /* ====================================================================
Link button
======================================================================*/
    .linkbt_wide {
        padding: 14px 0;
    }

    .linkbt {
        padding: 14px 20px;
    }

    .bg_black,
    .bg_black:hover {
        border: 2px solid #000;
        background-color: #000;
        color: #ffffff;
    }

    .bg_gray,
    .bg_gray:hover {
        border: 2px solid #b5bcbd;
        background-color: #b5bcbd;
        color: #ffffff;
    }

    .big_font {
        font-size: 120px;
    }


}

/*基本スマホ対応は767px。ただしピンポイントでiPhone13~は575px、さらに、それ以下の小さいスクリーンを対象とする場合320pxへ*/
@media only screen and (max-width: 575px) {}

@media only screen and (max-width: 320px) {
    .loop_top {
        margin-top: -50px;
    }

    .big_font {
        font-size: 80px;
    }
    .ribbon_1 h2 {
        font-size: 1rem;
    }

}