@charset "utf-8";

/*메인 PC*/
.pc{display:block;}
.m{display:none;}

/*공통*/
/* Slider CSS */
.slider-wrapper.pc{display:block;}
.slider-wrapper.m{display:none;}
.slider-wrapper {
    position: relative;
    max-width: 100%;
    margin: 0 auto;
    overflow: hidden;
}

.slider {
    display: flex;
    transition: transform 0.5s ease-in-out;
}

.slide {
    min-width: 100%;
    position: relative;
}

.slide img {
    width: 100%;
    vertical-align: top;
}

.slide-caption {
    position: absolute;
    bottom: 100px;
    left: 50%;
    transform: translateX(-50%);
    color: #fff;
    text-align: center;
    font-size:20px;
    line-height:30px;
    letter-spacing:-1.4px
}
.slide-caption h2{
    font-family: 'Cormorant Infant';
    font-size:40px;
    font-weight:bold;
    letter-spacing:-2px;
    margin-bottom:20px
}
.slider-controls {
    position: absolute;
    top: 50%;
    width: 100%;
    display: flex;
    justify-content: space-between;
    transform: translateY(-50%);
}


.slider-dots {
    text-align: center;
    position: absolute;
    bottom:34px;
    width: 100%;
}

.slider-dots .dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    background: #898989;
    margin:0 25px 0;
    border-radius: 50%;
    cursor: pointer;
}

.slider-dots .dot.active {
    background: #FFFFFF
}


/* 웨딩 정보 섹션 */
.wedding-info {
    max-width:100%;
    margin:0 auto;
    padding:100px 0;
    display: flex;
    flex-wrap: wrap;
    gap: 50px;
    background:#FFF7EC
}
.info_wrap{
    margin:0 auto
}
.wedding-title{
    text-align: center;
    font-size:44px;
    line-height:54px;
    color:#AF8A7F;
    font-family:'Cormorant Infant';
    margin-bottom:10px
}
.hotel-name{
    text-align: center;
    font-size:35px;
    line-height:47.3px;
    text-align:-1.75px;
    color:#293E45;
    margin-bottom:90px
}
/* 웨딩 콘텐츠 */
.wedding-content {
    display: flex;
    flex-direction: row;
    gap: 30px;
    width:1200px;
    flex-wrap: wrap;
}

/* 웨딩 설명 */
.wedding-description {
    flex: 1;
    min-width: 300px;
    margin-left:50px
}
.wedding-text, .luxury-title {
    font-size:28px;
    margin-bottom:50px;
    line-height:41px;
    color:#AF8A7F;
    font-weight:bold
}

.wedding-details, .luxury-text {
    font-size:20px;
    margin-bottom:60px;
    color:#3E3E3D;
    letter-spacing:.2px;
}

.wedding-link, .luxury-link {
    color: #7E6441;
    font-weight:600;
    text-decoration:underline;
    font-size:20px;
    line-height:30px;
}


/* 웨딩 이미지 */
.wedding-image {
    flex: 1;
    position: relative;
    min-width: 300px;
}

.main-image {
    width: 100%;
    border-radius:300px 300px 0 0;
    object-fit: cover;
}

.wedding-gallery {
    margin-top:8px;
    display: flex;
    gap:3px;
}

.wedding-gallery img {
    width: 143px;
    height: 87px;
    cursor: pointer;
    object-fit: cover;
    transition: 0.3s;
}
.wedding-gallery img:hover{
    filter: grayscale(1);
}

/* 럭셔리 웨딩 */
.luxury-wedding {
    flex: 1;
    margin-top:200px;
    display: flex;
    justify-content:center;
    gap:70px;
    align-items: center;

}

/* 웨딩 장소 섹션 */
.wedding-venue {
    padding:120px 0 160px;
    background: url(../img/venue_bg.jpg) no-repeat bottom #172226
}

.venue-title {
    text-align: center;
    font-size: 50px;
    font-weight: bold;
    color: #AF8A7F;
    margin-bottom: 120px;
    font-family:'Cormorant Infant';
}
/* 장소 카드 */
.venue-card {
    display: flex;
    flex-wrap: nowrap;
    gap: 50px;
    width: 1160px;
    margin: 0 auto;
    margin-bottom:190px;
    background: #FFF7EC;
    overflow: hidden;
    box-shadow: 0px 8px 40px #00000073;
    align-items: center;
    transform:translateX(-50px);
    position:relative;
}

.venue-card:nth-child(3){
    flex-direction: row-reverse;
    transform:translateX(50px);
    width: fit-content;
    height: 580px;
    gap:15px
}
.venue-card:nth-child(3) .venue-details{
    margin-left:32px;
    margin-bottom:10px;
}

.venue-image {
    width:696px
}

.venue-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 장소 세부사항 */
.venue-details {
    display: flex;
    flex-direction: column;
    justify-content:center
}

.venue-name {
    font-size:23px;
    font-weight:200;
    color: #373737;
    margin-bottom:8px;
}

.venue-name span {
    font-size:35px;
    line-height:40px;
    color: #DF4F3F;
    font-family: 'Cormorant Infant';
    font-weight:600;
}
.venue-card:nth-child(2) .venue-description{margin-bottom:90px}
.venue-card:nth-child(3) .venue-description{margin-bottom:16px}
.venue-card:nth-child(4) .venue-description{margin-bottom:60px}

.venue-description {
    font-size:20px;
    color: #373737;
}

.list_tit {
    font-size:15px;
    letter-spacing:-.8px;
    color: #373737;
    margin-bottom:10px
}

/* 정보 리스트 */
.salon_wrap{
    display: flex;
    gap:7px
}
.venue-info-list {
    list-style: none;
    padding: 0;
    display: flex;
    gap:7px;
}

.venue-info-list li {
    font-size: 1em;
    margin-bottom: 5px;
    color: #fff;
    border-radius:50%;
    width:97px;
    height:97px;
    display: flex;
    justify-content:center;
    align-items: center;
    text-align:center;
    flex-direction: column;
    font-size:16px;
    letter-spacing:-0.85px;
}
.venue-info-list li b{
    display:block;
}
.venue-info-list.color1 li {
    background-color: #293E45
}

.venue-info-list.color2 li {
    background-color: #AF8A7F
}

.venue-info-list.color3 li {
    background-color: #7D6158
}

.venue-info-list.color4 li {
    background-color: #A39A8F
}

/* 장소 링크 */
.venue-link {
    position:absolute;
    font-size:18px;
    text-decoration:underline;
    color:#7E6441;
    font-weight: 600;
}
.venue-card:nth-child(2) .venue-link {bottom:16px;right:20px}
.venue-card:nth-child(3) .venue-link {bottom:16px;left:360px}
.venue-card:nth-child(4) .venue-link {bottom:16px;right:20px}

/* 오시는 길 섹션 스타일 */
.location-info {
    max-width: 1200px;
    margin: 78px auto 106px;
}

/* 제목 스타일 */
.location-title {
    font-size:50px;
    font-weight:700;
    text-align: center;
    color: #293E45;
    margin-bottom:87px
}

/* 오시는 길 섹션 컨테이너 */
.location-container {
    display: flex;
    flex-wrap: wrap;
    gap:70px;
}

/* 상세 정보 스타일 */
.location-details {
    flex: 2;
    display: flex;
    flex-direction: column;
}

.hotel-name2 {
    font-size: 28px;
    font-weight:800;
    color: #2A2A2A;
    margin-bottom: 10px;
}

.hotel-address {
    font-size:20px;
    color: #2A2A2A;
    margin-bottom:11px;
}

/* 교통 및 주차 정보 스타일 */
.transit-info h4,
.parking-info h4 {
    font-size:22px;
    color: #AF8A7F;
    margin-bottom:13px;
}

.transit-info div,
.parking-info {
    margin-bottom:14px;
}

.transit-info strong,
.parking-info strong {
    font-size: 15px;
    color: #2A2A2A;
    font-weight:800
}

.transit-info p,
.parking-info p {
    font-size:15px;
    color: #2A2A2A;
    line-height:22px;
}

/* 연락처 정보 스타일 */
.contact-info {
    font-size: 17px;
    color:#2A2A2A;
    display: flex;
    gap:42px;
}

.contact-info strong {
    font-weight:800;
}


@media screen and (max-width: 760px){
    .pc{display:none;}
    .m{display:block;}

    .slider-wrapper.m{display:block;}
    .slider-wrapper.pc{display:none;}
    .slider-wrapper.m .slide{height: 400px;}
    .slider-dots{bottom:8px}
    .slider-dots .dot{margin:0 5px}
    .slide-caption{font-size:13px;line-height:18px;width:100%;bottom: 40px;}
    .slide-caption h2{font-size:20px;line-height:24px;}

    /**/
    .wedding-venue{background:url(../img/venue_bg_m.jpg) no-repeat bottom #172226;background-size:cover;}
    .wedding-info{padding:60px 0 90px; }
    .info_wrap{width:100%;padding:0 15px}
    .wedding-title{font-size:35px;line-height:42px;}
    .hotel-name{font-size:20px;line-height:30px;margin-bottom: 60px;}
    .wedding-content{width:100%;}
    .wedding-text{margin-bottom:30px}
    .wedding-text, .luxury-title{font-size:18px;line-height:28px}
    .wedding-details, .luxury-text{font-size:15px;line-height:23px;letter-spacing:-1.05px;margin-bottom:24px}
    .wedding-link, .luxury-link{font-size:15px;line-height:23px;}
    .wedding-image{min-width:100%}
    .wedding-gallery{gap:0;justify-content: space-between;margin-top:4px}
    .wedding-gallery img{width:24%;height: 44px;}
    .wedding-description{margin-left:0}
    .luxury-wedding{margin-top:100px;flex-direction: column-reverse;align-items:normal;}
    .venue-title{width:100%;font-size:25px;line-height:30px;margin-bottom:47px;gap:30px}
    .venue-title img{width:220px;margin-top:7px}
    .wedding-venue{padding:60px 10px 108px}
    .venue-image{width:100%;}
    .venue-card{width:100%;flex-direction: column;transform: none;gap:30px;margin-bottom:35px}
    .venue-name{font-size:19px;}
    .venue-name span{font-size:28px}
    .venue-description{font-size:14px;}
    .venue-card:nth-child(2) .venue-description{margin-bottom:30px}
    .venue-info-list li{width:87px;height:87px;font-size:14px;line-height:20px;}
    .venue-link{position:relative;font-size:15.99px;margin:30px auto 17px}
    .venue-details{width:100%;padding:0 20px}
    .venue-card:nth-child(1) .venue-link, .venue-card:nth-child(2) .venue-link, .venue-card:nth-child(3) .venue-link, .venue-card:nth-child(4) .venue-link{bottom:0;right:0;left:0}
    .venue-card:nth-child(3){gap:30px; flex-direction: column;transform:none;width:100%}
    .venue-card:nth-child(3){height:auto;}
    .venue-card:nth-child(3) .venue-details{margin:0;}
    .salon_wrap{ flex-direction: column;align-items: center;}
    .venue-info-list{justify-content:center;}
    .list_tit{text-align:center;}
    .video_area img{width:100%;}

    /**/
    .location-info{margin:73px 10px ; }
    .location-title{font-size:30px;margin-bottom:15px}
    .location-map img{width:100%;margin:0 auto;border:1px solid #ccc}
    .hotel-name2{font-size:20px}
    .transit-info strong, .parking-info strong{line-height:20px;margin-bottom:10px;}
    .hotel-address{font-size:18px;margin-bottom:25px}
    .transit-info h4, .parking-info h4{font-size:18px;margin-bottom:25px}
    .subway-info{margin-bottom:40px !important}
    .contact-info{flex-direction: column;}
    .map-button{margin:0 auto}
    .transit-info p, .parking-info p{font-size:13px;letter-spacing:-.65px;line-height:20px;}

}