@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;500;700&display=swap');

* {
    font-family: 'Noto Sans TC', 'Microsoft JhengHei', sans-serif;
}


body {
    background-color: #f5f5f5;
    /*overflow-x: hidden;*/
    height: 100%;
    margin: 0;
}

html {
    overflow-x: clip;
    scroll-behavior: smooth;
    font-size: 1rem;
    height: 100%;
    margin: 0;
}

/* 不??縮????，可??.no-scale */
.no-scale {
    font-size: 1rem !important;
}

a {
    color: black;
    text-decoration: none;
}

    a:hover {
        color: #DDDDDD;
        text-decoration: none;
    }

    a:active {
        color: #DDDDDD;
        text-decoration: none;
    }

hr {
    color: #868686;
}

.text-C {
    text-align: center;
}

.ellipsis {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.multiline-ellipsis {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.tripleline-ellipsis {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.bg-darkblue {
    background-color: #223C5D;
}

.btn-link-white {
    --bs-btn-font-weight: 400;
    --bs-btn-color: #FFF;
    --bs-btn-bg: transparent;
    --bs-btn-border-color: transparent;
    --bs-btn-hover-color: #DDD;
    --bs-btn-hover-border-color: transparent;
    --bs-btn-active-color: #DDD;
    --bs-btn-active-border-color: transparent;
    --bs-btn-disabled-color: #6c757d;
    --bs-btn-disabled-border-color: transparent;
    --bs-btn-box-shadow: 0 0 0 #000;
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    text-decoration: none;
}

.btn-link {
    --bs-btn-font-weight: 400;
    --bs-btn-color: #727272;
    --bs-btn-bg: transparent;
    --bs-btn-border-color: transparent;
    --bs-btn-hover-color: #223C5D;
    --bs-btn-hover-border-color: transparent;
    --bs-btn-active-color: #223C5D;
    --bs-btn-active-border-color: transparent;
    --bs-btn-disabled-color: #6c757d;
    --bs-btn-disabled-border-color: transparent;
    --bs-btn-box-shadow: none;
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    text-decoration: none;
    padding: 10px 10px
}

    .btn-link.active {
        font-weight: bold;
        background-color: #223C5D;
        color: white;
        border-radius: 2rem;
    }

    .btn-link:hover {
        background-color: #223C5D;
        color: white;
        border-radius: 2rem;
    }

/*=======HEADER=======*/
.topbar {
    background: #0C2545CC;
    color: #FFF;
}

.navbar-brand span {
    color: #FFF;
}

.nav-pill {
    background: #0C2545CC;
    padding-bottom: 0;
    padding-top: 0;
}

.eng-btn {
    width: 95px;
    text-align: center;
    background: #001A40;
    color: #FFF;
    padding: 0.5rem 0.5rem;
}

.font-btn {
    width: 95px;
    background: #0C2545CC;
    color: #FFF;
    padding: 0.5rem 0.5rem;
    border: 0;
}

.nav-link {
    font-weight: 600;
    color: #FFF;
}

    .nav-link:hover {
        background-color: #FFF;
        color: #0C2545;
    }


.navbar {
    position: relative;
    z-index: 999;
}

.navbar-toggler-icon {
    background-image: unset;
}

.navbar-toggler {
    color: #FFF;
    border: var(--bs-border-width) solid #FFF;
}

.logo-box {
    position: absolute;
    top: 8px;
    left: 250px;
    z-index: 1000;
}

.taipei-logo {
    height: 60px;
}

.logo-title-tw {
    color: white;
    font-size: 1.8rem;
    margin: 0 !important;
    padding: 0 !important;
}

.logo-title-en {
    color: white;
    font-size: 0.8rem;
    margin: 0 !important;
    padding: 0 !important
}

@media (max-width: 1536px) {
    .logo-box {
        position: absolute;
        top: 8px;
        left: 30px;
        z-index: 1000;
    }

    .taipei-logo {
        height: 60px;
    }
}

@media (max-width: 1024px) {
    .taipei-logo {
        height: 45px;
    }

    .navbar .container {
        padding-top: .5rem;
        padding-bottom: .5rem;
    }

    .logo-box {
        top: 10px;
        left: 54px;
    }

    .topbar {
        background: #0C2545CC;
        color: #363636;
    }

    .nav-pill {
        background: #0C2545CC;
        padding-bottom: 5px;
        padding-top: 5px;
    }

    .navbar-brand span {
        color: #000;
    }
}

@media (max-width: 992px) {
    .logo-box {
        top: 5px;
        left: 54px;
    }

    .taipei-logo {
        height: 40px;
    }

    .nav-pill {
        background: #0C2545CC;
        padding-bottom: 10px;
        padding-top: 14px;
    }

    .logo-title-tw {
        color: white;
        font-size: 1.5rem;
        margin: 0 !important;
        padding: 0 !important;
    }

    .logo-title-en {
        color: white;
        font-size: 0.7rem;
        margin: 0 !important;
        padding: 0 !important
    }
}

/*megamenu*/
/* ?dropdown 不被容器裁??維?滿?*/
header .navbar {
    overflow: visible;
}

/* B ???層?static，面?寬?= 100%，內容???.container 對? */
.mega-dropdown {
    position: static;
}

.mega-menu {
    margin-top: 0;
    border-radius: 0;
    background: #f7f7f7;
    /* ?用??，?後可????/?罩 */
    z-index: 1080;
    /* ??下方?容 */
}

/* ?側????? */
.mega-link {
    display: inline-block;
    padding: .25rem 0;
    color: #4A4A4A;
    text-decoration: none;
    font-weight: normal;
}

    .mega-link:hover,
    .mega-link:focus {
        color: #223C5D;
        text-decoration: underline;
    }

/* 左側 tab ?? */
#megaTab .nav-link {
    background: transparent;
    color: #4C4C4C;
    border-radius: .5rem;
    padding: .5rem .75rem;
    font-weight: 600;
    text-align: right;
}

    #megaTab .nav-link.active {
        color: #223C5D;
    }

/* ??：tab ?水平??、內容???*/
@media (max-width: 991.98px) {
    #megaTab {
        overflow-x: auto;
        white-space: nowrap;
    }

        #megaTab .nav-link {
            flex: 0 0 auto;
        }
}

.navbar-nav .nav-link.active,
.navbar-nav .show > .nav-link {
    color: rgb(179 179 179 / 90%);
}

/*=======BANNER=======*/

/* === banner ??=== */
.banner-wrap {
    position: relative;
    overflow: hidden;
}

.banner-bg {
    background: #3F8EC9;
    height: 560px;
}

.banner-content {
    margin-top: -540px;
}

@media(max-width:1536px) {
    .banner-bg {
        background: #3F8EC9;
        height: 500px;
    }

    .banner-content {
        margin-top: -480px;
    }
}


@media(max-width:1280px) {
    .banner-bg {
        height: 620px;
    }

    .banner-content {
        margin-top: -600px;
    }
}


@media(max-width:768px) {
    .banner-bg {
        height: 620px;
    }

    .banner-content {
        margin-top: -620px;
    }
}

.banner-card {
    background: rgba(255, 255, 255, .7);
    backdrop-filter: blur(2px);
    border: 0;
}

.degree {
    font-size: clamp(40px, 6vw, 64px);
    line-height: 1;
    font-weight: 700;
    position: relative;
}

.degreesymbol {
    position: absolute;
    top: 0;
    right: -50px;
    font-size: 1rem;
}

/* 跑馬??*/
.ticker {
    position: relative;
    overflow: hidden;
    white-space: nowrap;
    background: #001A40CC;
    border-radius: 50px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .06);
}

.ticker__track {
    display: inline-block;
    padding-block: .5rem;
    animation: marquee 16s linear infinite;
}

.ticker:hover .ticker__track {
    animation-play-state: paused;
}

@keyframes marquee {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

/* 天氣資???*/
.ph-icon {
    margin: auto;
    text-align: center;
}

.ph-graph {
    flex-wrap: nowrap;
    overflow-x: auto;
}

    .ph-graph .weekday {
        font-size: 1.1rem;
        font-weight: bold;
    }

    .ph-graph .weather-icon {
        margin-top: 8px;
        margin-bottom: 8px;
    }

    .ph-graph .day-degree {
        font-size: 1.1rem;
        font-weight: bold;
    }

        .ph-graph .day-degree span:first-child {
            margin-right: 6px;
        }

.chart-container {
    position: relative;
    margin: auto;
    height: 150px;
    width: 100%;
}

/* ?????橫?滑? */
.pillbar-scroll {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: none;
    scrollbar-width: none;
    width: 70%;
    margin: auto;
}

    .pillbar-scroll::-webkit-scrollbar {
        display: none;
    }

    .pillbar-scroll > .d-inline-flex {
        flex-wrap: nowrap;
    }

    .pillbar-scroll .btn {
        flex: 0 0 auto;
        white-space: nowrap;
        font-size: 1.2rem;
        font-weight: 800;
    }

/* ?示?*/
.indicator-dots {
    position: relative;
    height: 16px;
    margin-top: .5rem;
}

.dots-track {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

    .dots-track .dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #001A4070;
        transition: background .25s;
        cursor: pointer;
    }

        .dots-track .dot.active {
            background: #001A40;
        }

.dots-thumb {
    position: absolute;
    top: 50%;
    left: 0;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(13, 110, 253, .25);
    transform: translate(-50%, -50%);
    pointer-events: none;
    transition: left .25s ease;
}

/* 三大?塊色?*/
.zone-a {
    background: #363B69;
}

.zone-b {
    background: #1C597D;
}

.zone-c {
    background: #2C6544;
}

.zone-card {
    min-height: 260px;
    color: #fff;
    padding: 0rem 0rem;
}

    .zone-card .title {
        font-size: 1.6rem;
        font-weight: bold;
        text-align: center;
        padding: 0.5rem 0;
    }

.zone-a .zone-card .title {
    background: #33395D;
}

.zone-b .zone-card .title {
    background: #224B5D;
}

.zone-c .zone-card .title {
    background: #225D29;
}

.zone-card .content .btn-outline-light:hover img {
    display: none;
    transition: all 0.3s ease-in-out;
}

/* ?板淡入 */
.fade-swap {
    opacity: 0;
    transition: opacity .25s ease;
}

    .fade-swap.show {
        opacity: 1;
    }

/*??*/
.light-dot {
    border-radius: 100%;
    background-color: #FFF;
    display: inline-block;
    width: 7px;
    height: 7px;
    margin-left: 2px;
}

    .light-dot.orange {
        background-color: #FF8800;
    }

    .light-dot.yellow {
        background-color: #FFFF00;
    }


/*=======CIRCLE BUTTON=======*/
.circle-btn-box {
    position: relative;
    padding: 3rem 2rem;
}

.circle-btn {
    --size: 96px;
    --bg: #f6f7f8;
    --ring: 2px solid #eee;
    display: inline-flex;
    width: 100%;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    text-decoration: none;
    color: inherit;
    outline: none;
}

    .circle-btn::before {
        content: "";
        width: var(--size);
        height: var(--size);
        border-radius: 50%;
        background: var(--icon) center/80% no-repeat;
        display: block;
        transition: background-image .2s ease, transform .15s ease, box-shadow .15s ease;
    }

    .circle-btn:hover::before {
        background-image: var(--icon-hover);
        transform: translateY(-2px);
    }

    .circle-btn:focus-visible::before {
        box-shadow: 0 0 0 3px rgba(13, 110, 253, .35);
    }

    .circle-btn > span {
        display: block;
        text-align: center;
        line-height: 1.25;
        font-size: .95rem;
        color: #636363;
    }

    .circle-btn:hover > span {
        font-weight: bold;
    }

@media (prefers-reduced-motion: reduce) {
    .circle-btn::before {
        transition: none;
    }
}

/*=======首?標?=======*/

.section-title {
    font-weight: 700;
    letter-spacing: .08em;
    position: relative;
    font-size: 2rem;
    text-align: center;
}

.section-description {
    color: #6B6B6B;
    font-size: 0.85rem;
}

/*----- ?????+ ????-----*/
.news-section {
    padding: 2rem 3rem;
}

@media (max-width: 576px) {
    .news-section {
        padding: 2rem 1rem;
    }
}


#bookCarousel .carousel-item a {
    display: flex;
    justify-content: center;
    align-items: center;
}

    #bookCarousel .carousel-item a img {
        object-fit: cover;
        border-radius: 0;
        width: 300px;
        height: 400px;
        object-position: center;
    }

#bookCarousel .carousel-control-next {
    top: unset;
    right: 45px;
    bottom: 0;
}

#bookCarousel .carousel-control-prev {
    top: unset;
    left: 276px;
    bottom: 0;
}

@media (max-width:1536px) {
    #bookCarousel .carousel-control-next {
        right: 0px;
    }

    #bookCarousel .carousel-control-prev {
        left: 240px;
    }
}

@media (max-width:1440px) {
    #bookCarousel .carousel-control-next {
        right: 0px;
    }

    #bookCarousel .carousel-control-prev {
        left: 220px;
    }
}

@media (max-width:1367px) {
    #bookCarousel .carousel-control-next {
        right: 0px;
    }

    #bookCarousel .carousel-control-prev {
        left: 208px;
    }
}

@media (max-width:1280px) {
    #bookCarousel .carousel-control-next {
        right: 0px;
    }

    #bookCarousel .carousel-control-prev {
        left: 194px;
    }
}

@media (max-width:1024px) {
    #bookCarousel .carousel-control-next {
        right: 0%;
        top: 0%;
    }

    #bookCarousel .carousel-control-prev {
        left: 0%;
        top: 0%;
    }
}

@media (max-width:768px) {
    #bookCarousel .carousel-control-next {
        right: 0%;
        top: 0%;
    }

    #bookCarousel .carousel-control-prev {
        left: 0%;
        top: 0%;
    }
}

@media (max-width:576px) {
    #bookCarousel .carousel-control-next {
        right: 0%;
        top: 0%;
    }

    #bookCarousel .carousel-control-prev {
        left: 0%;
        top: 0%;
    }
}

.news-section .nav-link {
    color: #1F1F1F;
    font-size: 1.2rem;
    font-weight: normal;
    letter-spacing: 2px;
    text-align: start;
    padding-left: 0;
    padding-right: 0;
}

    .news-section .nav-link.active {
        color: #223C5D;
        background-color: unset;
        font-weight: bold;
    }

        .news-section .nav-link.active::after {
            content: "\f178";
            font-family: "Font Awesome 6 Free";
            font-weight: 900;
            margin-left: 5px;
            color: #223C5D;
            background-color: unset;
            font-weight: bold;
        }

.news-list a {
    color: #000000;
}

    .news-list a:hover .news-item {
        background-color: #edeff2;
    }

.news-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    border-bottom: 1px solid #E3E3E3;
    padding: 10px 2rem;
}

    .news-item .tag {
        background-color: #2E9789;
        border-radius: 40px;
        color: #FFF;
        padding: 4px 12px;
        font-size: 0.9rem;
        white-space: nowrap;
        width: fit-content;
        height: fit-content;
    }

    .news-item .content {
        min-width: 0;
    }


        .news-item .content .title {
            font-weight: bold;
            color: #000;
            font-size: 1.05rem;
        }

        .news-item .content .description {
            color: #777777;
        }

/*------ ????? ------*/
:root {
    --shadow: 0 10px 24px rgba(0, 0, 0, .10);
    --shadow-hover: 0 14px 32px rgba(0, 0, 0, .18);
    /* 將這裡??你??景?路?*/
    --hero-bg: url('../img/flood-workers.png');
    --overlay: rgba(17, 24, 39, .48);
}

.panel {
    min-height: 560px;
}

/* 保?高度，???flex 等??? */
/* ?側：??? + ?罩??::before/::after ?層 */
.hero {
    position: relative;
    display: flex;
    color: #fff;
    isolation: isolate;
}

    .hero::before,
    .hero::after {
        content: "";
        position: absolute;
        inset: 0;
        z-index: 0;
    }

    .hero::before {
        background: var(--hero-bg) center/cover no-repeat;
    }

    .hero::after {
        background: linear-gradient(0deg, rgba(0, 0, 0, .55), rgba(0, 0, 0, .35));
    }

    .hero > .hero-body {
        position: relative;
        z-index: 1;
        padding: clamp(1.5rem, 2.5vw, 3rem);
        width: 100%;
    }

.circle-btn-prevent {
    --size: 96px;
    display: inline-flex;
    width: 180px;
    height: 180px;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    text-decoration: none;
    color: inherit;
    outline: none;
}

    .circle-btn-prevent::before {
        content: "";
        width: var(--size);
        height: var(--size);
        border-radius: 50%;
        background: var(--icon) center/100% no-repeat;
        display: block;
        transition: background-image .2s ease, transform .15s ease, box-shadow .15s ease;
    }

    .circle-btn-prevent:hover {
        border: 3px solid #FFF;
        border-radius: 8px;
    }

    .circle-btn-prevent > span {
        display: block;
        text-align: center;
        font-size: 1.3rem;
        color: #FFF;
        margin: auto;
    }

    .circle-btn-prevent:hover > span {
        font-weight: bold;
    }


.data-section {
    padding: 1rem 0rem;
}

@media (max-width: 576px) {
    .data-section {
        padding: 2rem 1rem;
    }
}

/* 左? */
.nav-rect {
    width: 100%;
    border-radius: 0;
    min-height: 0;
    background: #FFF;
    color: #1F1F1F;
    border: 1px solid #FFF;
    text-align: left;
    transition: .15s ease;
    display: flex;
    align-items: center;
    font-size: 1.4rem;
    border-bottom: 1px dashed silver;
}

    .nav-rect:hover {
        background: #001A40CC;
        color: #fff;
    }

    .nav-rect.active {
        background: #001A40;
        color: #fff;
        border-color: #001A40;
    }

/* ?? */
.gis-content {
    background: #f5f7fa;
    height: 100%;
    border-radius: 0;
    text-align: center;
}

/*----- ????? ------*/

.link-section {
    padding: 2rem 1rem;
    background: linear-gradient(45deg, rgba(255,255,255,1) 0%,rgba(243,243,243,1) 50%,rgba(237,237,237,1) 51%,rgba(255,255,255,1) 100%);
}

.wave {
    background: #6a82fb;
    width: 500px;
    height: 500px;
    border-radius: 40%;
    opacity: 0.4;
    position: absolute;
    top: 0%;
    left: 50%;
    margin-left: -250px;
    margin-top: -250px;
    transform-origin: center;
    animation: drift 7s infinite linear;
}

@keyframes drift {
    0 {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.wave.two {
    animation: drift 9s infinite linear;
}

.wave.three {
    animation: drift 11s infinite linear;
    opacity: 0.1;
}

@media (max-width: 576px) {
    .link-section {
        padding: 2rem 1rem;
    }
}

.link-section .item {
    background-color: #FFF;
    padding: 15px;
    height: 100px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
}

.link-section .item-b {
    background-color: transparent;
    padding: 5px;
    height: 150px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
}

    /* ?a ?滿??，並?用 transform ???畫（???*/
    .link-section .item a,
    .link-section .item-b a {
        display: flex;
        inline-size: 100%;
        block-size: 100%;
        justify-content: center;
        align-items: center;
        transition: transform 260ms cubic-bezier(.2, .7, .2, 1);
        will-change: transform;
        transform: translateZ(0);
    }

    /* ??保?比?不??*/
    .link-section .item img,
    .link-section .item-b img {
        height: 100%;
        width: auto !important;
        object-fit: contain;
    }

/* hover / focus ?大（含?盤???/
.link-section .item:hover a,
.link-section .item a:focus-visible,
.link-section .item-b:hover a,
.link-section .item-b a:focus-visible {
    transform: scale(1.06);
}

/* 行?裝置點??微縮放，??更好??選?/
.link-section .item a:active,
.link-section .item-b a:active {
    transform: scale(1.03);
}

/* 使用??好?少???，自????*/
@media (prefers-reduced-motion: reduce) {

    .link-section .item a,
    .link-section .item-b a {
        transition: none;
    }
}

/*----- FOOTER -----*/
.footer-above {
    background: #223C5D;
    padding-top: 50px;
    padding-bottom: 30px;
    color: #FFF;
}

.footer-below {
    background-color: #162942;
    color: #FFF;
    font-size: 0.83rem;
}

    .footer-below a {
        font-size: 0.83rem;
    }

.footer-link-title {
    font-size: 1.2rem;
    margin-bottom: 10px;
    font-weight: bold;
}

    .footer-link-title a {
        color: #FFF;
    }

        .footer-link-title a:hover {
            color: #FFF;
            text-decoration: underline;
        }

.footer-link-item {
    font-size: 0.9rem;
    margin-bottom: 5px;
}

    .footer-link-item a {
        color: #FFF;
    }

        .footer-link-item a:hover {
            color: #FFF;
            text-decoration: underline;
        }

/*------------------------------*/
/*------------ ?? ------------*/
/*-----------------------------*/

/* Banner ?景?遮?*/
.inner-banner-docms {
    position: relative;
    background: url('../img/docms/bg.png') center/cover no-repeat;
    height: 40vh;
}

    .inner-banner-docms::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner {
    position: relative;
    background: url('../img/disaster/01.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner2 {
    position: relative;
    background: url('../img/disaster/02.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner2::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner3 {
    position: relative;
    background: url('../img/disaster/03.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner3::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner4 {
    position: relative;
    background: url('../img/disaster/04.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner4::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner5 {
    position: relative;
    background: url('../img/disaster/05.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner5::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner6 {
    position: relative;
    background: url('../img/disaster/06.png?v2') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner6::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner7 {
    position: relative;
    background: url('../img/disaster/07.jpg?v1') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner7::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner8 {
    position: relative;
    background: url('../img/disaster/08.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner8::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner9 {
    position: relative;
    background: url('../img/disaster/09.png') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner9::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner10 {
    position: relative;
    background: url('../img/disaster/10.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner10::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.inner-banner11 {
    position: relative;
    background: url('../img/disaster/11.jpg') center/cover no-repeat;
    height: 50vh;
}

    .inner-banner11::before {
        content: "";
        position: absolute;
        inset: 0;
        background: rgba(0, 0, 0, 0.5);
    }

.banner-text {
    position: relative;
    z-index: 1;
    width: 100%;
    margin: 0 3rem;
}

    .banner-text .title {
        font-size: 3rem;
        color: #FFF;
        font-weight: bold;
        letter-spacing: 10px;
        margin-bottom: 10px;
    }

    .banner-text .description {
        font-size: 1.2rem;
        color: #FFF;
        letter-spacing: 2px;
        overflow-y: auto;
        height: 90px;
    }

/* ??????*/
.inner-pagelink {
    position: absolute;
    bottom: -4.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    width:95%;
}

.inner-section {
    padding-top: 5rem;
    padding-bottom: 2rem;
}

/*======= 01 ?? =======*/
.currentSituation {
    position: relative;
}

    .currentSituation .title {
        font-size: 3rem;
        color: #FFF;
        position: relative;
        font-weight: bold;
        letter-spacing: 5px;
    }

        .currentSituation .title .num {
            opacity: .3;
            letter-spacing: 3px;
            font-size: 4.5rem;
            position: absolute;
            left: -12%;
            top: -65%;
        }

    .currentSituation .description {
        font-size: 1.2rem;
        color: #FFF;
        overflow-y: auto;
    }

.inner-section.-one {
    position: relative;
}

    /* 底層?????深?色塊??偽??製?*/
    .inner-section.-one::before {
        content: "";
        position: absolute;
        left: 0px;
        top: 12%;
        width: 30%;
        height: 220px;
        background: #133a63;
        border-radius: 0rem;
        z-index: -1;
    }

/* 左側????（浮??塊??? */
.info-card {
    position: relative;
    z-index: 2;
    color: #fff;
    padding: 2rem 2rem 3rem 6rem;
}

.panel-description {
    color: black;
    border-radius: 8px;
    z-index: 9999;
    font-weight: bold;
    padding: 2rem;
    box-shadow: 5px 5px 5px silver;
    background: #f6f8f9;
    height:250px;
}



.panel-info {
    margin: 1rem;
    color: black;
    border-radius: 8px;
    background: white;
    z-index: 9999;
    padding: 1rem;
    height: 350px;
    box-shadow: 10px 5px 5px silver;
}

.info-title {
    font-weight: bold;
    font-size: 1.3rem;
    text-align: center;
    margin: 8px;
}

.info-img {
    text-align: center;
    width: 250px;
    margin: 0 auto;
}

.img {
    text-align: center;
    width: 250px;
    height: 180px;
    margin: 0 auto;
    border-radius: 8px;
}

.info-desc {
    text-align: left;
    font-size: 1.1rem;
    font-weight: 300;
}

.info-source {
    font-size: 0.9rem;
}

.info-list {
    background: white;
    border-radius: 8px;
    background: white;
    padding: 1rem;
}

    .info-list li {
        font-size: 1.1rem;
        padding: 1rem;
        margin-left: 0.5rem;
        font-weight: 500;
        border-bottom: 1px solid #F5F5F5;
    }

.ul-01 li {
    font-size: 1.1rem;
    margin-left: 0.5rem;
    font-weight: 600;
    padding: 8px;
    border-bottom: 1px solid white;
    list-style-type: square;
    color: #223C5D;
}

.map-title {
    font-weight: bold;
    font-size: 20px;
    padding: 8px;
    color: darkblue;
}

.project-lower-contents-popup {
    position: absolute;
    inset: 0;
    height: 100%;
    width: 100%;
}

.project-lower-contents-popup-button {
    position: absolute;
    z-index: 102;
    border-radius: 9999px;
    height: 2.5rem;
    width: 2.5rem;
    background: none;
    border: 0px;
    background-image: url(../../assets/img/disaster/project-pin.svg);
    background-size: contain;
    background-repeat: no-repeat;
}

.project-lower-contents-popup-modal__item {
    box-shadow: 0 4px 32px 0 rgba(0, 0, 0, .08), inset 4px 4px 4px 0 hsla(0, 0%, 100%, .25);
}

.project-lower-contents-popup-modal__item {
    position: absolute;
    top: 0;
    left: 0;
    border-radius: .75rem;
    padding: 1.25rem;
    width: 20%;
    background-color: rgb(255 255 255 / .9);
    --tw-backdrop-blur: blur(4px);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    z-index: -10;
    opacity: 0;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-duration: .5s;
}

@keyframes bounce {
    0%,to {
        transform: translateY(-50%);
        animation-timing-function: cubic-bezier(.8,0,1,1)
    }

    50% {
        transform: none;
        animation-timing-function: cubic-bezier(0,0,.2,1)
    }
}

.project-lower-contents-popup-button {
    animation: bounce 3s infinite;
}

/*xI*/
    .project-lower-contents-popup-button.--01-1 {
        top: 50%;
        left: 59%
    }

    .project-lower-contents-popup-button.--01-2 {
        top: 45%;
        left: 25%
    }

    .project-lower-contents-popup-button.--01-3 {
        top: 80%;
        left: 17%
    }


    .project-lower-contents-popup-button.--01-4 {
        top: 45%;
        left: 85%
    }

    .project-lower-contents-popup-button.--01-5 {
        top: 70%;
        left: 90%
    }

    .project-lower-contents-popup-button.--01-6 {
        top: 55%;
        left: 80%
    }
    /*a_I*/
    .project-lower-contents-popup-button.--02-1 {
        top: 17%;
        left: 33%
    }

    .project-lower-contents-popup-button.--02-2 {
        top: 70%;
        left: 30%
    }

    .project-lower-contents-popup-button.--02-3 {
        top: 5%;
        left: 90%
    }

    .project-lower-contents-popup-button.--02-4 {
        top: 75%;
        left: 10%
    }

    .project-lower-contents-popup-button.--02-5 {
        top: 90%;
        left: 90%
    }

    /*aI*/
    .project-lower-contents-popup-button.--03-1 {
        top: 45%;
        left: 60%
    }

    .project-lower-contents-popup-button.--03-2 {
        top: 5%;
        left: 60%
    }

    .project-lower-contents-popup-button.--03-3 {
        top: 65%;
        left: 25%
    }

    .project-lower-contents-popup-button.--03-4 {
        top: 45%;
        left: 89%
    }

    .project-lower-contents-popup-button.--03-5 {
        top: 85%;
        left: 45%
    }

    .project-lower-contents-popup-button.--03-6 {
        top: 66%;
        left: 89%
    }

    /*ǬVfI*/
    .project-lower-contents-popup-button.--04-1 {
        top: 15%;
        left: 85%
    }

    .project-lower-contents-popup-button.--04-2 {
        top: 70%;
        left: 20%
    }

    .project-lower-contents-popup-button.--04-3 {
        top: 35%;
        left: 10%
    }

    .project-lower-contents-popup-button.--04-4 {
        top: 60%;
        left: 70%
    }
    /*sa`*/
    .project-lower-contents-popup-button.--05-1 {
        top: 18%;
        left: 95%
    }

    .project-lower-contents-popup-button.--05-2 {
        top: 80%;
        left: 35%
    }

    .project-lower-contents-popup-button.--05-3 {
        top: 70%;
        left: 50%
    }

    .project-lower-contents-popup-button.--05-4 {
        top: 75%;
        left: 20%
    }

    .project-lower-contents-popup-button.--05-5 {
        top: 70%;
        left: 90%
    }

    /*a`*/
    .project-lower-contents-popup-button.--06-1 {
        top: 5%;
        left: 70%
    }

    .project-lower-contents-popup-button.--06-2 {
        top: 40%;
        left: 30%
    }

    .project-lower-contents-popup-button.--06-3 {
        top: 55%;
        left: 50%
    }


    .project-lower-contents-popup-button.--06-4 {
        top: 55%;
        left: 10%
    }

    .project-lower-contents-popup-button.--06-5 {
        top: 80%;
        left: 75%
    }

    /*CŨa`*/
    .project-lower-contents-popup-button.--07-1 {
        top: 5%;
        left: 90%
    }

    .project-lower-contents-popup-button.--07-2 {
        top: 20%;
        left: 20%
    }

    .project-lower-contents-popup-button.--07-3 {
        top: 60%;
        left: 80%
    }


    .project-lower-contents-popup-button.--07-4 {
        top: 80%;
        left: 95%
    }

    /*aBa`*/
    .project-lower-contents-popup-button.--08-1 {
        top: 15%;
        left: 15%;
    }

    .project-lower-contents-popup-button.--08-2 {
        top: 50%;
        left: 50%;
    }


    /*qa`*/
    .project-lower-contents-popup-button.--09-1 {
        top: 55%;
        left: 60%
    }

    .project-lower-contents-popup-button.--09-2 {
        top: 10%;
        left: 70%
    }

    .project-lower-contents-popup-button.--09-3 {
        top: 90%;
        left: 80%
    }


    .project-lower-contents-popup-button.--09-4 {
        top: 90%;
        left: 60%
    }

    .project-lower-contents-popup-button.--09-5 {
        top: 65%;
        left: 85%
    }

    /*g۬ya`*/

    .project-lower-contents-popup-button.--10-1 {
        top: 5%;
        left: 80%
    }

    .project-lower-contents-popup-button.--10-2 {
        top: 25%;
        left: 75%
    }

    .project-lower-contents-popup-button.--10-3 {
        top: 15%;
        left: 60%
    }


    .project-lower-contents-popup-button.--10-4 {
        top: 55%;
        left: 65%
    }

    .project-lower-contents-popup-button.--10-5 {
        top: 75%;
        left: 85%
    }

    /*ʴӪa`*/

    .project-lower-contents-popup-button.--11-1 {
        top: 5%;
        left: 70%
    }

    .project-lower-contents-popup-button.--11-2 {
        top: 55%;
        left: 50%
    }

    .project-lower-contents-popup-button.--11-3 {
        top: 90%;
        left: 30%
    }


    .project-lower-contents-popup-button.--11-4 {
        top: 60%;
        left: 85%
    }

    .project-lower-contents-popup-button.--11-5 {
        top: 70%;
        left: 65%
    }

    .project-lower-contents-popup-button.--11-6 {
        top: 80%;
        left: 85%
    }

.situation-card {
    z-index: 999;
    overflow: hidden;
}

#situationCarousel {
    padding-top: 4rem;
    padding-bottom: 4rem;
}

    #situationCarousel .item a {
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
    }

        #situationCarousel .item a img {
            object-fit: cover;
            width: 90%;
            height: auto;
            border-radius: 0;
            object-position: center;
        }

    #situationCarousel .datalist .slick-arrow {
        position: absolute;
        width: 50px;
        height: 50px;
        z-index: 2;
        border: 0;
        text-indent: -9999px;
    }

    #situationCarousel .datalist .slick-prev {
        right: 6%;
        top: -23%;
        background: url(../img/prev-icon.png) no-repeat;
    }

    #situationCarousel .datalist .slick-next {
        right: 2%;
        top: -23%;
        background: url(../img/next-icon.png) no-repeat;
    }

    #situationCarousel .item .text {
        font-size: 1.1rem;
        text-align: center;
        font-weight: bold;
        color: #3C3C3C;
        margin-top: 10px;
    }

@media (max-width: 1536px) {
    #situationCarousel .datalist .slick-prev {
        right: 8%;
        top: -33%;
    }

    #situationCarousel .datalist .slick-next {
        right: 3%;
        top: -33%;
    }
}


@media (max-width: 1024px) {
    #situationCarousel .datalist .slick-prev {
        right: 8%;
        top: -25%;
    }

    #situationCarousel .datalist .slick-next {
        right: 2%;
        top: -25%;
    }

    .inner-section.-one::before {
        left: 0px;
        top: 8%;
        width: 100%;
        height: 330px;
    }

    .info-card {
        padding: 3rem 6rem 0rem 6rem;
    }
}

@media (max-width: 992px) {
    #situationCarousel .datalist .slick-prev {
        right: 52%;
        top: -12%;
    }

    #situationCarousel .datalist .slick-next {
        right: 43%;
        top: -12%;
    }

    .situationCarousel {
        padding: 1.8rem 0rem;
    }

    .inner-section.-one::before {
        top: 5%;
        width: 100%;
        height: 350px;
    }
}


@media (max-width: 576px) {
    #situationCarousel .datalist .slick-prev {
        right: 50%;
        top: -20%;
    }

    #situationCarousel .datalist .slick-next {
        right: 33%;
        top: -20%;
    }

    .info-card {
        padding: 2rem 2rem 2rem 3rem;
    }

    .inner-section.-one::before {
        top: 5%;
        width: 100%;
        height: 390px;
    }
}

/*======= 02 ?性??=======*/
.toughnessCity .title {
    font-size: 3rem;
    color: #323232;
    position: relative;
    font-weight: bold;
    letter-spacing: 5px;
    margin-left: 3.5%;
}

    .toughnessCity .title .num {
        color: #98beea;
        opacity: .3;
        letter-spacing: 3px;
        font-size: 4.5rem;
        position: absolute;
        left: -3%;
        top: -65%;
        z-index: -1;
    }

/*======= PROGRESS BAR =======*/
.dataBox {
    height: auto;
}

.dataItem {
    position: relative;
    padding: 25px;
}

.itemTitle {
    position: absolute;
    color: #373737;
    font-size: 1.3rem;
    border-radius: 10px;
    padding: 6px 24px;
    bottom: 33%;
    left: 26%;
    font-weight: bold;
}

.circle {
    width: 100%;
    display: inline-block;
    position: relative;
    text-align: center;
    line-height: 1.2;
}

    .circle strong {
        position: absolute;
        top: 35%;
        left: 0;
        width: 100%;
        text-align: center;
        line-height: 40px;
        font-size: 3rem;
        color: #535353;
    }

@media (max-width: 1024px) {
    .itemTitle {
        bottom: 33%;
        left: 18%;
    }
}

@media (max-width: 992px) {
    .itemTitle {
        bottom: 33%;
        left: 22%;
    }
}

@media (max-width: 576px) {
    .itemTitle {
        bottom: 33%;
        left: 26%;
    }
}

/*======= 03 ??準? =======*/
.inner-section.-four {
    position: relative;
}

    .inner-section.-four::before {
        content: "";
        position: absolute;
        left: 0px;
        top: 0%;
        width: calc(100%/3);
        height: 100%;
        background: #133a63;
        border-top-right-radius: 14px;
        border-bottom-right-radius: 14px;
        z-index: -1;
    }

.crisisPreparation .title {
    font-size: 4rem;
    color: #FFF;
    position: relative;
    font-weight: bold;
    letter-spacing: 5px;
    text-align: center;
}

    .crisisPreparation .title .num {
        opacity: .3;
        letter-spacing: 3px;
        font-size: 4.5rem;
        position: absolute;
        left: 18%;
        top: -18%;
    }

.crisisPreparation .info-card {
    position: relative;
    z-index: 2;
    color: #fff;
    padding: 3rem 2rem 3rem 2rem;
}

/* ?? */
.prep-card {
    border: 0;
    overflow: hidden;
    border-radius: 14px;
    background: #f8f9fa;
    height: 100%;
    position: relative;
    box-shadow: 0 6px 22px rgba(0, 0, 0, .06);
}

.prep-media {
    position: relative;
    overflow: hidden;
}

    .prep-media .ph {
        border-top-left-radius: 14px;
        border-top-right-radius: 14px;
        transform: scale(1);
        transition: transform .5s cubic-bezier(.22, .61, .36, 1);
    }

        .prep-media .ph img {
            object-fit: cover;
            height: auto;
            width: 100%;
        }

.prep-overlay {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 8px 8px;
    color: #fff;
    background: rgba(0, 0, 0, .55);
    backdrop-filter: saturate(120%);
    transition: background-color .3s ease;
    height: 140px;
}

.prep-card:hover .prep-overlay {
    background: rgba(0, 0, 0, .72);
}

.prep-card:hover .ph {
    transform: scale(1.04);
}

.prep-title {
    font-weight: 800;
    font-size: 1.2rem;
    margin: 0 0 4px 0;
    text-shadow: 0 1px 2px rgba(0, 0, 0, .35);
}

.prep-desc {
    font-size: 1rem;
    opacity: .95;
    margin: 0;
}

.decor-bg-right {
    background: #BDDCF3;
    border-top-left-radius: 14px;
    border-bottom-left-radius: 14px;
    min-height: 460px;
}

.decor-bg-left {
    background: #B6E6B4;
    border-top-right-radius: 14px;
    border-bottom-right-radius: 14px;
    min-height: 460px;
}

/* ??比?：常?4:3；可依?塊??? */
.ratio-4x3 {
    aspect-ratio: 4 / 3;
}

@media (max-width: 1440px) {
    .decor-bg-right {
        min-height: 385px;
    }

    .decor-bg-left {
        min-height: 385px;
    }
}

@media (max-width: 1024px) {
    .inner-section.-four::before {
        left: 0px;
        top: 0%;
        width: 100%;
        height: 40%;
        border-radius: 0;
    }

    .crisisPreparation .info-card {
        padding: 0rem 0rem 0rem 0rem;
    }

    .crisisPreparation .title .num {
        left: 37%;
        top: -18%;
    }
}

@media (max-width: 576px) {
    .crisisPreparation .title .num {
        left: 18%;
        top: -18%;
    }
}
/* ?????+?廣平台 */
.two-clouds {
    position: absolute;
    right: 0;
    top: -150px;
}

.social-media {
    display: flex;
    flex-wrap: wrap;
}

.social-btn {
    width: 98px;
    height: 98px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: white;
    text-decoration: none;
    margin: 0 10px;
}

    .social-btn.-facebook {
        background-color: #3b5998;
    }

    .social-btn.-youtube {
        background-color: #ff0000;
    }

    .social-btn.-line {
        background-color: #25d366;
    }

    .social-btn.-instagram {
        background-color: #8b4513;
    }

    .social-btn.-linkedin {
        background-color: #0077b5;
    }

.social-media a:hover {
    box-shadow: rgba(50, 50, 93, 0.45) 0px 30px 60px -12px inset, rgba(0, 0, 0, 0.7) 0px 18px 36px -18px inset;
}

#linkCarousel {
    position: relative;
    margin-top: 25px;
}

    #linkCarousel .datalist .item a .f1 {
        display: block;
        position: relative;
        width: 100%;
        height: 400px;
        overflow: hidden;
        border-radius: 23px 23px 90px 23px;
        margin: 0 auto;
    }

        #linkCarousel .datalist .item a .f1 .f1p1 img {
            display: block;
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

    #linkCarousel .datalist .slick-arrow {
        position: absolute;
        width: 60px;
        height: 60px;
        border-radius: 50%;
        z-index: 2;
        text-indent: -9999px;
        border: 0;
        box-shadow: 5px 5px 15px rgba(0, 0, 0, .2)
    }

    #linkCarousel .datalist .slick-prev {
        right: -30px;
        bottom: 50px;
        background: url(../../Images/left-arrow.png) no-repeat;
    }

    #linkCarousel .datalist .slick-next {
        right: 25px;
        bottom: 0px;
        background: url(../../Images/right-arrow.png) no-repeat;
    }

    #linkCarousel .menu {
        position: absolute;
        top: -80px;
        left: 220px;
        z-index: 2;
    }

        #linkCarousel .menu .mControl {
            display: flex;
        }

        #linkCarousel .menu .m {
            width: 35px;
            height: 35px;
            border-radius: 50%;
            border: 0
        }

            #linkCarousel .menu .m.stop {
                background: url(../img/icon/pause.png) no-repeat;
                background-position: center;
            }

            #linkCarousel .menu .m.play {
                background: url(../img/icon/play.png) no-repeat;
                background-position: center;
                display: none
            }

        #linkCarousel .menu .mNum {
            display: inline-block;
            color: #010101;
            letter-spacing: -.075em;
            font-weight: 400;
            line-height: 35px
        }

            #linkCarousel .menu .mNum:after {
                content: "";
                display: inline-block;
                vertical-align: middle;
                width: 55px;
                height: 1px;
                background: #b7b7b7;
                margin: -4px 5px 0 8px
            }

            #linkCarousel .menu .mNum .on {
                font-weight: 600;
            }

                #linkCarousel .menu .mNum .on:after {
                    content: "/";
                    display: inline-block;
                    vertical-align: middle;
                    font-size: 0.9rem;
                    margin: -2px 5px 0
                }

@media screen and (max-width:1519px) {
    #linkCarousel .menu {
        top: -60px;
        right: 10px;
    }

    #linkCarousel .datalist .slick-arrow {
        width: 54px;
        height: 54px;
    }

    #linkCarousel .datalist .slick-prev {
        right: -20px;
        bottom: 55px;
        background-position: center;
    }

    #linkCarousel .datalist .slick-next {
        right: 12px;
        bottom: 0px;
        background-position: center;
    }

    #linkCarousel .datalist .item a .f1 {
        width: 540px;
        height: 330px;
    }
}

@media screen and (max-width:1379px) {
    #linkCarousel .menu {
        top: -60px;
        left: 215px;
    }

    #linkCarousel .datalist .slick-prev {
        right: -20px;
        bottom: 60px;
    }

    #linkCarousel .datalist .slick-next {
        right: 20px;
        bottom: 5px;
    }

    #linkCarousel .datalist .item a .f1 {
        width: 500px;
        height: 330px;
    }
}

@media screen and (max-width:1259px) {
    #linkCarousel {
        width: auto;
        margin-left: 40px;
    }


        #linkCarousel .datalist .item a {
            position: static;
        }

        #linkCarousel .menu {
            left: 450px
        }

        #linkCarousel .datalist .item a .f1 {
            width: 100%;
            height: auto;
        }
}

@media screen and (max-width:1099px) {

    #linkCarousel {
        margin-left: 0;
        text-align: left;
    }

        #linkCarousel .datalist .slick-list {
            padding-bottom: 40px;
        }

        #linkCarousel .datalist .slick-prev {
            right: -20px;
            bottom: 75px;
            background-position: center;
        }

        #linkCarousel .datalist .slick-next {
            right: 22px;
            bottom: 22px;
            background-position: center;
        }

        #linkCarousel .datalist .item a .f1 {
            width: 100%;
            height: 300px;
        }

        #linkCarousel .menu {
            left: 200px;
        }
}

@media screen and (max-width:768px) {
    #linkCarousel .datalist .item a {
        width: 350px;
        height: 350px;
    }

    #linkCarousel .menu {
        left: 380px;
    }

    #linkCarousel .datalist .slick-prev {
        right: 0;
        bottom: 80px;
    }

    #linkCarousel .datalist .slick-next {
        right: 32px;
        bottom: 25px;
    }

    #linkCarousel .datalist .item a .f1 {
        width: 90%;
        height: 350px;
    }

    .two-clouds {
        position: absolute;
        right: -80px;
        top: -65px;
    }
}

@media screen and (max-width:699px) {
    #linkCarousel {
        margin-top: 25px;
    }

        #linkCarousel .datalist {
            overflow: visible;
        }

            #linkCarousel .datalist .slick-list {
                padding: 0
            }

            #linkCarousel .datalist .item a {
                max-width: 500px;
                width: 100%;
                height: auto;
                margin: auto;
            }

            #linkCarousel .datalist .slick-arrow {
                width: 36px;
                height: 36px;
            }

            #linkCarousel .datalist .slick-prev {
                right: calc(50% + 20px);
                bottom: auto;
                top: -15px;
            }

            #linkCarousel .datalist .slick-next {
                right: calc(50% - 20px);
                bottom: auto;
                top: -15px;
            }

        #linkCarousel .menu {
            top: -15px;
            left: calc(50% + 25px);
        }

            #linkCarousel .menu .mNum {
                display: none
            }

        #linkCarousel .datalist .item a .f1 {
            width: 100%;
            height: auto;
        }
}

@media screen and (max-width:576px) {
    .social-btn {
        width: 50px;
        height: 50px;
    }
}


.pancel-alert-title {
    background-color: #336666;
    font-weight: bold;
    color: white;
    font-size: 1.2rem;
    padding: 8px;
    margin-left: 10px;
    margin-right: 10px;
    border-radius: 8px 8px 0px 0px;
}

.pancel-alert-content {
    border: 1px solid #cccccc;
    padding: 8px;
    background: white;
    min-height: 250px;
    margin-left: 10px;
    margin-right: 10px;
}

.tag-unit {
    border-radius: 8px;
    background: #223C5D;
    color: white;
    padding: 4px;
}

.list-item-map {
    text-align: left;
    padding: 8px;
    border: 1px solid #cccccc;
    background-color: white !important;
}

.nav-pills .nav-link {
    color: black;
}

.floatMenu {
    width: 110px;
    top: 20%;
}

.pointer {
    -moz-transition: all .25s ease-in-out;
    -o-transition: all .25s ease-in-out;
    transition: all .25s ease-in-out;
    display: inline-block;
    font-size: 1em;
    height: 40px;
    text-align: center;
    margin-bottom: 5px;
}

    .pointer:hover {
        border-left: #f64c83 5px solid;
    }

.img-fluid-detail {
    max-width: 100%;
    height: auto;
    width: 300px !important;
}

.hero-marquee {
    height: var(--marquee-h);
    display: flex;
    align-items: center;
    background: #7092BE;
    color: #fff;
    box-shadow: 0 -2px 8px rgba(0, 0, 0, .12);
    z-index: 2;
    width: 100%;
    margin: 0 auto;
}
/* 中?跑馬????*/
.marquee-inner {
    position: relative;
    padding: 8px;
    flex: 1 1 auto;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 48px, #000 calc(100% - 48px), transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000 48px, #000 calc(100% - 48px), transparent 100%);
}

.marquee-track {
    display: inline-flex;
    gap: 2rem;
    white-space: nowrap;
    will-change: transform;
    animation: marquee 25s linear infinite;
    font-weight: 700;
}

@keyframes marquee {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

@media (prefers-reduced-motion: reduce) {
    .marquee-track {
        animation: none;
    }
}

.marquee-track a {
    color: #FFF;
}

    .marquee-track a:hover {
        color: #FFF;
        text-decoration: underline;
    }

.share {
    color: black !important;
}

    .share li {
        padding: 4px;
    }

        .share li a {
            color: black !important;
            margin: 4px;
        }

        .share li .facebook {
            background-color: #3c5998;
            border-radius: 50%;
        }

        .share li .plurk {
            border-radius: 50%;
            background-color: #C6602B;
        }

        .share li .twitter {
            border-radius: 50%;
            background-color: #6aaed0;
        }

        .share li .line {
            border-radius: 50%;
            background-color: #4bc700;
        }

        .share li .email {
            border-radius: 50%;
            background-color: #666;
        }

        .share li .google-plus {
            border-radius: 50%;
            background-color: #D84938;
        }

.goTop {
    position: fixed;
    right: 20px;
    bottom: 10px;
    z-index: 99999;
}

.topbtn {
    width: 50px;
    height: 50px;
    border-radius: 25px;
    color: white;
    background-color: #1a1a1a;
    opacity: .8;
    cursor: pointer;
    padding-top: 4px;
    box-shadow: 6px 6px 10px rgba(0, 0, 0, 0.6);
    text-align: center;
    padding-top: 10px;
}


.map {
    width: 100%;
    height: 650px;
    overflow: hidden;
    border: 1px solid rgb(211, 211, 211);
    border-radius: 3px;
}

.text-C {
    text-align: left;
}

@media (min-width: 1680px) {
    .text-C {
        text-align: center;
    }
}


.btn-outline-light {
    color: black;
    align-items: center;
    background-color: #e9ebf0;
    font-size: 1rem;
    border-radius: 1rem;
    font-weight: 700;
    margin: 4px;
}

.panel-info-home {
    margin: 1rem;
    color: black;
    border-radius: 8px;
    z-index: 9999;
    padding: 1rem;
    height: auto;
    min-height: 450px;
}

.home-link {
    margin-top: 16px;
    text-align: left;
    font-weight: 700;
    color: #2E4D7B;
    cursor: pointer;
    text-align: center;
}


    .home-link:hover {
        text-align: left;
        color: #52698B;
    }



.info-list-home {
    background: white;
    border-radius: 8px;
    background: white;
    padding: 1.5rem;
}

    .info-list-home li {
        font-size: 1.1rem;
        padding: 8px;
        margin-left: 0.5rem;
        font-weight: 300;
        border-bottom: 1px solid #F5F5F5;
    }

        .info-list-home li span {
            line-height: 1.9rem;
        }

.bg-wave {
    background-image: url('../img/bg/bg_wave.svg');
    top: 30px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    border-radius: 3rem;
}

.bg-wave-down {
    background-image: url('../img/bg/bg_wave_down.svg');
    top: 30px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.img-home {
    text-align: center;
    width: 150px;
    height: 150px;
    padding: 8px;
    margin: 0 auto;
    border-radius: 8px;
}

.small, small {
    font-size: 1em !important;
}

.green-bg {
    background: #007979;
    color: white;
    font-weight: bold;
    font-size: 18px;
    text-align: center;
    width: 100%;
    padding: 8px;
}

.list-menu {
    display:inline-flex;
}

.list-menu > li {
    width:50%;
}


.pagination {
    width: 100%;
    position: relative;
    margin: 20px 0px;
    font-size: 1rem;
    clear: both;
    z-index: 4;
}

    .pagination ul {
        display: inline-block;
        margin: 0px;
    }

        .pagination ul::after {
            display: inline;
        }

        .pagination ul > li {
            display: inline;
        }

            .pagination ul > li::after {
                display: inline;
            }

            .pagination ul > li > a, .pagination ul > li > span {
                color: #777777;
                float: left;
                padding: 4px 8px;
                line-height: 20px;
                background-color: #FFFFFF;
                border: 1px solid #cccccc;
                border-left-width: 0px;
            }

            .pagination ul > li > span {
                color: #999999;
                font-weight: bold;
                line-height: 13px;
                border: none;
            }

            .pagination ul > li.ep > a {
                border-left-width: 1px;
            }

            .pagination ul > li > a {
                text-decoration: none;
            }

                .pagination ul > li > a:hover, .pagination ul > li > a:focus, .pagination ul > li > a:active, .pagination ul > li > a.active {
                    color: #303030;
                    background-color: #f5f5f5;
                }

            .pagination ul > li:first-child > a {
                border-left-width: 1px;
            }

@media only screen and (max-width: 420px) {
    .pagination ul > li .button {
        display: inline;
    }
}

.pagination ul > li.website {
    display: inline;
}

@media only screen and (max-width: 420px) {
    .pagination ul > li.website {
        display: none;
    }
}

.pagination ul > li.mobile {
    display: none;
}

@media only screen and (max-width: 420px) {
    .pagination ul > li.mobile {
        display: inline;
    }
}

.pagination ul > li.website.mobile {
    display: inline;
}

@media only screen and (max-width: 420px) {
    .pagination ul > li.website.mobile {
        display: inline;
    }
}

.pagination .totalPage {
    margin: 0px 5px;
    vertical-align: top;
    padding-top: 5px;
    display: inline-block;
    font-size: 1.2rem;
    font-size: 12px;
}

@media only screen and (max-width: 420px) {
    .pagination .totalPage {
        display: block;
        padding-top: 10px;
    }
}

.pagination .totalPage .num {
    margin: 0px 5px;
    letter-spacing: 0px;
}

.pagination .totalPage .slash {
    margin: 0px 3px;
}

@media only screen and (max-width: 800px) {
    .pagination.text-L .totalPage {
        margin: 0px 5px 0px 0px;
    }
}

@media only screen and (max-width: 420px) {
    .pagination.text-L .totalPage {
        margin: 0px 5px;
    }
}

@media only screen and (max-width: 800px) {
    .pagination.text-C .totalPage {
        margin: 0px 5px;
    }
}

@media only screen and (max-width: 800px) {
    .pagination.text-R .totalPage {
        margin: 0px 0px 0px 5px;
    }
}

@media only screen and (max-width: 420px) {
    .pagination.text-R .totalPage {
        margin: 0px 5px;
    }
}


.docms-photo {
    text-align:center;
    width:50%;
    margin:0 auto;
}

@media only screen and (max-width: 420px) {
    .docms-photo {
        width: 100%;
        margin: 0 auto;
    }
    .col-3 {
        width: 100%;
    }
}