/*
2025-11-04
2025-11-05
*/
@charset "utf-8";
/* @import url('/common/fonts/Pretendard/pretendard.css'); */

#event_body {
    padding: 0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-size: 16px;
    /* font-family: 'Pretendard'; */
    font-weight: 200;
    line-height: 160%;
    letter-spacing: -1px;

    --ch-red3: #ee1b2b;
    --ch-red4: #e33441;

    --ch-red1: #ff4773;
    --ch-red2: #ff0a00;
    --ch-red3: #db001c;
    --ch-red4: #b50024;
    --ch-red5: #85052e;
}

@media (min-width: 992px) {
    #event_body {
        font-size: 22px;
    }
}
.container-xxl {
    padding: 0 1.2rem;
}

.img_c img {
    width: 100%;
}

.u {
    padding-bottom: 2px;
    border-bottom: 1px solid #000000;
}
.accent {
    font-weight: 400;
}
.lt1 {color:var(--ch-red1);}
.lt2 {color:var(--ch-red2);}
.lt3 {color:var(--ch-red3);}
.lt4 {color:var(--ch-red4);}
.lt5 {color:var(--ch-red5);}




















#s_1 {
    height: 100svh;
    background: url('/common/event/images/swisspass/s_1.webp') 60% 0% no-repeat;
    background-size: cover;
}

#s_1 .container-xxl {
    position: relative;
    padding: 0;
    width: 100%;
    height: 100svh;
}
.event_main_title {
    position: absolute;
    top: 10svh;
    left: 8vw;
    width: calc(100vw - 16vw);
    color: #fff;
}

.event_main_title h1 {
    display: flex;
    align-items: flex-start;
    position: relative;
    font-size: 2em;
}
.event_main_title h1 .lt1{
    margin: 0 0 0 10px;
}
.event_main_title h1 img {
    display: block;
    width: 15px;
    background-color: var(--ch-red3);
    margin: 0 10px 0 0;
}
.event_main_title h1 i {
    color: #ddffb9;
    position: absolute;
    top: -1rem;
    left: -1rem;
    font-size: .6em;
}

.event_main_title h2 {
    font-size: 1.6em;
    line-height: 140%;
}
.event_main_title .accent {
    padding: 2px 7px;
    background-color: var(--ch-red3);
}
.event_main_title ul {
    margin: 1rem 0 0 0;
}
.event_main_title ul li i {
    color: #ff9ca4;
}
.event_main_logos {
    display: flex;
    flex-direction: row;
    gap: 17px;
    margin: 12px 0 0 0;
}
.event_main_logos img {
    /* position: absolute; */
    /* left: 0; */
    /* bottom: 10svh; */
    display: block;
    height: 25px;
}


.event_main_promotions {
    position: absolute;
    bottom: 10svh;
    left: 8vw;
    /* width: calc(100vw - 16vw); */
    color: #fff;
    font-size: .85em;
}
.event_main_promotions h3 {
    /* display: inline-flex; */
    /* justify-content: center; */
    
    padding-top: 1.2rem;
    border-top: 3px solid var(--ch-red1);
    color: #fff;
}
.event_main_promotions ul li {
    /* text-shadow: 0px 0px 5px #00000082; */
}
.event_main_promotions ul li i {
    color: var(--ch-red3);
}
@media (min-width: 992px) {
    #s_1 .container-xxl {
        padding: initial;
    }
    
    .event_main_title {
        left: 20px;
        top: 15vh;
    }
    .event_main_title h1 {
        font-size: 80px;
        letter-spacing: -5px;
    }
    .event_main_title h1 .lt1 {
        margin-left: 1rem;
    }
    .event_main_title h1 i {
        left: -1.7rem;
    }
    .event_main_title h1 img {
        width: 30px;
    }
    .event_main_promotions {
        /* left: auto;
        right: 1rem;
        bottom: 3rem;
        width: auto; */
        left: 20px;
        right: auto;
        bottom: 9svh;
        width: auto;
    }
    .event_main_promotions h3{
        margin-bottom: 1rem;
        font-size: 1.4em;
        border-top: 6px solid var(--ch-red1);
    }
    .event_main_logos {
        margin: 2rem 0 0 0;
        gap: 35px;
    }
    .event_main_logos img {
        height: 55px;
    }

}








#s_2 {
    /* padding-bottom: 3rem; */
    /* border-bottom: 1px solid #efefef; */
}
.icons {
    display: block;
    margin: 0 auto;
    padding-left: 1rem;
    padding-right: 1rem;
    width: 100%;
    max-width: 600px;
}
.icons:nth-of-type(1) {
    margin-bottom: 3rem;
}
/* .icons:nth-of-type(2) {
    margin: 3rem auto;
} */
.icons:nth-of-type(2) {
    margin: 3rem auto 0 auto;
}
#s_2 p {
    margin: 0;
    text-align: center;
    line-height: 160%;
}
#s_2 p .accent {
    color: var(--ch-red3);
}
#s_2 p.bl1 {
    margin-bottom: 2rem;
}

.ticket_description {
    display: flex;
    max-width: 690px;
    margin: 3rem auto 0 auto;
    background-color: #fbfbff;

    justify-content: space-between;
    /* flex-direction: row-reverse; */
    background: #ffbaba;
    background: linear-gradient(359deg, rgb(255 255 255) 50%, rgb(255 227 227) 100%);


    flex-direction: column;
    align-items: center;
    padding: 1rem;
    border-radius: 30px;
}

.ticket_description img.pass_sample {
    display: block;
    width: 120px;
    rotate: -8deg;
}
.ticket_description .tit {
    display: flex;
    align-items: center;
    font-weight: 400;
    margin: 0 0 12px 0;
    color: var(--ch-red5);
}
.ticket_description img.logo_raileurope {
    height: 20px;
    display: block;
    margin-left: 10px;
}
.ticket_description ul {
    margin-left: 30px;
    margin-bottom: 2rem;
    font-size: .9em;
}
.ticket_description ul li {
    list-style-type: disc;
}

@media (min-width: 992px) {
    #s_2 {
        /* padding-bottom: 7rem; */
    }
    .ticket_description {
        padding: 4rem;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
}











#s_3 {
    padding: 3rem 0;
    background-color: #fff8f8;
}
.s_tit {
    margin: 0 0 3rem 0;
    text-align: center;
}
.s_tit_en {
    display: inline-flex;
    /* align-items: center; */
    align-items: baseline;
    color: var(--ch-red2);
    letter-spacing: 0;
    font-size: 16px;
    font-weight: 300;
    font-family: "gill-sans-nova", sans-serif;
}
.s_tit_en img {
    display: block;
    height: 14px;
    margin-left: 8px;
    margin-right: 8px;
}
.s_tit h2 {
    margin-bottom: 10px;
    font-size: 2.4rem;
    color: var(--ch-red4);
}
.s_tit h1 {
    display: inline-flex;
    margin-bottom: 0;
    padding: 0px 8px;
    /* background-color: var(--ch-red4); */
    color: #fff;
    font-family: "gill-sans-nova", sans-serif;
}
.s_tit h1 span {
    display: inline-flex;
    padding: 0px 5px;
    color: #fff;
}
.s_tit h1 span.lt1 {background-color: var(--ch-red1);}
.s_tit h1 span.lt2 {background-color: var(--ch-red2);}
.s_tit h1 span.lt3 {background-color: var(--ch-red3);}
.s_tit h1 span.lt4 {background-color: var(--ch-red4);}
.s_tit h1 span.lt5 {background-color: var(--ch-red5);}

.travel_best_w {}
.travel_best {
    margin: 0 0 2rem 0;
}
.travel_best:last-child {
    margin-bottom: 0;
}
.travel_best_c {
    padding: 2rem;
    height: 100%;
    background-color: #fff;
}
.travel_best_c .tit {
    margin: 0 0 1.2rem 0;
    color: var(--ch-red4);
}
.travel_best_c .ctt {}
.travel_best_c .ctt b {
    font-weight: 400;
}
.travel_best_c .travel_best_icon {
    display: block;
    margin: 2rem auto 0 auto;
    width: 120px;
}
@media (min-width: 992px) {
    #s_3 {
        padding: 7rem 0;
    }
    .s_tit {
        margin: 0 0 4.5rem 0;
    }
    .s_tit h2 {
        font-size: 3rem;
    }
    .travel_best {
        margin: 0 0 4rem 0;
    }
    .travel_best_c {
        padding: 4rem;
    }
    .travel_best_c .tit {
        font-size: 26px;
    }
    .travel_best .reverse {
        flex-direction: row-reverse;
    }
}






#s_4  {}
.s_img {
    display: block;
    margin: 0 auto 4.5rem auto;
    width: 100%;
}
.promotion {
    margin: 0 0 3rem 0;
}

.promotion .tit {
    margin: 0 0 1rem 0;
    color: var(--ch-red4);
    font-size: 1.5rem;
    font-weight: 500;
}
.promotion .tit .accent{
    display: inline-block;
    margin: 0 5px 0 0;
    padding: 2px 6px;
    background-color: var(--ch-red3);
    color: #fff;
}
.promotion .ctt {
    margin-bottom: 2rem;
}
.promotion .ctt b {
    font-weight: 400;
}
.promotion .ctt .accent {
    color: var(--ch-red4);
    font-weight: 400;
}
#gift_ctt {
    position: relative;
    height: calc(100% - 50px);
}
.promotion .ctt h5 {}
.promotion .ctt p:last-child{margin:0}
.promotion .ctt ul {}
.promotion .ctt ul li i {
    color: var(--ch-red3);
}

.promotion_detail {
    display: inline-flex;
    flex-direction: column;
    border-top: 1px solid var(--ch-red3);
    padding-top: 1.3rem;
    margin-top: 1rem;
}

/* .promotion .photos {
    display: flex;
    margin: 2rem 0 0 0;
} */
.promotion .photos img {
    display: block;
    border: 1px solid #d7d7d7;
    border-radius: 10px;
    margin: 5px;
    box-shadow: 1px 2px 7px #d3d3d35e;
    width: 100%;
    max-width: 750px;
}
.gift_set_list {
    /* display: inline-flex; */
    display: none;
    margin: .5rem 0 0 0;
    padding: .5rem 1rem;
    background-color: #eee;
}
.gift_set_list li {
    margin: 0 5px 0 0;
}
.gifts {
    display: flex;
    margin: 2rem 0 0 0;
    flex-wrap: wrap;
    flex-direction: row;
}
.gifts li {
    margin: 0 0 10px 0;
    width: 50%;
}
.gifts li .name {
    margin: 0;
    text-align: center;
    letter-spacing: 0;
    font-family: "gill-sans-nova", sans-serif;
    /* color: var(--ch-red2); */
    font-weight: 300;
    font-size: 16px;
}
.gifts li .icon {

}
.gifts .icon img {
    display: block;
    width: 70px;
    margin: 0 auto;
}


@media (min-width: 992px) {
    .promotion .tit .accent {
        padding: 5px 10px;
    }
    .promotion {
        margin: 0 0 6rem 0;
    }
    .promotion .tit {
        font-size: 26px;
    }
    .promotion .reverse {
        flex-direction: row-reverse;
    }
    .gifts {
        position: absolute;
        bottom: 0;
    }
    .gifts li {
        width: initial;
        margin: 0 10px;
    }
    .gifts li .name {
        font-size: 20px;
    }
}
















.goods_link {
    /* display: flex; */
}
.goods_link a {
    display: block;
    width: 100%;
    padding: 1rem 2rem;
    
    color: #fff;
    text-align: center;
    border-radius: 10px;
    position: relative;
    font-weight: 400;
}
.goods_link a img {
    position: absolute;
    left: 10px;
    top: 10px;

    display: block;
    width: 30px;
    border-radius: 50%;
    background-color: var(--ch-red3);
}
.goods_link a.goods_link_1 {background-color: var(--ch-red3);}
.goods_link a.goods_link_2 {background-color: var(--ch-red4);}
.goods_link a.goods_link_3 {background-color: var(--ch-red5);}
.goods_link a:hover {
    background-color: var(--ch-red2);
}

.goods_link a i {
    display: block;
    margin: 5px auto 1rem auto;
    color: #fff;
    font-size: 2rem;
}









#section_consulting_bar {
    margin-bottom: 0;
    padding: 3rem 0;
    background-color: var(--b24-blue2);
    color: #fff;
}

.consult_w {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}
.consult_w .txt {
    margin: 0 0 1rem 0;
}
.consult_w .link {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1rem 2rem;
    min-width: 300px;
    border-radius: 10px;
    border-bottom: 3px solid var(--ch-red5);
    background-color: var(--consult);
    background: var(--consult-bg);
    font-weight: 400;
}
.consult_w .link:hover {
    background-color: var(--ch-red3);
}
.consult_w .link:active {
    border-bottom: 0;
    border-top: 3px solid var(--ch-red5);
}
.consult_w .link img {
    width: 130px;
    margin-bottom: 10px;
    margin-top: 5px;
}
.consult_w .link .link_txt {
    color: #fff;
}

@media (min-width: 992px) {
    #section_consulting_bar {
        padding: 7rem;
    }
    .consult_w {
        flex-direction: row;
        justify-content: space-between;
    }
    .consult_w .txt {
        margin: 0 1rem 0rem 0;
    }
}



#shotcut_consulting {
    background-color: var(--ch-red2);
    border-bottom-color: var(--ch-red5);
}




@media (min-width: 992px) {
    #right_floating_box {
        bottom: 135px;
    }
}