/* CSS Document */

#smartfan {
    width:100%;
    height:auto;
    padding-bottom:0!Important;
    overflow-x: hidden;
}

#smartfan section {
    width:100%;
}

/* フェードイン前の初期状態 */
.fade-in {
  opacity: 0;
  transform: translateY(30px);
  /* 30px下に下げておく */
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

/* 画面に入った時に付与するクラス */
.fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
  /* 元の位置に戻る */
}

video {
    width:100%;
}

.youtube-wrap {
	width: 80%;
  max-width: 960px;
  margin: 50px auto 0;
}

#smartfan .youtube-wrap iframe {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
}

ul li img {
    width:100%;
    object-fit: contain;
}

h1, h2, h3, h4, h5 {
    font-family: "ten-mincho-text", serif;
}

h2 {
    font-size:4rem;
}

h3 {
    font-size:3rem;
}

h4 {
    font-size:2rem;
}

.intro, .feature, .app {
    background:#e3eef6;
}

.faq {
    background:#e5e5e5;
}

#smartfan .store, .eligible, .spec,.notice {
    background:#fff;
}

section>h3 {
    text-align:center;
    margin:0 auto 50px;
}

section>p {
    width:50%;
    max-width:600px;
    margin:0 auto 50px;
}

.intro, .feature, .app, .eligible, .spec, .faq, .notice, #smartfan .store {
    padding:100px 0;
}



.title {
    width:100%;
    aspect-ratio: 16/9;
    margin:0;
    padding:0;
}

.title_bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width:100%;
  aspect-ratio: 16/9;
}

.title_inner {
  position: relative;
  z-index: 1;
  width:90%;
  height:100%;
  margin:0 auto;
  display:flex;
  flex-flow: row-reverse nowrap;
  align-items: center;
  justify-content:space-between;
}

.title_inner h1 {
    width:25%;
    object-fit: contain;
}

.title_catch {
    width:fit-content;
    height:fit-content;
}


.title_inner h2 {
    color:#fff;
    width:100%;
    text-shadow:#000 0 0 5px;
}

.title_inner h3 {
    color:#fff;
    font-size:2rem !important;
    text-shadow:#000 0 0 5px;
}


.intro_text {
    width:80%;
    max-width:800px;
    margin:100px auto;
}

.intro_text h2 {
    text-align:center;
    white-space: nowrap;
    overflow: visible;
    margin-bottom:50px;
}

.intro_text p {
    width:80%;
    max-width:600px;
    margin:0 auto;
}

.feature_box {
    width:90%;
    max-width:1000px;
    margin:50px auto 0;
    display:flex;
    flex-flow:row nowrap;
    gap:10%;
}

.feature_box li {
    width:45%;
    max-width:450px;

}

.feature_box li img {
    margin-bottom:25px;
}

.feature_box li h4 {
    width:100%;
    text-align:center;
    margin-bottom:20px;
}

.feature_box li p {
    width:100%;
}

.app_desc {
    width:90%;
    max-width:1000px;
    margin:0 auto 100px;
    display:flex;
    flex-flow:row nowrap;
    gap:10%;
}

.app_desc li {
    width:45%;
}

.app_desc h3 {
    margin-bottom:20px;
}

.app_desc p {
    margin-bottom:30px;
}

.app_dl {
    width:90%;
    margin:0 auto;
}

.app_dl h4 {
    line-height:2rem;
}

.app_dl h4 span {
    font-size:1.5rem;
}

.app_dl ul {
    width:100%;
    display:flex;
    flex-flow:column nowrap;
    align-items: center;
    gap:20px;
}

.app_dl ul li {
    width:100%;
    display:flex;
    flex-flow:row nowrap;
    align-items: center;
    justify-content: center;
}

.app_dl ul li>img {
    width:25%;
    max-width:200px;
    margin-right:5%;
}

.app_dl ul li a {
    width:50%;
}

.app_dl ul li a img {
    height:60px;
    object-fit: contain;
}

.app_box {
    width:90%;
    max-width:1000px;
    display:flex;
    flex-flow:row wrap;
    gap:5%;
    margin:0 auto;
}

.app_box li {
    width:30%;
}

.app_box li img {
    margin-bottom:10px;
}

.app_box li h4 {
    margin-bottom:10px;
    text-align:center;
}

.app_box li p {
    margin-bottom:50px;
}

.eligible ul {
    width:80%;
    max-width:800px;
    margin:0 auto;
    display:flex;
    flex-flow:row nowrap;
    gap:10%;
}

.eligible ul li {
    width:45%;
}

.spec ul {
    display:flex;
    flex-flow: row nowrap;
    gap:5%;
    margin:0 auto;
    width:50%;
    max-width:800px;
    gap:10%;
}

.spec ul li {
}

.spec ul li img {
    width:100%;
}

.spec table {
    width:70%;
    max-width:700px;
    margin:0 auto 50px;
}

.spec table tr {
    border-bottom: 1px solid #686d70;
}

.spec table tr th {
    width:25%;
    text-align:left;
    font-weight:800;
    padding:10px 0;
}

.spec table tr td {
    width:75%;
    text-align:left;
    padding:10px 0;
}



.faq ul {
    width:90%;
    max-width:1000px;
    margin:0 auto;
    display:flex;
    flex-flow: row wrap;
    gap:10%;
}

.faq ul li {
    width:45%;
}

.faq ul li h4 {
    margin-bottom:20px;
}

.faq ul li p {
    margin-bottom:50px;
}

.notice_box {
    width:90%;
    max-width:1000px;
    margin:100px auto;
    background: #3f002e;
    border-radius: 25px;
    padding:50px 0;
}

.notice_box h4 {
    width:80%;
    margin:0 auto 50px;
    color:#fff;
    text-align:center;
}

.notice_box p {
    width:80%;
    margin:0 auto 25px;
    color:#fff;
    text-align:left;
}

#smartfan .store ul.store-direct {
    width:fit-content;
    margin:0 auto 50px;
    display:flex;
    flex-flow: column nowrap;
    gap:25px;
}

#smartfan .store ul.store-direct li {
    width:fit-content;
}

.store_list {
    width:100%;
    display:flex;
    flex-flow:row nowrap;
    align-items: center;
}

.store_list img {
    width:30%;
    margin-right:5%;
}

.store_list>ul {
    display:flex;
    flex-flow:column nowrap;
    width:65%;
    margin-bottom:0;
}

.store_list>ul li {
    width:fit-content;
    padding:5px 0;
}

.store_list>ul li:first-child {
    border-bottom:1px solid #686d70;
    width:100%;
    margin-bottom:5px;
}

#smartfan .store>h4,.store>h2 {
    text-align:center;
    margin:0 auto 25px;
}

#smartfan .store ul.btn_online {
    width:80%;
    max-width:800px;
    margin:0 auto 100px;
    display:flex;
    flex-flow: row nowrap;
    gap:5%;
    align-items: center;
}

#smartfan .store ul.btn_online li {
    width:30%;
}

#smartfan .store ul.btn_online li a {
    background:#fff;
    border:1px solid #000;
    border-radius: 20px;
    padding:10px;
    display:block;
    width:100%;
    height:100%;
    text-align:center;
    transition: 0.2s;
}

#smartfan .store ul.btn_online li a:hover {
    background:#fcb900;
    color:#fff;
    border:1px solid #fcb900;
}


.note {
    background:#e5e5e5;
    padding:25px;
    margin-bottom:0;
}

.note p {
    width:90%;
    max-width:1000px;
    margin:0 auto;
}

/* ==========================================================================
   メディアクエリ：スマホ（767px以下）
   ========================================================================== */
@media screen and (max-width: 767px) {

	.youtube-wrap {
	width: 90%;
	}

    section h2 {
        font-size:2rem;
    }

    section>h3 {
        font-size:2rem !important;
        margin-bottom:25px;
    }

    h4 {
        font-size:1.6rem;
    }

    section>p {
        width:90%;
    }

    .intro, .feature, .app, .eligible, .spec, .faq, .notice, #smartfan .store {
    padding: 50px 0;
}

    .title {
        height:100%;
        aspect-ratio: 5/6;
		background:#00396d;
    }

    .title_bg {
    aspect-ratio: 5/6;
}

    .title_inner {
        height:95%;
    flex-flow: column-reverse nowrap;
    justify-content: space-between;
    aspect-ratio: 5/6;
    margin:2.5% auto;
}

.title_catch {
    width: 100%;
    text-align:left;
}

.title_inner h1 {
    width:100%;
    text-align:right;
}

.title_inner h1 img {
    width:50%;
}

.title_inner h2 {
    font-size:3rem;
}

.title_inner h3 {
    font-size: 1.5rem !important;
}

.intro_text {
    width:90%;
    max-width:90%;
    margin: 0 auto;
}

.intro_text h2 {
    margin-bottom: 25px;
}

.intro_text p {
    width: 100%;
    margin: 0 auto;
}

.feature_box li img {
    margin-bottom: 10px;
}

.feature_box li h4 {
    margin-bottom: 10px;
}

.app_desc {
    margin: 0 auto 50px;
    flex-flow: column nowrap;
    gap: 10%;
}

.app_desc li {
    width: 100%;
}

.app_desc h3 {
    text-align:center;
    margin-top:10px;
}

.app_dl ul li a img {
    height: 50px;
    object-fit: contain;
}

.app_box {
    gap: 10%;
}

.app_box li {
    width: 45%;
}

.spec table {
    width: 90%;
    margin: 0 auto 25px;
}

.spec ul {
    display: flex;
    flex-flow: column nowrap;
    width: 60%;
    gap: 10%;
}

.faq ul {
    flex-flow: column wrap;
    gap: 10%;
}

.faq ul li {
    width: 100%;
}

.faq ul li h4 {
    margin-bottom: 10px;
}

.notice_box {
    margin: 50px auto;
    background: #3f002e;
    border-radius: 25px;
    padding: 25px 0;
}

.notice_box h4 {
    margin: 0 auto 25px;
}

.notice_box p {
    width: 90%;
    margin: 0 auto 10px;
}

.store_list {
    flex-flow: column nowrap;
}

.store_list img {
    width: 80%;
    margin:0 auto;
}

.store_list>ul {
    width: 90%;
}
	
#smartfan .store_list > ul > li:first-child > h4 {
    width: 100%;
    text-align: center;
  }

#smartfan .store ul.btn_online {
    flex-flow: column nowrap;
    margin-bottom:50px;
}

#smartfan .store ul.btn_online li {
    width: 100%;
    margin-bottom:10px;
}

#smartfan .store>h2 {
    font-size:3rem;
}

.note {
    padding: 25px 0;
}

.note p {
    font-size:1rem;
}

}