@charset "UTF-8";
/*************************************
* reset
*************************************/
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;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
 display: block;
}
ol, ul {
 list-style: none;
}
a {
 margin: 0;
 padding: 0;
 font-size: 100%;
 vertical-align: baseline;
 background: transparent;
 text-decoration: none;
 color: #000;
 outline: none;
}
a:hover {
 text-decoration: none;
 opacity: 0.75;
 transition: opacity 0.2s linear;
}
a:hover img {
 opacity: 0.75;
}
a[href^="tel:"] {
 cursor: default;
}
table {
 border-collapse: collapse;
 border-spacing: 0;
}
table a {
 color: #0784c8;
}
input, select {
 vertical-align: middle;
 border-radius: 0;
}
@media (max-width: 480px) {
 input, select {
  font-size: 18px !important;
 }
}
input:not([type="checkbox"]), textarea {
 box-sizing: border-box;
 -moz-box-sizing: border-box;
 -webkit-box-sizing: border-box;
 -webkit-appearance: none;
 max-width: 100%;
}
button {
 background-color: transparent;
 border: none;
 cursor: pointer;
 outline: none;
 padding: 0;
 appearance: none;
}
img {
 line-height: 1;
 vertical-align: top;
 image-rendering: -webkit-optimize-contrast;
}
*, *:before, *:after {
 -webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 -o-box-sizing: border-box;
 -ms-box-sizing: border-box;
 box-sizing: border-box;
}
img {
 max-width: 100%;
 height: auto;
 width: auto;
}
h1, h2, h3, h4 {
 font-weight: normal;
 line-height: 1;
}
/*************************************
* common
*************************************/
html {
 font-size: 62.5%;
 overflow-y: scroll;
 height: 100%;
}

html.is-active {
    overflow: hidden;
}

body {
 height: 100%;
 line-height: 1.8;
 font-size: 1.4rem;
 font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
 background: #fff;
 color: #444;
 word-wrap: break-word;
 overflow-wrap: break-word;
 min-width: 320px;
}
@media (min-width: 769px) {
 body {
  font-size: 1.8rem;
  letter-spacing: 0.1em;
 }
 .pc_no {
  display: none;
 }
}
@media screen and (max-width:768px) {
 .sp_no {
  display: none;
 }
}
/*************************************
* layout
*************************************/
/* pc *****************/
@media screen and (min-width:769px) {
 #main-cnt {
  min-width: 800px;
  margin: 0 auto;
 }
 #main-cnt img {
  display: block;
  margin: 0 auto;
 }
 #main-cnt .btn a {
  display: block;
  width: 800px;
  margin: 0 auto;
 }
 #main-cnt .mv {
  position: relative;
 }
 #main-cnt .mv h1 img {
  width: 1200px;
  height: 980px;
  object-fit: cover;
 }
 #main-cnt .mv .mv_btn {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
 }
 .copy {
  padding: 80px 0 10px;
  text-align: center;
 }
}
/* sp *****************/
@media screen and (max-width:768px) {
 #main-cnt img {
  display: block;
  margin: 0 auto;
 }
 #main-cnt img {
  display: block;
  margin: 0 auto;
 }
 #main-cnt .btn a {
  display: block;
  margin: 0 auto;
 }
 #main-cnt .mv {
  position: relative;
 }
 #main-cnt .mv .mv_btn {
  position: absolute;
  right: 0;
  left: 0;
  bottom: 0;
 }
 .copy {
  padding: 40px 0 10px;
  text-align: center;
 }
}

/*************************************
* header
*************************************/

.header {
    width: 100%;
    height: 80px;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 5;
    background-color: #fff;
}

.l-header__inner {
    height: inherit;
    display: flex;
    justify-content: center;
    align-items: center;

}
.header__nav {
    display: flex;
    gap: 20px;
}

.header__link {

}

@media screen and (max-width:769px) {
    .header {
        height: 60px;
    }
    .header__nav {
        display: none;
    }
}

/*************************************
* drawer
*************************************/

.c-drawer__icon {
    display: none;
    transition: all 0.5s;
    width: 30px;
    height: 20px;
    position: fixed;
    top: 20px;
    right: 15px;
    z-index: 6;
}
.c-drawer__icon.is-active {
    z-index: 20;

}
.c-drawer__bars {
    width: inherit;
    height: inherit;
    position: relative;
}
.c-drawer__bar {
    display: block;
    width: 100%;
    height: 2px;
    background-color: #000;
    transition: all 0.8s;
    position: absolute;
    left: 0;
    transform-origin: center;

}
.is-toggle1 {
    top: 0;
}
.c-drawer__icon.is-active .is-toggle1{
    top: 10px;
    transform: rotate(45deg);
}
.is-toggle2 {
    top: 50%;
    transform: translateY(-50%);
}
.c-drawer__icon.is-active .is-toggle2{
    transform: translateX(20px);
    opacity: 0;
}
.is-toggle3 {
    bottom: 0;
}
.c-drawer__icon.is-active .is-toggle3{
    top: 10px;
    transform: rotate(-45deg);
}
.c-drawer__content {
    opacity: 0;
    visibility: hidden;
    width: 100%;
    height: 100vh;
    background-color: #fff;
    top: 0;
    left: 0;
    position: fixed;
    padding: 60px 15px 40px;
    transition: all 0.5s ease-in-out;
    z-index: -10;
    display: flex;
    justify-content: center;
    align-items: center;
}
.c-drawer__content.is-active {
    opacity: 1;
    visibility: visible;
    z-index: 10;
}

.c-drawer__list {
    display: flex;
    flex-direction: column;
    justify-content: right;
    gap: 32px;

}
.c-drawer__item {
    text-align: center;
}

@media screen and (max-width:769px) {
    .c-drawer__icon {
        display: block;
    }
}


/*************************************
* wrapper
*************************************/
#wrapper {
    margin-top: 80px;
}

@media screen and (max-width:769px) {
    #wrapper {
        margin-top: 60px;
    }
}

/*************************************
* floating-banner
*************************************/

.floating-banner {
    height: 100px;
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: -10;
    opacity: 0;
    visibility: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.3s;
}

.floating-banner.is-active  {
    z-index: 10;
    opacity: 1;
    visibility: visible;
}

.floating-banner a{
    border-radius: 12px;
    font-size: 18px;
    font-weight: 700;
    text-align: center;
    color: #fff;
    display: block;
    padding: 15px 0px;
    background-color: #cd5c5c;
    width: min(calc(100% - 40px), 800px);
    margin: 0 auto;
    box-shadow: 0px 8px 0px 0px #b34747;
}




