@charset "UTF-8";

/* CSS Document */



/*==================================================

contents
=================================================*/

#contents img {
    width: 100%;
	max-width: 100%;
	height: auto;
}

#top-image {
    width: 85%;
    position: relative;
    margin: 0 auto;
    z-index: 8;
}
#top-image .photo {
    width: 100%;
    position: relative;
    display: flex;
    flex-flow: row wrap;
    margin: 0 auto;
    z-index: 1;
}
#top-image .photo div {
    width: 50%;
}
.swiper-pagination-bullet {
    margin: 0 8px!important;
}
.swiper-pagination-bullet {
    height: 12px;
    width: 12px;
    background-color: #FFF;
    opacity: .6;
}
.swiper-pagination-bullet-active {
    background-color: #f8f816;
    opacity: 1;
}
.swiper-slide img {
    height: auto;
    width: 100%;
}

#top-image .txt {
    width: 35.7%;
    max-width: 600px;
    position: absolute;
	left: -5%;
    bottom: 14%;
    z-index: 2;
}

#top-image .sc {
    width: 1em;
    height: 15em;
    position: absolute;
    overflow: hidden;
    color: #003894;
    font-size: 1.4rem;
    line-height: 100%;
    font-weight: 400;
    writing-mode: vertical-lr;
    right: -4%;
    bottom: 0;
    z-index: 3;
}
#top-image .sc span {
    display: inline-block;
    position: relative;
    background-color: #fff;
    padding: 1em 0;
    z-index: 2;
}
#top-image .sc::after {
    content: " ";
	display: block;
    position: absolute;
    width: 1px;
    height: 60%;
    background-color: #003894;
    top: 0;
    left: 50%;
	transform: translate(-50%, 0);
    z-index: 1;
    animation: arrow 3s linear infinite 0s normal;
}

@keyframes arrow {
  0% {
    top: -100%;
  }
  100% {
    top: 110%;
  }
}

#top-image img {
    width: 100%;
	max-width: 100%;
	height: auto;
}

#contents .banner {
    width: 85%;
    max-width: 1000px;
    margin: 0 auto;
}

#contents .title-s {
    width: 100%;
    text-align: center;
    margin: 0 auto;
}
#contents .title-s strong {
    display: inline-block;
    position: relative;
    font-size: clamp(2.4rem, 4vw, 4rem);
    text-align: center;
    line-height: 160%;
    font-weight: 400;
    letter-spacing: .1em;
}
#contents .title-s strong::before {
    content: " ";
	display: block;
    width: 60%;
    height: 1px;
    position: absolute;
    background-color: #003894;
    top: 80%;
	left: -80%;
	transform: translate(0, -50%);
    z-index: 1;
}
#contents .title-s strong::after {
    content: " ";
	display: block;
    width: 60%;
    height: 1px;
    position: absolute;
    background-color: #003894;
    top: 80%;
	right: -80%;
	transform: translate(0, -50%);
    z-index: 1;
}
#contents .title-s span {
    display: block;
    color: #003894;
    font-size: clamp(1.4rem, 2vw, 2rem);
    line-height: 160%;
    font-weight: 500;
    letter-spacing: 0;
    margin: 0 auto;
}
#contents .title-ss {
    width: 100%;
    text-align: center;
    margin: 40px auto 80px;
}
#contents .title-ss span {
    display: inline-block;
    position: relative;
    font-size: clamp(1.8rem, 2.4vw, 2.4rem);
    text-align: center;
    line-height: 140%;
    font-weight: 500;
    padding: 0 .2em;
    z-index: 2;
}
#contents .title-ss span::after {
    content: " ";
	display: block;
    position: absolute;
    width: 100%;
    height: 8px;
    background-color: #f8f816;
    left: 0;
    bottom: 0;
    z-index: -1;
}

#contents .search {
    width: 85%;
    max-width: 1200px;
    position: relative;
    margin: 100px auto 0;
}

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev,
.swiper-button-next {
    visibility: hidden;
    height: 30px;
    width: 30px;
    top: 18%;
}
.swiper-button-prev {
    left: 1%;
}
.swiper-button-next {
    right: 1%;
}

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev::after,
.swiper-button-next::after {
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    width: 50px;
    height: 50px;
    margin: auto;
}
/* 前への矢印カスタマイズ */
.swiper-button-prev::after {
    background-image: url("../../images/arrow_l.png");
}
/* 次への矢印カスタマイズ */
.swiper-button-next::after {
    background-image: url("../../images/arrow_r.png");
}
/* 画像サイズ調整 */
.swiper-slide img {
    width: 100%;
    height: auto;
}

#contents .search > ul {
    width: 100%;
    position: relative;
}

#contents .brand-list {
    width: 100%;
    display: flex;
    flex-flow: row nowrap;
    padding: 0 0 5%;
}
#contents .brand-list .photo {
    width: 50%;
}
#contents .brand-list .txt {
    width: 50%;
    padding-left: 5%;
}
#contents .brand-list .txt h3 {
    display: inline-block;
    color: #FFF;
    font-size: clamp(1.8rem, 2.4vw, 2.4rem);
    line-height: 160%;
    background-color: #003894;
    padding: .3em 1em;
}
#contents .brand-list .txt p {
    margin: 1em 0;
}
#contents .brand-list .txt h4 {
    color: #F00;
    font-size: clamp(1.4rem, 1.6vw, 1.6rem);
}
#contents .brand-list .txt h4 strong {
    display: inline-block;
    font-size: clamp(1.6rem, 2vw, 2rem);
    line-height: 160%;
    color: #000;
    background-color: #f8f816;
    margin-right: 1em;
    padding: .4em 1em;
}
#contents .brand-list .txt ul {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    margin-top: 4%;
}
#contents .brand-list .txt ul li {
    width: 5em;
    text-align: center;
    font-size: clamp(1.2rem, 1.4vw, 1.4rem);
    background-color: #f8f816;
    border-radius: 6px;
    margin: .5em .5em 0 0;
    padding: .2em 0;
}
#contents .brand-list .txt ul li.is-group01 {
    background-color: #aed4b2;
}
#contents .brand-list .txt ul li.is-group02 {
    background-color: #b5c5df;
}
#contents .brand-list .txt ul li.is-group03 {
    background-color: #e3e1a6;
}
#contents .brand-list .txt ul li.is-group04 {
    background-color: #b7dfde;
}
#contents .brand-list .txt ul li.is-group05 {
    background-color: #edd2c8;
}
#contents .brand-list .txt ul li.is-group06 {
    background-color: #cbc1d2;
}
#contents .brand-list .txt ul li.is-group07 {
    background-color: #ebc69c;
}
#contents .brand-list .txt ul li.long {
    width: 13em;
}

#contents .search .thumbnail {
    width: 100%;
    border-top: 1px solid #DDD;
    padding-top: 60px;
}
#contents .search .thumbnail ul {
    width: 100%;
    display: flex;
    flex-flow: row wrap;
    margin: 0 auto;
}
#contents .search .thumbnail ul li {
    width: 12.28%;
    cursor: pointer;
    border: 1px solid #DDD;
    opacity: .5;
    margin: 0 1% 2%;
}
#contents .search .thumbnail ul li.active {
    opacity: 1;
}

#contents .area {
    width: 100%;
    position: relative;
    background-color: #f1f1f1;
    margin: 80px auto 60px;
    padding: 60px 0;
}
#contents .area .inner {
    width: 90%;
    max-width: 800px;
    text-align: center;
    margin: 0 auto;
}
#contents .area .title-ss {
    width: 100%;
    text-align: center;
    margin: 0 auto 40px;
}
#contents .area .inner {
    width: 90%;
    max-width: 800px;
    margin: 0 auto;
}
#contents .area .inner select {
    width: 46%;
    display: inline-block;
    position: relative;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    font-size: clamp(1.6rem, 1.8vw, 1.8rem);
    color: #003894;
    background-color: #FFF;
    background-image: url("../../images/arrow_d.png");
    background-position: right -1px center;
    background-repeat: no-repeat;
    background-size: auto 100%;
    border: 2px solid #003894;
    margin: .5em 1.8%;
    padding: 1em 1em;
}

#contents .button-area {
    width: 90%;
    margin: 0 auto 80px;
}
#contents .button-area .button {
    margin: 0 auto;
}
#contents .button-area .button {
    max-width: 400px;
    color: #FFF;
    background-color: #003894;
    background-image: url("../../images/arrow_w.png");
    margin: 0 auto;
    padding: 1.4em 1em;
}
#contents .button-area .button:hover {
    color: #003894;
    background-color: #FFF;
    background-image: url("../../images/arrow_b.png");
}

.logo-scroll {
    width: 100%;
    overflow: hidden;
}
.logo-scroll ul {
    width: 200%;
    display: table;
    table-layout: fixed;
}
.logo-scroll ul li {
    display: table-cell;
    padding: 0 1.5%;
}

/*==================================================

size m
=================================================*/


@media only screen and (min-width:1px) and (max-width: 768px) {
	
    
    #contents .search {
        width: 85%;
        margin: 10% auto 0;
    }
    #contents .search > ul {
        margin-top: 8%;
    }
    .swiper-button-prev,
    .swiper-button-next {
        visibility: visible;
    }
    #contents .brand-list {
        width: 100%;
        flex-direction: column;
    }
    #contents .brand-list .photo {
        width: 100%;
    }
    #contents .brand-list .txt {
        width: 100%;
        padding: 0;
    }
    #contents .brand-list .txt h3 {
        display: block;
        text-align: center;
        padding: .8em 1em;
    }
    #contents .brand-list .txt p {
        margin: 1em 0;
    }
    #contents .brand-list .txt h4 {
        color: #F00;
        text-align: center;
    }
    #contents .brand-list .txt h4 strong {
        margin: 0 0 2% 0;
    }
    #contents .brand-list .txt ul {
        width: 100%;
        display: flex;
        flex-flow: row wrap;
        margin-top: 4%;
    }
    #contents .brand-list .txt ul li {
        width: 23%;
        text-align: center;
        font-size: 1.4rem;
        border-radius: 4px;
        margin: .5em 1% 0;
        padding: .4em 0;
    }
    
    #top-image {
        width: 100%;
        position: relative;
        margin: 0 auto;
        z-index: 6;
    }
    #top-image .photo {
        width: 100%;
        position: relative;
        flex-direction: column;
        margin: 0 auto;
        z-index: 1;
    }
    #top-image .photo div {
        width: 100%;
    }
    .swiper-pagination-bullet {
        margin: 0 8px!important;
    }
    .swiper-pagination-bullet {
        height: 10px;
        width: 10px;
        background-color: #FFF;
        opacity: .6;
    }

    #top-image .txt {
        width: 70%;
        max-width: 600px;
        position: absolute;
        left: 0;
        bottom: 50%;
        -webkit-transform: translate(0, 55%); 
        transform: translate(0, 55%);
        z-index: 2;
    }

    #top-image .sc {
        display: none;
    }

    #contents .banner {
        width: 85%;
        max-width: 1000px;
        margin: 0 auto;
    }

    #contents .title-s {
        width: 100%;
        text-align: center;
        margin: 0 auto;
    }
    #contents .title-s strong {
        display: inline-block;
        position: relative;
        font-size: clamp(2.4rem, 4vw, 4rem);
        text-align: center;
        line-height: 160%;
        font-weight: 400;
        letter-spacing: .1em;
    }
    #contents .title-s strong::before {
        content: " ";
        display: block;
        width: 60%;
        height: 1px;
        position: absolute;
        background-color: #003894;
        top: 80%;
        left: -80%;
        transform: translate(0, -50%);
        z-index: 1;
    }
    #contents .title-s strong::after {
        content: " ";
        display: block;
        width: 60%;
        height: 1px;
        position: absolute;
        background-color: #003894;
        top: 80%;
        right: -80%;
        transform: translate(0, -50%);
        z-index: 1;
    }
    #contents .title-s span {
        display: block;
        color: #003894;
        font-size: clamp(1.4rem, 2vw, 2rem);
        line-height: 160%;
        font-weight: 500;
        letter-spacing: 0;
        margin: 0 auto;
    }
    #contents .title-ss {
        width: 100%;
        text-align: center;
        margin: 5% auto 8%;
    }
    #contents .title-ss span {
        display: inline-block;
        position: relative;
        font-size: clamp(1.8rem, 2.4vw, 2.4rem);
        text-align: center;
        line-height: 140%;
        font-weight: 500;
        padding: 0 .2em;
        z-index: 2;
    }
    #contents .title-ss span::after {
        content: " ";
        display: block;
        position: absolute;
        width: 100%;
        height: 8px;
        background-color: #f8f816;
        left: 0;
        bottom: 0;
        z-index: -1;
    }

    #contents .search .thumbnail {
        width: 100%;
        padding-top: 6%;
    }
    #contents .search .thumbnail ul {
        width: 100%;
        display: flex;
        flex-flow: row wrap;
        margin: 0 auto;
    }
    #contents .search .thumbnail ul li {
        width: 23%;
        opacity: .5;
        margin: 0 1% 2%;
    }

    #contents .area {
        width: 100%;
        margin: 8% auto 6%;
        padding: 6% 0;
    }
    #contents .area .title-ss {
        margin: 0 auto 5%;
    }
    #contents .area .inner select {
        width: 80%;
        display: inline-block;
        margin: .5em 1.8%;
        padding: 1em 1em;
    }

    #contents .button-area {
        width: 90%;
        margin: 0 auto 8%;
    }
    #contents .button-area .button {
        margin: 0 auto;
    }
    #contents .button-area .button {
        max-width: 400px;
        color: #FFF;
        background-color: #003894;
        background-image: url("../../images/arrow_w.png");
        margin: 0 auto;
        padding: 1.4em 1em;
    }
    #contents .button-area .button:hover {
        color: #003894;
        background-color: #FFF;
        background-image: url("../../images/arrow_b.png");
    }

    .logo-scroll {
        width: 100%;
        overflow: hidden;
    }
    .logo-scroll ul {
        width: 400%;
        display: table;
        table-layout: fixed;
    }
    .logo-scroll ul li {
        display: table-cell;
        padding: 0 1%;
    }
	
}

/*==================================================

size s
==================================================*/

@media only screen and (min-width:1px) and (max-width: 568px) {
	
	
	/*==================================================
	
	header
	==================================================*/

		
	/*==================================================
	
	Navi
	==================================================*/
	
	
	/*==================================================
	
	contents
	==================================================*/
	
	
	/*==================================================
	
	footer
	==================================================*/
	

}

@media only screen and (min-width:1px) and (max-width: 480px) {
	
	
	/*==================================================
	
	header
	==================================================*/

	
	/*==================================================
	
	Navi
	==================================================*/
	
	
	/*==================================================
	
	contents
	==================================================*/
	
	
	/*==================================================
	
	table
	==================================================*/
	
	
	/*==================================================
	
	footer
	==================================================*/
	
	
}