@charset "UTF-8";

/*-----------
共通
-----------*/
/* 見出し・テキスト */
.topHeadline {
  position: relative;
}

.topHeadline h2 {
  margin-bottom: 0.75em;
  font-size: clamp(1.75rem, 1.148rem + 2.47vw, 3rem);
  /* 28-48px */
  line-height: normal;
}

.topHeadline h2::after {
  display: block;
  color: var(--sf-main-color);
  font-size: clamp(1.5rem, 1.019rem + 1.98vw, 2.5rem);
  /* 24-40px */
  font-weight: 700;
  line-height: 1em;
  text-transform: capitalize;
}

.topHeadline h2.news::after {
  content: "news";
}

.topHeadline h2.movie::after {
  content: "movie";
}

.topHeadline h2.access::after {
  content: "access";
}

@media print, screen and (min-width: 1024px) {
  .topHeadline h2 {
    margin-bottom: 1em;
  }
}

/*-----------
カラーごと
-----------*/
body.orange #mv {
  background-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(8%, transparent), color-stop(8%, #FFF3E2));
  background-image: linear-gradient(to bottom, transparent 0%, transparent 8%, #FFF3E2 8%);
}

body.green #mv {
  background-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(8%, transparent), color-stop(8%, #F2FAE8));
  background-image: linear-gradient(to bottom, transparent 0%, transparent 8%, #F2FAE8 8%);
}

body.blue #mv {
  background-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(8%, transparent), color-stop(8%, #E8F4FA));
  background-image: linear-gradient(to bottom, transparent 0%, transparent 8%, #E8F4FA 8%);
}

@media print, screen and (min-width: 768px) {
  body.orange #mv {
    background-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(20%, transparent), color-stop(20%, #FFF3E2));
    background-image: linear-gradient(to bottom, transparent 0%, transparent 20%, #FFF3E2 20%);
  }

  body.green #mv {
    background-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(20%, transparent), color-stop(20%, #F2FAE8));
    background-image: linear-gradient(to bottom, transparent 0%, transparent 20%, #F2FAE8 20%);
  }

  body.blue #mv {
    background-image: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(20%, transparent), color-stop(20%, #E8F4FA));
    background-image: linear-gradient(to bottom, transparent 0%, transparent 20%, #E8F4FA 20%);
  }
}

/*-----------
mv
-----------*/
#mv {
  position: relative;
}

#mv::before {
  content: "";
  display: block;
  width: 100%;
  height: 50px;
  position: absolute;
  top: calc(8% - 50px);
  left: 0;
  z-index: -1;
  -webkit-mask-image: url(../images/mask-arc.svg);
  mask-image: url(../images/mask-arc.svg);
  -webkit-mask-position: top center;
  mask-position: top center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 400%;
  mask-size: 400%;
  background-color: var(--lt-main-color);
}

.mvFirst {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 1rem;
  width: min(100%, 1536px);
  margin-inline: auto;
  padding: 1rem 20px 2.5rem;
}

.mvImage img {
  width: 100%;
  height: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 20px;
  -webkit-box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
}

.mvInfo {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 1.5rem 1rem;
  background-color: var(--white);
  border-radius: 20px;
  -webkit-box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
}

.mvInfo .name {
  margin-block: 0;
  margin-bottom: 0.5em;
  text-align: center;
}

.mvInfo .name span {
  display: block;
  font-weight: 700;
  line-height: 1.6em;
}

.mvInfo .sub {
  /* margin-bottom: 0.5em; */
  font-size: clamp(1rem, 0.88rem + 0.49vw, 1.25rem);
  /* 16-20px */
}

.mvInfo .main {
  font-size: clamp(1.5rem, 1.019rem + 1.98vw, 2.5rem);
  /* 24-40px */
}

.mvInfo .main > span {
  font-size: clamp(1.125rem, 0.824rem + 1.23vw, 1.75rem);
  /* 18-28px */
}

.mvInfo .telBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 8px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 0.75em;
  font-size: clamp(1.25rem, 0.829rem + 1.73vw, 2.125rem);
  /* 20-34px */
  font-weight: 700;
}

.mvInfo .telBox::before {
  content: "";
  display: block;
  width: 0.875rem;
  height: fit-content;
  aspect-ratio: 3/4;
  -webkit-mask-image: url(../images/icon-tel.svg);
  mask-image: url(../images/icon-tel.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: var(--main-color);
}

.mvInfo .telBox .telNum {
  display: block;
  line-height: 1em;
  font-size: clamp(1.25rem, 1.069rem + 0.74vw, 1.625rem);
  /* 20-26px */
  /* font-size: clamp(1.125rem, 0.944rem + 0.74vw, 1.5rem); */
  /* 18-24px */
}

.mvInfo .telBox .ja {
  display: inline-block;
  margin-right: 8px;
  font-size: clamp(1rem, 0.819rem + 0.74vw, 1.375rem);
  /* 16-22px */
}

.mvAddress dl {
  margin-top: 0.5em;
}

.mvAddress dl div {
  display: grid;
  grid-template-columns: 5em minmax(0, 1fr);
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
}

.mvAddress dt {
  font-weight: 400;
}

.mvAddress dd {
  line-height: 1.6;
}

.mvAddress .small {
  font-size: 0.875rem;
}

.mvNotes.wrap {
  width: var(--contents-width-minus);
  padding-bottom: 3.75rem;
}

.mvNotes .inner {
  -webkit-box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  border-radius: 10px;
  overflow: hidden;
}

.mvNotes h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 8px;
  padding: 0.5em;
  color: var(--white);
  text-align: center;
  font-size: clamp(1.25rem, 1.009rem + 0.99vw, 1.75rem);
  /* 20-28px */
  background-color: var(--red);
}

.mvNotes h2::before {
  content: "";
  display: block;
  width: 1.25rem;
  height: fit-content;
  aspect-ratio: 40/37;
  -webkit-mask-image: url(../images/icon-comment.svg);
  mask-image: url(../images/icon-comment.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: var(--white);
}

.mvNotesBox {
  padding: 1em;
  background-color: var(--white);
}

.mvNotesBox ul {
  list-style: disc;
  margin: 0 0 0 1em;
}

/* MV コンテンツメニュー */
.mvMenu.wrap {
  padding: 0 20px;
}

.mvMenu.single {
  padding-bottom: 2.5rem;
}

/* .mvMenu h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 8px;
  margin-bottom: 1em;
  text-align: center;
  font-size: clamp(1.25rem, 0.829rem + 1.73vw, 2.125rem);
}

.mvMenu h2::before {
  content: "";
  display: block;
  width: 1em;
  height: fit-content;
  aspect-ratio: 1/1;
  -webkit-mask-image: url(../images/icon-list.svg);
  mask-image: url(../images/icon-list.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: var(--main-color);
} */

#mvMenuNavi ul {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1.25rem;
}

#mvMenuNavi ul li a {
  display: grid;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  grid-template-columns: minmax(0, 1fr);
  /* gap: 8px; */
  position: relative;
  padding: 1.5em 2.7em 1.5em 1em;
  height: 100%;
  color: var(--black);
  font-weight: 700;
  text-decoration: none;
  background-color: var(--white);
  -webkit-box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  border-radius: 10px;
}

#mvMenuNavi ul li a::before {
  right: 0.5em;
}

#mvMenuNavi ul li a::after {
  right: calc(0.5em - 2px);
}

/* MV 管理・運営事業所 */
.mvManagement.wrap {
  padding: 2.5rem 20px 3.75rem;
}

.mvManagement h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 8px;
  margin-bottom: 1em;
  text-align: center;
  font-size: clamp(1.25rem, 0.829rem + 1.73vw, 2.125rem);
  /* 20-34px */
}

.mvManagement h2::before {
  content: "";
  display: block;
  width: 1em;
  height: fit-content;
  aspect-ratio: 1/1;
  -webkit-mask-image: url(../images/icon-home.svg);
  mask-image: url(../images/icon-home.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: var(--main-color);
}

#managementNavi ul {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1.25rem;
}

#managementNavi a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  gap: 8px;
  height: 100%;
  background-color: var(--white);
  -webkit-box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  box-shadow: 3px 3px 6px rgb(0 0 0 / 0.1);
  border-radius: 10px;
}

#managementNavi a img {
  width: 100px;
  height: 100%;
  aspect-ratio: 15/13;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 10px 0 0 10px;
}

#managementNavi a .name {
  display: grid;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  grid-template-columns: minmax(0, 1fr) calc(1.25rem + 0.5em);
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 8px;
  position: relative;
  width: calc(100% - 100px);
  padding: 0.5em;
  font-size: clamp(0.875rem, 0.755rem + 0.49vw, 1.125rem);
  /* 14-18px */
  font-weight: 700;
}

#managementNavi a .icon-arrow-circle::before {
  right: calc(0.5em + 2px);
}

#managementNavi a .icon-arrow-circle::after {
  right: 0.5em;
}

#managementNavi a .sub {
  display: block;
}

#managementNavi a .main {
  display: block;
}

@media print, screen and (min-width: 768px) {
  #mv::before {
    height: 100px;
    top: calc(20% - 100px);
    -webkit-mask-size: 800%;
    mask-size: 800%;
  }

  /* MV コンテンツメニュー */
  #mvMenuNavi ul {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  /* MV 管理・運営事業所 */
  #managementNavi ul {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem 2.5rem;
  }

  #managementNavi a img {
    width: 150px;
  }

  #managementNavi a .name {
    width: calc(100% - 150px);
  }
}

@media print, screen and (min-width: 1024px) {

  .mvFirst {
    grid-template-columns: 55% minmax(0, 1fr);
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
    gap: 60px;
    min-height: 460px;
    padding: 3.75rem 20px 5rem;
  }

  .mvImage {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
  }

  .mvImage img {
    aspect-ratio: unset;
    border-radius: 40px;
  }

  .mvInfo {
    align-items: flex-start;
    min-height: 460px;
    padding: 3.75rem 3rem;
    border-radius: 40px;
  }

  .mvInfo .name {
    text-align: left;
  }

  .mvInfo .frontDesk {
    width: fit-content;
  }

  .mvAddress dt {
    font-weight: 400;
  }

  .mvNotes.wrap {
    padding-bottom: 7.5rem;
  }

  .mvNotes .inner {
    border-radius: 20px;
  }

  .mvNotes h2::before {
    width: 2rem;
  }

  .mvNotesBox {
    padding: 2em 2.5em;
  }

  /* MV コンテンツメニュー */
  .mvMenu.single {
    padding-bottom: 5rem;
  }

  #mvMenuNavi ul {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  #mvMenuNavi ul li a {
    padding: 2em 2.7em 2em 1em;
  }

  /* MV 管理・運営事業所 */
  .mvManagement.wrap {
    padding: 5rem 20px 7.5rem;
  }

  #managementNavi a .name {
    padding: 0.5em 0.75em 0.5em 0.5em;
  }

  #managementNavi a .icon-arrow-circle::before {
    right: calc(0.75em + 2px);
  }

  #managementNavi a .icon-arrow-circle::after {
    right: 0.75em;
  }
}

@media (any-hover: hover) {

  /* MV コンテンツメニュー */
  #mvMenuNavi ul li a:hover {
    color: var(--main-color);
    background-color: var(--ltg-main-color);
  }

  #mvMenuNavi ul li a:hover::before {
    transform: translateX(0);
  }

  #mvMenuNavi ul li a:hover::after {
    transform: translateX(0);
  }

  /* MV 管理・運営事業所 */
  #managementNavi a:hover {
    background-color: var(--ltg-main-color);
  }

  #managementNavi a:hover .name::before,
  #managementNavi a:hover .name::after {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

/*-----------
topNews
-----------*/
.topNews .wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 15px;
}

@media print, screen and (min-width: 1024px) {
  .topNews .wrap {
    grid-template-columns: 25% minmax(0, 1fr);
    gap: 40px;
  }
}