@charset "utf-8";

body {
    overflow-x: hidden;
}
* {
    box-sizing: border-box;
}
.pc {
    display: none;
}

/* header */
#header {
    position: absolute;
    left: 10px;
    top: 17px;
    z-index: 999;
}
#header h1 {
}
#header h1 a {
    display: block;
    width: 127px;
}
#header h1 a img {
    width: 100%;
}
#header h1 a._pc {
    display: none;
}

/* pagetitle */
#pagetitle {
    position: relative;
    padding: 85px 10px 15px;
    color: #000;
}
.pagetitle_90th {
    position: absolute;
    right: 10px;
    top: 10px;
    width: 32px;
    height: 34px;
}
.pagetitle__title {
    font-size: 24px;
    text-align: center;
    letter-spacing: 0.12em;
}
.pagetitle__copy {
    margin-top: 20px;
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 0.04em;
    text-align: center;
}
.pagetitle__copy span:nth-child(1) {
    display: block;
    letter-spacing: 0.12em;
}
.pagetitle__summary {
    margin-top: 15px;
    font-size: 13px;
    line-height: 1.5;
    letter-spacing: 0.04em;
}
.pagetitle__caption {
    margin-top: 10px;
    font-size: 12px;
    color: #666;
    line-height: 1.5;
    letter-spacing: 0.04em;
}

/********************
 * Calendar
 ********************/
#calendar_sp {
    position: relative;
    margin-top: 5px;
    padding: 0 2.66vw;
    font-size: 2.66vw;
}
#calendar_sp > .cal_wrap {
    min-height: 200vw;
}

/**
 * item
 */
.cal_item_sp {
    position: relative;
    margin-top: 2px;
}
.cal_item_sp > .cal_wrap {
}

.cal_item_sp:first-child .cal_title {
    display: none;
}

/* image */
.cal_image {
    position: relative;
    height: 10.66vw;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    transition: height 0.3s ease-out;
}
._focus .cal_image {
    height: 60.8vw;
}

.cal_bg {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background-color: #000;
    opacity: 0.6;
    transition: opacity 0.4s ease-in-out;
}
._focus .cal_bg {
    opacity: 0;
}

.cal_summary {
    position: relative;
    display: flex;
    width: 100%;
    height: 10.66vw;
    align-items: center;
    justify-content: space-between;
    transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out;
}
._focus .cal_summary {
    opacity: 0;
    transform: translateY(30px);
}

.cal_brand {
    font-size: 13px;
    color: #999;
}
.cal_summary .cal_brand {
    padding-left: 6vw;
    font-size: 14px;
    color: #fff;
}
.cal_summary .cal_date {
    padding-right: 6vw;
}
.cal_summary .cal_date span {
    font-size: 14px;
    color: #a0a0a0;
}
.cal_summary .cal_date span:nth-child(1) {
}
.cal_summary .cal_date span:nth-child(2) {
}

.cal_close {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 30px;
    height: 30px;
    background-image: url(../IMAGES/close_white.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 18px auto;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.4s ease-in-out;
}
.cal_item_sp:first-child .cal_close {
    display: none;
}
._active .cal_close {
    pointer-events: auto;
    opacity: 1;
}

/* body */
.cal_body {
    display: none;
    padding-bottom: 20px;
}
.cal_title {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin-top: 14px;
}
.cal_title .cal_logo {
    width: 50%;
    height: 30px;
    background-position: left;
    background-repeat: no-repeat;
    background-size: contain;
}
.cal_title .cal_date {
}
.cal_title .cal_date span {
    color: #606060;
}
.cal_title .cal_date span:nth-child(1) {
    font-size: 13px;
}
.cal_title .cal_date span:nth-child(2) {
    font-size: 12px;
}
.cal_copy {
    margin-top: 12px;
    font-size: 15px;
}
.cal_copy.id-0 {
    font-size: 15px;
    line-height: 1.4;
}
.cal_subject {
    margin-top: 30px;
    font-size: 13px;
    letter-spacing: 0.04em;
}
.cal_downloads {
    display: flex;
    gap: 10px;
    width: 100%;
    margin-top: 10px;
    flex-wrap: wrap;
}
.cal_downloads__item {
    width: calc((100% - 10px) / 2);
    background-color: #eaeaea;
}
.cal_downloads a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 35px;
    color: #606060;
    text-decoration: none;
}
.cal_downloads a span:nth-child(1) {
    font-size: 13px;
}
.cal_downloads a span:nth-child(2) {
    margin-left: 5px;
    font-size: 12px;
}
.cal_links {
    margin-top: 23px;
    border-top: 1px solid #ccc;
}
.cal_links__item {
    border-bottom: 1px solid #ccc;
}
.cal_links a {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    height: 35px;
    padding-left: 10px;
    font-size: 12px;
    color: #333;
    line-height: 1.1;
    text-decoration: none;
}
.cal_links a:before {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    display: block;
    width: 8px;
    height: 12px;
    margin-top: -6px;
    background-image: url(../IMAGES/arrow.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

/********************
    * download
********************/

#download {
    position: relative;
    margin-top: 12vw;
}

/* header */
.dl_header {
}
.dl_title {
    font-size: 15px;
    color: #000;
    text-align: center;
    letter-spacing: 0.04em;
}

/* body */
.dl_body {
    margin-top: 4vw;
    padding: 0 2.66vw;
}
.dl_downloads {
    display: flex;
    gap: 10px;
    width: 100%;
    margin-top: 10px;
    flex-wrap: wrap;
}
.dl_downloads__item {
    width: calc((100% - 10px) / 2);
    background-color: #eaeaea;
}
.dl_downloads a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 35px;
    color: #606060;
    text-decoration: none;
}
.dl_downloads a span:nth-child(1) {
    font-size: 13px;
}
.dl_downloads a span:nth-child(2) {
    margin-left: 5px;
    font-size: 12px;
}

/********************
 * feature
 ********************/

#feature {
    margin-top: 16lvw;
    margin-bottom: 50px;
    padding: 0 2.66vw;
    color: #000;
}

/* body */
.feat_body {
    width: 100%;
}
.feat_item {
    position: relative;
    margin-top: 20px;
    padding-top: 25px;
    border-top: 0.99px solid #ccc;
}
.feat_item:nth-child(1) {
    margin-top: 0;
    border: none;
}
.feat_item__title {
    position: relative;
    padding-left: 155px;
    font-size: 14px;
}
.feat_item__wrap {
    width: 100%;
    margin-top: 10px;
}
.feat_item__image {
    position: absolute;
    left: 0;
    top: 25px;
    width: 135px;
}
.feat_item__image img {
    width: 100%;
}
.feat_item__summary {
    position: relative;
    margin-top: 5px;
    padding-left: 155px;
    padding-right: 5px;
    font-size: 12px;
    line-height: 1.8;
    text-align: justify;
}

/* footer */
.feat_footer {
    width: 100%;
    margin-top: 20px;
    padding-top: 10px;
    border-top: 1px solid #ccc;
}
.feat_footer ul {
    margin-top: 20px;
}
.feat_footer li {
    margin-top: 6px;
    font-size: 12px;
    color: #666;
}

/* footer {
	padding-top: 20px;
	padding-bottom: 97px;
} */
