/* web font */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Oswald:wght@200..700&display=swap");
@media print, screen and (min-width: 768px) {
  header {
    width: 100%;
    border-bottom: 1px solid #331F00;
  }
  header .l-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    height: 76px;
  }
  header .c-logo {
    width: 160px;
    margin-right: 24px;
  }
  header .c-logo-sfc {
    width: 140px;
  }
  header p {
    margin-top: -8px;
    margin-right: auto;
    padding-left: 0.5em;
    text-indent: -0.5em;
    line-height: 1.2;
    font-size: 20px;
    font-size: calc(2 + rem);
  }
  header p a {
    color: #15A88D;
  }
  header p a:hover {
    opacity: 0.7;
  }
}
@media print, screen and (min-width: 768px) {
  footer {
    position: relative;
    width: 100%;
    border-top: 1px solid #331F00;
    border-bottom: 1px solid #331F00;
  }
  footer .l-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    height: 170px;
  }
  footer .c-logo {
    width: 160px;
  }
  footer ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-direction: row;
  }
  footer ul li:last-child {
    margin-left: 35px;
  }
  footer ul li a {
    display: block;
    background-color: #15A88D;
    padding: 0 1.5em;
    border-radius: 10px;
    line-height: 56px;
    font-size: 18px;
    font-size: calc(1.8 + rem);
    font-weight: 500;
    color: #ffffff;
  }
  footer ul li a:hover {
    opacity: 0.7;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 860px) {
  footer ul li:last-child {
    margin-left: 20px;
  }
  footer ul li a {
    font-size: 16px;
    font-size: calc(1.6 + rem);
  }
}
@media print, screen and (min-width: 768px) {
  .c-pagetop {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    right: 50%;
    bottom: 5%;
    width: 85px;
    transform: translateX(690px);
    transition: opacity 0.5s ease;
    z-index: 100;
  }
  .c-pagetop.active {
    visibility: visible;
    opacity: 1;
  }
  .c-pagetop.stop {
    position: absolute;
    top: -140px;
    bottom: inherit;
  }
  .c-pagetop:hover {
    cursor: pointer;
  }
}
@media print, screen and (min-width: 768px) and (max-width: 1460px) {
  .c-pagetop {
    right: 3%;
    transform: none;
  }
}
@media screen and (max-width: 767px) {
  header {
    width: 100%;
    border-bottom: 1px solid #331F00;
  }
  header .l-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    width: 100%;
    height: 74px;
    padding: 0 2.56vw;
  }
  header .c-logo {
    width: 28vw;
    max-width: 120px;
    margin-right: 1.28vw;
  }
  header .c-logo-sfc {
    width: 18.4vw;
  }
  header p {
    margin-right: auto;
    padding-left: 0.5em;
    text-indent: -0.5em;
    line-height: 1.2;
    font-size: 15px;
    font-size: 3.8461538462vw;
  }
  header p a {
    color: #15A88D;
  }
}
@media screen and (max-width: 767px) {
  footer {
    width: 100%;
    border-top: 1px solid #331F00;
    border-bottom: 1px solid #331F00;
  }
  footer .l-inner {
    width: 80%;
    padding-top: 6.4vw;
    padding-bottom: 12.8vw;
  }
  footer .c-logo {
    width: 41vw;
    margin-bottom: 5.2vw;
  }
  footer ul li:first-child {
    margin-bottom: 2.6vw;
  }
  footer ul li a {
    display: block;
    width: 100%;
    background-color: #15A88D;
    border-radius: 10px;
    text-align: center;
    line-height: 13.333vw;
    font-size: 15px;
    font-size: 3.8461538462vw;
    font-weight: 500;
    color: #ffffff;
  }
  .c-pagetop {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    right: 4%;
    bottom: 5%;
    width: 12.4vw;
    transition: opacity 0.5s ease;
    z-index: 100;
  }
  .c-pagetop.active {
    visibility: visible;
    opacity: 1;
  }
  .c-pagetop.stop {
    position: absolute;
    bottom: 45vw;
  }
}
/* CSS reset */
a, abbr, acronym, address, applet, big, blockquote, body, caption, cite, code, dd, del, dfn, div, dl, dt, em, fieldset, font, form, h1, h2, h3, h4, h5, h6, html, iframe, img, ins, kbd, label, legend, li, object, ol, p, pre, q, s, samp, small, span, strike, strong, sub, sup, tbody, tfoot, thead, tt, ul, var, figure, figcaption {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
  list-style: none;
}

.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  clear: both;
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
}

.txt_center {
  text-align: center !important;
}

.block_center {
  margin-left: auto !important;
  margin-right: auto !important;
}

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

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

.fleft {
  display: block;
  float: left;
}

.fright {
  display: block;
  float: right;
}

.txt_red {
  color: #ff3333;
}

.pl0 {
  padding-left: 0 !important;
}

.pr0 {
  padding-right: 0 !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.ml5 {
  margin-left: 5px !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

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

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

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

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

.pl5 {
  padding-left: 5px !important;
}

.pr5 {
  padding-right: 5px !important;
}

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

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

.pt8 {
  padding-top: 8px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.mr10 {
  margin-right: 10px !important;
}

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

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

.pl10 {
  padding-left: 10px !important;
}

.pr10 {
  padding-right: 10px !important;
}

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

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

.ml15 {
  margin-left: 15px !important;
}

.mr15 {
  margin-right: 15px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.pl15 {
  padding-left: 15px !important;
}

.pr15 {
  padding-right: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.mr20 {
  margin-right: 20px !important;
}

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

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

.pl20 {
  padding-left: 20px !important;
}

.pr20 {
  padding-right: 20px !important;
}

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

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

.ml25 {
  margin-left: 25px !important;
}

.mr25 {
  margin-right: 25px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.pl25 {
  padding-left: 25px !important;
}

.pr25 {
  padding-right: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.mr30 {
  margin-right: 30px !important;
}

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

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

.pl30 {
  padding-left: 30px !important;
}

.pr30 {
  padding-right: 30px !important;
}

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

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

.ml35 {
  margin-left: 35px !important;
}

.mr35 {
  margin-right: 35px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.pl35 {
  padding-left: 35px !important;
}

.pr35 {
  padding-right: 35px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.mr40 {
  margin-right: 40px !important;
}

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

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

.pl40 {
  padding-left: 40px !important;
}

.pr40 {
  padding-right: 40px !important;
}

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

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

.ml45 {
  margin-left: 45px !important;
}

.mr45 {
  margin-right: 45px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.pl45 {
  padding-left: 45px !important;
}

.pr45 {
  padding-right: 45px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mr50 {
  margin-right: 50px !important;
}

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

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

.pl50 {
  padding-left: 50px !important;
}

.pr50 {
  padding-right: 50px !important;
}

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

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

.mt75 {
  margin-top: 75px !important;
}

html {
  font-size: 62.5%;
}

body {
  overflow-x: hidden;
  position: relative;
  font-family: "Noto Sans JP", sans-serif;
  color: #331F00;
}
body img {
  max-width: 100%;
  height: auto;
}
body a {
  transition: all 0.3s ease;
  text-decoration: none;
}
body a img {
  transition: all 0.3s ease;
}
body a img:hover {
  opacity: 0.7;
}
@media print, screen and (max-width: 767px) {
  body a img:hover {
    opacity: 1;
  }
}

* {
  box-sizing: border-box;
}

sup {
  vertical-align: super;
  font-size: 0.7em;
}

@media print, screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
.u-scroll {
  overflow-y: hidden !important;
}
@media screen and (max-width: 767px) {
  .u-scroll figure {
    min-width: 150vw;
  }
}/*# sourceMappingURL=common.css.map */