@charset "UTF-8";
/* 変数の定義
--------------------------------------------------*/
/* 色の定義
--------------------------------------------------*/
/* テキストパーツ
--------------------------------------------------*/
.white {
  color: #fff;
}

.black {
  color: #373741;
}

.gold {
  color: #AD9757;
}

.yellow {
  color: #F9F4EA;
}

/* フォントの定義
--------------------------------------------------*/
html, body, ul, ol, dl, li, dt, dd, p, div, span, img, svg, a, table, tr, th, td, figure {
  font-family: "Zen Old Mincho", serif;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #373741;
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Zen Old Mincho", serif;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #373741;
}

body {
  font-family: "Zen Old Mincho", serif;
  font-style: normal;
  font-weight: 400;
}

html {
  font-size: 62.5%;
}

p {
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.5;
  color: #373741;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 769px) {
  p {
    font-size: 1.6rem;
  }
}

.en {
  font-family: "Sorts Mill Goudy", serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.05em;
}

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

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* sec_FV
--------------------------------------------------*/
#top__kv {
  width: 100%;
  height: 650px;
}
#top__kv .kv_catch_wrap {
  position: absolute;
  z-index: 100;
  top: calc(50% - 30px);
  left: 50%;
  transform: translate(-50%, -50%);
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #top__kv .kv_catch_wrap {
    top: calc(50% + 60px);
    left: 6.25vw;
    transform: translate(0, -50%);
    text-align: left;
  }
}
@media screen and (min-width: 1600px) {
  #top__kv .kv_catch_wrap {
    transform: translate(-50%, -50%);
    left: 50%;
    width: 1400px;
  }
}
#top__kv .white_block {
  display: inline-block;
  font-size: 1.8rem;
  font-weight: 500;
  color: white;
  border: 1px solid white;
  padding: 1px 10px;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
@media screen and (min-width: 769px) {
  #top__kv .white_block {
    font-size: 2rem;
  }
}
#top__kv .main_catch {
  font-size: 3.8rem;
  font-weight: 700;
  color: white;
  margin-top: 5px;
}
@media screen and (min-width: 769px) {
  #top__kv .main_catch {
    font-size: 6.4rem;
  }
}
#top__kv .sub_catch {
  font-size: 1.8rem;
  font-weight: 500;
  color: white;
  margin-top: 8px;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
@media screen and (min-width: 769px) {
  #top__kv .sub_catch {
    font-size: 2.4rem;
  }
}
#top__kv .scroll_bar {
  position: absolute;
  z-index: 100;
  bottom: 74px;
  left: 5.128vw;
  writing-mode: vertical-rl;
  color: white;
  font-size: clamp(1.2rem, 3.589vw, 1.4rem);
  letter-spacing: 0;
}
@media screen and (min-width: 769px) {
  #top__kv .scroll_bar {
    left: auto;
    right: 1.25vw;
    bottom: 280px;
    font-size: 1.8rem;
  }
}
#top__kv .scroll_bar::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 120px;
  background-color: white;
}
@media screen and (min-width: 769px) {
  #top__kv .scroll_bar::before {
    height: 180px;
  }
}
#top__kv .tel_wrap {
  position: absolute;
  z-index: 10;
  right: 5.128vw;
  bottom: 40px;
  text-align: center;
  padding: clamp(10px, 3.333vw, 13px);
  background-color: white;
}
#top__kv .tel_about_txt {
  color: #AD9757;
  font-weight: 500;
}
#top__kv .tel_txt {
  color: #AD9757;
  font-size: 2.2rem;
  font-weight: 500;
  width: 248px;
  padding-bottom: 5px;
  border-bottom: 1px solid #AD9757;
}
#top__kv .tel_under_txt {
  margin-top: 6px;
  color: #AD9757;
  font-size: 1.2rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
}
#top__kv .kotei_tel {
  color: #AD9757;
  font-size: 1.6rem;
  font-weight: 700;
}
#top__kv .tel_under_time {
  margin-top: 3px;
  color: #AD9757;
  font-size: 1.2rem;
  font-weight: 700;
}
#top__kv .swiper_kv {
  height: 100%;
}
#top__kv .swiper-img {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
#top__kv .swiper-slide-active .swiper-img,
#top__kv .swiper-slide-duplicate-active .swiper-img,
#top__kv .swiper-slide-prev .swiper-img {
  -webkit-animation: zoomUp 7s linear 0s normal both;
          animation: zoomUp 7s linear 0s normal both;
}
#top__kv .swiper-pagination {
  position: absolute;
  z-index: 10;
  top: auto;
  left: 50%;
  transform: translate(-50%, 0);
  bottom: 20px;
  width: auto;
  height: 10px;
}
@media screen and (min-width: 769px) {
  #top__kv .swiper-pagination {
    bottom: 40px;
    left: 6.25vw;
    transform: translate(0, 0);
  }
}
@media screen and (min-width: 1600px) {
  #top__kv .swiper-pagination {
    width: 1400px;
    left: 50%;
    transform: translate(-50%, 0);
    text-align: left;
  }
}
#top__kv .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1px solid white;
  background-color: transparent;
  opacity: 1;
  margin: 0 7.5px;
}
#top__kv .swiper-pagination-bullet-active {
  background-color: white;
}

/* sec_お知らせ
--------------------------------------------------*/
#top__news {
  margin-top: 40px;
  padding: 20px 0 13px;
  background-color: white;
}
@media screen and (min-width: 769px) {
  #top__news {
    background-color: transparent;
  }
}
@media screen and (min-width: 769px) {
  #top__news .inner-wrap {
    padding: 50px 6.25vw 60px;
    background-color: white;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
  }
}
@media screen and (min-width: 769px) {
  #top__news .inner-wrap::before {
    content: "";
    position: absolute;
    pointer-events: none;
    top: 10px;
    left: 10px;
    width: calc(100% - 20px);
    height: calc(100% - 20px);
    border: 1px solid #AD9757;
  }
}
@media screen and (min-width: 769px) {
  #top__news .left_wrap {
    width: 300px;
  }
}
#top__news .main_ttl {
  margin-bottom: 20px;
}
@media screen and (min-width: 769px) {
  #top__news .main_ttl {
    font-size: 3.2rem;
  }
}
#top__news .sp-news_wrap {
  position: relative;
  padding: 20px 10px;
}
@media screen and (min-width: 769px) {
  #top__news .sp-news_wrap {
    padding: 0;
    width: calc(100% - (300px + 3.75vw));
  }
}
#top__news .sp-news_wrap::before {
  content: "";
  position: absolute;
  width: calc(100% + 10.256vw - 20px);
  height: 100%;
  top: 0;
  left: calc(-5.128vw + 10px);
  border: 1px solid #AD9757;
}
@media screen and (min-width: 769px) {
  #top__news .sp-news_wrap::before {
    display: none;
  }
}
#top__news .main_btn.sp-view {
  margin-top: 5px;
}

/* sec_恵比寿寮について
--------------------------------------------------*/
#top__about {
  padding: 60px 0;
}
@media screen and (min-width: 769px) {
  #top__about {
    padding: 80px 0;
  }
}
@media screen and (min-width: 1000px) {
  #top__about .inner-wide-wrap {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
  }
}
#top__about .main_ttl {
  line-height: 1.6;
  letter-spacing: 0.15em;
  margin-bottom: 20px;
}
@media screen and (min-width: 1000px) {
  #top__about .about_left {
    max-width: 540px;
    width: 33.75vw;
  }
}
#top__about .about_left.pc-view {
  display: none;
}
@media screen and (min-width: 769px) {
  #top__about .about_left.pc-view {
    display: none;
  }
}
@media screen and (min-width: 1000px) {
  #top__about .about_left.pc-view {
    display: block;
  }
}
#top__about .about_left.sp-view {
  display: block;
}
@media screen and (min-width: 769px) {
  #top__about .about_left.sp-view {
    display: block;
  }
}
@media screen and (min-width: 1000px) {
  #top__about .about_left.sp-view {
    display: none;
  }
}
#top__about .about_img {
  position: relative;
}
#top__about .about_img01 {
  display: block;
  width: 76.448vw;
  margin-left: auto;
  margin-right: 0;
}
@media screen and (min-width: 769px) {
  #top__about .about_img01 {
    max-width: 460px;
  }
}
@media screen and (min-width: 1000px) {
  #top__about .about_img01 {
    width: 28.749vw;
  }
}
#top__about .about_img02 {
  display: block;
  width: 53.181vw;
  margin-top: -51.8px;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}
@media screen and (min-width: 769px) {
  #top__about .about_img02 {
    max-width: 320px;
  }
}
@media screen and (min-width: 1000px) {
  #top__about .about_img02 {
    width: 20vw;
    margin-top: -80px;
  }
}
@media screen and (min-width: 1000px) {
  #top__about .about_right {
    min-width: calc(100% - 620px);
    width: calc(100% - 38.75vw);
  }
}
#top__about .about_txt {
  font-size: 1.6rem;
  line-height: 2;
  margin-top: 20px;
}
@media screen and (min-width: 769px) {
  #top__about .about_txt {
    font-size: 1.8rem;
  }
}
#top__about .about_note {
  font-size: 1.2rem;
  line-height: 2;
  margin-top: 30px;
}
@media screen and (min-width: 769px) {
  #top__about .about_note {
    font-size: 1.4rem;
  }
}

/* sec_インフォメーション
--------------------------------------------------*/
#top__info {
  padding: 60px 0 70px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url(../img/top/sp_info_bg.webp);
}
@media screen and (min-width: 769px) {
  #top__info {
    background-image: url(../img/top/info_bg.webp);
  }
}
#top__info::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(55, 55, 65, 0.4);
  mix-blend-mode: multiply;
  pointer-events: none;
}
#top__info .en {
  position: relative;
  text-align: center;
  font-size: 3.2rem;
}
@media screen and (min-width: 769px) {
  #top__info .en {
    font-size: 4rem;
  }
}
#top__info .info_link_wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 40px;
  margin-top: 30px;
}
@media screen and (min-width: 769px) {
  #top__info .info_link_wrap {
    flex-direction: row;
    justify-content: center;
    gap: 5vw;
    margin-top: 40px;
  }
}
@media screen and (min-width: 1600px) {
  #top__info .info_link_wrap {
    gap: 80px;
  }
}
#top__info .line_link {
  width: 280px;
  max-width: 380px;
  background-color: white;
  color: #AD9757;
  border-color: white;
  padding: 23px 20px;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #top__info .line_link {
    width: 380px;
    max-width: 310px;
    margin: 0;
    padding: 35px 40px;
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 1000px) {
  #top__info .line_link {
    width: 380px;
    max-width: 380px;
  }
}
#top__info .line_link::before {
  background-color: #AD9757;
}
@media screen and (min-width: 769px) {
  #top__info .line_link::before {
    right: 40px;
  }
}
#top__info .line_link::after {
  content: "";
  position: absolute;
  top: -10px;
  left: -10px;
  width: calc(100% + 20px);
  height: calc(100% + 20px);
  border: 1px solid white;
  pointer-events: none;
  transition: all 0.4s ease-out;
}
#top__info .line_link:hover {
  color: white;
  background-color: #AD9757;
  border-color: #AD9757;
}
#top__info .line_link:hover::before {
  background-color: white;
}
@media screen and (min-width: 769px) {
  #top__info .line_link:hover::before {
    right: 30px;
  }
}
#top__info .line_link:hover::after {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-color: #AD9757;
}

/* sec_アクセス
--------------------------------------------------*/
#top__access {
  padding: 60px 0;
  background-color: white;
}
@media screen and (min-width: 769px) {
  #top__access {
    padding: 70px 0 100px;
  }
}
#top__access .main_ttl {
  text-align: center;
  padding-bottom: 20px;
  border-bottom: 1px solid #AD9757;
}
@media screen and (min-width: 769px) {
  #top__access .main_ttl {
    padding-bottom: 40px;
  }
}
#top__access .map_wrap {
  margin-top: 10px;
}
@media screen and (min-width: 769px) {
  #top__access .map_wrap {
    margin-top: 45px;
  }
}
#top__access .access_ttl {
  position: relative;
  font-size: 2rem;
  font-weight: 400;
  line-height: 2.8;
  padding-left: 23px;
}
@media screen and (min-width: 769px) {
  #top__access .access_ttl {
    font-size: 2.8rem;
    padding-left: 29.5px;
  }
}
#top__access .access_ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%) rotate(45deg);
  width: 12px;
  height: 12px;
  border-radius: 1px;
  border: 1px solid #AD9757;
}
@media screen and (min-width: 769px) {
  #top__access .access_ttl::before {
    width: 15px;
    height: 15px;
  }
}
#top__access .googlemap_wrap iframe {
  width: 100%;
  height: 200px;
}
@media screen and (min-width: 769px) {
  #top__access .googlemap_wrap iframe {
    height: 300px;
  }
}
@media screen and (min-width: 769px) {
  #top__access .map_flex_wrap {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-top: 60px;
  }
}
#top__access .map_left_wrap {
  margin-top: 19px;
  display: grid;
}
@media screen and (min-width: 769px) {
  #top__access .map_left_wrap {
    margin-top: 0;
    margin-left: 2.5vw;
    width: calc(305px + 5vw);
  }
}
#top__access .map_name, #top__access .map_access_ttl {
  position: relative;
  font-size: 2rem;
  padding-left: 8px;
}
@media screen and (min-width: 769px) {
  #top__access .map_name, #top__access .map_access_ttl {
    padding-left: 0;
  }
}
#top__access .map_name::before, #top__access .map_access_ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  width: 1px;
  height: 20px;
  background-color: #AD9757;
}
@media screen and (min-width: 769px) {
  #top__access .map_name::before, #top__access .map_access_ttl::before {
    display: none;
  }
}
#top__access .map_access {
  margin-top: 10px;
  margin-left: 10px;
}
@media screen and (min-width: 769px) {
  #top__access .map_access {
    margin-left: 0;
  }
}
#top__access .window_link {
  margin: auto;
  margin-top: 20px;
}
@media screen and (min-width: 769px) {
  #top__access .window_link {
    margin: 0;
    margin-top: 30px;
  }
}
#top__access .map_right_wrap {
  margin-top: 40px;
}
@media screen and (min-width: 769px) {
  #top__access .map_right_wrap {
    margin-top: 0;
    width: calc(100% - (305px + 7.5vw));
    padding-left: 2.5vw;
    border-left: 1px solid #AD9757;
  }
}
#top__access .way_list {
  margin-top: 27px;
}
#top__access .way_txt {
  position: relative;
  margin-top: 20px;
  padding-left: 20px;
  font-size: 1.6rem;
}
#top__access .way_txt::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  width: 13px;
  height: 14px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100%;
  background-image: url("data:image/svg+xml,%3Csvg width='13' height='15' viewBox='0 0 13 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9.625 0.75C11.0742 0.75 12.25 1.92578 12.25 3.375V10.375C12.25 11.6875 11.2656 12.7812 10.0078 12.9727L11.2656 14.2305C11.457 14.4219 11.3203 14.75 11.0469 14.75H9.98047C9.73438 14.75 9.51562 14.668 9.35156 14.5039L7.875 13H4.375L2.87109 14.5039C2.70703 14.668 2.48828 14.75 2.24219 14.75H1.17578C0.902344 14.75 0.765625 14.4219 0.957031 14.2305L2.21484 12.9727C0.957031 12.7812 0 11.6875 0 10.375V3.375C0 1.92578 1.14844 0.75 2.625 0.75H9.625ZM1.75 6.875C1.75 7.36719 2.13281 7.75 2.625 7.75H4.8125C5.27734 7.75 5.6875 7.36719 5.6875 6.875V4.25C5.6875 3.78516 5.27734 3.375 4.8125 3.375H2.625C2.13281 3.375 1.75 3.78516 1.75 4.25V6.875ZM7.4375 3.375C6.94531 3.375 6.5625 3.78516 6.5625 4.25V6.875C6.5625 7.36719 6.94531 7.75 7.4375 7.75H9.625C10.0898 7.75 10.5 7.36719 10.5 6.875V4.25C10.5 3.78516 10.0898 3.375 9.625 3.375H7.4375ZM2.625 9.5C2.13281 9.5 1.75 9.91016 1.75 10.375C1.75 10.8672 2.13281 11.25 2.625 11.25C3.08984 11.25 3.5 10.8672 3.5 10.375C3.5 9.91016 3.08984 9.5 2.625 9.5ZM9.625 11.25C10.0898 11.25 10.5 10.8672 10.5 10.375C10.5 9.91016 10.0898 9.5 9.625 9.5C9.13281 9.5 8.75 9.91016 8.75 10.375C8.75 10.8672 9.13281 11.25 9.625 11.25Z' fill='%23AD9757'/%3E%3C/svg%3E%0A");
}
#top__access .train_wrap {
  margin-top: 24px;
}
@media screen and (min-width: 769px) {
  #top__access .train_wrap {
    margin-top: 60px;
  }
}
@media screen and (min-width: 1000px) {
  #top__access .train_map_wrap {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
  }
}
#top__access .train_map {
  width: 100%;
}
@media screen and (min-width: 1000px) {
  #top__access .train_map {
    max-width: 520px;
    width: 32.5vw;
  }
}
#top__access .train_right_wrap {
  margin-top: 30px;
}
@media screen and (min-width: 1000px) {
  #top__access .train_right_wrap {
    margin-top: 0;
    width: calc(100% - 37.5vw);
  }
}
@media screen and (min-width: 1600px) {
  #top__access .train_right_wrap {
    width: calc(100% - 600px);
  }
}
#top__access .time_wrap {
  margin-top: 10px;
  padding: 20px;
  border: 1px solid #AD9757;
}
@media screen and (min-width: 769px) {
  #top__access .time_wrap {
    padding: 30px;
  }
}
#top__access .time_ttl {
  position: relative;
  display: inline-block;
  font-size: 1.6rem;
  margin-bottom: 5px;
}
@media screen and (min-width: 769px) {
  #top__access .time_ttl {
    padding-left: 20px;
  }
}
#top__access .time_ttl .dots {
  position: absolute;
  top: 50%;
  right: -32px;
  transform: translate(0, -50%);
  width: 27px;
  height: 2px;
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg width='27' height='2' viewBox='0 0 27 2' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='1' fill='%23AD9757'/%3E%3Ccircle cx='7' cy='1' r='1' fill='%23AD9757'/%3E%3Ccircle cx='13' cy='1' r='1' fill='%23AD9757'/%3E%3Ccircle cx='19' cy='1' r='1' fill='%23AD9757'/%3E%3Ccircle cx='26' cy='1' r='1' fill='%23AD9757'/%3E%3C/svg%3E%0A");
}
#top__access .time_list {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-wrap: wrap;
}
#top__access .time_list::before {
  content: "";
  position: absolute;
  top: 6px;
  left: 50%;
  transform: translate(-50%, 0);
  width: 1px;
  height: calc(100% - 6px);
  background-color: #AD9757;
}
@media screen and (min-width: 769px) {
  #top__access .time_list::before {
    top: 10px;
    height: calc(100% - 10px);
  }
}
#top__access .time {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: calc(50% - 11px);
  margin-top: 6px;
}
@media screen and (min-width: 1000px) {
  #top__access .time {
    width: 48%;
    margin-top: 10px;
  }
}
@media screen and (min-width: 1200px) {
  #top__access .time {
    width: 45%;
  }
}
@media screen and (min-width: 1400px) {
  #top__access .time {
    width: calc(50% - 3.125vw);
  }
}
#top__access .time .dots {
  position: relative;
  width: 12px;
  height: 2px;
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='2' viewBox='0 0 12 2' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='1' fill='%23AD9757'/%3E%3Ccircle cx='6' cy='1' r='1' fill='%23AD9757'/%3E%3Ccircle cx='11' cy='1' r='1' fill='%23AD9757'/%3E%3C/svg%3E%0A");
}
#top__access .time_txt {
  width: calc(100% - 18px);
  background-color: #F9F4EA;
  display: inline-block;
  padding: 2px 6.5px;
  font-size: 1.4rem;
}
@media screen and (min-width: 769px) {
  #top__access .time_txt {
    font-size: clamp(1.3rem, 1vw, 1.6rem);
  }
}
@media screen and (min-width: 450px) {
  #top__access .time_txt .sm-view {
    display: none;
  }
}
/*# sourceMappingURL=top.css.map */