@charset "utf-8";
/* CSS Document */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
body{ font-family: "Noto Sans JP", sans-serif;}

.tyss_bg{ background: url("../images/tyss_bg.png") 0 0 repeat;}
.tyss_contents{ max-width: 600px; padding: 0; margin: 0 auto;}

header{ width: 100%; display: flex; justify-content: space-between; flex-wrap: nowrap; padding: 15px; margin: 0; background: #fff;}
header .tyss_logo img{ max-height: 100px;}
.tyss_menu img{ width: 50px;}

h1{ margin: 0; padding: 0; font-size: 0;}

.tyss_line_stamp{ background: #06c155; padding: 15px 15px 30px;}
.tyss_line_stamp .stamp{ display: flex; justify-content: space-between; flex-wrap: nowrap;}
.stamp_img{ max-width: 100px; aspect-ratio: 1 / 1.4; object-fit: contain;}
.stamp_logo{ width: calc(100% - 120px); aspect-ratio: 721 / 315; object-fit: contain;}
.stamp_dl{ text-align: center; margin: 0; padding: 0;}
.stamp_dl a{ display: block; width: 70%; margin: 0 auto;}

.tyss_line_login{ background: #c80000; padding: 15px; text-align: center;}
.tyss_line_login .login{ background: #fff; width: 95%; margin: 0 auto; padding: 15px;}
.tyss_line_login .login a{ display: block; width: 80%; margin: 0 auto 20px;}

.checkbox-container {
  margin-top: 10px;
}

#lineLoginBtn.disabled {
  pointer-events: none;
  opacity: 0.5;
  cursor: default;
}

#lineLoginBtn {
  pointer-events: auto;
  opacity: 1;
  cursor: pointer;
}

.tyss_top_movie{ background: #733c93;}
.tyss_top_movie .movie_info{ width: 80%; margin: 0 auto; padding: 0 0 30px;}

.tyss_terms{ background: #000; padding: 0 20px 20px; width: 100%; margin: 0 auto; box-sizing: border-box;}

.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
  padding: 0 1em;
  background: #fff;
}

.accordion-content p{ padding-bottom: 20px;}

.accordion-item{ padding-top: 20px;}
.accordion-item.open .accordion-content {
  max-height: auto;
  padding: 1em 1em 2em;
}

.accordion-header {
  cursor: pointer;
  margin: 0;
}

.accordion-header img {
  width: 100%;
  max-width: 100%; /* 必要に応じて調整 */
  display: block;
}

.tyss_btn_items a{ display: block; padding: 0 0 20px; width: 70%; margin: 0 auto;}

footer{ width: 100%; background: #f5f5f5; padding: 20px;}
footer .footer_sns{ display: flex; justify-content: center; gap: 20px; width: 40%; flex: 1; margin: 0 auto 20px;}
footer strong{ display: block; font-size: 24px; font-weight: bold; margin: 0 0 10px; text-align: center;}
footer .footer_copy{ font-size: 11px; text-align: center; padding: 30px 0 0;}

.company_area{ width: 100%; background: #fff; padding: 20px; font-size: 11px;}
.company_logo{ width: 130px;}
.company_copy{ margin: 0 0 20px;}
.arrow-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;         /* 横並びにする */
  gap: 1em;              /* 各リンクの間の余白 */
}

.arrow-links li a {
  text-decoration: none;
  color: #333;           /* お好みで */
  display: inline-block;
}

.arrow-links li a::before {
  content: "\25B6";
  margin-right: 0.4em;
  color: #e6011e;         /* 矢印の色。お好みで変更OK */
}

.tyss_modal {
  position: fixed;
  top: 0;
  right: -100%;
  width: 300px;
  height: 100%;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: -2px 0 10px rgba(0,0,0,0.2);
  transition: right 0.4s ease;
  z-index: 1000;
  padding: 2em 1em;
}

.tyss_modal.open {
  right: 0;
}

.modal_close {
  position: absolute;
  top: 0.2em;
  right: 0.2em;
  background: none;
  border: none;
  font-size: 2.5em;
  cursor: pointer;
}

.modal_links {
  list-style: none;
  padding: 2em 0 0 0;
}

.modal_links li {
  margin-bottom: 1em;
}

.modal_links a {
  text-decoration: none;
  color: #666;
  font-weight: bold;
}
.btn_top {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 999;
  cursor: pointer;
}

.btn_top img {
  width: 60px; /* サイズ調整したければここで */
  height: auto;
}

.barcode_txt01{ color: #fff; margin: 0 auto 20px; font-size:18px; font-weight:600;}
.btn_barcode{ text-align: center;}
.btn_barcode a{ display: block; width: 60%; margin: 0 auto 20px;}

.btn_back_to_top{ width: 60%; margin: 0 auto; padding: 20px 0;}

.tyss_barcode{ background: #f5f5f5; padding: 8%;}
.tyss_icon_barcode{ width: 60%; margin: 30px auto 60px;}
.tyss_barcode p{ margin-bottom: 30px;}
.tyss_jan_code_number{ width: 100%; border: 5px solid #000; padding: 5px; margin: 0 0 30px;}
.barcode_btns{ width: 80%; margin: 0 auto;}
.barcode_btns a{ display: block; margin: 0 auto 30px;}

.tyss_movie{ margin: 0 auto 30px;}
.tyss_movie h3{ font-size: 21px; color:#fff; margin: 0 0 10px; text-align: center;}

.about_dozle{ padding:20px 0; color:#fff;}
.about_dozle h5{ font-size:18px; text-align:center;}
.about_dozle img{ display: block; margin:0 auto 20px;}
.about_dozle p{ font-size:12px;}
.about_dozle p a{ color:#fff;}
.video-container {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 比率 */
  height: 0;
  overflow: hidden;
}

.video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.tyss_top_terms a{ color:#000;}

@media screen and (max-width: 768px) {
	.tyss_bg{ background: none;}
	.tyss_contents{ width: 100%; box-sizing: border-box; max-width: none;}
	header .tyss_logo img{ max-height: 50px;}
}