/*======================================================
base
======================================================*/
html {
  scroll-padding-top: 0;
  scroll-behavior: smooth;
}

body {
  position: relative;
  font-size: 16px;
  line-height: 1;
}

main {
  width: 100%;
}

header {
  display: none;
}

a {
  text-decoration: none;
  transition: opacity 0.3s;
}
a:hover {
  opacity: 0.7;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

li {
  list-style: none;
}

/*======================================================
main
======================================================*/
main .fixed_bg {
  display: block;
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  background-image: url(/images/cam-lp/oyako2025/mv_bg_pc.png);
  background-size: cover;
  background-position: center;
}
main .flex_container {
  display: flex;
  align-items: flex-start;
  position: relative;
  z-index: 2;
}
@media (max-width: 530px) {
  main .flex_container {
    justify-content: center;
  }
}
main .line_btn {
  position: relative;
  display: block;
  max-width: 347px;
  width: 100%;
  border-radius: 10px;
  transition: box-shadow 0.3s, transform 0.3s;
}
@media (max-width: 530px) {
  main .line_btn {
    max-width: 87.47vw;
    height: 9.24vw;
  }
}
main .line_btn img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
main .line_btn img:first-child {
  opacity: 1;
  z-index: 1;
}
main .line_btn:hover {
  opacity: 1;
  transform: translateY(4px);
}
main .line_btn:hover img:last-child {
  opacity: 1;
}
main .cta_sp1 .line_btn {
  height: 68px;
}
main .cta_sp2 .line_btn {
  height: 50px;
}
main .pc_contents_01 {
  flex: 1;
  position: sticky;
  top: 0;
  z-index: 5;
  transition: 0.3s;
}
@media (max-width: 860px) {
  main .pc_contents_01 {
    display: none;
  }
}
main .pc_contents_01__logo {
  position: absolute;
  top: 26px;
  left: 31px;
  display: block;
  max-width: 400px;
  width: 36vw;
}
main .pc_contents_01__catch {
  max-width: 110px;
  width: 8vw;
  position: absolute;
  top: 17.56vh;
  right: 10.8vw;
}
@media (max-width: 1000px) {
  main .pc_contents_01__catch {
    right: 50%;
    transform: translateX(50%);
  }
}
main .pc_contents_01__popup {
  max-width: 474px;
  width: 36.02vw;
  position: absolute;
  top: 62.69vh;
  right: 7.2vw;
}
@media (max-width: 1000px) {
  main .pc_contents_01__popup {
    right: 50%;
    transform: translateX(50%);
  }
}
main .pc_contents_01__popup .line_btn {
  max-width: 423px;
  width: 31.1vw;
  max-height: 83px;
  height: 4.3vw;
  position: absolute;
  bottom: min(19px, 1.39vw);
  left: 50%;
  transform: translateX(-50%);
}
@media (max-width: 390px) {
  main .pc_contents_01__popup .line_btn {
    max-width: 102.05vw;
    height: 12.05vw;
    bottom: 1vw;
  }
}
main .pc_contents_01__popup .line_btn:hover {
  transform: translateX(-50%) translateY(4px);
}
main .pc_contents_02 {
  flex: none;
  width: 12vw;
  position: sticky;
  top: 0;
  z-index: 5;
  transition: 0.3s;
}
@media (max-width: 860px) {
  main .pc_contents_02 {
    display: none;
  }
}
@media (min-width: 1340px) {
  main .pc_contents_02 {
    width: 20vw;
  }
}
@media (min-width: 1920px) {
  main .pc_contents_02 {
    width: 25vw;
  }
}
main .scroll_content {
  flex: none;
  max-width: 390px;
  width: 100%;
  transition: 0.3s;
  background-color: #fff;
  position: relative;
}
@media (max-width: 860px) {
  main .scroll_content {
    margin: 0 auto;
  }
}
@media (max-width: 530px) {
  main .scroll_content {
    max-width: 530px;
  }
}
main .scroll_content .mv_youtube {
  background-image: url("/images/cam-lp/suimin202506/back.png");
  background-size: 100%;
  background-repeat: repeat-y;
  padding: 20px;
}
main .scroll_content .mv_youtube iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  margin: 0 auto;
}
main .scroll_content .cta_sp1,
main .scroll_content .cta_sp2 {
  position: relative;
}
main .scroll_content .cta_sp1 .line_btn,
main .scroll_content .cta_sp2 .line_btn {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
main .scroll_content .cta_sp1 .line_btn:hover,
main .scroll_content .cta_sp2 .line_btn:hover {
  transform: translateX(-50%) translateY(4px);
}
main .scroll_content .cta_sp1 .line_btn {
  top: 893px;
}
@media (max-width: 530px) {
  main .scroll_content .cta_sp1 .line_btn {
    top: 229vw;
  }
}
main .scroll_content .cta_sp2 .line_btn {
  top: 505px;
}
@media (max-width: 530px) {
  main .scroll_content .cta_sp2 .line_btn {
    top: 129vw;
  }
}
main .scroll_content .p2 h2 {
  background-color: #216986;
}
main .scroll_content .p12 + .cta_sp1,
main .scroll_content .p12 + .cta_sp2 {
  margin-top: -10px;
}
main .scroll_content .faq_intro {
  padding: 23px 0;
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  color: #fff;
  background-color: #5d75b9;
}
main .scroll_content .faq dl div dt,
main .scroll_content .faq dl div dd {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px;
  font-size: 14px;
  line-height: 1.3;
}
main .scroll_content .faq dl div dt::before,
main .scroll_content .faq dl div dd::before {
  font-size: 18px;
  color: #5d75b9;
  font-weight: bold;
}
main .scroll_content .faq dl div dt {
  border-bottom: 1px solid #5d75b9;
}
main .scroll_content .faq dl div dt::before {
  content: "Q";
}
main .scroll_content .faq dl div dt .open_icon {
  margin-left: auto;
  position: relative;
  min-width: 15px;
  width: 15px;
  height: 15px;
}
main .scroll_content .faq dl div dt .open_icon span {
  display: block;
  width: 15px;
  height: 2px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #5d75b9;
}
main .scroll_content .faq dl div dt .open_icon span:first-child {
  transform: translate(-50%, -50%) rotate(90deg);
}
main .scroll_content .faq dl div dd {
  display: none;
  background-color: #f3faff;
}
main .scroll_content .faq dl div dd::before {
  content: "A";
}
main .scroll_content .faq dl .faq_open dt .open_icon span:first-child {
  transform: translate(-50%, -50%);
}
main .scroll_content .faq dl .faq_open dd {
  display: flex;
}
main .scroll_content .faq dl .faq_open dd p + p {
  margin-top: 1em;
}
main .fixed_btn_sp {
  display: none;
  max-width: 391px;
  width: 100%;
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  padding: 10px;
  background-color: rgba(9, 34, 77, 0.5);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}
main .fixed_btn_sp:hover {
  opacity: 1;
}
@media (max-width: 530px) {
  main .fixed_btn_sp {
    max-width: 531px;
  }
}
@media (max-width: 860px) {
  main .fixed_btn_sp {
    display: block;
  }
}
@media (max-width: 860px) {
  main.cam-lp .footer-camlp {
    padding-bottom: 120px;
  }
}/*# sourceMappingURL=suimin202506.css.map */