@charset "UTF-8";
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  margin: 0;
}

main {
  display: block;
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

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

abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img,
embed,
object,
iframe {
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
       appearance: radio;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

select::-ms-expand {
  display: none;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable] {
  outline: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

/* ------------------------------------------------
 * * #FONTS
 * * @sans  'IBM Plex Sans': 400(Regular), 600(SemiBold)
 * * @serif 'Fanwood Text': 400(Regular), 400(Italic)
 * * ------------------------------------------------*/
/* ------------------------------------------------
 * * #ICONフォント設定
 * * 'Roboto Condensed': 300, 400, 700
 * * ------------------------------------------------*/
@font-face {
  font-family: "newold";
  src: url("../fonts/newold.ttf?98aq8p") format("truetype"), url("../fonts/teranoyado.woff?98aq8p") format("woff"), url("../fonts/teranoyado.svg?98aq8p#meganeto") format("svg");
  font-style: normal;
}
[class^=icon-], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "teranoyado" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering ===========*/
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

:root {
  --header-height: 220px;
  --header_fixed-height: 84px;
  --mainlogo_width: 175px;
  --mainlogo_height: 267px;
  --mainlogo_aspect: 175/267;
  --mainlogo-full_aspect: 175/342;
  --iconlogo_width: 175px;
  --iconlogo_height: 69px;
  --iconlogo_aspect: 175/69;
  --depth_loadPanel: 20001;
  --depth_introPanel: 20020;
  --depth_naviBtn: 20006;
  --depth_navi: 20005;
  --depth_header: 20007;
  --pgheaderH: 180px;
  --pgheaderH_sp: 100px;
  --padding_pc: 50px;
  --padding_tbl: 30px;
  --padding_sp: 22px;
  --maxW_pc: 1120px;
  --minW_pc: 1000px;
  --flm-maxW_narrow2: 640px;
  --flm-maxW_narrow1: 820px;
  --flm-maxW_normal: 900px;
  --flm-maxW_wide: 1100px;
  --flm-maxW_wide2: 1200px;
  --flm-maxW_limit: 1440px;
  --flm-maxW: var(--flm-maxW_normal);
  --flm-padding: 50px;
  --flm-padding_tbl: 30px;
  --flm-padding_sp: 22px;
  --color_black: #232323;
  --color_text: --color_black;
  --color_dark-gray: #4d4d4d;
  --color_gray: #888888;
  --color_mid-gray: #969696;
  --color_lt-gray: #b3b3b3;
  --color_menu: #e5e5e5;
  --bgcolor_gray: #666666;
  --bgcolor_gray: #e3e3e3;
  --bgcolor_dark-gray: #262626;
  --bgcolor_lt-gray: #F0F0F0;
  --bgcolor_off-white: #f7f7f7;
  --bgcolor_footer-gray: #F5F5F5;
  --color_facebook: #3B5998;
  --color_twitter: #55acee;
  --color_X: #55acee;
  --color_instagram_single: #d6249f;
  --color_instagram: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%,#d6249f 60%,#285AEB 90%);
  --color_pinterest: #E60019;
  --color_line: #00b900;
  --color_youtube: #ff0000;
  --color_mappin: #d95140;
  --color_vimeo: #1ab7ea;
  --color_pinterst: #AD0000;
  --color_tumblr: #35465c;
  --color_amazon: #ff9900;
  --color_amazon_hvr: #ffcf88;
  --color_rakuten: #BF0101;
  --color_rakuten_hvr: #e68484;
  --color_yahoo: #FF9019;
  --easeInQuad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --easeOutQuad: cubic-bezier(0.25, 1, 0.5, 1);
  --easeInOutQuad: cubic-bezier(0.45, 0, 0.55, 1);
}
@media screen and (max-width: 540px) {
  :root {
    --header_fixed-height: 70px;
  }
}

@keyframes fadeOut {
  0% {
    opacity: 1;
    height: 100vh;
    transform: translate(0, 0);
    overflow: hidden;
  }
  99.999% {
    opacity: 0;
    transform: translate(0, 0);
  }
  100% {
    opacity: 0;
    transform: translate(0, -20000px);
    height: 0;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: translate(0, -20000px);
    overflow: hidden;
    height: 0;
  }
  .001% {
    opacity: 0;
    height: 100vh;
    transform: translate(0, 0);
  }
  100% {
    opacity: 1;
    height: 100vh;
    transform: translate(0, 0);
  }
}
@keyframes fadeOut2 {
  0% {
    opacity: 1;
    transform: translate(0, 0);
    overflow: hidden;
  }
  99.999% {
    opacity: 0;
    transform: translate(0, 0);
  }
  100% {
    opacity: 0;
    transform: translate(0, -20000px);
  }
}
@keyframes fadeIn2 {
  0% {
    opacity: 0;
    transform: translate(0, -20000px);
    overflow: hidden;
  }
  .001% {
    opacity: 0;
    transform: translate(0, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}
html, body {
  font-family: "游ゴシック", "YuGothic", sans-serif;
  font-weight: 400;
  font-feature-settings: "palt";
  font-size: 62.5%;
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  height: 100%;
}

body {
  position: relative;
  font-size: 1.6rem;
  line-height: 1.5;
  background-color: white;
  color: var(--color_text);
}
@media screen and (max-width: 540px) {
  body {
    font-size: 1.4rem;
  }
}

*::after {
  display: block;
  clear: both;
}

:root {
  --ff_mincho: "Hina Mincho", serif;
  --ff_jp: "Noto Sans JP", sans-serif;
  --ff_en: Rubik;
}

figure img {
  display: block;
  width: 100%;
  height: auto;
}

.u-image {
  display: block;
  width: 100%;
  height: auto;
}

.u-figure {
  overflow: hidden;
  border-radius: var(--bdradius);
}

.u-bgimage {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.u-ff--mincho {
  font-family: var(--ff_mincho);
}

.sd {
  -webkit-overflow-scrolling: touch;
  position: relative;
  z-index: 0;
  display: flex;
  align-content: center;
  align-items: center;
  flex-direction: column;
  flex-wrap: nowrap;
  max-width: 100%;
  pointer-events: all;
}
.sd.icon, .sd.text {
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: center;
  overflow: visible;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.p-cookie_notice {
  position: fixed;
  z-index: 100;
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  width: auto;
  background-color: #ffffff;
  box-shadow: 2px 3px 10px 3px rgba(230, 230, 230, 0.8);
  border-radius: 20px;
  padding: 15px;
  font-size: 11px;
  white-space: nowrap;
  transition: opacity 0.4s;
}
body.pc .p-cookie_notice:hover {
  opacity: 0.5;
}
.p-cookie_notice h5 {
  font-weight: bold;
  font-size: 13px;
  margin-bottom: 0.7em;
}
.p-cookie_notice p {
  line-height: 1.5;
  margin-bottom: 10px;
}
.p-cookie_notice ul li {
  line-height: 1.4;
}
.p-cookie_notice ul li + li {
  margin-top: 0.5em;
}
.p-cookie_notice button {
  position: absolute;
  z-index: 1;
  right: 15px;
  top: 15px;
  border: none;
  width: 30px;
  height: 30px;
  background: transparent;
}
.p-cookie_notice button::before, .p-cookie_notice button::after {
  position: absolute;
  left: 0;
  top: 50%;
  display: block;
  content: "";
  background-color: #333;
  width: 100%;
  height: 1px;
}
.p-cookie_notice button::before {
  transform: rotate(45deg);
}
.p-cookie_notice button::after {
  transform: rotate(-45deg);
}

body {
  font-family: var(--ff_jp);
}

.l-container {
  --width_side: 50px;
  position: relative;
  width: 100%;
  overflow: hidden;
}
@media screen and (max-width: 896px) {
  .l-container {
    --width_side: 40px;
  }
}
@media screen and (max-width: 540px) {
  .l-container {
    --width_side: 30px;
  }
}

.l-header {
  --height_this: 160px;
  --padding_this: 30px 0px 20px;
  --fz_header-title: 20px;
  position: relative;
  z-index: 4;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--keycolor);
  max-width: 100%;
  width: 100%;
  height: var(--height_this);
  padding: var(--padding_this);
  overflow: hidden;
}
@media screen and (max-width: 540px) {
  .l-header {
    --height_this: 85px;
    --padding_this: 14px 0px 14px 14px;
    --padding_this: 0;
  }
}
.l-header .l-header__title {
  position: relative;
  z-index: 5;
  max-width: 220px;
}
.l-header .l-header__image {
  width: 38%;
  max-width: 38%;
}
@media screen and (max-width: 896px) {
  .l-header {
    justify-content: center;
  }
  .l-header .l-header__image {
    position: absolute;
    z-index: 1;
    margin: 0 0 0 0;
  }
  .l-header .l-header__image.--left {
    left: -94px;
    right: auto;
    top: 34px;
    bottom: auto;
  }
  .l-header .l-header__image.--right {
    top: auto;
    left: auto;
    right: -101px;
    bottom: 37px;
  }
}
@media screen and (max-width: 540px) {
  .l-header .l-header__title {
    max-width: 180px;
  }
  .l-header .l-header__image {
    width: 193px;
    max-width: 100%;
    height: 28px;
  }
}

.l-side {
  --fz_this: 16px;
  position: fixed;
  z-index: 10;
  top: 0;
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  max-width: 100%;
  width: var(--width_side);
  height: 100vh;
}
@media screen and (max-width: 896px) {
  .l-side {
    --fz_this: 14px;
  }
}
@media screen and (max-width: 540px) {
  .l-side {
    --fz_this: 12px;
  }
}
.l-side.--left {
  left: 0;
}
.l-side.--right {
  right: 0;
}
.l-side p {
  color: #000000;
  writing-mode: vertical-rl;
  flex: none;
  font-weight: 500;
  font-size: var(--fz_this);
  letter-spacing: 0.15em;
  line-height: 1.9;
  text-align: center;
  text-orientation: upright;
  -webkit-text-orientation: upright;
  max-width: 100%;
  width: auto;
  height: auto;
}
@media screen and (max-width: 540px) {
  .l-side {
    width: 38px;
    height: auto;
  }
  .l-side.--left {
    left: auto;
    right: 0;
    top: 80px;
  }
  .l-side.--right {
    top: 272px;
  }
}

#daifuku {
  --keycolor: #ffdfc6;
}

#enfuku {
  --keycolor: #d3eed6;
}

#kinfuku {
  --keycolor: #ffdf80;
}

#mifuku {
  --keycolor: #cdb7c9;
}

.p-omikuji {
  --g-angle: 180deg;
  --height_this: 70vh;
  --fz_rubi: 30px;
  --fz_text: 72px;
  background: linear-gradient(var(--g-angle), var(--keycolor) 0%, #ffffff 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  height: var(--height_this);
  width: 100%;
  max-width: 100%;
}
#mifuku .p-omikuji {
  --fz_text: 60px;
}
@media screen and (max-width: 540px) {
  .p-omikuji {
    --fz_rubi: 22px;
    --fz_text: 60px;
    --height_this: 55vh;
  }
}
.p-omikuji .p-omikuji__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  max-width: 100%;
  width: 100%;
  height: var(--height_this);
}
.p-omikuji .p-omikuji__inner::before {
  position: absolute;
  z-index: 0;
  left: 0;
  top: 0;
  background-image: url("https://storage.googleapis.com/studio-design-asset-files/projects/8dO85zLnqn/s-1280x550_v-fms_webp_952917b4-40b9-49fc-981a-cff3059b4909.webp");
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: contain;
  pointer-events: none;
  width: 100%;
  height: 100%;
  display: block;
  content: "";
}
@media screen and (max-width: 896px) {
  .p-omikuji .p-omikuji__inner::before {
    background-size: cover;
  }
}
.p-omikuji .p-omikuji__inner .p-omikuji__result {
  flex-direction: row;
  align-items: flex-start;
  justify-content: center;
  max-width: 100%;
  height: 30vh;
}
.p-omikuji .p-omikuji__inner .p-omikuji__result .p-omikuji__result-rubi {
  display: flex;
  font-weight: 400;
  font-size: var(--fz_rubi);
  line-height: 1;
  letter-spacing: 0.2em;
  height: calc(100% + 20px);
  margin: -10px 0px -10px 0px;
  text-align: center;
  max-width: 100%;
  width: auto;
  writing-mode: vertical-rl;
  justify-content: center;
}
.p-omikuji .p-omikuji__inner .p-omikuji__result .p-omikuji__result-text {
  display: flex;
  justify-content: center;
  font-weight: 700;
  font-size: var(--fz_text);
  letter-spacing: 0.2em;
  line-height: 1.7;
  width: auto;
  height: 30vh;
  margin: 0px 0px 0px -20px;
  text-align: center;
  writing-mode: vertical-rl;
  max-width: calc(100% + 20px);
}
@media screen and (max-width: 896px) {
  .p-omikuji .p-omikuji__inner {
    margin: 0px 38px 0px 38px;
    max-width: calc(100% - 76px);
    width: calc(100% - 76px);
  }
  .p-omikuji .p-omikuji__inner::before {
    background-size: cover;
  }
}
@media screen and (max-width: 540px) {
  .p-omikuji .p-omikuji__inner {
    margin: 0px 38px 40px 0px;
    max-width: calc(100% - 38px);
    width: calc(100% - 38px);
  }
  .p-omikuji .p-omikuji__inner::before {
    background-size: cover;
  }
}

.p-message {
  --fz_lead: 22px;
  --fz_type: 32px;
  padding: 50px 0;
}
@media screen and (max-width: 896px) {
  .p-message {
    --fz_lead: 19px;
    --fz_type: 28px;
  }
}
@media screen and (max-width: 540px) {
  .p-message {
    --fz_lead: 18px;
    --fz_type: 28px;
  }
}
.p-message .p-message__lead {
  align-items: flex-start;
  margin: 0px 50px 0px 50px;
  max-width: calc(100% - 100px);
  width: 840px;
}
.p-message .p-message__lead .p-message__lead-label {
  background: rgba(0, 0, 0, 0);
  border-right: 2px solid #000;
  color: #000000;
  font-style: normal;
  font-weight: 500;
  font-size: var(--fz_lead);
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
  width: 47px;
  writing-mode: vertical-rl;
}
.p-message .p-message__text {
  margin: -100px 0px 0px 0px;
  width: 600px;
}
.p-message .p-message__text .p-message__type {
  font-feature-settings: "palt" 1;
  font-size: var(--fz_type);
  font-weight: 500;
  letter-spacing: 0.5em;
  line-height: 1.72;
  text-align: center;
  margin-bottom: 25px;
  width: 600px;
}
.p-message .p-message__text .p-message__copy {
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 1.9;
  text-align: justify;
  max-width: 100%;
  width: auto;
  justify-content: space-between;
}
@media screen and (max-width: 896px) {
  .p-message .p-message__lead {
    max-width: 80%;
    width: 80%;
  }
  .p-message .p-message__text {
    margin: -100px 0px 0px 64px;
    width: calc(72% - 64px);
    max-width: calc(72% - 64px);
  }
}
@media screen and (max-width: 540px) {
  .p-message {
    padding-top: 0;
  }
  .p-message .p-message__lead {
    max-width: 92%;
    width: 92%;
  }
  .p-message .p-message__lead .p-message__lead-label {
    width: 34px;
  }
  .p-message .p-message__text {
    margin: -100px 0px 0px 28px;
    width: calc(70% - 28px);
    max-width: calc(70% - 28px);
  }
}

.p-share {
  --fz_lead: 14px;
  --fz_share: 13px;
  width: 100%;
}
@media screen and (max-width: 540px) {
  .p-share {
    --fz_share: 12px;
  }
}
.p-share .p-share__lead {
  z-index: 2;
  font-weight: 400;
  font-size: var(--fz_lead);
  letter-spacing: 0.05em;
  line-height: 1.9;
}
.p-share .p-share__list {
  z-index: 2;
  display: flex;
  justify-content: space-between;
  width: 400px;
  margin-top: 20px;
}
@media screen and (max-width: 540px) {
  .p-share .p-share__list {
    width: 90%;
    margin-top: 40px;
  }
}
.p-share .p-share__list .p-share__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30%;
  height: 30px;
}
.p-share .p-share__list .p-share__item .p-share__item-icon {
  display: block;
  width: 20px;
  height: auto;
  margin-right: 10px;
  max-width: calc(100% - 10px);
}
.p-share .p-share__list .p-share__item .p-share__item-name {
  font-weight: 400;
  font-size: var(--fz_share);
  line-height: 1.4;
  text-align: center;
  color: white;
}
.p-share .p-share__list .p-share__item.--facebook {
  background-color: var(--color_facebook);
}
.p-share .p-share__list .p-share__item.--twitter {
  background-color: var(--color_twitter);
}
.p-share .p-share__list .p-share__item.--line {
  background-color: var(--color_line);
}
.p-share .p-share__logo {
  z-index: 2;
  display: block;
  aspect-ratio: 2/1;
  max-width: 800px;
  width: auto;
  height: 20vh;
  margin-top: 20px;
}
@media screen and (max-width: 896px) {
  .p-share .p-share__logo {
    max-width: 100%;
    height: 267px;
  }
}
@media screen and (max-width: 540px) {
  .p-share .p-share__logo {
    height: auto;
    margin: 0px 0px 0px 28px;
    width: calc(70% - 28px);
    max-width: calc(70% - 28px);
  }
}
.p-share .p-photo {
  display: block;
  position: absolute;
  z-index: 0;
  height: auto;
}
.p-share .p-photo.--left {
  left: 0px;
  top: -55px;
  bottom: -386px;
  width: 30%;
}
.p-share .p-photo.--right {
  right: -6%;
  top: 0;
  width: 50%;
  height: auto;
}
@media screen and (max-width: 896px) {
  .p-share .p-photo.--right {
    right: -10%;
    width: 65%;
  }
}
@media screen and (max-width: 540px) {
  .p-share .p-photo.--left {
    top: -21px;
    bottom: 17px;
    left: -43px;
    width: 40%;
  }
  .p-share .p-photo.--right {
    right: -10%;
    width: 65%;
  }
}

.p-line .p-line__banner {
  max-width: 600px;
  width: 100%;
  height: auto;
}
.p-line .p-line__link {
  display: block;
  max-width: 400px;
  width: 100%;
  margin: 50px auto;
}
.p-line .p-line__message {
  margin: 20px auto 40px;
  font-size: 14px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 540px) {
  .p-line {
    padding-top: 90px;
  }
  .p-line .p-line__banner {
    width: 75%;
  }
  .p-line .p-line__link {
    display: block;
    max-width: 400px;
    width: 100%;
    margin: 50px auto;
  }
  .p-line .p-line__message {
    margin: 20px auto 40px;
    font-size: 14px;
    letter-spacing: 0.05em;
  }
}

.l-footer {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 16px 0px 16px 0px;
  width: 100%;
  max-width: 100%;
  height: auto;
  background: #FFFFFF;
}
.l-footer .l-footer__link {
  width: 274px;
}