/* Unified logo positioning for home/about and all pages */
#top-header > .container {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    padding-left: 48px !important;
    padding-right: 10px !important;
}

#main-header > .container.et_menu_container {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    position: relative !important;
    display: flex !important;
    justify-content: center !important;
    padding-left: 48px !important;
    padding-right: 16px !important;
}

#main-header .et_menu_container {
    align-items: center !important;
}

#main-header #et-top-navigation {
    flex: 0 0 auto !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    pointer-events: auto !important;
}

/* 僅桌面需要滿寬以承載置中主選單；手機若設 100% 會把 flex 內的 logo 擠到下一行 */
@media (min-width: 981px) {
    #main-header #et-top-navigation {
        width: 100% !important;
    }
}

#main-header #top-menu-nav {
    margin: 0 auto !important;
    pointer-events: auto !important;
}

#main-header #top-menu {
    display: flex !important;
    justify-content: center !important;
    width: max-content !important;
    margin: 0 auto !important;
}

#top-header #et-info {
    margin-left: 24px !important;
    padding-left: 0 !important;
    float: none !important;
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
}

#main-header .logo_container {
    margin-left: 0 !important;
    position: absolute !important;
    left: 48px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 3 !important;
    pointer-events: none !important;
    min-height: 56px !important;
    padding: 4px 0 !important;
    overflow: visible !important;
}

#main-header .logo_container a,
#main-header .logo_container #logo {
    pointer-events: auto !important;
}

#main-header .logo_container #logo {
    margin-left: 0 !important;
    max-height: 56px !important;
    width: auto !important;
    height: auto !important;
    display: block !important;
}

#main-header #et-top-navigation {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

#top-menu li a {
    font-size: 16px !important;
    line-height: 1.2 !important;
    padding-top: 18px !important;
    padding-bottom: 18px !important;
}

@media (min-width: 981px) {
    #main-header.et-fixed-header .logo_container {
        min-height: 44px !important;
        height: auto !important;
        padding: 4px 0 !important;
        overflow: visible !important;
    }

    #main-header.et-fixed-header #logo {
        max-height: 46px !important;
        opacity: 1 !important;
        visibility: visible !important;
    }
}

@media (max-width: 980px) {
    /*
     * 博客手機：Divi 仍會因 et_fixed_nav / secondary nav 把頂部聯絡條固定並覆蓋內容，
     * 這裡在最後載入的 CSS 中強制改回正常文檔流；主白色導覽列仍由 sticky 的 #main-header 承擔吸頂。
     */
    html body.hc-is-blog.et_fixed_nav #top-header,
    html body.hc-is-blog.et_fixed_nav.et_show_nav #top-header,
    html body.hc-is-blog.et_fixed_nav.et_show_nav.et_secondary_nav_enabled #top-header {
        position: relative !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        transform: none !important;
        margin: 0 !important;
        z-index: 100000 !important;
    }

    html body.hc-is-blog #page-container,
    html body.hc-is-blog #et-main-area {
        padding-top: 0 !important;
        margin-top: 0 !important;
    }

    html body.hc-is-blog #main-header {
        position: sticky !important;
        top: 0 !important;
    }

    #top-header > .container {
        padding-left: 10px !important;
        padding-right: 8px !important;
    }

    #main-header > .container.et_menu_container {
        padding-left: 10px !important;
        padding-right: 8px !important;
    }

    #main-header #et-top-navigation {
        flex: initial !important;
        justify-content: flex-end !important;
    }

    /*
     * 非博客手機：logo 仍為絕對定位，#top-menu-nav 隱藏後若 #et-top-navigation 無寬度會塌縮，
     * 漢堡與右側區塊（如語言切換）會不顯示；博客頁由 body.hc-is-blog 另行收窄。
     */
    html body:not(.hc-is-blog) #main-header #et-top-navigation {
        width: 100% !important;
        max-width: none !important;
        flex: 1 1 auto !important;
        justify-content: flex-end !important;
    }

    #top-header #et-info {
        margin-left: 0 !important;
    }

    #main-header .logo_container {
        margin-left: 0 !important;
        min-height: 64px !important;
        padding: 4px 0 !important;
    }

    #main-header .logo_container #logo {
        max-height: 56px !important;
    }

    /* 博客：頂部導覽過擠時改為漢堡選單，避免與 logo 垂直錯位 */
    body.hc-is-blog #main-header #top-menu-nav {
        display: none !important;
    }

    body.hc-is-blog #main-header #et-top-navigation {
        align-items: center !important;
        min-height: 0 !important;
        display: flex !important;
    }

    body.hc-is-blog #main-header #et_mobile_nav_menu .mobile_nav {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        justify-content: flex-end !important;
        padding: 0 !important;
        min-height: 0 !important;
    }

    body.hc-is-blog #main-header #et_mobile_nav_menu .mobile_menu_bar {
        margin: 0 !important;
        padding: 6px !important;
        align-self: center !important;
    }

    /* 避免上移後被白條裁切 */
    html body.hc-is-blog #main-header {
        padding-top: 0 !important;
        overflow: visible !important;
    }

    /*
     * 博客手機：logo 併入白色主導覽列左側（避免絕對定位 + 列高過矮導致 logo 掉到內容區）
     */
    body.hc-is-blog #main-header > .container.et_menu_container {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        justify-content: flex-start !important;
        align-items: center !important;
        min-height: 0 !important;
        column-gap: 6px !important;
        padding-top: 6px !important;
        padding-bottom: 6px !important;
    }

    /*
     * 使用 html body 提高優先級，並避免 flex 壓縮與負 margin（floating-contact.css）
     * 把 logo 裁切為不可見；勿對 logo 區域使用 overflow:hidden。
     */
    /*
     * 博客手機：勿在含 #mobile_menu 的祖先上使用 transform，否則 position:absolute 的下拉
     * 會以窄父級為參考，導致選單被壓成細條；垂直位移只用 margin。
     */
    html body.hc-is-blog #main-header .logo_container {
        position: relative !important;
        float: none !important;
        left: auto !important;
        top: auto !important;
        right: auto !important;
        transform: none !important;
        display: flex !important;
        align-items: center !important;
        flex: 0 1 auto !important;
        flex-shrink: 1 !important;
        min-height: 0 !important;
        max-width: min(58vw, 220px) !important;
        padding: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
        order: 1 !important;
        align-self: center !important;
        overflow: visible !important;
        z-index: 300 !important;
    }

    html body.hc-is-blog #main-header .logo_container .logo_helper {
        display: none !important;
    }

    html body.hc-is-blog #main-header .logo_container a {
        display: block !important;
        line-height: 0 !important;
    }

    html body.hc-is-blog #main-header .logo_container #logo {
        max-height: 44px !important;
        width: auto !important;
        height: auto !important;
        max-width: 100% !important;
        object-fit: contain !important;
        object-position: left center !important;
        opacity: 1 !important;
        visibility: visible !important;
        display: block !important;
    }

    /*
     * 父層 flex 內須保持「窄欄」：下拉 ul 已 position:absolute 全寬，此處不可 width:100%。
     */
    /* 語言鈕緊挨漢堡左側、同一行，靠右成組 */
    html body.hc-is-blog #main-header #et-top-navigation {
        flex: 1 1 auto !important;
        flex-grow: 1 !important;
        flex-shrink: 1 !important;
        flex-basis: 0 !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        margin-left: 0 !important;
        margin-right: 4px !important;
        justify-content: flex-end !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        flex-direction: row !important;
        gap: 6px !important;
        order: 2 !important;
        align-self: center !important;
        transform: none !important;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
        z-index: 250 !important;
    }

    html body.hc-is-blog #main-header #et-top-navigation #et_mobile_nav_menu {
        margin-left: 0 !important;
        margin-top: 0 !important;
        flex-shrink: 0 !important;
        float: none !important;
        display: flex !important;
        align-items: center !important;
        width: auto !important;
        max-width: none !important;
    }

    html body.hc-is-blog #main-header #et-top-navigation .hc-blog-lang-switch {
        margin-right: 0 !important;
        margin-left: 0 !important;
        flex-shrink: 0 !important;
        display: inline-flex !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        gap: 5px !important;
    }

    html body.hc-is-blog #main-header #et-top-navigation .hc-blog-lang-link {
        padding: 5px 8px !important;
        font-size: 13px !important;
        font-weight: 600 !important;
        line-height: 1.2 !important;
        border-radius: 6px !important;
        min-height: 0 !important;
    }

    /* Divi 手機選單掛在 #et-top-navigation 內：改為相對整條白欄容器全寬展開 */
    html body.hc-is-blog #main-header > .container.et_menu_container {
        overflow: visible !important;
    }

    html body.hc-is-blog #main-header ul#mobile_menu.et_mobile_menu,
    html body.hc-is-blog #main-header ul.et_mobile_menu {
        position: absolute !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: none !important;
        top: 100% !important;
        margin-top: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        box-sizing: border-box !important;
        z-index: 100002 !important;
    }
}

/* Homepage: remove footer cleanly after deleting bottom contact block */
body.home #main-content,
body.home #post-4,
body.home #post-4 .entry-content,
body.home .et_pb_section_6,
body.home .et_pb_row_4 {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

body.home #main-footer {
    display: none !important;
}

/* Home safety override: prevent animation-hidden sections from leaving white gaps */
body.home #main-content .et_pb_section,
body.home #main-content .et_pb_row,
body.home #main-content .et_pb_column,
body.home #main-content .et_pb_module {
    visibility: visible !important;
}

body.home #main-content .et_animated,
body.home #main-content .et_pb_section.et_animated,
body.home #main-content .et_pb_row.et_animated,
body.home #main-content .et_pb_column.et_animated,
body.home #main-content .et_pb_module.et_animated {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
}

/* Homepage hero: match the preferred visual state */
body.home #main-content .et_pb_section_0,
body.home #post-4 .et_pb_section_0 {
    margin-top: -14px !important;
    padding-top: 0 !important;
}

body.home #main-content .et_pb_section_0 .et_pb_row_0,
body.home #post-4 .et_pb_section_0 .et_pb_row_0 {
    width: 100% !important;
    max-width: 100% !important;
}

body.home #main-content .et_pb_section_0 .et_pb_column_0,
body.home #post-4 .et_pb_section_0 .et_pb_column_0 {
    padding-top: 7vw !important;
    padding-right: 6vw !important;
    padding-bottom: 6vw !important;
    padding-left: 6vw !important;
}

body.home #main-content .et_pb_text_0,
body.home #post-4 .et_pb_text_0 {
    border-left: 10px solid #1f1e38 !important;
    padding-left: 16px !important;
    margin-bottom: 0 !important;
    max-width: 800px !important;
}

body.home #main-content .et_pb_text_0 h1,
body.home #post-4 .et_pb_text_0 h1 {
    color: #1f1e38 !important;
    font-weight: 900 !important;
    font-size: clamp(52px, 5.2vw, 72px) !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.55) !important;
    -webkit-text-stroke: 1px rgba(31, 30, 56, 0.45) !important;
}

body.home #main-content .et_pb_text_1,
body.home #post-4 .et_pb_text_1 {
    display: none !important;
}

body.home #main-content .hc-home-price-text,
body.home #post-4 .hc-home-price-text {
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 8px !important;
    margin: 18px 0 0 26px !important;
    padding: 10px 14px !important;
    background: rgba(214, 214, 214, 0.42) !important;
    border-radius: 6px !important;
    white-space: nowrap !important;
    line-height: 1.1 !important;
}

body.home #main-content .hc-home-price-label,
body.home #post-4 .hc-home-price-label {
    color: #ffe3a1 !important;
    font-size: clamp(34px, 3.2vw, 46px) !important;
    font-weight: 800 !important;
    text-shadow: 0 2px 6px rgba(0, 0, 0, 0.18) !important;
}

body.home #main-content .hc-home-price-value,
body.home #post-4 .hc-home-price-value {
    color: #b8344a !important;
    font-size: clamp(34px, 3.2vw, 46px) !important;
    font-weight: 900 !important;
    -webkit-text-stroke: 1px #ffffff !important;
    text-shadow: none !important;
}

body.home #main-content .et_pb_button_0_wrapper,
body.home #post-4 .et_pb_button_0_wrapper {
    display: block !important;
    width: fit-content !important;
    clear: both !important;
    margin-top: 14px !important;
    margin-left: 26px !important;
}

body.home #main-content .et_pb_button_0_wrapper::before,
body.home #post-4 .et_pb_button_0_wrapper::before {
    content: none !important;
    display: none !important;
}

body.home #main-content .et_pb_button_0_wrapper .et_pb_button_0,
body.home #post-4 .et_pb_button_0_wrapper .et_pb_button_0 {
    background: #25d366 !important;
    border: 2px solid #25d366 !important;
    color: #ffffff !important;
    border-radius: 12px !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    padding: 14px 34px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18) !important;
}

body.home #main-content .hc-hero-price-cta-wrap .hc-wa-wx-stack .et_pb_button_0,
body.home #post-4 .hc-hero-price-cta-wrap .hc-wa-wx-stack .et_pb_button_0 {
    font-size: 17px !important;
    padding: 12px 14px !important;
    line-height: 1.2 !important;
    letter-spacing: 0.03em !important;
    font-weight: 800 !important;
}

body.home #main-content .et_pb_button_0_wrapper .et_pb_button_0:hover,
body.home #post-4 .et_pb_button_0_wrapper .et_pb_button_0:hover {
    background: #20bf5d !important;
    border-color: #20bf5d !important;
    color: #ffffff !important;
}

body.home #main-content .et_pb_button_0_wrapper .et_pb_button_0.et_pb_custom_button_icon::after,
body.home #post-4 .et_pb_button_0_wrapper .et_pb_button_0.et_pb_custom_button_icon::after {
    display: none !important;
}

@media (max-width: 767px) {
    body.home #main-content .hc-home-price-label,
    body.home #post-4 .hc-home-price-label,
    body.page-id-6 #main-content .hc-home-price-label {
        color: #111111 !important;
        -webkit-text-stroke: 0 !important;
        text-shadow: none !important;
    }
}

/*
 * 博客桌面：Divi 固定雙欄時 main-header 設 top:30px，若 #top-header 實際高度略小，
 * 會在深色頂欄與白導覽之間露出 body 背景（細白/淺色縫）。略收 main-header 的 top 並拉齊頂欄。
 */
@media (min-width: 981px) {
    html body.hc-is-blog.et_fixed_nav.et_secondary_nav_enabled #top-header {
        margin: 0 !important;
        padding-bottom: 0 !important;
        min-height: 28px !important;
        display: flex !important;
        align-items: center !important;
        box-sizing: border-box !important;
    }

    html body.hc-is-blog.et_fixed_nav.et_secondary_nav_enabled #top-header > .container {
        padding-top: 6px !important;
        padding-bottom: 6px !important;
        display: flex !important;
        align-items: center !important;
        box-sizing: border-box !important;
    }

    html body.hc-is-blog.et_fixed_nav.et_secondary_nav_enabled #main-header {
        top: 28px !important;
        margin-top: 0 !important;
        border-top: none !important;
    }

    html body.admin-bar.hc-is-blog.et_fixed_nav.et_secondary_nav_enabled #main-header {
        top: 61px !important;
    }
}
