/* =========================
   毛怪固定走在 section-top-bar 上
========================= */

.section-top-bar-wrap {
    position: relative;
    overflow: visible;
    z-index: 30;
}

/* 那條水平線 */
.section-top-bar {
    position: relative;
    height: 12px;
    background: repeating-linear-gradient(
        -45deg,
        #c8ff1a 0,
        #c8ff1a 10px,
        #000 10px,
        #000 20px
    );
    z-index: 1;
}

/* 外層：只負責左右移動，位置永遠綁在線上 */
.hipo-run {
    position: absolute;
    top: 0;
    left: 2%;
    width: 95px;
    z-index: 50;
    pointer-events: none;

    /* 關鍵：把毛怪整體往上提，只讓腳落在線上 */
    transform: translateY(calc(-100% + 6px));

    animation: hipoWalk 10s ease-in-out infinite alternate;
}

/* 內層：身體微晃 */
.hipo-body {
    width: 100%;
    display: block;
    transform-origin: center bottom;

    animation: hipoBob 0.55s ease-in-out infinite alternate;
}

/* 左右來回 */
@keyframes hipoWalk {
    0% {
        left: 2%;
    }

    100% {
        left: calc(100% - 105px);
    }
}

/* 身體微晃，不像滑行 */
@keyframes hipoBob {
    0% {
        transform: translateY(0) rotate(-2deg);
    }

    25% {
        transform: translateY(-2px) rotate(1deg);
    }

    50% {
        transform: translateY(0) rotate(2deg);
    }

    75% {
        transform: translateY(-1px) rotate(-1deg);
    }

    100% {
        transform: translateY(0) rotate(-2deg);
    }
}

/* 平板 */
@media (max-width: 991.98px) {
    .hipo-run {
        width: 78px;
        transform: translateY(calc(-100% + 14px));
    }

    @keyframes hipoWalk {
        0% {
            left: 2%;
        }

        100% {
            left: calc(100% - 86px);
        }
    }
}

/* 手機 */
@media (max-width: 767.98px) {
    .hipo-run {
        width: 60px;
        transform: translateY(calc(-100% + 12px));
    }

    @keyframes hipoWalk {
        0% {
            left: 2%;
        }

        100% {
            left: calc(100% - 66px);
        }
    }
}

/* =========================
   CARD ZONE
========================= */

.hc-card-hotspot {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: block;
    border-radius: inherit;
    cursor: pointer;
}

.hc-card .btn {
    position: relative;
    z-index: 2;
}

/* =========================
   STYLISH
========================= */

/* 有 submenu 的主選單：hover 時不顯示底線綠線 */
.has-dropdown:hover > a::after {
    transform: scale(0) !important;
}

/* 小箭頭 */
.nav-arrow {
    font-size: 9px;
    display: inline-block;
    margin-left: 4px;
    vertical-align: middle;
    line-height: 1;
    transition: transform 0.3s ease;
    color: #c8ff1a;
}

.has-dropdown:hover .nav-arrow {
    transform: rotate(180deg);
}

/* Dropdown 容器 */
.header_nav_menu ul li .dropdown {
    position: absolute;
    left: 0;
    top: calc(100% + 8px);
    transform: translateY(10px);
    width: 148px;
    background: #111111;
    border-top: 3px solid #c8ff1a;
    padding: 4px 0;
    z-index: 999;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.75), 0 0 0 1px rgba(200, 255, 26, 0.1);
}

/* 上方三角形缺口 */
.header_nav_menu ul li .dropdown::before {
    content: '';
    position: absolute;
    top: -8px;
    left: 40px;
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-bottom: 5px solid #c8ff1a;
}

/* Hover 展開 */
.header_nav_menu ul li:hover .dropdown {
    top: calc(100% + 8px);
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* 各項目分隔線 */
.header_nav_menu ul li .dropdown li {
    display: block;
    margin-right: 0;
    border-bottom: 1px solid rgba(200, 255, 26, 0.08);
}

.header_nav_menu ul li .dropdown li:last-child {
    border-bottom: none;
}

/* 項目連結：深底灰字 */
.header_nav_menu ul li .dropdown li a {
    font-size: 14px;
    font-weight: 700;
    color: #f2f2f2;
    background: transparent;
    padding: 10px 16px 10px 22px;
    display: block;
    text-transform: none;
    white-space: nowrap;
    position: relative;
    text-shadow: none;
    transition: color 0.2s ease, padding-left 0.2s ease, background 0.2s ease;
}

/* 左側滑入綠色條 */
.header_nav_menu ul li .dropdown li a::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 2px;
    background: #c8ff1a;
    border-radius: 1px;
    transition: width 0.2s ease;
}

/* Hover：綠字 + 右移 + 色條滑入 */
.header_nav_menu ul li .dropdown li a:hover {
    color: #c8ff1a;
    background: rgba(200, 255, 26, 0.05);
    padding-left: 28px;
}

.header_nav_menu ul li .dropdown li a:hover::before {
    width: 12px;
}

/* 隱藏底線動畫（繼承自 nav a::after） */
.header_nav_menu ul li .dropdown li a::after {
    display: none !important;
}

/* =========================
   SlickNav Submenu 
========================= */
@media (max-width: 991px) {

    /* 有 submenu 的父項 row（含箭頭） */
    .slicknav_nav .slicknav_row {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px 16px;
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
        color: #ffffff;
        font-size: 13px;
        font-weight: 700;
        letter-spacing: 0.5px;
    }

    /* 展開箭頭 */
    .slicknav_nav .slicknav_arrow {
        color: #c8ff1a;
        font-size: 11px;
        margin-left: 6px;
        transition: transform 0.25s ease;
    }

    /* 展開時箭頭旋轉 */
    .slicknav_nav .slicknav_open > .slicknav_row .slicknav_arrow {
        transform: rotate(180deg);
    }

    /* 父項 hover：只改字色 */
    .slicknav_nav .slicknav_row:hover {
        background: transparent !important;
        color: #c8ff1a !important;
        border-radius: 0 !important;
    }

    .slicknav_nav > ul > li > a:hover {
        background: transparent !important;
        color: #c8ff1a !important;
        border-radius: 0 !important;
    }

    /* Submenu 整區容器 */
    .slicknav_nav ul {
        margin: 0 !important;
        padding: 0 !important;
        background: #0d0d0d;
        border-left: 3px solid #c8ff1a;
    }

    /* Submenu 分隔線 */
    .slicknav_nav ul li {
        border-bottom: 1px solid rgba(200, 255, 26, 0.08) !important;
    }

    .slicknav_nav ul li:last-child {
        border-bottom: none !important;
    }

    /* Submenu 連結：深底灰字 */
    .slicknav_nav ul li a {
        display: block;
        padding: 10px 16px 10px 22px !important;
        margin: 0 !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        color: #cccccc !important;
        background: transparent !important;
        border: none !important;
        text-shadow: none !important;
        position: relative;
        transition: color 0.2s ease, padding-left 0.2s ease, background 0.2s ease !important;
    }

    /* Submenu 左側滑入色條 */
    .slicknav_nav ul li a::before {
        content: '';
        position: absolute;
        left: 8px;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 2px;
        background: #c8ff1a;
        border-radius: 1px;
        transition: width 0.2s ease;
    }

    /* Submenu tap/hover */
    .slicknav_nav ul li a:hover {
        color: #c8ff1a !important;
        background: rgba(200, 255, 26, 0.05) !important;
        padding-left: 28px !important;
        border-radius: 0 !important;
    }

    .slicknav_nav ul li a:hover::before {
        width: 12px;
    }
}