body.single-post:not(.elementor-page) .elementor-widget-theme-post-content {
    padding: 10px;
    margin: 0 auto;
    max-width: 1140px !important;
}

.single-post .page-content p {
    color: #9c8d7c;
    font-size: 16px;
    font-family: "Fira Sans", Sans-serif !important;
}

.single-post .page-content a, a {
    color: #875d3e;
    text-decoration: none !important;
}

.single-post .page-content ul {
    padding: 0;
    color: #875d3e;
    font-size: 16px;
    margin: 10px 0;
}

.single-post .page-content ul li {
    line-height: 28px;
    margin: 10px 0;
}

.form-contact {
    display: flex;
    flex-direction: column;
    gap: 5px 0;
}

.form-contact .form-line lable p {
    margin-top: 15px;
}

.form-contact .form-line label {
    color: #9c8d7c !important;
}

.form-contact .wpcf7-submit {
    background: #9c8d7c !important;
    color: #fff !important;
    font-size: 22px !important;
    width: 100% !important;
    border: none !important;
    padding: 10px 15px !important;
}

.form-contact .wpcf7-submit:hover {
    background: #875d3e !important;
    color: #fff !important;
}

.jdw-time-line .pp-timeline-card {
    gap: 60px;
    display: flex;
}

.jdw-time-line .pp-timeline.pp-timeline-horizontal {
    margin: 0;
    padding: 60px;
    width: 1200px;
    position: relative;
    background: linear-gradient(to right, #875d3e 0%, #875d3e 29%, #fcfcf7 29%, #fcfcf7 100%);
}

.jdw-time-line .pp-timeline-card .pp-timeline-card-image {
    width: 50%;
}

.jdw-time-line .pp-timeline-card .jdw-time-line-content {
    width: 50%;
    gap: 20px 0;
    display: flex;
    flex-direction: column;
}

.jdw-time-line .pp-timeline-card .jdw-time-line-content hr {
    border: 0;
    opacity: .25;
    border-bottom: 1px solid #e9e7db;
}

.jdw-time-line .pp-timeline-navigation {
    margin: 40px 0;
}

.jdw-time-line .pp-timeline-navigation:before {
    height: 0;
    transform: translateY(0);
    border-bottom: 1px dashed #875d3e;
}

.jdw-time-line .slick-current .pp-timeline-card-date {
    font-weight: 600;
}

.jdw-btn-wrap {
    gap: 5px;
    left: 60%;
    bottom: 60px;
    display: flex;
    position: absolute;
    align-items: center;
    transform: translateX(-50%);
}

.jdw-btn-wrap > button {
    border: 0;
    outline: none;
    padding: 10px;
    border-radius: 0;
    color: #9c8d7c;
    background-color: transparent;
}

.jdw-btn-wrap > span {
    color: #9c8d7c;
}

.jdw-nav-btn-wrap > button {
    border: 0;
    padding: 0;
    width: 30px;
    height: 30px;
    bottom: 20px;
    outline: none;
    display: flex;
    position: absolute;
    align-items: center;
    border-radius: 100px;
    justify-content: center;
    transform: translateY(-50%);
    background-color: #ebe6d1;
    color: var(--e-global-color-primary);
}

.jdw-nav-btn-wrap > button.prev-btn {
    left: 0;
}

.jdw-nav-btn-wrap > button.next-btn {
    right: 0;
}

.product-content h1, .product-content h2, .product-content h3, .product-content h4, .product-content h5 {
    line-height: 1.4;
    font-family: "Fira Sans", Sans-serif;
}

.product-content h1 {
    font-size: 52px;
    margin-top: 36px;
}

.product-content h2 {
    font-size: 48px;
    margin-top: 30px;
}

.product-content h3 {
    font-size: 32px;
    margin-top: 24px;
}

.product-content h4 {
    font-size: 22px;
    margin-top: 16px;
}

.product-content h5 {
    font-size: 16px;
    margin-top: 12px;
}

.product-content p, .product-content ul li {
    font-size: 16px;
    color: #9c8d7c;
    line-height: 28px;
    margin-bottom: 10px;
    font-family: "Fira Sans", Sans-serif;
}

.product-content table td {
    font-size: 20px;
    color: #875d3e;
    font-weight: 500;
}

.product-content table {
    border-color: #875d3e !important;
}

h3.jdw-post-date {
    font-size: 16px;
    color: #875d3e;
    margin: 0 0 .5rem 0;
}

.jdw-related-products .pp-slider-arrow {
    display: none;
}

.product-gallery-nav {
    margin: 0;
    padding: 0;
    list-style: none;
}

.product-gallery .gallery-item img, .product-gallery-nav .nav-item img {
    width: 100%;
    display: block;
}

.product-gallery .gallery-item, .product-gallery-nav .nav-item {
    margin: 5px;
    padding: 5px;
    border: 1px solid #ccc;
}

.product-gallery-nav .slick-arrow {
    top: 50%;
    z-index: 9;
    width: 30px;
    opacity: .7;
    height: 30px;
    font-size: 32px;
    text-align: left;
    position: absolute;
    transform: translateY(-50%);
    color: var(--e-global-color-primary);
}

.product-gallery-nav .slick-prev {
    left: 10px;
}

.product-gallery-nav .slick-next {
    right: 10px;
    text-align: right;
}

.product-gallery-nav .slick-arrow:hover {
    opacity: 1;
    color: var(--e-global-color-primary);
}

.jdw-cta-1 .elementor-cta__content-item > img {
    opacity: 0;
    visibility: hidden;
    transition: all .4s;
}

.jdw-cta-1:hover .elementor-cta__content-item > img {
    opacity: 1;
    visibility: visible;
}

.jdw-cta .elementor-cta__title:after {
    width: 50px;
    content: '';
    display: block;
    margin: 8px auto 10px;
    border-bottom: 2px solid #FFF;
}

.jdw-cta .elementor-cta .elementor-cta__bg-overlay {
    background-color: rgba(31, 16, 5, .65);
}

.jdw-cta .elementor-cta:hover .elementor-cta__bg-overlay, .jdw-cta .elementor-cta:hover .elementor-cta__description {
    transform: rotateY(90deg);
}

#jdw-back-top {
    opacity: 0;
    right: 30px;
    width: 36px;
    bottom: 80px;
    height: 36px;
    display: flex;
    z-index: 1000;
    color: #FFF;
    cursor: pointer;
    position: fixed;
    font-size: 16px;
    visibility: hidden;
    align-items: center;
    justify-content: center;
    background-color: #C9A76C;
    transition: background-color .3s, opacity .5s, visibility .5s;
}

#jdw-back-top:hover {
    background-color: var(--e-global-color-primary);
}

#jdw-back-top.show {
    opacity: 1;
    visibility: visible;
}

@keyframes blink {
    0% {
        opacity: 1
    }

    50% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-webkit-keyframes blink {
    0% {
        opacity: 1
    }

    50% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-moz-keyframes blink {
    0% {
        opacity: 1
    }

    50% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@-webkit-keyframes underline_hover_on2 {
    0% {
        -webkit-background-size: 0 2px;
        background-size: 0 2px
    }

    100% {
        -webkit-background-size: 100% 2px;
        background-size: 100% 2px
    }
}

@keyframes underline_hover_on2 {
    0% {
        -webkit-background-size: 0 2px;
        background-size: 0 2px
    }

    100% {
        -webkit-background-size: 100% 2px;
        background-size: 100% 2px
    }
}

@-webkit-keyframes underline_hover_off2 {
    0% {
        -webkit-background-size: 100% 2px;
        background-size: 100% 2px
    }

    100% {
        -webkit-background-size: 0 2px;
        background-size: 0 2px
    }
}

@keyframes underline_hover_off2 {
    0% {
        -webkit-background-size: 100% 2px;
        background-size: 100% 2px
    }

    100% {
        -webkit-background-size: 0 2px;
        background-size: 0 2px
    }
}

.jdw-arrow-right-btn a .elementor-button-content-wrapper {
    position: relative;
    padding-right: 24px;
}

.jdw-arrow-right-btn .elementor-button-icon {
    top: 50%;
    right: 0;
    font-size: 14px;
    position: absolute;
    transform: translateY(-50%);
    transition: right .3s ease, opacity .3s ease;
}

.jdw-arrow-right-btn .elementor-button-icon.befoer {
    opacity: 0;
    right: 20px;
}

.jdw-arrow-right-btn a:hover .elementor-button-icon {
    opacity: 0;
    right: -20px;
}

.jdw-arrow-right-btn a:hover .elementor-button-icon.befoer {
    opacity: 1;
    right: 0;
}

.jdw-underline_hover a {
    padding-bottom: 13px !important;
    background-image: linear-gradient(to right, currentColor 0, currentColor 100%);
    background-position: 0 100%;
    background-repeat: no-repeat;
    background-size: 0 1px;
    animation: .8s cubic-bezier(.25,.8,.25,1) both underline_hover_on2;
}
.jdw-underline_hover a:hover {
    animation: .8s cubic-bezier(.25,.8,.25,1) both underline_hover_off2;
}

.jdw-button-animation .elementor-button {
    position: relative;
}

.jdw-button-animation .elementor-button-text {
    -webkit-transition: -webkit-transform .3s ease-out;
    -ms-transition: -ms-transform .3s ease-out;
    transition: transform .3s ease-out;
    will-change: transform;
}

.jdw-button-animation .elementor-button-icon {
    top: 50%;
    right: 0;
    opacity: 0;
    font-size: 14px;
    position: absolute;
    transform: translateY(-50%);
    will-change: right, opacity;
    transition: opacity .3s ease-out, right .3s ease-out;
}

.jdw-button-animation .elementor-button:hover .elementor-button-icon {
    right: 3.2em !important;
    opacity: 1;
}

.jdw-button-animation .elementor-button:hover .elementor-button-text {
    -webkit-transform: translateX(-1.45rem);
    -ms-transform: translateX(-1.45rem);
    transform: translateX(-1.45rem);
}

.jdw-posts-style-1 .elementor-button-icon {
    font-size: 14px;
}

.jdw-posts-style-1 .elementor-post-info__item--type-date:hover {
    color: #126380 !important;
}

.jdw-posts-style-1 .elementor-post-info__terms-list:after {
    content: '·';
    color: #9C9C9C;
    display: inline-block;
    vertical-align: baseline;
    font-size: 18px;
    font-weight: 900;
    font-style: normal;
    margin: 0 .55em;
}

.jdw-posts-style-1:hover .jdw-posts-style-1-head {
    border-color: #1A1919 !important;
}

.jdw-posts-style-1 .jdw-posts-style-1-readmore .elementor-button {
    overflow: hidden;
    position: relative;
}

.jdw-posts-style-1 .jdw-posts-style-1-readmore .elementor-button-text {
    opacity: 0;
    visibility: hidden;
    text-indent: -110px;
    transition: visibility .4s ease, margin-right .4s ease-out, text-indent .5s ease-out, color .4s ease, opacity .4s ease;
}

.jdw-posts-style-1:hover .jdw-posts-style-1-readmore .elementor-button .elementor-button-text {
    opacity: 1;
    text-indent: 0;
    visibility: visible;
}

.jdw-products-style-1 .jdw-products-style-1-readmore {
    opacity: 0;
    z-index: 1002;
    transition: all .4s ease-in-out !important;
}

.jdw-products-style-1 .jdw-products-style-1-readmore .elementor-icon {
    width: 47px;
    height: 47px;
    display: flex;
    text-align: center;
    align-items: center;
    justify-content: center;
}

.jdw-products-style-1:hover .jdw-products-style-1-readmore {
    opacity: 1;
}

.jdw-image-carousel,
.jdw-image-carousel .swiper,
.jdw-image-carousel .pp-image-slider-box,
.jdw-image-carousel .pp-image-slider-wrap,
.jdw-image-carousel .pp-image-slider-container {
    height: 100%;
}

.jdw-table {

}

.jdw-table table td, .jdw-table table th {
    border: 0;
}

.jdw-table table td {
    color: #5E5E5E;
    font-size: 16px;
    text-align: left;
    padding: 1em .8em;
}

.jdw-table table th {
    color: #333;
    padding: .8em;
    font-size: 19px;
    font-weight: 400;
    text-align: left;
    font-family: "Lexend Deca", sans-serif;
    background-color: rgba(100,122,101,.3);
}

.jdw-table table > tbody > tr:nth-child(odd) > td {
    background-color: #FAFAFA;
}

.jdw-table table > tbody > tr:nth-child(2n) > td {
    background-color: rgba(234, 234, 234, .6);
}

.jdw-table table a {
    color: #187192;
}

.jdw-table table a:hover {
    color: #126380;
}

.elementor-widget-n-tabs .jdw-table table {
    width: 100%;
    border-top: 2px solid #333;
}

@media (max-width:1200px) {
    .jdw-time-line .pp-timeline.pp-timeline-horizontal {
        width: 100%;
        padding: 0 15px;
    }

}

@media (max-width:1024px) {
    .jdw-time-line .pp-timeline-card {
        gap: 30px;
        align-items: center;
    }

    .jdw-time-line .pp-timeline-card .jdw-time-line-content {
        gap: 0;
    }

    .jdw-nav-btn-wrap {
        display: none;
    }

}

@media (max-width:768px) {
    .jdw-time-line .pp-timeline.pp-timeline-horizontal {
        padding: 0;
        background: #fff;
    }

    .jdw-time-line .pp-timeline-card .pp-timeline-card-image {
        width: 100%;
    }

    .jdw-time-line .pp-timeline-card .jdw-time-line-content {
        width: 100%;
    }

    .jdw-time-line .pp-timeline-card {
        flex-direction: column;
    }

    .jdw-arrow.media-top:after {
        top: unset;
        right: unset;
        bottom: 100%;
        left: 50%;
        margin: 0;
        margin-left: -20px;
        border-color: transparent;
        border-bottom-color: #FFF;
    }

    .jdw-arrow.media-bottom:after {
        top: 100%;
        right: unset;
        bottom: unset;
        left: 50%;
        margin: 0;
        margin-left: -20px;
        border-color: transparent;
        border-top-color: #FFF;
    }

    .jdw-btn-wrap {
        left: 0%;
        bottom: 0px;
        position: relative;
        transform: translateX(0%);
    }

}

/* 2025-07-25 */

.jdw-pp-slider .pp-slider-arrow  {
  opacity: 0;
  visibility: hidden;
  animation: 1s t4s-ani-fadeIn;
}

.jdw-pp-slider:hover .pp-slider-arrow {
  opacity: 1;
  visibility: visible;
}

.jdw-pp-slider .pp-slider-arrow {
    width: 40px;
    height: 40px;
}

.jdw-pp-slider .swiper-container-wrap .swiper-pagination-bullet {
    transition: all .3s;
}

.jdw-pp-slider .swiper-container-wrap .swiper-pagination-bullet.swiper-pagination-bullet-active {
    width: 30px !important;
    border-radius: 5px;
}

.jdw-porduct-loop-2 .image-box:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.1);
    z-index: 1;
    transition: .5s;
    opacity: 0;
}

.jdw-porduct-loop-2:hover .image-box:before {
    opacity: 1;
}

.jdw-porduct-loop-2 .view-wrap {
    position: absolute;
    z-index: 3;
    transition: .5s ease 0s;
    opacity: 0;
    visibility: hidden;
    text-align: center;
    pointer-events: none;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    left: 50%;
    top: 50%;
    width: 136px;
    max-width: 90%;
    min-width: 136px;
    transform: translate(-50%, -100%);
}

.jdw-porduct-loop-2:hover .view-wrap {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -50%);
}

.jdw-porduct-loop-2 .view-wrap .btn-wrap {
    z-index: 3;
    overflow: hidden;
    position: relative;
    pointer-events: auto;
}

.jdw-porduct-loop-2 .view-wrap .view-icon {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    font-size: 18px;
    position: absolute;
    transform: translateY(100%);
    transition: opacity .15s, transform .25s, -webkit-transform .25s;
}

.jdw-porduct-loop-2 .view-wrap .view-icon .elementor-widget-container {
    display: flex;
    align-items: center;
    justify-content: center;
}

.jdw-porduct-loop-2 .view-wrap .view-icon .elementor-icon-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
}

.jdw-porduct-loop-2 .view-wrap .view-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transform: translateY(0);
    transition: opacity .15s, transform .25s, -webkit-transform .25s;
}

.jdw-porduct-loop-2 .view-wrap .btn-wrap:hover .view-title {
    transform: translateY(-100%);
}

.jdw-porduct-loop-2 .view-wrap .btn-wrap:hover .view-icon {
    transform: translateY(0);
}

.jdw-author-box .elementor-image-box-title:hover > a {
    color: #ff6a00;
}

.jdw-author-box.elementor-widget-image-box.elementor-position-left .elementor-image-box-wrapper {
    flex-direction: row;
    text-align: start;
    display: flex;
}

.jdw-author-box.elementor-position-left .elementor-image-box-img {
    margin-right: 10px !important;
}

.jdw-author-box .elementor-image-box-img {
    width: 100%;
    height: 60px;
    max-width: 60px;
    max-height: 60px;
    object-fit: cover;
    border-radius: 50%;
}

.jdw-author-box .elementor-image-box-img img {
    height: 100%;
    border-radius: 50%;
    border: 1px solid #ededed;
}

.jdw-icon-eye .elementor-widget-container {
    border-radius: 50%;
    cursor: pointer;
}

.jdw-icon-eye:hover .elementor-widget-container {
    background-color: #FFF !important;
}

.jdw-icon-eye .elementor-icon-wrapper {
    color: #fff;
    width: 35px;
    height: 35px;
    padding: 0;
    transition: all .3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.jdw-line-title {
    color: #000;
}

.jdw-line-title .elementor-widget-container {
    display: flex;
    align-items: center;
    justify-content: center;
}

.jdw-line-title .elementor-widget-container:before,
.jdw-line-title .elementor-widget-container:after {
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 30px;
    height: 2px;
    background: #222;
}

.jdw-line-title .elementor-heading-title {
    margin: 0 30px;
    display: inline-block;
}

.jdw-eff-border-run .pp-post-thumbnail-wrap:before,
.jdw-eff-border-run .pp-post-thumbnail-wrap:after {
    position: absolute;
    content: "";
    opacity: 0;
    width: 0;
    height: 0;
    z-index: 2;
    transition: all .8s ease;
}

.jdw-eff-border-run .pp-post-thumbnail-wrap:before {
    border-top: 1px solid #fff;
    border-left: 1px solid #fff;
    top: 15px;
    left: 15px;
}

.jdw-eff-border-run .pp-post-thumbnail-wrap:after {
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    right: 15px;
    bottom: 15px;
}

.jdw-eff-border-run .pp-post-thumbnail:hover .pp-post-thumbnail-wrap:before,
.jdw-eff-border-run .pp-post-thumbnail:hover .pp-post-thumbnail-wrap:after {
    opacity: 1;
    width: calc(100% - 30px);
    height: calc(100% - 30px);
}

.jdw-eff-border-run .pp-post-thumbnail {
    overflow: hidden;
}

.jdw-eff-border-run .pp-post-thumbnail img {
    transition: .6s ease-in-out;
    transform: scale(1.15);
}

.jdw-eff-border-run .pp-post-thumbnail:hover img {
    transform: scale(1.15) translateY(-25px);
}

.jdw-testimonial .pp-testimonial-skin-7 {
    display: flex;
    align-items: center;
    flex-direction: row-reverse;
    justify-content: space-between;
}

.jdw-testimonial .pp-testimonial-skin-7 .pp-testimonial-image {
    margin: 0;
    width: 50%;
}

.jdw-testimonial .pp-testimonial-skin-7 .pp-testimonial-content-wrap {
    width: 50%;
}

.jdw-testimonial .pp-testimonial-skin-7 .elementor-star-rating {
    margin-bottom: 40px;
}

@keyframes t4s-ani-fadeIn {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes t4s-ani-fadeOut {
    from {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

@media (min-width: 768px) {
    .jdw-line-title .elementor-widget-container:before,
    .jdw-line-title .elementor-widget-container:after {
        width: 60px;
    }
}