/* =========================
MODERN BREADCRUMB HERO
TH SOLUTION STYLE
========================= */

.breadcrumb-modern{
    position:relative;
    overflow:hidden;
    padding:55px 0 45px;
    background:
    linear-gradient(
        135deg,
        #fff7ed 0%,
        #ffffff 45%,
        #fffaf5 100%
    );
    border-bottom:1px solid #fde7d8;
}

/* BACKGROUND EFFECT */

.breadcrumb-modern::before{
    content:'';
    position:absolute;
    top:-120px;
    right:-120px;
    width:320px;
    height:320px;
    background:rgba(249,115,22,.06);
    border-radius:50%;
}

.breadcrumb-modern::after{
    content:'';
    position:absolute;
    bottom:-100px;
    left:-100px;
    width:260px;
    height:260px;
    background:rgba(251,146,60,.05);
    border-radius:50%;
}

/* CONTENT */

.breadcrumb-content{
    position:relative;
    z-index:2;
}

/* BRAND BADGE */

.product-brand-badge{
    display:inline-flex;
    align-items:center;
    gap:10px;
    background:#fff;
    border:1px solid #fed7aa;
    color:#ea580c;
    padding:10px 18px;
    border-radius:50px;
    font-size:14px;
    font-weight:700;
    margin-bottom:20px;
    box-shadow:0 5px 20px rgba(249,115,22,.08);
}

/* TITLE */

.product-title-detail{
    font-size:clamp(26px,3vw,42px);
    font-weight:800;
    line-height:1.45;
    color:#1e293b;
    margin-bottom:18px;
    text-align:left !important;

    white-space:normal;
    overflow:visible;
    text-overflow:unset;
    word-break:break-word;
}

/* SUB TEXT */

.product-subtitle{
    color:#64748b;
    font-size:17px;
    line-height:1.8;
    margin-bottom:25px;
    max-width:900px;
}

/* BREADCRUMB */

.theme-breadcrumb{
    padding-top:0 !important;
}

.theme-breadcrumb .breadcrumb{
    margin:0;
    padding:0;
    background:none;
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.theme-breadcrumb .breadcrumb-item{
    display:flex;
    align-items:center;
    font-size:14px;
    color:#94a3b8 !important;
}

.theme-breadcrumb .breadcrumb-item + .breadcrumb-item::before{
    content:"/";
    color:#cbd5e1;
    padding-right:10px;
}

.theme-breadcrumb .breadcrumb-item a{
    color:#ea580c !important;
    text-decoration:none;
    transition:.3s;
    font-weight:500;
}

.theme-breadcrumb .breadcrumb-item a:hover{
    color:#c2410c !important;
}

.theme-breadcrumb .breadcrumb-item.active{
    color:#475569 !important;
    font-weight:600;
}

/* MOBILE */

@media(max-width:768px){

    .breadcrumb-modern{
        padding:40px 0 35px;
    }

    .product-title-detail{
        font-size:26px;
        line-height:1.5;
    }

    .product-subtitle{
        font-size:15px;
    }

}


/* =========================
THSOLUTION PRODUCT HERO
========================= */

.collection-wrapper{
    padding:40px 0;
}

/* IMAGE SIDE */

.product-image-card{
    background:#fff;
    border-radius:28px;
    padding:30px;
    box-shadow:0 10px 40px rgba(15,23,42,.06);
    position:relative;
    overflow:hidden;
    height:100%;
}

.product-image-card::before{
    content:'';
    position:absolute;
    top:-100px;
    right:-100px;
    width:220px;
    height:220px;
    background:rgba(37,99,235,.05);
    border-radius:50%;
}

.product-image-wrapper{
    min-height:650px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.product-image-wrapper img{
    max-height:620px;
    max-width:100%;
    object-fit:contain;
    transition:.4s;
}

.product-image-wrapper img:hover{
    transform:scale(1.04);
}

/* RIGHT SIDE */

.product-info-card{
    background:#fff;
    border-radius:28px;
    padding:40px;
    box-shadow:0 10px 40px rgba(15,23,42,.06);
    position:relative;
    height:100%;
}

/* BADGES */

.product-badges{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:20px;
}

.product-badge{
    background:#fff7ed;
    color:#f97316;
    padding:8px 14px;
    border-radius:50px;
    font-size:13px;
    font-weight:600;
}

/* TITLE */

.product-title{
    font-size:15px;
    font-weight:700;
    line-height:1.45;
    color:#0f172a;
    margin-bottom:20px;
}

/* PRICE */

.product-price-box{
    background:#f8fafc;
    border-radius:20px;
    padding:25px;
    margin-bottom:25px;
}

.product-price{
    font-size:42px;
    font-weight:800;
    color:#990A00;
    line-height:1;
}

.product-price span{
    font-size:20px;
    color:#334155;
    font-weight:500;
}

.price-note{
    margin-top:10px;
    color:#64748b;
    font-size:15px;
}

/* STOCK */

.stock-info{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:15px;
    margin-bottom:25px;
}

.stock-badge{
    background:#dcfce7;
    color:#166534;
    padding:10px 16px;
    border-radius:12px;
    font-weight:600;
    font-size:14px;
}

.stock-delivery{
    color:#475569;
    font-size:15px;
}

/* DETAIL BOX */

.info-box{
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:20px;
    padding:25px;
    margin-bottom:20px;
}

.info-title{
    font-size:20px;
    font-weight:700;
    margin-bottom:20px;
    color:#0f172a;
}

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

.product-spec li{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:20px;
    padding:14px 0;
    border-bottom:1px dashed #e2e8f0;
}

.product-spec li:last-child{
    border-bottom:none;
}

.product-spec span{
    color:#64748b;
    font-size:15px;
}

.product-spec b{
    color:#0f172a;
    text-align:right;
}

/* DESCRIPTION */

.product-description{
    color:#475569;
    line-height:1.9;
    font-size:16px;
    margin-bottom:25px;
}

/* CTA */

.quote-box{
    background:linear-gradient(135deg,#0f172a,#ea580c);
    border-radius:24px;
    padding:30px;
    color:#fff;
    margin-top:30px;
}

.quote-box h4{
    font-size:24px;
    font-weight:700;
    margin-bottom:12px;
}

.quote-box p{
    opacity:.9;
    margin-bottom:25px;
}

.quote-actions{
    display:flex;
    flex-wrap:wrap;
    gap:15px;
}

.btn-quote{
    background:#fff;
    color:#0f172a;
    padding:14px 24px;
    border-radius:14px;
    font-weight:700;
    text-decoration:none;
    transition:.3s;
}

.btn-quote:hover{
    transform:translateY(-2px);
    color:#0f172a;
}

.btn-line{
    background:rgba(255,255,255,.15);
    border:1px solid rgba(255,255,255,.25);
    color:#fff;
    padding:14px 24px;
    border-radius:14px;
    text-decoration:none;
    font-weight:600;
}

.btn-line:hover{
    background:#fff;
    color:#0f172a;
}

/* MOBILE */

@media(max-width:991px){

    .product-title{
        font-size:28px;
    }

    .product-price{
        font-size:34px;
    }

    .product-image-wrapper{
        min-height:400px;
    }

    .product-info-card{
        padding:28px;
    }

}

/* =========================
PRODUCT TABS MODERN UI
========================= */
/* =========================
ORANGE TAB STYLE
TH SOLUTION
========================= */

.product-tabs-modern .nav-tabs{
    border:none;
    gap:14px;
    flex-wrap:wrap;
    margin-bottom:35px;
}

/* DEFAULT BUTTON */

.product-tabs-modern .nav-link{
    border:none !important;
    background:#fff7ed;
    color:#c2410c;
    border-radius:16px;
    padding:14px 26px;
    font-weight:700;
    font-size:15px;
    transition:.3s;

    box-shadow:
    0 4px 20px rgba(249,115,22,.08);

    display:flex;
    align-items:center;
    gap:10px;
}

/* HOVER */

.product-tabs-modern .nav-link:hover{
    background:#fed7aa;
    color:#9a3412;
    transform:translateY(-2px);
}

/* ACTIVE */

.product-tabs-modern .nav-link.active{
    background:linear-gradient(
        135deg,
        #f97316,
        #ea580c
    ) !important;

    color:#fff !important;

    box-shadow:
    0 10px 30px rgba(249,115,22,.25);
}

/* ACTIVE HOVER */

.product-tabs-modern .nav-link.active:hover{
    color:#fff !important;
}

/* MOBILE */

@media(max-width:768px){

    .product-tabs-modern .nav-tabs{
        gap:10px;
    }

    .product-tabs-modern .nav-link{
        width:100%;
        justify-content:center;
        border-radius:14px;
    }

}

/* TAB CONTENT */

.product-tab-card{
    background:#fff;
    border-radius:28px;
    padding:40px;
    box-shadow:0 10px 35px rgba(15,23,42,.05);
}

/* SECTION TITLE */

.section-heading{
    font-size:28px;
    font-weight:700;
    margin-bottom:30px;
    color:#0f172a;
}

/* SPEC TABLE */

.spec-modern{
    width:100%;
    border-collapse:separate;
    border-spacing:0 10px;
}

.spec-modern tr{
    background:#f8fafc;
    transition:.3s;
}

.spec-modern tr:hover{
    background:#fff7ed;
}

.spec-modern td{
    padding:18px 22px;
    font-size:15px;
}

.spec-modern td:first-child{
    width:35%;
    font-weight:600;
    color:#334155;
    border-radius:14px 0 0 14px;
}

.spec-modern td:last-child{
    color:#0f172a;
    border-radius:0 14px 14px 0;
}

/* PRODUCT DETAIL */

.product-detail-content{
    line-height:1.9;
    color:#475569;
    font-size:16px;
}

/* FAQ */

.faq-modern{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.faq-item{
    background:#fff;
    border:1px solid #e2e8f0;
    border-radius:20px;
    overflow:hidden;
}

.faq-question{
    padding:22px 25px;
    background:#f8fafc;
    font-weight:700;
    font-size:17px;
    color:#0f172a;
}

.faq-answer{
    padding:25px;
    color:#475569;
    line-height:1.9;
}

/* REVIEW */

.review-summary{
    background:linear-gradient(135deg,#0f172a,#ea580c);
    border-radius:28px;
    padding:40px;
    color:#fff;
    text-align:center;
    height:100%;
}

.review-score{
    font-size:72px;
    font-weight:800;
    line-height:1;
}

.review-stars{
    font-size:22px;
    margin:15px 0;
    color:#facc15;
}

.review-card{
    background:#fff;
    border-radius:22px;
    padding:30px;
    box-shadow:0 5px 25px rgba(15,23,42,.04);
    margin-bottom:20px;
}

.review-user{
    display:flex;
    align-items:center;
    gap:15px;
    margin-bottom:15px;
}

.review-avatar{
    width:52px;
    height:52px;
    border-radius:50%;
    background:#f97316;
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:700;
    font-size:20px;
}

.review-name{
    font-weight:700;
    color:#0f172a;
}

.review-date{
    font-size:14px;
    color:#64748b;
}

.review-text{
    line-height:1.9;
    color:#475569;
}

/* MOBILE */

@media(max-width:768px){

    .product-tab-card{
        padding:25px;
    }

    .section-heading{
        font-size:24px;
    }

    .review-score{
        font-size:52px;
    }

}

/* =========================
RELATED PRODUCT SECTION
THSOLUTION MODERN UI
========================= */

.related-section{
    padding:80px 0;
    background:#f8fafc;
    position:relative;
    overflow:hidden;
}

.related-section::before{
    content:'';
    position:absolute;
    top:-120px;
    right:-120px;
    width:320px;
    height:320px;
    background:rgba(37,99,235,.04);
    border-radius:50%;
}

/* SECTION HEADER */

.related-header{
    display:flex;
    justify-content:space-between;
    align-items:end;
    margin-bottom:40px;
    gap:20px;
}

.related-title h2{
    font-size:40px;
    font-weight:800;
    color:#0f172a;
    margin-bottom:12px;
}

.related-title p{
    color:#64748b;
    margin:0;
    font-size:17px;
}

/* PRODUCT GRID */

.related-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:25px;
}

/* PRODUCT CARD */

.product-card-modern{
    background:#fff;
    border-radius:28px;
    overflow:hidden;
    position:relative;
    transition:.35s;
    box-shadow:0 8px 30px rgba(15,23,42,.05);
    height:100%;
    display:flex;
    flex-direction:column;
}

.product-card-modern:hover{
    transform:translateY(-8px);
    box-shadow:0 18px 45px rgba(15,23,42,.12);
}

/* STOCK BADGE */

.stock-label{
    position:absolute;
    top:18px;
    left:18px;
    z-index:2;
    background:#dcfce7;
    color:#166534;
    padding:8px 14px;
    border-radius:50px;
    font-size:13px;
    font-weight:700;
}

/* IMAGE */

.product-image-area{
    background:#fff;
    padding:35px;
    height:280px;
    display:flex;
    align-items:center;
    justify-content:center;
    position:relative;
}

.product-image-area img{
    max-width:100%;
    max-height:220px;
    object-fit:contain;
    transition:.4s;
}

.product-card-modern:hover img{
    transform:scale(1.06);
}

/* CONTENT */

.product-content{
    padding:28px;
    display:flex;
    flex-direction:column;
    flex:1;
}

.product-brand{
    color:#f97316;
    font-size:13px;
    font-weight:700;
    letter-spacing:.5px;
    text-transform:uppercase;
    margin-bottom:12px;
}

.product-name{
    font-size:18px;
    font-weight:700;
    line-height:1.6;
    color:#0f172a;
    margin-bottom:14px;

    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
    min-height:58px;
}

.product-mpn{
    color:#64748b;
    font-size:14px;
    margin-bottom:20px;
}

/* PRICE */

.product-price{
    font-size:30px;
    font-weight:800;
    color:#990A00;
    margin-bottom:25px;
}

.product-price span{
    font-size:15px;
    color:#64748b;
    font-weight:500;
}

/* BUTTON */

.product-btn{
    margin-top:auto;
}

.product-btn a{
    width:100%;
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
    background:#0f172a;
    color:#fff;
    padding:15px 20px;
    border-radius:16px;
    text-decoration:none;
    font-weight:700;
    transition:.3s;
}

.product-btn a:hover{
    background:#f97316;
    transform:translateY(-2px);
}

/* MOBILE */

@media(max-width:1200px){

    .related-grid{
        grid-template-columns:repeat(3,1fr);
    }

}

@media(max-width:991px){

    .related-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:767px){

    .related-section{
        padding:60px 0;
    }

    .related-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .related-title h2{
        font-size:30px;
    }

    .product-image-area{
        height:220px;
    }

}