@charset "UTF-8";
.index_ttl {
  /* 1220→36px */
  font-size: clamp(29px, 2.95vw, 36px);
}
.index_ttl .en {
  font-size: 16px;
  line-height: 1;
  display: block;
  margin-bottom: 0.3em;
}
/* ======================
mv
========================= */
.lead {
  /* text-shadow: 0px 0px 5px rgba(0, 0, 0, 0.95); */
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.lead__catch {
  font-size: clamp(21px, 5.8vw, 45.5px);
  line-height: 1.38;
  letter-spacing: 0.05em;
  font-feature-settings: "palt";
  margin-bottom: 0.3em;
}
.lead__txt {
  font-size: clamp(12px, 2.92vw, 16.6px);
  line-height: 1.54;
}
.lead span {
  display: inline-block;
  background: #012a2d;
  margin-bottom: 0.2em;
  padding: 0 5px;
}

/* ======================
bnr
========================= */

.bnr .bnr__wrap {
  padding: 18px 0;
}
.bnr__cont {
  width: 50%;
  padding: 6px 7.42% 6px 0;
  border-left: 1px solid #fff;
  transition: 0.2s;
}
.bnr__cont:hover {
  opacity: 1;
  filter: brightness(1.2);
  /* background: #fff; */
}
.bnr__cont::after {
  content: "";
  width: 35px;
  height: 35px;
  background-image: url(../imgs/common/btn.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 90.5%;
  transform: translate(-50%, -50%);
  transition: 0.2s;
}
.bnr__cont:hover:after {
  background-image: url(../imgs/common/btn_hv.svg);
}
.bnr__ttl {
  font-size: 16px;
  margin-bottom: 0.5em;
  position: relative;
  z-index: 2;
}
/* カタログ */
.bnr__catalog {
  padding-left: 2.67%;
}
.bnr__catalog .bnr__txt {
  /* 1220→23px */
  font-size: clamp(19px, 1.89vw, 24px);
  line-height: 1.448;
  color: #003f2c;
  position: relative;
  z-index: 1;
}
.bnr__catalog .bnr__txt .cl_or {
  display: block;
}
.bnr__catalog img {
  width: 45%;
  max-width: 265px;
  position: absolute;
  top: 52%;
  right: 15%;
  transform: translateY(-50%);
}
/* お問い合わせ */
.bnr__contact {
  padding-left: 4.25%;
  border-right: 1px solid #fff;
}
.bnr__contact .tel {
  font-size: clamp(40px, 3.85vw, 47px);
  line-height: 1;
  display: block;
  margin-bottom: 0.1em;
}
.bnr__contact .cl_rd {
  /* 1220→23px */
  font-size: clamp(19px, 1.89vw, 24px);
  color: #910000;
}
/* ======================
event
========================= */
.event {
  padding: clamp(55px, 11.46vw, 104px) 0 min(9.33vw, 70px);
}

.event .index_ttl {
  margin-bottom: 57px;
}
.event__btn {
  justify-content: flex-start;
  gap: 1em;
}
.event__listbk {
  width: 72%;
  max-width: 855px;
}
.event__item {
  padding: 30px 0;
}
.event__item:first-child {
  padding-top: 0;
}
.event__item:not(:last-child) {
  border-bottom: 1px solid #d6dbdd;
}
.event__item a {
  align-items: flex-start;
}
.event__item a .event__item-imgbk {
  width: 34%;
  max-width: 286px;
  aspect-ratio: 286 / 191;
  overflow: hidden;
}
.event__item a .event__item-imgbk img {
  transition: 0.3s;
}
.event__item a:hover .event__item-imgbk img {
  scale: 1.1;
}
.event__item-txtbk {
  width: 63%;
  max-width: 531px;
}
.event__item-ttl {
  font-size: clamp(18px, 2.86vw, 22px);
  margin-bottom: 0.5em;
}
.event__item-txtList {
  font-size: clamp(14px, 1.9vw, 15px);
  margin-bottom: 1.7em;
}
.event__item-txtList > div {
  display: flex;
}
.event__item-txtList dt {
  width: 3em;
}
.event__item-txtList dt:after {
  content: "：";
}
.event__item-txtList dd {
  width: calc(100% - 3em);
}
.event__item-txt {
  font-size: 15px;
}
/* ======================
lineup
========================= */
.lineup {
  padding: clamp(55px, 11.46vw, 90px) 0;
}
.lineup .index_ttl {
  margin-bottom: min(7.33vw, 55px);
}
.lineup__list {
  margin-bottom: 22px;
}
.lineup__item {
  width: 32%;
  max-width: 369px;
}
.lineup__item a .lineup__item-imgbk {
  margin-bottom: 1.6em;
  aspect-ratio: 369 / 250;
  overflow: hidden;
}
.lineup__item a .lineup__item-imgbk img {
  transition: 0.3s;
}
.lineup__item a:hover .lineup__item-imgbk img {
  scale: 1.1;
}
.lineup__item-ttl {
  font-size: clamp(19px, 1.89vw, 24px);
  margin-bottom: 0.2em;
}
.lineup__item-ttl span {
  display: inline-block;
}
.lineup__item-ttl .num {
  font-size: 18px;
  line-height: 1;
  display: block;
  margin-bottom: 0.8em;
}
/* ======================
works
========================= */
.works {
  padding: clamp(55px, 11.46vw, 90px) 0;
}
.works__txt {
  margin-bottom: clamp(30px, 9.33vw, 70px);
}
.works__list {
  margin-bottom: clamp(30px, 14vw, 105px);
}
.works__item {
  width: 32%;
  max-width: 369px;
}
.works__item .works__item-ttl {
  font-size: clamp(19px, 1.89vw, 24px);
  margin-bottom: 0.5em;
}
.works__item .works__item-imgbk {
  aspect-ratio: 147 / 106;
  overflow: hidden;
}
.works__item .works__item-imgbk img {
  transition: 0.3s;
}
.works__item a:hover .works__item-imgbk img {
  scale: 1.1;
}
.works__item-list {
  font-size: clamp(14px, 2vw, 15px);
  padding-top: 1.2em;
}
.works__item-list > div {
  display: flex;
}
.works__item-list dt {
  flex-shrink: 0;
}
.works__item-list dt:after {
  content: "：";
}

/* ======================
selectbeam
========================= */
.selectbeam {
  padding: clamp(55px, 11.46vw, 92px) 0;
}
.selectbeam__ttl {
  width: 85%;
  max-width: 392px;
  margin: 0 auto 38px;
}
.selectbeam__txt {
  max-width: 620px;
  margin: 0 auto clamp(40px, 8.53vw, 64px);
}
.sb__list {
  margin-bottom: min(10.13vw, 76px);
  gap: 4vw 0;
}
.sb__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: min(10%, 23px);
  aspect-ratio: 1/1;
  width: 23.5%;
  max-width: 263px;
  max-height: 242px;
  background: #fff;
}
.sb__item-imgbk {
  width: 80%;
  max-width: 99px;
}
.sb__item-txt {
  font-size: clamp(18px, 2.55vw, 25px);
  color: #012a2d;
}
.sb__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 630px;
  margin: 0 auto;
  padding: 30px 5% 39px;
  background: #aec2bc;
}
.sb__link-ttl {
  font-size: clamp(18px, 2.8vw, 21px);
  margin-bottom: 0.5em;
}
.sb__link a {
  font-size: clamp(18px, 2.67vw, 20px);
  text-align: center;
  width: 100%;
  max-width: 310px;
  padding: 15.5px 5px;
  border: 2px solid #012a2d;
  border-radius: 5px;
  transition: 0.2s;
}
.sb__link a:hover {
  color: #012a2d;
  background: #fff;
}
/* ======================
contents
========================= */
.contents {
  padding: 56px 0 100px;
}
.contents .index_ttl {
  margin-bottom: min(5.73vw, 43px);
}
.contents__item {
  width: 32%;
  max-width: 369px;
  padding-top: max(15px, 3.4%);
  border-top: 1px solid #e6e6e6;
}
.contents__item a {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}
.contents__item-txtbk {
  flex: 1;
  margin-bottom: 8%;
}
.contents__item-ttl {
  font-size: clamp(18px, 2.55vw, 25px);
  line-height: 1.4;
  color: #012a2d;
  margin-bottom: 0.4em;
}
.contents__item a .contents__item-imgbk {
  aspect-ratio: 369 / 250;
  overflow: hidden;
}
.contents__item a .contents__item-imgbk img {
  transition: 0.3s;
}
.contents__item a:hover .contents__item-imgbk img {
  scale: 1.1;
}
@media screen and (max-width: 980px) {
  /* ======================
	bnr
	========================= */
  .bnr .bnr__wrap {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  .bnr__cont {
    width: 100%;
    max-width: 640px;
    border-left: 1px solid #fff;
    border-right: 1px solid #fff;
  }
  /* ======================
	event
	========================= */
  .event .inner-1200 {
    display: block;
  }
  .event__ttlbk {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 1em;
    margin-bottom: min(7.6vw, 57px);
  }
  .event .index_ttl {
    margin-bottom: 0;
  }
  .event__listbk {
    width: 100%;
    max-width: initial;
  }
  .event__item-txt {
    display: none;
  }
}
@media screen and (max-width: 840px) {
  /* ======================
	lineup
	========================= */
  .lineup__list {
    gap: 6.85vw 4%;
  }
  .lineup__item {
    width: 48%;
  }

  /* ======================
	works
	========================= */
  .works__list {
    gap: 6.85vw 4%;
  }
  .works__item {
    width: 48%;
  }
  /* ======================
	contents
	========================= */
  .contents__list {
    gap: 6.85vw 4%;
  }
  .contents__item {
    width: 48%;
  }
}
@media screen and (max-width: 750px) {
  /* ======================
	mv
	========================= */
  .mv {
    height: 417px;
  }
  .mv__img {
    width: auto;
  }
  /* ======================
	selectbeam
	========================= */

  /* ======================
	selectbeam
	========================= */
  .sb__item {
    aspect-ratio: 4/1;
    width: 48%;
    max-width: initial;
    height: auto;
    padding: 2%;
  }
}
@media screen and (max-width: 640px) {
  /* ======================
	bnr
	========================= */
  .bnr .bnr__wrap {
    width: 100%;
    gap: 0;
  }
  .bnr__cont {
    padding: 20px 4%;
    border: none;
  }
  .bnr__catalog::before {
    content: "";
    width: 92%;
    height: 1px;
    background-color: #fff;
    display: block;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
  .bnr__catalog .bnr__txt,
  .bnr__contact .cl_rd {
    font-size: clamp(15px, 4.69vw, 19px);
  }
  .bnr__contact .tel {
    font-size: clamp(30px, 9.38vw, 40px);
  }
}
@media screen and (max-width: 480px) {
  .index_ttl {
    font-size: clamp(25px, 5.21vw, 29px);
  }
  /* ======================
		bnr
		========================= */
  .bnr__catalog img {
    width: 68%;
    max-width: 216px;
    margin: 0 auto;
    position: static;
    transform: initial;
  }
}
@media screen and (min-width: 769px) {
}
