@charset "utf-8";

/* =========================================
travelling-tea-house
========================================= */

/* ===============================
mv
=============================== */
.md_breadcrumbs,
.md_breadcrumbs a {
  color: #fff;
}

/* PC調整 ------------------ */
@media (min-width:769px) {
  .mv {
    position: relative;
    min-width: 1200px;
    min-height: 780px;
    background: url(../img/mv_bg_pc.jpg)no-repeat center center / cover;
    color: #fff;
  }
  .mv_lead {
    width: 930px;
    margin: 145px auto 0;
    padding: 0 0.5em;
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    letter-spacing: 0.2em;
  }
  .mv_title {
    margin-bottom: 30px;
    font-size: 24px;
    line-height: 1.71;
    letter-spacing: 0.2em;
    font-weight: 400;
  }
  .mv_title span {
    display: block;
  }
  .mv_title .text_1 {
    margin: 0 -0.5em 10px;
    margin-bottom: 10px;
  }
  .mv_title .text_3 {
    margin-left: 8.2em;
  }
  .mv .en {
    font-size: 15px;
    line-height: 1.47;
  }
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .mv {
    min-width: 320px;
    min-height: 568px;
    padding: 58px 15px;
    background: url(../img/mv_bg_sp.jpg)no-repeat center center / cover;
    color: #fff;
  }
  .mv_lead {
    width: fit-content;
    margin: 0 auto;
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    letter-spacing: 0.2em;
  }
  .mv_title {
    margin-bottom: 30px;
    font-size: 18px;
    line-height: 1.4;
    letter-spacing: 0.18em;
    font-weight: 400;
    white-space: nowrap;
  }
  .mv_title .text_1 {
    display: block;
    margin-bottom: 15px;
    text-indent: -0.5em;
  }
  .mv_title .text_2 {
    display: block;
    letter-spacing: 0.1em;
  }
  .mv .en {
    font-size: 12px;
    line-height: 1.84;
    letter-spacing: 0.12em;
  }
}

/* ===============================
photo_slide_wrap
=============================== */
.photo_slide_wrap {
  overflow: hidden;
  width: 100%;
  padding: 28px 0;
  background-color: #000;
}
.photo_slide {
  display: flex;
  will-change: transform;
  transform: translate3d(0, 0, 0);
}
.photo_slide > div {
  flex: 0 0 auto;
  width: 21%;
}
.photo_slide img {
  display: block;
  width: 100%;
  height: auto;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}

/* SP調整 ------------------ */
@media screen and (max-width:768px) {
  .photo_slide > div {
    width: 80%;
    max-width: 260px;
  }
}

/* ===============================
pg_ 汎用
=============================== */
.pg_inner {
  max-width: 900px;
  margin: 0 auto;
}
.pg_title {
  margin-bottom: 2em;
  font-size: 20px;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #0f5957;
  font-weight: bold;
}
.pg_bl_en {
  margin-top: 2.3em;
  font-size: 14px;
}
.pg_bl_en .italic {
  font-family: "Source Sans 3", sans-serif;
  font-style: italic;
  font-size: 16px;
  font-weight: 500;
}
.pg_title_en {
  font-size: 14px;
}
.pg_column_wrap {
  display: flex;
  justify-content: space-between;
  max-width: 900px;
  margin: 0 auto 40px;
}
.pg_column_wrap > * {
  width: 405px;
}
.pg_inner .mb1 {
  margin-bottom: 2.2em;
}
.pg_inner .link {
  color: #df5500;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .pg_inner {
    line-height: 2.2;
  }
  .pg_title {
    margin-bottom: 1em;
    font-size: 19px;
    line-height: 1.52;
  }
  .pg_bl_en {
    margin-top: 2.3em;
    font-size: 14px;
  }
  .pg_title_en {
    font-size: 14px;
  }
  .pg_column_wrap {
    display: block;
  }
  .pg_column_wrap > * {
    width: auto;
  }
}

/* ===============================
overview
=============================== */
.overview {
  padding: 58px 0 80px;
  background-color: #0f5957;
  color: #fff;
}
.overview .pg_title {
  margin-bottom: 16px;
  color: #fff;
  font-size: 22px;
  font-family: 'Noto Serif JP', serif;
  font-weight: 400;
  letter-spacing: 0.05em;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .overview {
    padding: 52px 15px 53px;
  }
  .overview .pg_title {
    margin-bottom: 15px;
    font-size: 19px;
    letter-spacing: 0.05em;
  }
}


/* ===============================
beginning
=============================== */
.beginning {
  padding: 48px 0 44px;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .beginning {
    padding: 46px 15px 73px;
  }
}

/* ===============================
teahouse / future
=============================== */
.future .mail {
  margin: 2.2em auto;
  color: #0e5957;
  letter-spacing: 0.1em;
  font-weight: bold;
  font-size: 15px;
}
.future .mail a {
  color: #0e5957;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .teahouse {
    padding: 0 15px 37px;
  }
  .future {
    padding: 0 15px 0;
  }
  .future .mail {
    margin-top: 0;
  }
}

/* ===============================
examples
=============================== */
.examples_header {
  max-width: 900px;
  margin: 0 auto 1em;
}
.examples_title,
.examples_date {
  font-size: 20px;
  letter-spacing: 0.1em;
  line-height: 1.54;
  color: #0e5957;
  font-weight: bold;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .examples_header {
    padding: 0 15px;
  }
  .examples_title,
  .examples_date {
    font-size: 19px;
  }
  .examples_date {
    margin-bottom: 2.2em;
  }
}

/* ===============================
examples / kamiyama
=============================== */

/* PC調整 ------------------ */
@media (min-width:769px) {
  .kamiyama_header {
    max-width: 900px;
    margin: 0 auto 46px;
  }
  .kamiyama_body {
    position: relative;
    height: max(552px, 46vw);
  }
  .kamiyama_body img {
    width: 100%;
    height: auto;
  }
  .kamiyama_img_01 {
    position: absolute;
    top: 0;
    left: 0;
    width: max(530px, 44.1667vw);
  }
  .kamiyama_img_02 {
    position: absolute;
    top: max(50px, 4.167vw);
    right: 0;
    width: max(600px, 50vw);
  }
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .kamiyama {
    margin-bottom: 2.2em;
  }
  .kamiyama_header {
    padding: 0 15px 2.2em;
  }
  .kamiyama_img_01 {
    margin-bottom: 38px;
  } 
}

/* ===============================
examples / expo2025
=============================== */

/* PC調整 ------------------ */
@media (min-width:769px) {
  .expo2025 {
    position: relative;
    margin-bottom: max(70px, 5.833vw);
  }
  .expo2025_header {
    position: absolute;
    inset: max(15px, 1.25vw) 0 0;
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
  }
  .expo2025_body {
    position: relative;
    height: max(636px, 53vw);
    margin-bottom: 15px;
  }
  .expo2025_body img {
    width: 100%;
    height: auto;
  }
  .expo2025_img_01 {
    position: absolute;
    top: max(176px, 14.667vw);
    left: 0;
    width: max(530px, 44.1667vw);
  }
  .expo2025_img_02 {
    position: absolute;
    top: max(55px, 4.583vw);
    right: 0;
    width: max(600px, 50vw);
  }
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .expo2025 {
    margin-bottom: 2.2em;
  }
  .expo2025_header {
    padding: 0 15px 2.2em;
  }
  .expo2025_img_01 {
    margin-bottom: 38px;
  } 
}

/* ===============================
examples / nolimitsartcastle
=============================== */
.nolimitsartcastle {
  max-width: 900px;
  margin: 0 auto;
}
.nolimitsartcastle_header {
  margin-bottom: 45px;
}
.nolimitsartcastle_body {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  max-width: 812px;
  margin: 0 auto;
}
.nolimitsartcastle_img img {
  display: block;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .nolimitsartcastle {
    margin-bottom: 48px;
  }
  .nolimitsartcastle_header {
    margin-bottom: 2.2em;
    padding: 0 15px;
  }
  .nolimitsartcastle_body {
    display: block;
  }
  .nolimitsartcastle_img + .nolimitsartcastle_img {
    margin-top: 10px;
  } 
}

/* ===============================
examples / comment
=============================== */
.comment {
  padding: 48px 0 44px;
}
.icon_instagram {
  margin-top: 10px;
  width: 50px;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .comment {
    margin-bottom: 60px;
    padding: 0 15px;
  }
}

/* ===============================
artist
=============================== */
.artist_column_wrap {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}
.artist_photo {
  width: 450px;
  margin-right: -30px;
}
.artist_detail {
  width: 435px;
}
.artist .mail,
.artist .mail a {
  color: #0e5957;
  font-weight: bold;
}
.artist_list {
  display: flex;
  flex-wrap: wrap;
}
.artist_list li {
  margin-right: 1em;
}

/* SP調整 ------------------ */
@media (max-width:768px) {
  .artist {
    padding: 0 15px;
  }
  .artist_column_wrap {
    display: block;
  }
  .artist_photo {
    width: auto;
    margin: 0 -15px 2.2em;
  }
  .artist_detail {
    width: auto;
  }
  .artist .mail,
  .artist .mail a {
    font-size: 15px;
    line-height: 1.65;
    letter-spacing: 0.1em;
  }
  .artist_list {
    display: block;
  }
  .artist_list li {
    margin-right: 0;
  }
}
