@charset "UTF-8";
/* reset */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  -ms-text-size-adjust: none;
      text-size-adjust: none;
}

body, h1, h2, h3, h4, p,
figure, blockquote, dl, dd {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}

ul[role=list],
ol[role=list] {
  list-style: none;
}

body {
  min-height: 100vh;
  line-height: 1.5;
}

h1, h2, h3, h4,
button, input, label {
  line-height: 1.1;
}

h1, h2,
h3, h4 {
  text-wrap: balance;
}

button {
  border: none;
  background: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  outline: none;
}

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
  color: currentColor;
}

img,
picture {
  max-width: 100%;
  display: block;
}

input, button,
textarea, select {
  font-family: inherit;
  font-size: inherit;
}

textarea:not([rows]) {
  min-height: 10em;
}

:target {
  scroll-margin-block: 5ex;
}

/* base */
html {
  height: 100vh;
  font-size: 62.5%;
}

body {
  width: 100%;
  color: #242424;
  background-color: #FFFDEA;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: min(3.59vw, 16px);
  line-height: 1.6;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  text-decoration-thickness: 1px;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
@media only screen and (min-width: 768px) {
  body {
    font-size: 16px;
  }
}

main {
  position: relative;
  overflow: hidden;
}

span.iB {
  display: inline-block;
}

.is-sp {
  display: block;
}
@media only screen and (min-width: 768px) {
  .is-sp {
    display: none;
  }
}

.is-pc {
  display: none;
}
@media only screen and (min-width: 768px) {
  .is-pc {
    display: block;
  }
}

a {
  background-color: transparent;
  text-decoration: none;
  color: #242424;
}

a:not([class]) {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
a:not([class]):hover {
  opacity: 0.7;
}

a.link--out::after {
  margin-left: 0.5em;
  display: inline-block;
  position: relative;
  width: 0.857em;
  height: 0.857em;
  vertical-align: -0.1em;
  content: "";
  background: url("/assets/images/ico_window.svg") no-repeat center center;
  background-size: contain;
}

.container {
  padding: 0 4vw;
}
@media only screen and (min-width: 768px) {
  .container {
    max-width: 1200px;
    padding: 0 40px;
    margin: 0 auto;
  }
}

/*
.flex {
    @include for-pc {
        display: flex;
        flex-wrap: wrap;
    }
}
.ul-yl {
    background: linear-gradient(transparent 60%, #FFE27C 40%);
}
.txt--tcu {
    text-combine-upright: all;    
	line-height: 1;
    @include for-pc {
        text-combine-upright:none;
    }
}
.font-yumin {
    font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
    */
.deco {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  /*z-index: -1;*/
}

/*---------------------------------

  header

---------------------------------*/
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  /*&.is-hide {

  }*/
}
@media only screen and (min-width: 768px) {
  .header {
    -webkit-transition: 1s;
    transition: 1s;
  }
}
.header__inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media only screen and (min-width: 768px) {
  .header__inner {
    z-index: 0;
  }
}
.header__logo {
  width: 65px;
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 10;
  -webkit-transition: 1s;
  transition: 1s;
}
@media only screen and (min-width: 768px) {
  .header__logo {
    width: 100px;
    top: 26px;
    left: 30px;
  }
}

/*---------------------------------

  footer

---------------------------------*/
.footer {
  background: #EA4645;
  color: #fff;
  padding-bottom: 50px;
}
.footer-top {
  padding: 30px 0;
}
.footer-bottom__inner {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
.footer-bottom .container {
  max-width: 1360px;
}
.footer-logo {
  width: min(51.282vw, 239px);
  margin: 0 auto 7.179vw;
}
@media only screen and (min-width: 768px) {
  .footer-logo {
    max-width: 239px;
    margin: 0 2% 20px 0;
  }
}
.footer-copy {
  text-align: center;
  font-size: 12px;
}
@media only screen and (min-width: 768px) {
  .footer-copy {
    text-align: right;
  }
}/*# sourceMappingURL=common.css.map */