@charset "utf-8";
#Center { position: relative; }
#Center .guide_title { position: absolute; top: 0; left: 0; }

/*----------------------------------------------------------------------*/
/* KeyVisual */
#KeyVisual { position: relative; z-index: 1; overflow: hidden; }
#KeyVisual .banner_warp { max-width: 1300px; margin: 0 auto; }
#KeyVisual .owl-carousel .owl-stage-outer { overflow: visible; }
#KeyVisual .index_slider_list a { display:block; max-width:100%; overflow:hidden; width: 100%; height: 0; padding-bottom: 50%; position: relative; border-radius: 30px; }
#KeyVisual .index_slider_list a:hover, #KeyVisual .index_slider_list a:focus { opacity:0.8; }
#KeyVisual .index_slider_list img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
#KeyVisual .index_slider_list .owl-item li a { opacity: .1; }
#KeyVisual .index_slider_list .owl-item.active li a { opacity: 1; }
#KeyVisual .index_slider_list .owl-item li a:focus { opacity: 1; }

/* noscript */
#KeyVisual.noscript > div { max-width:960px; margin:0 auto; }
#KeyVisual.noscript .index_slider_list li { margin:10px 0; }
#KeyVisual.noscript + .return_form_noscript { padding-bottom:40px; }

/*----------------------------------------------------------------------*/
/* 首頁共用樣式 */
.IndexBlock { overflow: hidden; font-family: "Roboto", 'Noto Sans TC', sans-serif; padding: 40px 0; }
.IndexBlock a { -webkit-transition: all 0.3s ease; -moz-transition: all 0.3s ease; transition: all 0.3s ease; }
.index_title { margin-bottom: 30px; }
.index_title .en { font-size: 3.75em; font-weight: 700; text-transform:uppercase; color: var(--color2); letter-spacing: .055em; line-height: 1; margin-bottom: 5px; }
.index_title h2 { font-size: 1.875em; color: #333; line-height: 1.25em; position: relative; white-space: nowrap; letter-spacing: .2em; font-weight: 600; display: flex; flex-wrap: wrap; align-items: center; }
.index_title h2::before { content: ''; width: 18px; height: 27px; background: url(../images/icon_water.svg) no-repeat; display: inline-block; margin-top: 3px; margin-right: 0.375em; }

@media screen and (max-width: 639px) {
    .IndexBlock { padding: 30px 0; }
    .index_title { text-align: center; }
    .index_title h2 { font-size: 1.5em; justify-content: center; }
}
@media screen and (min-width: 1280px) {
    .index_title .en span { display: block; }
    .col_2 .inner { display: flex; }
}
@media screen and (min-width: 1280px) and (max-width: 1599px) {
    .col_2 .inner > section { width: calc(50% - 30px); }
    .col_2 .inner > section:first-child { margin-right: 60px; }
}
@media screen and (min-width: 1600px) {
    .col_2 .inner > section { width: calc(50% - 50px); }
    .col_2 .inner > section:first-child { margin-right: 100px; }
}

/*----------------------------------------------------------------------*/
/* 血液庫存 */
.InventoryGroup { position: relative; }
.InventoryGroup .date { font-size: .8125em; }
.InventoryGroup .info { font-size: .8125em; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; }
.InventoryGroup .info li { padding: 0 1em; margin: 5px 0; }
.InventoryGroup .info li img { vertical-align: middle; margin-right: 5px; }

.IndexTopGroup { position: relative; border-bottom: 1px solid #9a9a9a; padding-bottom: 150px; }
.IndexTopGroup::after { content: ''; position: absolute; bottom: -1px; left: 50%; width: calc(100% - 200px); height: 145px;background: url(../images/imagery.png) no-repeat center bottom; max-width: 1800px; background-size: contain; transform: translateX(-50%); }
@media screen and (min-width: 640px) and (max-width: 1279px) {
    .IndexTopGroup { padding-bottom: 11vw; }
	.IndexTopGroup::after { width: calc(100% - 10%); }
}
@media screen and (max-width: 639px) {
    .IndexTopGroup { padding-bottom: 12vw; }
	.IndexTopGroup::after { width: calc(100% - 30px); }
}

.InventoryList > li { margin-bottom: 20px; }
.InventoryList > li:nth-child(n+3) { margin-top: 20px; }
.InventoryList .item { background: #fff; border-radius: 30px; padding: 17px; text-align: center; }
.InventoryList .titleBar { position: relative; margin-bottom: 12px; padding: 0 12px; }
.InventoryList .titleBar .title { position: relative; font-size: 1.5em; text-decoration: none; font-weight: 600; letter-spacing: .2em; }

.InventoryList .item ul { display: flex; justify-content: center; max-width: 560px; margin: 0 auto; }
.InventoryList .item ul .text { font-size: 1.125em; font-weight: bold; color: var(--color2); margin-bottom: 5px; }
.InventoryList .item ul li { position: relative; padding: 0 .875vw; width: 25%; }
.InventoryList .item ul li:nth-child(n+2)::before { content: ''; position: absolute; left: 0; top: 1.25em; width: 1px; height: 30px; background: #f5b2b2; }
.InventoryList .item ul .icon { width: 45px; max-width: 100%; margin: 0 auto; }
.InventoryList .item ul .icon img { max-width: 100%; }

.InventoryBtns { margin-bottom: 30px; }
.InventoryBtns .item { position: relative; border-radius: 30px; margin-top: 20px; margin-bottom: 20px; }
.InventoryBtns .item a { position: absolute; left: 0; top: 0; width: 100%; height: 100%; text-decoration: none; border-radius: 30px; overflow: hidden; }
.InventoryBtns .item a::before { content: ''; position: absolute; left: 0; top: 0; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(48,48,48,.8) 0%,rgba(255,255,255,0) 100%); pointer-events: none; }
.InventoryBtns .item .title { margin: 20px 20px 0 40px; display: flex; justify-content: space-between; align-items: center; }
.InventoryBtns .item .title span { position: relative; z-index: 1; color: #fff; font-size: 1.5rem; letter-spacing: .2em; text-shadow: 0 0 7px rgba(0,0,0,.5); }
.InventoryBtns .item .title::after { content: ''; position: relative; display: block; flex-shrink: 0; margin-top: 2px; width: 30px; height: 30px; border-radius: 50%; background: #fff url(../images/icon_arrow_r.png) no-repeat center center; transition: all 0.3s ease; }
.InventoryBtns .imgBox { position: relative; padding-bottom: 47.225%; border-radius: 30px; overflow: hidden; }
.InventoryBtns .imgBox img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }

.InventoryBtns .item a:hover::before, .InventoryBtns .item a:focus::before { background: linear-gradient(to bottom, rgba(48,48,48,1) 0%,rgba(255,255,255,0) 100%); }
.InventoryBtns .item a:hover .title::after, .InventoryBtns .item a:focus .title::after { background: #e61037 url(../images/icon_arrow.png) no-repeat center center; }

@media screen and (min-width: 768px) {
    .InventoryList .titleBar { display: flex; justify-content: space-between; align-items: flex-end; }
    .InventoryList .item ul .text { font-size: 1.5em; }
    .InventoryList .item ul .icon { width: 50px; }
}
@media screen and (max-width: 767px) {
    .index_title .en { font-size: 6vw; }
    .InventoryList .item ul li { padding: 0 2.5vw; }
    .InventoryList .item { max-width: 500px; margin: 0 auto; }
    .InventoryGroup .date { text-align: center; margin-bottom: 10px; }
    .InventoryList .titleBar a { font-size: 1.25em; }
    .InventoryList .titleBar a::after { top: -3px; }
    .InventoryBtns .item .title { margin: 20px 20px 0 25px; }
}
@media screen and (min-width: 640px) {
    .InventoryBtns { display: flex; flex-wrap: wrap; }
    .InventoryBtns .item { width: calc(50% - 20px); }
    .InventoryBtns .item:nth-child(even) { margin-left: 15px; }
    .InventoryBtns .item:nth-child(odd) { margin-right: 15px; }
}
@media screen and (max-width: 639px) {
    .InventoryBtns .item { max-width: 500px; margin-left: auto; margin-right: auto; }
}


/* 哪裡可以捐血 */
.GiveGroup { position: relative; z-index: 5; background-color: #fff; border-radius: 0 0 30px 30px; padding: 35px 40px 30px 40px; }
.GiveGroup::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 5px; background: linear-gradient(to right, #e8431e 0%,#e6003f 100%); }

.GiveGroup .file_download { width:100%; margin:0 0 10px 0; }
.GiveGroup .file_download ul { display:flex; align-items:center; flex-wrap:wrap; }
.GiveGroup .file_download ul li { margin:0 10px 10px 0; }
.GiveGroup .file_download ul a {
    display:block; border:2px solid var(--color2); border-radius:60px; padding:0 1.25em; transition:all 0.3s ease;
	color:var(--color2); line-height:46px; font-weight:600; text-decoration:none; 
	}
	@media screen and (min-width: 1280px) {
    .GiveGroup .file_download ul a { font-size:1.125em; }
	}
.GiveGroup .file_download ul a:hover, .GiveGroup .file_download ul a:focus { background-color:var(--color2); color:#fff; }

.GiveGroup .choose { display:flex; flex-wrap:wrap; margin-right:-20px; }
.GiveGroup .choose li { margin-right:20px; }
.GiveGroup .choose .lebel { font-weight: 600; }
.GiveGroup .choose .cont { display: flex; align-items: center; }
.GiveGroup .deadline .dash { margin: 0 5px; }
.GiveGroup .choose.FormElmt select + select { margin-left: 8px; }
.GiveGroup .keyword input[type="text"] { width: 300px; max-width: 100%; flex: 1; }
.GiveGroup .choose .btn { display:flex; }
.GiveGroup .choose .btn button { border: 1px solid #ee858c; color: #ee858c; font-weight: bold; height: 50px; border-radius: 5px; position: relative; display: block; margin-left: 8px; padding: 0 .9em; }
.GiveGroup .choose .btn button.search { padding: 0 2.2em 0 .9em; }
.GiveGroup .choose .btn button.search::before { content: ''; width: 22px; height: 22px; position: absolute; right: .75em; top: calc(50% - 11px); background: url(../images/icon_search.svg) center center; transition: all 0.3s ease; }
.GiveGroup .choose .btn button.search:hover::before, .GiveGroup .choose .btn button.search:focus::before { background: url(../images/icon_search_hover.svg) center center; }
.GiveGroup .choose .btn button.reset { color:#999; border-color: #999; }
.GiveGroup .choose .btn button:hover, .GiveGroup .choose .btn button:focus { background-color: #ee858c; color: #fff; }
.GiveGroup .choose .btn button.reset:hover, .GiveGroup .choose .btn button.reset:focus { background-color: #999; }

.or_line { text-align: center; position: relative; margin: 10px 0; }
.or_line::before { content: ''; width: 100%; height: 1px; background-color: #ddd; position: absolute; left: 0; top: 0.75em; }
.or_line > span { background-color: #fff; padding: 0 .75em; position: relative; font-weight: 400; font-size: 1.25em; color: #ccc; }

.GiveGroup .find { font-weight: 600; display: flex; flex-wrap: wrap; align-items: center; }
.GiveGroup .find p { margin: 10px 8px 10px 0; }
.GiveGroup .find .btn button { color: #ee858c; border: 2px solid #ee858c; height: 50px; border-radius: 30px; position: relative; padding: 0 2.35em 0 1.25em; font-weight: 600; }
.GiveGroup .find .btn button::after { content: ''; width: 19px; height: 19px; position: absolute; right: 1em; top: calc(50% - 8px); background: url(../images/icon_find.png) no-repeat; transition: all 0.3s ease; }
.GiveGroup .find .btn button:hover, .GiveGroup .find .btn button:focus { background-color: #ee858c; color: #fff; }
.GiveGroup .find .btn button:hover::after, .GiveGroup .find .btn button:focus::after { background: url(../images/icon_find_hover.png) no-repeat; }

@media screen and (max-width: 1023px) {
    .GiveGroup .choose .btn button { height: 40px; }
    .GiveGroup .choose .btn button::before { width: 18px; height: 18px; top: calc(50% - 9px); }
}
@media screen and (min-width: 1280px) {
    .GiveGroup .choose .lebel { font-size: 1.125em; }
    .GiveGroup .find { font-size: 1.125em; }
    .GiveGroup .find .btn button { font-size: 1.125rem; padding: 0 1.8em 0 .9em; }
    .GiveGroup .find .btn button::after { right: .75em; }
    .GiveGroup .choose li { padding: 5px 0; }
    .GiveGroup .choose .btn button { font-size: 1.125em; }
}

@media screen and (min-width: 560px) {
    .GiveGroup .choose li { display: flex; flex-wrap: wrap; align-items: center; }
    .GiveGroup .choose .lebel { flex-shrink: 0; width: 5.875em; }
}
@media screen and (max-width: 559px) {
    .GiveGroup { padding: 25px 15px 30px 15px; }
    .GiveGroup .choose li { margin-bottom: 10px; }
    .GiveGroup .keyword input[type="text"] { width: 100%; }
}

@media screen and (max-width: 767px) {
    .GiveGroup { max-width: 570px; margin: 0 auto; }
}
@media screen and (min-width: 1024px) and (max-width: 1599px) {
    .GiveGroup { max-width: 750px; margin: 0 auto; }
}

/*----------------------------------------------------------------------*/
/* 捐血集點換贈品 */
.IndexBlock.IndexAbout { padding: 0; overflow: visible; }

.AboutGroup { position: relative; }
.AboutGroup .titleBox { background: linear-gradient(to right, #e8431e 0%, #e6003f 100%); padding-left: 20px; padding-top: 46px; padding-bottom: 46px; padding-right: 20px; }
.AboutGroup .index_title { margin-bottom: 0; }
.AboutGroup .index_title .en { color: #fff; }
.AboutGroup .index_title h2 { color: #fff; }
.AboutGroup .index_title h2::before { background: url(../images/icon_water_w.svg) no-repeat; }
.AboutGroup .contBox { background-color: #fff; }
.AboutGroup .more_btn { margin-top: 20px; }

.AboutList li { margin-top: 15px; margin-bottom: 15px; }
.AboutList a { display: flex; text-decoration: none; background-color: #fcd6d6; border-radius: 10px; padding: 5px; }
.AboutList .imgBox { width: 200px; flex-shrink: 0; margin-right: 10px; }
.AboutList .imgBox .img { position: relative; padding-bottom: 100%; border-radius: 10px; overflow: hidden; }
.AboutList .imgBox .img img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.AboutList .cont { flex: 1; display: flex; flex-direction: column; justify-content: space-between; padding: 5px 10px 5px 5px; }
.AboutList .title { font-size: 1.125em; line-height:1.5em; overflow:hidden; text-overflow:ellipsis; display:-webkit-box; -webkit-box-orient:vertical; max-height:6em; -webkit-line-clamp:4; margin: 5px 0; }
.AboutList .last { display: flex; justify-content: space-between; align-items: flex-end; }
.AboutList .last .point { color: var(--main_color); font-size: .8125em; }
.AboutList .last .point .number { font-size: 2rem; font-weight: 600; }
.AboutList .last .btn::after { content: ''; position: relative; display: block; flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; background: #fff url(../images/icon_arrow_r.png) no-repeat center center; transition: all 0.3s ease; }
.AboutList a:hover, .AboutList a:focus { box-shadow: 0 0 10px rgba(0,0,0,.2); }
.AboutList a:hover .btn::after, .AboutList a:focus .btn::after { background: #e61037 url(../images/icon_arrow.png) no-repeat center center; }

.AboutBtns ul { display: flex; flex-wrap: wrap; }
.AboutBtns ul li { margin: 10px; }
.AboutBtns a { text-decoration: none; display: block; color: var(--color1); border: 2px solid var(--color1); background-color: #fff; border-radius: 35px; padding: .556em 1.194em; font-size: 1.125em; font-weight: 500; }
.AboutBtns a:hover, .AboutBtns a:focus { background-color: var(--color1); color: #fff; }
.AboutBtns a span { display: flex; align-items: center; }
.AboutBtns a span::after { content: ''; display: block; width: 20px; height: 20px; background: url(../images/index_about_btns.png) no-repeat; margin-top: 2px; margin-left: 3px; }
.AboutBtns a:hover span::after, .AboutBtns a:focus span::after { background-position: -20px 0; }
.AboutBtns .btn2 a span::after { background-position: 0 -20px; }
.AboutBtns .btn2 a:hover span::after, .AboutBtns .btn2 a:focus span::after { background-position: -20px -20px; }

@media screen and (min-width: 768px) and (max-width: 959px) {
    .AboutList .imgBox { width: 150px; }
    .AboutList .title { font-size: 1em; }
    .AboutList .last .point .number { font-size: 1.75rem; }
}
@media screen and (min-width: 490px) and (max-width: 767px) {
    .AboutList .item { height: 100%; max-width: 350px; margin: auto; }
    .AboutList a { flex-direction: column; padding: 10px; height: 100%; }
    .AboutList .imgBox { width: 100%; margin: 0; }
}
@media screen and (max-width: 639px) {
    .AboutList .title { font-size: 1em; }
    .AboutList .last .point .number { font-size: 1.75rem; }
    .AboutGroup .titleBox { padding-top: 40px; padding-bottom: 35px; }
}
@media screen and (min-width: 490px) {
    .AboutList { display: flex; flex-wrap: wrap; }
    .AboutList li { width: 50%; }
    .AboutList li:nth-child(even) { padding-left: 12px; }
    .AboutList li:nth-child(odd) { padding-right: 12px; }
}
@media screen and (max-width: 489px) {
    .AboutList .imgBox { width: 48%; }
    .AboutList .title { max-height:4.5em; -webkit-line-clamp:3; }
    .AboutList .last .point .number { font-size: 1.5rem; }
    .AboutBtns a { font-size: 1em; }
}

@media screen and (max-width: 1279px) {
    .AboutBtns ul { justify-content: center; margin: 20px 0; }
    .AboutGroup .contBox { padding: 20px 5% 40px 5%; }
}
@media screen and (min-width: 1280px) {
    .AboutGroup { display: flex; align-items: flex-start; margin-top: -50px; }
    .AboutGroup .col_left { width: 40%; position: relative; }
    .AboutGroup .contBox { width: calc(60% + 5vw); margin-top: 50px; margin-left: -5vw; padding: 40px 40px 40px 7.5vw; border-radius: 0 0 0 50px; }
    .AboutBanner .img { border-radius: 0 500px 0 0; overflow: hidden; }
    .AboutGroup .titleBox { padding-left: 7.5vw; border-radius: 0 50px 0 0; }
    .AboutBtns { padding-left: 7.5vw; padding-right: 5vw; }
    .AboutBtns ul { margin-top: 40px; }
    .AboutBtns ul li:first-child { margin-left: 0; }
}

@media screen and (min-width: 1600px) {
    .AboutGroup .contBox { padding: 40px 7.5vw; }
    .AboutBtns a { padding: .556em 36px; }
}

@media screen and (min-width: 768px) and (max-width: 1279px) {
    .AboutGroup .titleBox { padding-left: 5%; padding-right: 5%; }
}


/*----------------------------------------------------------------------*/
/* 最新消息及活動 */
.IndexNewsGroup { position: relative; }
.IndexNewsGroup::before, .IndexNewsGroup::after { content: ''; background: url(../images/corners.svg) no-repeat; width: 250px; height: 250px; position: absolute; z-index: -1; }
.IndexNewsGroup::before { left: 0; top: 0; transform: rotate(180deg); }
.IndexNewsGroup::after { right: 0; bottom: 0; }

.IndexNews, .IndexStory { padding: 50px 0; }
.NewsList li { padding: 30px 0; border-bottom: 1px solid #ddd; }
.NewsList .date { font-weight: 400; display: inline-block; color: #555; margin-bottom: 12px; line-height: 31px; }
.NewsList .tag { display: inline-block; background-color: #fcd6d6; padding: .3em 1em; border-radius: 20px; color: #e6003f; font-size: .9375em; margin-bottom: 12px; }
.NewsList .date + .tag { margin-left: 5px; }
.NewsList .title a { text-decoration: none; font-size: 1.25em; }
.more_btn { text-align: right; margin-top: 30px; }
.more_btn a { text-decoration: none; display: inline-block; position: relative; padding-right: 40px; min-height: 30px; }
.more_btn a::after { content: ''; position: absolute; right: 0; top: calc(50% - 15px); width: 30px; height: 30px; border-radius: 50%; background: #555 url(../images/icon_arrow.png) no-repeat center center; transition: all 0.3s ease; }
.more_btn a:hover::after, .more_btn a:focus:after { background: var(--main_color) url(../images/icon_arrow.png) no-repeat center center; }

.tabs_group .tab_title a { text-decoration: none; display: block; color: var(--color1); border: 2px solid var(--color1); background-color: #fff; border-radius: 15px; padding: .375em 1.194em; }
.tabs_group .tab_title.active a { background-color: var(--color1); color: #fff; }

@media screen and (max-width: 767px) {
    .tabs_group .tab_title.active a { border-radius: 15px 15px 0 0; }
    .tab_title { margin-top: 20px; }
    .tab_cont { background-color: #fff; border-radius: 0 0 15px 15px; padding: 0 15px 15px; }
    .NewsList li { padding: 15px 0 12px; }
    .NewsList .title a { font-size: 1.125em; }
    .NewsList .date, .NewsList .tag { margin-bottom: 8px; }
    .IndexNews, .IndexStory { padding: 30px 0; }
    .IndexNewsGroup::before, .IndexNewsGroup::after { width: 100px; height: 100px; }
    .IndexStoryGroup::before, .IndexStoryGroup::after { width: 100px; height: 100px; }
}
@media screen and (min-width: 768px) {
    .tabs_group { position: relative; padding-top: 70px; }
    .tabs_group .tab_title { position: absolute; top: 0; z-index: 1; padding-right: 20px; }
    .NewsList li:first-child { border-top: 1px solid #ddd; }
}
@media screen and (min-width: 768px) and (max-width: 1599px) {
    .IndexNewsGroup .inner { padding-left: 5%; padding-right: 5%; }
    .IndexStoryGroup .inner { padding-left: 5%; padding-right: 5%; }
    .IndexNews, .IndexStory { padding: 40px 0; }
}
@media screen and (max-width: 559px) {
    .IndexNews, .IndexStory { padding: 20px 0; }
}

@media screen and (min-width: 1280px) {
    .NewsList { display: grid; grid-auto-flow: column; grid-template-rows: repeat(3, 1fr); grid-template-columns: 1fr 1fr; gap: 0 100px; }
    .NewsList li:nth-child(4) { border-top: 1px solid #ddd; }
}
@media screen and (min-width: 1280px) and (max-width: 1599px) {
    .NewsList { gap: 0 60px; }
}

/*----------------------------------------------------------------------*/
/* 捐血人故事 */
.StoryList .item { box-sizing:border-box; margin:10px auto; max-width: 380px; }
.StoryList .item > div { overflow: hidden; height: 100%; margin-left: auto; margin-right: auto; background: #fff; border: 1px solid #eee; border-radius: 20px; box-shadow: 1px 2px 5px rgba(0,0,0,.08); }
.StoryList .img { position:relative; overflow:hidden; }
.StoryList .img > div { padding-bottom:66.66%; background-repeat:no-repeat; background-position:center center; background-size:cover; transition:all 0.6s ease; }
.StoryList .cont { padding: 20px; }
.StoryList .cat { font-size: 1.125em; color: var(--main_color); padding-bottom: 10px; }
.StoryList .title a { display: block; text-decoration: none; font-size: 1.25em; line-height: 1.5em; height: 3em; overflow:hidden; text-overflow:ellipsis; display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; }

.IndexStoryGroup { position: relative; border-bottom: 1px solid #9a9a9a; padding-bottom: 80px; }
.IndexStoryGroup::before, .IndexStoryGroup::after { content: ''; background: url(../images/corners.svg) no-repeat; width: 250px; height: 250px; position: absolute; z-index: -1; }
.IndexStoryGroup::before { left: 0; top: 0; transform: rotate(180deg); }
.IndexStoryGroup::after { right: 0; bottom: 0; }
.IndexStory::after { content: ''; position: absolute; bottom: -1px; left: 10vw; width: 777px; height: 115px;background: url(../images/imagery2.png) no-repeat center bottom; max-width: 50%; background-size: contain; }

@media screen and (max-width: 767px) {
    .StoryList { padding-top: 5px; }
    .StoryList .cat { font-size: 1em; }
    .StoryList .title a { font-size: 1.125em; }
    .IndexStoryGroup { padding-bottom: 12vw; }
    .IndexStory::after { max-width: 75%; }
}

/*----------------------------------------------------------------------*/
/* 相關連結 */
.LinksList { text-align: center; }
.LinksList a { text-decoration: none; display: block; border-radius: 10px; }
.LinksList a:hover .imgBox, .LinksList a:focus .imgBox { box-shadow: 0 0 10px rgba(0,0,0,.2); }
.LinksList .item { max-width: 300px; margin: 10px auto; }
.LinksList .imgBox { background-color: #fff; border-radius: 10px; padding: 10px; transition: all 0.3s ease; }
.LinksList .img { height: 80px; display: flex; justify-content: center; align-items: center; }
.LinksList .img img { max-width: 100%; max-height: 100%; }
.LinksList .title { padding: 10px; }
.IndexLinks { padding-bottom: 60px; }
.IndexLinks .owl-carousel .owl-stage-outer { overflow: visible; }
.IndexLinks .owl-carousel .owl-dots { bottom: -20px; }

/*----------------------------------------------------------------------*/
/* 輪播 owl-carousel */
.owl-carousel .disabled { display: none; }

.owl-carousel .owl-nav > div {
	position:absolute; top:50%; border:1px solid #cdcdcd; text-indent:-999px; z-index:9999; overflow:hidden;
	-webkit-border-radius:5px;	-moz-border-radius:5px; border-radius:5px;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
	}
.owl-carousel .owl-nav > div:hover { border-color:#333; }
.owl-carousel .owl-nav > div::after { 
	content:''; display:block; position:absolute; top:50%; width:12px; height:12px; margin-top:-6px;
	border-left:2px solid #999; border-top:2px solid #999; 
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
	}
	.owl-carousel .owl-nav .owl-prev::after { 
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
        left:50%; margin-left:-3px;
		}
	.owl-carousel .owl-nav .owl-next::after { 
		-webkit-transform: rotate(135deg);
		-moz-transform: rotate(135deg);
		transform: rotate(135deg);
        right:50%; margin-right:-3px;
		}
.owl-carousel .owl-nav > div:hover::after { border-color:#333; }

.owl-carousel .owl-dots { width:100%; text-align:center; line-height:0; position: absolute; bottom: -30px; }
.owl-carousel .owl-dots .owl-dot { 
	display:inline-block; width:14px; height:14px; margin:0 0.4vw; background-color:#fff; border: 2px solid #fcd6d6; box-sizing: border-box;
	-webkit-border-radius:7px; -moz-border-radius:7px; border-radius:7px; 
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.owl-carousel .owl-dots .owl-dot:focus { outline:0; }
.owl-carousel .owl-dots .owl-dot:hover { border-color: var(--color2); }
.owl-carousel .owl-dots .owl-dot.active, .owl-carousel .owl-dots .owl-dot:focus { 
    background-color: var(--color2);
}

@media screen and (min-width: 1024px) {
	.owl-carousel .owl-nav > div { margin-top:-23px; width:46px; height:46px; }
	.IndexBlock .owl-carousel .owl-nav > div { margin-top:-23px; width:46px; height:46px; margin-top: -23px; }
    .IndexBlock .owl-carousel .owl-nav .owl-prev { left: -70px; }
    .IndexBlock .owl-carousel .owl-nav .owl-next { right: -70px; }
    #KeyVisual { padding: 30px 40px; margin-bottom: 20px; }
}
@media screen and (max-width: 1023px) {
	.owl-carousel .owl-nav > div { margin-top:-17px; width:34px; height:34px; }
    .owl-carousel .owl-nav > div::after { width: 8px; height: 8px; margin-top: -5px; }
    .IndexBlock .owl-carousel .owl-nav .owl-prev { left: -50px; }
    .IndexBlock .owl-carousel .owl-nav .owl-next { right: -50px; }
    .owl-carousel .owl-dots .owl-dot { margin: 0 5px; }
}
@media screen and (max-width: 639px) {
    .index_carousel { max-width: 320px; }
    .index_carousel .owl-nav { position: relative; padding-top: 10px; }
    .IndexBlock .owl-carousel .owl-nav > div { top: auto; }
    .IndexBlock .owl-carousel .owl-nav .owl-prev { right: auto; left: calc(50% - 45px); }
    .IndexBlock .owl-carousel .owl-nav .owl-next { right: calc(50% - 45px); }
    #KeyVisual { padding: 20px 15px 30px; }
}
@media screen and (min-width: 640px) and (max-width: 1023px) {
    #KeyVisual { padding: 30px 5%; }
}