@charset "UTF-8";
/* # =================================================================
# Global selectors
# ================================================================= */
@import url("https://use.typekit.net/tpw4drf.css");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@700&display=swap");
html {
  box-sizing: border-box;
  overflow-y: scroll;
  /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%;
  /* iOS 8+ */ }

*,
::before,
::after {
  box-sizing: border-box; }

::before,
::after {
  text-decoration: inherit;
  /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit; }

/* Remove margin, padding of all elements and set background-no-repeat as default */
* {
  background-repeat: no-repeat;
  /* Set `background-repeat: no-repeat` to all elements */
  padding: 0;
  /* Reset `padding` and `margin` of all elements */
  margin: 0;
  line-height: 1.0; }

/* # =================================================================
# General elements
# ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
  display: none;
  height: 0; }

hr {
  overflow: visible;
  /* Show the overflow in Edge and IE */ }

/*
* Correct `block` display not defined for any HTML5 element in IE 8/9
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox
* Correct `block` display not defined for `main` in IE 11
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block; }

summary {
  display: list-item;
  /* Add the correct display in all browsers */ }

small {
  font-size: 80%;
  /* Set font-size to 80% in `small` elements */ }

[hidden],
template {
  display: none;
  /* Add the correct display in IE */ }

abbr[title] {
  border-bottom: 1px dotted;
  /* Add a bordered underline effect in all browsers */
  text-decoration: none;
  /* Remove text decoration in Firefox 40+ */ }

a {
  background-color: transparent;
  /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects;
  /* Remove gaps in links underline in iOS 8+ and Safari 8+ */ }

a:active,
a:hover {
  outline-width: 0;
  /* Remove the outline when hovering in all browsers */ }

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* Specify the font family of code elements */ }

b,
strong {
  font-weight: bolder;
  /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */ }

dfn {
  font-style: italic;
  /* Address styling not present in Safari and Chrome */ }

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000; }

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* # =================================================================
# Forms
# ================================================================= */
/* Apply cursor pointer to button elements */
button,
[type="button"],
[type="reset"],
[type="submit"]
[role="button"] {
  cursor: pointer; }

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default; }

[type="number"] {
  width: auto;
  /* Firefox 36+ */ }

[type="search"] {
  -webkit-appearance: textfield;
  /* Safari 8+ */ }

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  /* Safari 8 */ }

textarea {
  overflow: auto;
  /* Internet Explorer 11+ */
  resize: vertical;
  /* Specify textarea resizability */ }

optgroup {
  font-weight: bold;
  /* Restore the font weight unset by the previous rule. */ }

button {
  overflow: visible;
  /* Address `overflow` set to `hidden` in IE 8/9/10/11 */ }

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  padding: 0; }

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  outline: 1px dotted ButtonText; }

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS */ }

button,
select {
  text-transform: none;
  /* Firefox 40+, Internet Explorer 11- */ }

/* Remove the default button styling in all browsers */
/* Style select like a standard input */
select {
  /*  -moz-appearance: none;  Firefox 36+ */
  /*  -webkit-appearance: none;  Chrome 41+ */ }

select::-ms-expand {
  display: none;
  /* Internet Explorer 11+ */ }

select::-ms-value {
  color: currentColor;
  /* Internet Explorer 11+ */ }

legend {
  border: 0;
  /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit;
  /* Correct the color inheritance from `fieldset` elements in IE */
  display: table;
  /* Correct the text wrapping in Edge and IE */
  max-width: 100%;
  /* Correct the text wrapping in Edge and IE */
  white-space: normal;
  /* Correct the text wrapping in Edge and IE */ }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS and Safari */
  font: inherit;
  /* Change font properties to `inherit` in Chrome and Safari */ }

[type="search"] {
  -webkit-appearance: textfield;
  /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px;
  /* Correct the outline style in Safari */ }

/* # =================================================================
# Specify media element style
# ================================================================= */
img {
  border-style: none;
  /* Remove border when inside `a` element in IE 8/9/10 */
  max-width: 100%;
  height: auto; }

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline; }

svg:not(:root) {
  overflow: hidden;
  /* Internet Explorer 11- */ }

audio,
canvas,
progress,
video {
  display: inline-block;
  /* Internet Explorer 11+, Windows Phone 8.1+ */ }

/* # =================================================================
# Accessibility
# ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~="screen"] {
    display: inherit; }

  [hidden~="screen"]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important; } }
/* Specify the progress cursor of updating elements */
[aria-busy="true"] {
  cursor: progress; }

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer; }

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default; }

/* # =================================================================
# Selection
# ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }

::selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }

.pc_block {
  display: block; }
  @media only screen and (max-width: 768px) {
    .pc_block {
      display: none; } }

.pc_inline {
  display: inline; }
  @media only screen and (max-width: 768px) {
    .pc_inline {
      display: none; } }

.sp_block {
  display: none; }
  @media only screen and (max-width: 768px) {
    .sp_block {
      display: block; } }

.sp_inline {
  display: none; }
  @media only screen and (max-width: 768px) {
    .sp_inline {
      display: inline; } }

img {
  display: block;
  width: 100%; }

li {
  list-style: none; }

a {
  text-decoration: none;
  color: inherit;
  transition: .2s; }
  a:hover {
    transition: .2s;
    opacity: .7; }

* {
  font-family: "futura-pt-bold", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif;
  color: #0a0a0a;
  font-weight: 700; }

body {
  width: 100%;
  overflow: hidden; }

.defFlex, .top_taste_section .list, .top_access_section .contents, .rv_section .contents {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start; }

.fadein {
  opacity: 0;
  transform: translate(0, 50px);
  transition: 1s; }

.fadein.scrollin,
.slide_r.scrollin,
.slide_l.scrollin {
  opacity: 1;
  transform: translate(0, 0); }

.slide_r {
  opacity: 0;
  transform: translate(50px, 0);
  transition: 1s; }

.slide_l {
  opacity: 0;
  transform: translate(-50px, 0);
  transition: 1s; }

@keyframes ani_bg_1 {
  0% {
    transform: rotate(0); }
  50% {
    transform: rotate(15deg); }
  100% {
    transform: rotate(0); } }
@keyframes ani_logo_1 {
  0% {
    transform: rotate(0); }
  50% {
    transform: rotate(180deg); }
  100% {
    transform: rotate(360deg); } }
.lang_en {
  display: block; }

.lang_jp {
  display: none;
  font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif; }
  .lang_jp * {
    font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif; }

.jp .lang_en {
  display: none; }
.jp .lang_jp {
  display: block; }
@media only screen and (max-width: 768px) {
  .jp .top_class_section .bg_2 {
    display: none; } }

body {
  background-color: #FFFAF7;
  position: relative; }
  body .sideline_l,
  body .sideline_r {
    position: fixed;
    top: 0;
    z-index: 100;
    width: 50px;
    height: 100%;
    background-color: #FF5602; }
    @media only screen and (max-width: 768px) {
      body .sideline_l,
      body .sideline_r {
        width: 1.3vw; } }
  body .sideline_l {
    left: 0; }
  body .sideline_r {
    right: 0; }

.header {
  position: relative;
  width: 100%; }
  @media only screen and (max-width: 768px) {
    .header {
      height: 12vw;
      background-color: #FF5602;
      padding: 3vw 1.3vw;
      display: flex;
      flex-direction: row;
      justify-content: flex-start;
      align-items: center; } }
  .header_text {
    width: 36px;
    position: absolute;
    top: 49px;
    left: 6px;
    z-index: 101; }
    @media only screen and (max-width: 768px) {
      .header_text {
        position: static;
        width: 66vw;
        margin: 0 5.2vw 0 2.3vw; } }
  .header_links {
    width: 29px;
    position: absolute;
    top: 373px;
    right: 10px;
    z-index: 101; }
    @media only screen and (max-width: 768px) {
      .header_links {
        position: static;
        width: 16vw; } }
    .header_links a {
      display: block;
      margin: 18px auto;
      width: auto;
      max-height: 27px; }
      @media only screen and (max-width: 768px) {
        .header_links a {
          display: inline-block;
          max-width: 5.3vw;
          max-height: 5.3vw;
          margin: 0 0 0 2vw; } }

.top_mv_section {
  width: 93vw;
  max-width: 810px;
  margin: 0 auto;
  padding: 73px 0 78px; }
  @media only screen and (max-width: 768px) {
    .top_mv_section {
      padding: 8.8vw 0 31vw; } }
  .top_mv_section .main {
    width: 100%;
    position: relative; }
    .top_mv_section .main .link_1,
    .top_mv_section .main .link_2,
    .top_mv_section .main .link_3,
    .top_mv_section .main .link_4,
    .top_mv_section .main .link_5,
    .top_mv_section .main .bg_1,
    .top_mv_section .main .bg_2,
    .top_mv_section .main .bg_3,
    .top_mv_section .main .logo,
    .top_mv_section .main .lang_switch {
      position: absolute;
      z-index: 2; }
    .top_mv_section .main .link_1 {
      width: 356px;
      top: -12px;
      left: 79px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .link_1 {
          width: 41vw;
          top: 28vw;
          left: 10vw; } }
    .top_mv_section .main .link_2 {
      width: 130px;
      top: 125px;
      right: 32px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .link_2 {
          width: 15vw;
          top: 44vw;
          right: 3.5vw; } }
    .top_mv_section .main .link_3 {
      width: 225px;
      right: 135px;
      bottom: 90px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .link_3 {
          width: 28vw;
          right: 14vw;
          bottom: 9vw; } }
    .top_mv_section .main .link_4 {
      width: 168px;
      bottom: -17px;
      left: 180px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .link_4 {
          width: 20vw;
          bottom: -2vw;
          left: 20vw; } }
    .top_mv_section .main .link_5 {
      width: 72px;
      bottom: 115px;
      left: 46px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .link_5 {
          width: 8vw;
          bottom: 14vw;
          left: 6vw; } }
    .top_mv_section .main .bg_1 {
      width: 541px;
      top: -200px;
      left: -280px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .bg_1 {
          width: 49vw;
          top: 4vw;
          left: -7vw; } }
    .top_mv_section .main .bg_2 {
      width: 265px;
      top: -94px;
      right: -183px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .bg_2 {
          width: 24vw;
          top: 4vw;
          right: 1vw; } }
    .top_mv_section .main .bg_3 {
      width: 529px;
      bottom: -227px;
      right: -223px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .bg_3 {
          width: 58vw;
          bottom: -45vw;
          right: -4vw; } }
    .top_mv_section .main .logo {
      display: block;
      width: 266px;
      bottom: -98px;
      left: -106px; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .logo {
          width: 51vw;
          position: static;
          margin: 0 auto 14vw; } }
    .top_mv_section .main .lang_switch {
      width: 74px;
      top: 42px;
      right: 203px;
      cursor: pointer; }
      @media only screen and (max-width: 768px) {
        .top_mv_section .main .lang_switch {
          width: 21vw;
          top: auto;
          bottom: -25vw;
          right: auto;
          left: 6.6vw; } }
      .top_mv_section .main .lang_switch.jp .lang_switch_en {
        display: none; }
      .top_mv_section .main .lang_switch.jp .lang_switch_jp {
        display: block; }
      .top_mv_section .main .lang_switch .lang_switch_jp {
        display: none; }
    .top_mv_section .main .bg_1,
    .top_mv_section .main .bg_2,
    .top_mv_section .main .bg_3 {
      animation: ani_bg_1 2s ease-in-out infinite reverse forwards running; }

.top_lead_section {
  padding: 155px 0 0;
  position: relative; }
  @media only screen and (max-width: 768px) {
    .top_lead_section {
      margin: 0;
      padding: 32vw 0 3.7vw; } }
  .top_lead_section > .ttl {
    max-width: 227px;
    margin: 0 auto 47px; }
    @media only screen and (max-width: 768px) {
      .top_lead_section > .ttl {
        max-width: 36vw;
        margin: 0 auto 5.6vw; } }
  .top_lead_section .text {
    font-size: 18px;
    line-height: 1.9;
    width: 87vw;
    max-width: 706px;
    margin: 0 auto;
    text-align: center; }
    @media only screen and (max-width: 768px) {
      .top_lead_section .text {
        font-size: 4vw;
        line-height: 1.6; } }
  .top_lead_section .slider_block {
    margin: 51px 0; }
    @media only screen and (max-width: 768px) {
      .top_lead_section .slider_block {
        margin: 6vw 0; } }
    .top_lead_section .slider_block .slider_item {
      width: 468px;
      margin: 6px; }
      @media only screen and (max-width: 768px) {
        .top_lead_section .slider_block .slider_item {
          width: 76vw;
          margin: .9vw; } }
      .top_lead_section .slider_block .slider_item.slick-current img {
        opacity: 1; }
      .top_lead_section .slider_block .slider_item img {
        opacity: .4;
        transition: 1s; }
  .top_lead_section .sign {
    width: 87vw;
    max-width: 626px;
    margin: 20px auto 0; }
    @media only screen and (max-width: 768px) {
      .top_lead_section .sign {
        width: 52vw;
        margin: 4vw 7.5vw 0 auto; } }
    .top_lead_section .sign img {
      max-width: 322px;
      margin: 0 0 0 auto; }
  .top_lead_section .bg_1,
  .top_lead_section .bg_2 {
    position: absolute;
    z-index: -1; }
  .top_lead_section .bg_1 {
    top: -2px;
    left: 96px;
    width: 387px; }
    @media only screen and (max-width: 768px) {
      .top_lead_section .bg_1 {
        top: -6vw;
        left: 5.5vw;
        width: 52vw; } }

.top_class_section {
  padding: 83px 0 454px; }
  @media only screen and (max-width: 768px) {
    .top_class_section {
      padding: 0;
      margin: 0 0 28vw; } }
  .top_class_section > .ttl {
    max-width: 417px;
    margin: 0 auto 41px; }
    @media only screen and (max-width: 768px) {
      .top_class_section > .ttl {
        max-width: 70vw;
        margin: 0 auto 9.6vw; } }
  .top_class_section .slider_block {
    margin: 0 0 42px; }
    @media only screen and (max-width: 768px) {
      .top_class_section .slider_block {
        margin: 0 0 9vw; } }
    .top_class_section .slider_block .slider_item {
      width: 660px;
      margin: 6px; }
      @media only screen and (max-width: 768px) {
        .top_class_section .slider_block .slider_item {
          width: 76vw;
          margin: .9vw; } }
      .top_class_section .slider_block .slider_item.slick-current img {
        opacity: 1; }
      .top_class_section .slider_block .slider_item img {
        opacity: .4;
        transition: 1s; }
  .top_class_section .class_item {
    width: 87vw;
    max-width: 735px;
    margin: 0 auto 44px; }
    @media only screen and (max-width: 768px) {
      .top_class_section .class_item {
        margin: 0 auto 30vw; } }
    .top_class_section .class_item dt {
      font-size: 20px;
      color: #fff;
      background-color: #0a0a0a;
      border-radius: 40px;
      text-align: center;
      width: 100%;
      max-width: 244px;
      padding: 14px 0;
      margin: 0 0 22px; }
      @media only screen and (max-width: 768px) {
        .top_class_section .class_item dt {
          font-size: 4.3vw;
          border-radius: 6vw;
          max-width: 49vw;
          padding: 2.6vw 0;
          margin: 0 0 5.4vw; } }
    .top_class_section .class_item dd {
      font-size: 16px;
      line-height: 2; }
      @media only screen and (max-width: 768px) {
        .top_class_section .class_item dd {
          font-size: 4vw;
          line-height: 1.6; } }
      .top_class_section .class_item dd .link {
        display: block;
        margin: 6px 48px 0 auto;
        border-bottom: 3px solid #FF5602;
        font-size: 16px;
        color: #FF5602;
        position: relative; }
        @media only screen and (max-width: 768px) {
          .top_class_section .class_item dd .link {
            margin: 6.4vw 12.8vw 0 auto;
            font-size: 4vw;
            line-height: 1.3; } }
        .top_class_section .class_item dd .link.sm {
          max-width: 112px;
          padding: 0 0 6px;
          margin: 26px 48px 0 auto; }
          @media only screen and (max-width: 768px) {
            .top_class_section .class_item dd .link.sm {
              max-width: 28vw;
              padding: 0 0 .5vw 0; } }
        .top_class_section .class_item dd .link.md {
          max-width: 318px; }
          @media only screen and (max-width: 768px) {
            .top_class_section .class_item dd .link.md {
              max-width: 51vw;
              padding: 0 23vw .5vw 0; } }
          .top_class_section .class_item dd .link.md img {
            max-width: 105px;
            margin: 0 0 0 6px; }
            @media only screen and (max-width: 768px) {
              .top_class_section .class_item dd .link.md img {
                max-width: 23vw;
                margin: 0; } }
        .top_class_section .class_item dd .link.lg {
          max-width: 370px; }
          @media only screen and (max-width: 768px) {
            .top_class_section .class_item dd .link.lg {
              max-width: 65vw;
              padding: 0 37vw .5vw 0; } }
          .top_class_section .class_item dd .link.lg img {
            max-width: 144px;
            margin: 0 0 6px 13px; }
            @media only screen and (max-width: 768px) {
              .top_class_section .class_item dd .link.lg img {
                max-width: 35vw;
                margin: 0; } }
        .top_class_section .class_item dd .link img {
          display: inline-block;
          vertical-align: middle; }
          @media only screen and (max-width: 768px) {
            .top_class_section .class_item dd .link img {
              position: absolute;
              top: 50%;
              transform: translateY(-50%);
              right: 0;
              z-index: 1; } }
        .top_class_section .class_item dd .link::after {
          content: '';
          display: block;
          width: 36px;
          height: 36px;
          background-image: url(../images/ico_tri.png);
          background-size: 100%;
          position: absolute;
          top: 50%;
          transform: translateY(-50%);
          right: -48px;
          z-index: 1; }
          @media only screen and (max-width: 768px) {
            .top_class_section .class_item dd .link::after {
              width: 9.6vw;
              height: 9.6vw;
              right: -12.8vw; } }
  .top_class_section .bg_1,
  .top_class_section .bg_2 {
    position: absolute; }
  .top_class_section .bg_1 {
    width: 236px;
    top: -18px;
    right: 73px;
    z-index: 1; }
    @media only screen and (max-width: 768px) {
      .top_class_section .bg_1 {
        width: 27vw;
        top: 62vw;
        right: 1vw; } }
  .top_class_section .bg_2 {
    width: 417px;
    bottom: 73px;
    left: 173px;
    z-index: -1; }
    @media only screen and (max-width: 768px) {
      .top_class_section .bg_2 {
        width: 45vw;
        bottom: 72vw;
        left: auto;
        right: -9vw; } }

.top_taste_section {
  padding: 0 0 207px; }
  @media only screen and (max-width: 768px) {
    .top_taste_section {
      padding: 0 0 40vw;
      margin: -10vw 0 0; } }
  .top_taste_section > .ttl {
    max-width: 613px;
    margin: 0 auto 46px; }
    @media only screen and (max-width: 768px) {
      .top_taste_section > .ttl {
        max-width: 67vw;
        margin: 0 auto 8.5vw; } }
  .top_taste_section .list {
    width: 87vw;
    max-width: 823px;
    margin: 0 auto 23px;
    gap: 0 2%; }
    @media only screen and (max-width: 768px) {
      .top_taste_section .list {
        width: 77vw;
        flex-direction: column;
        margin: 0 auto 6.4vw;
        gap: 5.3vw 0; } }
    .top_taste_section .list .list_item {
      width: 32%; }
      @media only screen and (max-width: 768px) {
        .top_taste_section .list .list_item {
          width: 100%; } }
      .top_taste_section .list .list_item iframe {
        width: 100% !important;
        min-width: auto !important; }
  .top_taste_section .text {
    text-align: center;
    font-size: 14px;
    margin: 0 0 27px; }
    @media only screen and (max-width: 768px) {
      .top_taste_section .text {
        font-size: 4vw;
        margin: 0 0 10.4vw;
        line-height: 1.5; } }
  .top_taste_section .link {
    margin: 0 auto;
    border-bottom: 3px solid #FF5602;
    position: relative;
    color: #FF5602;
    font-size: 16px;
    line-height: 1.3; }
    @media only screen and (max-width: 768px) {
      .top_taste_section .link {
        font-size: 4vw;
        margin: 0 calc(10.7vw + 7.5vw) 0 auto;
        line-height: 1.2;
        padding: 0 0 1vw; } }
    .top_taste_section .link.lg {
      width: 155px; }
      @media only screen and (max-width: 768px) {
        .top_taste_section .link.lg {
          width: 19vw; } }
    .top_taste_section .link.sm {
      width: 96px;
      padding: 0 0 4px; }
      @media only screen and (max-width: 768px) {
        .top_taste_section .link.sm {
          width: 24vw;
          padding: 0 0 1vw; } }
    .top_taste_section .link::after {
      content: '';
      display: block;
      width: 36px;
      height: 36px;
      background-image: url(../images/ico_insta_2.png);
      background-size: 100%;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: -43px;
      z-index: 1; }
      @media only screen and (max-width: 768px) {
        .top_taste_section .link::after {
          width: 9.6vw;
          height: 9.6vw;
          right: -10.7vw; } }

.form .form_item {
  margin: 0 0 30px; }
  @media only screen and (max-width: 768px) {
    .form .form_item {
      margin: 0 0 5.3vw; } }
  .form .form_item:nth-last-of-type(1) {
    margin: 0; }
  .form .form_item .ttl {
    font-size: 16px;
    color: #FF5602;
    margin: 0 0 14px; }
    @media only screen and (max-width: 768px) {
      .form .form_item .ttl {
        font-size: 4vw;
        margin: 0 0 3.5vw 2vw; } }
  .form .form_item .field input[name="your_name"],
  .form .form_item .field input[name="your_email"],
  .form .form_item .field input[name="your_date_1"],
  .form .form_item .field input[name="your_date_2"],
  .form .form_item .field input[name="your_date_3"],
  .form .form_item .field input[name="your_number"],
  .form .form_item .field textarea[name="your_inq"] {
    width: 100%;
    font-size: 16px;
    background-color: #fff;
    border-radius: 24px;
    border: 1px solid #111;
    padding: 10px 17px; }
    @media only screen and (max-width: 768px) {
      .form .form_item .field input[name="your_name"],
      .form .form_item .field input[name="your_email"],
      .form .form_item .field input[name="your_date_1"],
      .form .form_item .field input[name="your_date_2"],
      .form .form_item .field input[name="your_date_3"],
      .form .form_item .field input[name="your_number"],
      .form .form_item .field textarea[name="your_inq"] {
        border-radius: 5vw;
        padding: 1.5vw 5vw; } }
  .form .form_item .field textarea[name="your_inq"] {
    height: 162px;
    line-height: 2; }
    @media only screen and (max-width: 768px) {
      .form .form_item .field textarea[name="your_inq"] {
        height: 53vw; } }
  .form .form_item .field span {
    display: inline-block;
    font-size: 20px; }
    @media only screen and (max-width: 768px) {
      .form .form_item .field span {
        font-size: 3.7vw; } }
    .form .form_item .field span.mr {
      margin-right: 37px; }
      @media only screen and (max-width: 768px) {
        .form .form_item .field span.mr {
          margin-right: 4.2vw; } }
    .form .form_item .field span.ml {
      margin-left: 13px; }
      @media only screen and (max-width: 768px) {
        .form .form_item .field span.ml {
          margin-left: 2vw; } }
  .form .form_item .field .date_block {
    margin: 21px 0 42px; }
    @media only screen and (max-width: 768px) {
      .form .form_item .field .date_block {
        margin: 5vw 0 5vw 2vw; } }
    .form .form_item .field .date_block input {
      display: inline-block;
      max-width: 269px;
      padding: 12px 17px; }
      @media only screen and (max-width: 768px) {
        .form .form_item .field .date_block input {
          max-width: 45vw;
          padding: 2vw 5vw; } }
  .form .form_item .field input[name="your_number"] {
    max-width: 101px; }
    @media only screen and (max-width: 768px) {
      .form .form_item .field input[name="your_number"] {
        max-width: 24vw; } }
.form .submit_btn {
  display: block;
  width: 69px;
  height: 30px;
  background-color: #FF5602;
  font-size: 12px;
  color: #fff;
  text-align: center;
  border-radius: 15px;
  border: none; }
  @media only screen and (max-width: 768px) {
    .form .submit_btn {
      width: 21vw;
      height: 9.8vw;
      font-size: 4.5vw;
      border-radius: 6vw; } }

.top_contact_section {
  padding: 0 0 215px;
  width: 87vw;
  max-width: 468px;
  margin: 0 auto;
  position: relative; }
  @media only screen and (max-width: 768px) {
    .top_contact_section {
      padding: 0 0 41vw; } }
  .top_contact_section > .ttl {
    max-width: 229px;
    margin: 0 auto 28px; }
    @media only screen and (max-width: 768px) {
      .top_contact_section > .ttl {
        max-width: 48vw;
        margin: 0 auto 6.6vw; } }
  .top_contact_section .form .submit_btn {
    margin: 31px auto 0; }
    @media only screen and (max-width: 768px) {
      .top_contact_section .form .submit_btn {
        margin: 6.4vw 0 0 auto; } }
  .top_contact_section .bg_1,
  .top_contact_section .bg_2 {
    position: absolute;
    z-index: -1; }
  .top_contact_section .bg_1 {
    width: 495px;
    top: -250px;
    left: 0;
    transform: translateX(-73%); }
    @media only screen and (max-width: 768px) {
      .top_contact_section .bg_1 {
        width: 58vw;
        top: -65vw;
        left: -5vw;
        transform: translateX(0); } }
  .top_contact_section .bg_2 {
    width: 388px;
    bottom: 70px;
    right: 0;
    transform: translateX(94%); }
    @media only screen and (max-width: 768px) {
      .top_contact_section .bg_2 {
        width: 52vw;
        bottom: 4vw;
        right: auto;
        transform: translateX(0);
        left: 5vw; } }

.top_access_section {
  padding: 0 0 99px; }
  @media only screen and (max-width: 768px) {
    .top_access_section {
      padding: 0 0 9.8vw; } }
  .top_access_section > .ttl {
    max-width: 140px;
    margin: 0 auto 22px; }
    @media only screen and (max-width: 768px) {
      .top_access_section > .ttl {
        max-width: 35vw;
        margin: 0 auto 7.4vw; } }
  .top_access_section .contents {
    align-items: center;
    width: 87vw;
    max-width: 1016px;
    margin: 0 auto;
    gap: 37px; }
    @media only screen and (max-width: 768px) {
      .top_access_section .contents {
        flex-direction: column;
        gap: 5vw 0; } }
    .top_access_section .contents .maps {
      width: 231px;
      border: 3px solid #FF5602;
      border-radius: 50%;
      overflow: hidden; }
      @media only screen and (max-width: 768px) {
        .top_access_section .contents .maps {
          width: 51vw; } }
      .top_access_section .contents .maps iframe {
        width: 100%;
        height: 231px; }
        @media only screen and (max-width: 768px) {
          .top_access_section .contents .maps iframe {
            height: 49.4vw; } }
    .top_access_section .contents .emp,
    .top_access_section .contents .desc {
      width: calc(calc(100% - 231px - 37px - 37px)/2); }
      @media only screen and (max-width: 768px) {
        .top_access_section .contents .emp,
        .top_access_section .contents .desc {
          width: 100%; } }
    @media only screen and (max-width: 768px) {
      .top_access_section .contents .emp {
        display: none; } }
    @media only screen and (max-width: 768px) {
      .top_access_section .contents .desc {
        text-align: center; } }
    .top_access_section .contents .desc .ttl {
      font-size: 18px;
      color: #FF5602;
      display: inline-block;
      border-bottom: 2px solid #FF5602;
      margin: 0 0 13px;
      padding: 0 0 5px; }
      @media only screen and (max-width: 768px) {
        .top_access_section .contents .desc .ttl {
          font-size: 4vw;
          padding: 0 0 1vw;
          margin: 0 0 3vw;
          border-bottom: 3px solid #FF5602; } }
    .top_access_section .contents .desc .text {
      font-size: 13px;
      line-height: 1.9; }
      @media only screen and (max-width: 768px) {
        .top_access_section .contents .desc .text {
          font-size: 4vw;
          line-height: 1.4; } }

.footer {
  padding: 64px 0;
  background-color: #FF5602; }
  @media only screen and (max-width: 768px) {
    .footer {
      padding: 9vw 0; } }
  .footer .logo {
    display: block;
    max-width: 149px;
    margin: 0 auto; }
    @media only screen and (max-width: 768px) {
      .footer .logo {
        max-width: 42vw; } }

.gotop {
  opacity: 0;
  transition: .5s;
  width: 120px;
  position: fixed;
  bottom: 90px;
  left: 90px;
  z-index: 102;
  animation: ani_logo_1 15s linear infinite reverse forwards running; }
  @media only screen and (max-width: 768px) {
    .gotop {
      height: 0;
      overflow: hidden; } }
  .gotop.active {
    opacity: 1; }

.slick-dots {
  text-align: center;
  margin: 15px 0 0; }
  @media only screen and (max-width: 768px) {
    .slick-dots {
      margin: 2vw 0 0; } }
  .slick-dots li {
    display: inline-block;
    width: 13px;
    margin-right: 9px; }
    @media only screen and (max-width: 768px) {
      .slick-dots li {
        width: 3vw;
        margin-right: 3vw; } }
    .slick-dots li:nth-last-of-type(1) {
      margin-right: 0; }
    .slick-dots li.slick-active button:before {
      background-color: #FF5602; }
    .slick-dots li button {
      position: relative;
      text-indent: -9999px;
      box-shadow: none;
      border: none; }
      .slick-dots li button:before {
        content: '';
        display: block;
        background-color: #ffffff;
        border: 2px solid #FF5602;
        border-radius: 50%;
        width: 13px;
        height: 13px;
        position: absolute;
        top: 0;
        left: 0; }
        @media only screen and (max-width: 768px) {
          .slick-dots li button:before {
            width: 3vw;
            height: 3vw; } }

.rv_section {
  padding: 140px 0 155px;
  width: 87vw;
  max-width: 866px;
  margin: 0 auto; }
  @media only screen and (max-width: 768px) {
    .rv_section {
      padding: 16vw 0 37vw; } }
  .rv_section * {
    font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, sans-serif; }
  .rv_section > .ttl {
    text-align: center;
    font-size: 40px;
    margin: 0 0 60px; }
    @media only screen and (max-width: 768px) {
      .rv_section > .ttl {
        font-size: 7.4vw;
        text-align: left;
        margin: 0 0 8.8vw; } }
  .rv_section .contents {
    width: 100%; }
    @media only screen and (max-width: 768px) {
      .rv_section .contents {
        flex-direction: column; } }
    .rv_section .contents .price {
      width: 262px;
      margin: 0 67px 0 0;
      font-size: 40px;
      color: #FF5602;
      transform: translateY(-5px); }
      @media only screen and (max-width: 768px) {
        .rv_section .contents .price {
          width: 100%;
          margin: 0 0 8.4vw;
          font-size: 7.7vw;
          transform: translateY(0); } }
      .rv_section .contents .price small {
        font-size: 30px;
        color: #FF5602; }
        @media only screen and (max-width: 768px) {
          .rv_section .contents .price small {
            font-size: 5.6vw; } }
    .rv_section .contents .main {
      width: calc(100% - 262px - 67px); }
      @media only screen and (max-width: 768px) {
        .rv_section .contents .main {
          width: 100%; } }
      .rv_section .contents .main .text {
        font-size: 18px;
        line-height: 1.4;
        margin: 0 0 80px; }
        @media only screen and (max-width: 768px) {
          .rv_section .contents .main .text {
            font-size: 3.7vw;
            line-height: 1.7;
            margin: 0 0 12vw; } }
      .rv_section .contents .main .form .submit_btn {
        margin: 31px 0 0; }
        @media only screen and (max-width: 768px) {
          .rv_section .contents .main .form .submit_btn {
            margin: 6.4vw 0 0 auto; } }
    .rv_section .contents .bg_1,
    .rv_section .contents .bg_2,
    .rv_section .contents .bg_3 {
      position: absolute;
      z-index: -1; }
    .rv_section .contents .bg_1 {
      top: 23px;
      right: 76px;
      width: 309px; }
      @media only screen and (max-width: 768px) {
        .rv_section .contents .bg_1 {
          width: 39vw;
          top: 13.9vw;
          right: 5vw; } }
    .rv_section .contents .bg_2 {
      width: 224px;
      top: 42%;
      right: 0;
      transform: translateX(-60%); }
      @media only screen and (max-width: 768px) {
        .rv_section .contents .bg_2 {
          width: 33vw;
          transform: translateX(0);
          right: 6.5vw;
          top: 57%; } }
    .rv_section .contents .bg_3 {
      width: 282px;
      bottom: 628px;
      left: 0;
      transform: translateX(88%); }
      @media only screen and (max-width: 768px) {
        .rv_section .contents .bg_3 {
          width: 38vw;
          bottom: 8vw;
          transform: translateY(-100%);
          left: 13vw; } }

.thankyou_section {
  min-height: 100vh;
  width: 87vw;
  margin: 0 auto;
  padding: 150px 0;
  text-align: center; }
  @media only screen and (max-width: 768px) {
    .thankyou_section {
      padding: 20vw 0;
      min-height: 78vh; } }
  .thankyou_section .ttl {
    font-size: 60px;
    margin-bottom: 45px; }
    @media only screen and (max-width: 768px) {
      .thankyou_section .ttl {
        font-size: 11vw;
        margin-bottom: 5.6vw; } }
  .thankyou_section .text {
    line-height: 1.9;
    margin-bottom: 45px; }
    @media only screen and (max-width: 768px) {
      .thankyou_section .text {
        line-height: 1.6;
        margin-bottom: 5.6vw; } }
    .thankyou_section .text .en {
      font-size: 22px; }
      @media only screen and (max-width: 768px) {
        .thankyou_section .text .en {
          font-size: 4.6vw; } }
    .thankyou_section .text .jp {
      font-size: 18px; }
      @media only screen and (max-width: 768px) {
        .thankyou_section .text .jp {
          font-size: 4vw; } }
  .thankyou_section .link {
    font-size: 28px; }
    @media only screen and (max-width: 768px) {
      .thankyou_section .link {
        font-size: 6vw; } }

/*# sourceMappingURL=style.css.map */
