/* ============================================================
   CFE PRODUCT DETAIL — VISUAL REDESIGN v3
   
   SETUP (two steps):
   1. Upload this file → /assets/css/product-detail-redesign.css
   2. In includes/header.php, replace the existing Anton font line:
      <link href="https://fonts.googleapis.com/css2?family=Anton&display=swap" rel="stylesheet">
      WITH these three lines:
      <link href="https://fonts.googleapis.com/css2?family=Anton&display=swap" rel="stylesheet">
      <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600&display=swap" rel="stylesheet">
      <link href="https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&display=swap" rel="stylesheet">
   3. In includes/header.php after detail.css line add:
      <link rel="stylesheet" href="<?php echo $base_url ?>assets/css/product-detail-redesign.css">
   ============================================================ */

/* ── TOKENS ────────────────────────────────────── */
:root {
    --cfe-cream:    #f7f3ee;
    --cfe-warm:     #ede6db;
    --cfe-gold:     #b8933f;
    --cfe-gold-lt:  #f0e4c8;
    --cfe-navy:     #1a2540;
    --cfe-red:      #c0392b;
    --cfe-muted:    #7a7060;
    --cfe-border:   rgba(26,37,64,.10);
}

/* ── PAGE SECTION ───────────────────────────────── */
section.customSec[style*="background:#f4f0ea"],
section.customSec[style*="background: #f4f0ea"] {
    background: var(--cfe-cream) !important;
    padding: 48px 0 60px !important;
}

/* ── BREADCRUMB ─────────────────────────────────── */
.rs-breadcrumbs.img2 {
    background: url('/assets/images/product-inner-banner.svg') center center / cover no-repeat !important;
    /* margin-top: 130px !important; */
    min-height: 300px !important;
    padding: 0 !important;
    border-bottom: 1px solid var(--cfe-border) !important;
}
.rs-breadcrumbs.img2::before,
.rs-breadcrumbs.img2::after { display: none !important; }
.rs-breadcrumbs.img2 .breadcrumbs-inner { padding: 0 !important; }

@media (max-width: 991px) {
    .rs-breadcrumbs.img2 { margin-top: 100px !important; min-height: 180px !important; }
}
@media (max-width: 767px) {
    .rs-breadcrumbs.img2 { margin-top: 80px !important; min-height: 130px !important; }
}

/* ── GALLERY ────────────────────────────────────── */
.pd3-gallery-rightthumbs {
    gap: 16px !important;
    grid-template-columns: 1fr 92px !important;
}
.pd3-main {
    border-radius: 24px !important;
    overflow: hidden !important;
    background: var(--cfe-warm) !important;
    box-shadow: 0 32px 64px rgba(26,37,64,.12) !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1/1 !important;
    cursor: zoom-in !important;
}
.pd3-main img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    padding: 0 !important;
    transition: transform .4s cubic-bezier(.25,.46,.45,.94) !important;
}

/* Thumbnails */
.pd3-thumbs-vert { gap: 12px !important; }
.pd3-thumb {
    width: 88px !important;
    height: 76px !important;
    border-radius: 14px !important;
    border: 2px solid transparent !important;
    background: var(--cfe-warm) !important;
    padding: 4px !important;
    cursor: pointer !important;
    box-shadow: 0 4px 16px rgba(26,37,64,.08) !important;
    transition: border-color .2s, box-shadow .2s !important;
    overflow: hidden !important;
}
.pd3-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 10px !important;
}
.pd3-thumb:hover  { box-shadow: 0 6px 20px rgba(26,37,64,.14) !important; }
.pd3-thumb.active {
    border-color: var(--cfe-gold) !important;
    box-shadow: 0 0 0 4px var(--cfe-gold-lt) !important;
}

/* ── INFO PANEL ─────────────────────────────────── */
.pd3-sticky {
    position: sticky !important;
    top: 110px !important;
    background: #ffffff !important;
    border-radius: 28px !important;
    padding: 32px 30px !important;
    border: 1px solid rgba(26,37,64,.07) !important;
    box-shadow: 0 24px 60px rgba(26,37,64,.10) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

/* Pills & brand */
.pd3-head {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 6px !important;
}
.pd3-pill {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: .10em !important;
    text-transform: uppercase !important;
    background: var(--cfe-gold-lt) !important;
    color: var(--cfe-gold) !important;
    padding: 5px 14px !important;
    border-radius: 999px !important;
}
.pd3-brand {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase !important;
    color: var(--cfe-muted) !important;
}

/* Title — uses Cormorant Garamond if loaded, falls back to Georgia */
.pd3-title {
    font-family: 'Cormorant Garamond', Georgia, serif !important;
    font-size: 30px !important;
    font-weight: 600 !important;
    line-height: 1.15 !important;
    color: var(--cfe-navy) !important;
    margin: 10px 0 4px !important;
    letter-spacing: -.01em !important;
}

/* Sub label */
.pd3-sub {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    color: var(--cfe-muted) !important;
    margin-bottom: 16px !important;
}

/* Price */
.pd3-price {
    display: flex !important;
    align-items: baseline !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    margin-bottom: 4px !important;
}
.pd3-new {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 27px !important;
    font-weight: 600 !important;
    color: var(--cfe-navy) !important;
    letter-spacing: -.02em !important;
}
.pd3-old {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: #bbb !important;
    text-decoration: line-through !important;
}
.pd3-off {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: .04em !important;
    padding: 4px 11px !important;
    border-radius: 999px !important;
    background: #fff1f0 !important;
    color: var(--cfe-red) !important;
    border: 1px solid rgba(192,57,43,.20) !important;
    box-shadow: none !important;
}

/* Divider */
.pd3-divider {
    height: 1px !important;
    background: var(--cfe-border) !important;
    margin: 18px 0 !important;
}

/* Variant option chips */
.pd3-label {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: .09em !important;
    text-transform: uppercase !important;
    color: var(--cfe-muted) !important;
    margin-bottom: 10px !important;
}
.pd3-chips {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}
.pd3-chip {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    border: 1.5px solid rgba(26,37,64,.14) !important;
    background: #fff !important;
    padding: 8px 16px !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    color: var(--cfe-navy) !important;
    transition: all .18s ease !important;
}
.pd3-chip:hover  { border-color: var(--cfe-gold) !important; }
.pd3-chip.active {
    border-color: var(--cfe-gold) !important;
    background: var(--cfe-gold-lt) !important;
    color: var(--cfe-gold) !important;
}

/* ── QTY + CTA ROW ──────────────────────────────── */
.pd3-cta-row {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    margin-top: 16px !important;
}

/* Stepper */
.pd3-stepper.pd3-stepper-compact {
    background: var(--cfe-warm) !important;
    border: 1.5px solid var(--cfe-border) !important;
    border-radius: 10px !important;
    padding: 4px 6px !important;
    gap: 4px !important;
    flex: 0 0 auto !important;
}
.pd3-step {
    width: 28px !important;
    height: 28px !important;
    border-radius: 7px !important;
    background: #fff !important;
    border: 1px solid var(--cfe-border) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--cfe-navy) !important;
    cursor: pointer !important;
    transition: background .15s !important;
    line-height: 1 !important;
}
.pd3-step:hover { background: var(--cfe-warm) !important; }
.pd3-stepper input {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--cfe-navy) !important;
    width: 50px !important;
    text-align: center !important;
    background: transparent !important;
    border: none !important;
    outline: none !important;
}

/* Add to Cart — primary CTA */
.pd3-cta {
    flex: 1 !important;
    border: none !important;
    border-radius: 10px !important;
    background: var(--cfe-red) !important;
    color: #fff !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    letter-spacing: .02em !important;
    cursor: pointer !important;
    padding: 10px 18px !important;
    box-shadow: 0 6px 18px rgba(192,57,43,.22) !important;
    transition: transform .2s ease, box-shadow .2s ease !important;
    height: 42px !important;
}
.pd3-cta:not(.disabled):hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 24px rgba(192,57,43,.30) !important;
    filter: none !important;
}
.pd3-cta.disabled {
    background: #c5c5c5 !important;
    box-shadow: none !important;
    cursor: not-allowed !important;
}

/* Secondary buttons */
.pd3-secondary-btns {
    display: flex !important;
    gap: 8px !important;
    margin-top: 8px !important;
}
.pd3-btn-sm {
    flex: 1 !important;
    border-radius: 10px !important;
    padding: 9px 14px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    letter-spacing: .01em !important;
    text-align: center !important;
    transition: all .18s ease !important;
    height: 38px !important;
    line-height: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
/* Buy Now — navy */
.pd3-btn-sm.add_to_cart,
.pd3-btn-sm.btn-success,
.pd3-btn-sm.pd3-btn-ghost {
    background: var(--cfe-navy) !important;
    border: 1px solid var(--cfe-navy) !important;
    color: #fff !important;
    box-shadow: 0 3px 12px rgba(26,37,64,.18) !important;
}
.pd3-btn-sm.add_to_cart:hover,
.pd3-btn-sm.btn-success:hover,
.pd3-btn-sm.pd3-btn-ghost:hover {
    background: #243060 !important;
    border-color: #243060 !important;
    transform: translateY(-1px) !important;
    filter: none !important;
}
/* Request a Quote — outline */
.pd3-btn-sm.pd3-btn-outline {
    background: transparent !important;
    border: 1.5px solid rgba(26,37,64,.22) !important;
    color: var(--cfe-navy) !important;
    box-shadow: none !important;
}
.pd3-btn-sm.pd3-btn-outline:hover {
    background: var(--cfe-warm) !important;
    border-color: var(--cfe-gold) !important;
    transform: translateY(-1px) !important;
    filter: none !important;
}

/* ── TABS ───────────────────────────────────────── */
.furniTabsWrap {
    background: #fff !important;
    border-radius: 24px !important;
    border: 1px solid rgba(26,37,64,.08) !important;
    box-shadow: 0 8px 40px rgba(26,37,64,.07) !important;
    overflow: hidden !important;
    margin-top: 32px !important;
}
.furniTabsHeader {
    display: flex !important;
    border-bottom: 1px solid rgba(26,37,64,.08) !important;
    background: var(--cfe-cream) !important;
    padding: 0 8px !important;
    gap: 4px !important;
}
.furniTabButton {
    flex: 1 !important;
    border: none !important;
    background: transparent !important;
    padding: 18px 20px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    color: var(--cfe-muted) !important;
    cursor: pointer !important;
    position: relative !important;
    transition: color .2s ease !important;
    outline: none !important;
    border-radius: 0 !important;
}
.furniTabButton:hover { color: var(--cfe-navy) !important; }
.furniTabButton.active {
    color: var(--cfe-navy) !important;
    font-weight: 600 !important;
}
.furniTabButton.active::after {
    content: "" !important;
    position: absolute !important;
    left: 16px !important;
    right: 16px !important;
    bottom: -1px !important;
    height: 3px !important;
    width: auto !important;
    background: var(--cfe-gold) !important;
    border-radius: 99px !important;
}
.furniTabsContent {
    padding: 36px 32px !important;
    min-height: 120px !important;
}
.furniTabContent {
    display: none !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 15px !important;
    line-height: 1.75 !important;
    color: #555 !important;
}
.furniTabContent.active {
    display: block !important;
    animation: cfeTabIn .3s ease forwards !important;
}
@keyframes cfeTabIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Description content styling */
.furniTabContent p { color: #555 !important; font-size: 15px !important; line-height: 1.75 !important; }
.furniTabContent h2,
.furniTabContent h3,
.furniTabContent h4,
.furniTabContent strong,
.furniTabContent b {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    color: var(--cfe-navy) !important;
    font-weight: 600 !important;
}
.furniTabContent ul {
    list-style: none !important;
    padding-left: 0 !important;
    margin-top: 12px !important;
}
.furniTabContent ul li {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    padding: 7px 0 !important;
    border-bottom: 1px solid rgba(26,37,64,.05) !important;
    color: #555 !important;
    list-style: none !important;
}
.furniTabContent ul li::before {
    content: "" !important;
    width: 6px !important;
    height: 6px !important;
    min-width: 6px !important;
    border-radius: 50% !important;
    background: var(--cfe-gold) !important;
    margin-top: 9px !important;
    display: block !important;
}
.furniTabContent ul li:last-child { border-bottom: none !important; }

/* Financing tab */
.furniFlexitiLogo {
    width: 48px !important;
    vertical-align: middle !important;
    margin-right: 8px !important;
}

/* ── QUOTE MODAL ────────────────────────────────── */
#quoteModal .modal-content {
    border-radius: 24px !important;
    border: none !important;
    box-shadow: 0 40px 80px rgba(26,37,64,.18) !important;
    overflow: hidden !important;
}
#quoteModal .modal-header {
    background: var(--cfe-cream) !important;
    border-bottom: 1px solid var(--cfe-border) !important;
    padding: 22px 28px !important;
}
#quoteModal .modal-title {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: var(--cfe-navy) !important;
}
#quoteModal .modal-body { padding: 28px 28px 8px !important; }
#quoteModal .form-label {
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: .07em !important;
    text-transform: uppercase !important;
    color: var(--cfe-muted) !important;
    margin-bottom: 6px !important;
}
#quoteModal .form-control {
    border-radius: 12px !important;
    border: 1.5px solid rgba(26,37,64,.14) !important;
    padding: 12px 16px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 14px !important;
    color: var(--cfe-navy) !important;
    transition: border-color .2s !important;
    box-shadow: none !important;
}
#quoteModal .form-control:focus {
    border-color: var(--cfe-gold) !important;
    box-shadow: 0 0 0 3px var(--cfe-gold-lt) !important;
    outline: none !important;
}
#quoteModal .btn-theme,
#quoteModal button.submit {
    background: var(--cfe-red) !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 14px 40px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    color: #fff !important;
    box-shadow: 0 6px 20px rgba(192,57,43,.25) !important;
    transition: transform .18s, box-shadow .18s !important;
}
#quoteModal .btn-theme:hover,
#quoteModal button.submit:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 28px rgba(192,57,43,.32) !important;
}

/* ── RESPONSIVE ─────────────────────────────────── */
@media (max-width: 991px) {
    .pd3-sticky { position: static !important; margin-top: 28px !important; }
    .pd3-title  { font-size: 24px !important; }
    .pd3-gallery-rightthumbs { grid-template-columns: 1fr 76px !important; }
    .furniTabsContent { padding: 28px 20px !important; }
}
@media (max-width: 767px) {
    .pd3-main   { border-radius: 18px !important; }
    .pd3-sticky { padding: 22px 18px !important; border-radius: 20px !important; }
    .pd3-title  { font-size: 21px !important; }
    .pd3-new    { font-size: 22px !important; }
    .pd3-thumb  { width: 68px !important; height: 60px !important; border-radius: 10px !important; }
    .furniTabsHeader {
        display: block !important;
        background: #fff !important;
        border-bottom: none !important;
        padding: 0 !important;
    }
    .furniTabButton {
        width: 100% !important;
        text-align: left !important;
        padding: 16px 20px !important;
        font-size: 12px !important;
        border-bottom: 1px solid rgba(26,37,64,.07) !important;
        border-radius: 0 !important;
    }
    .furniTabButton.active { background: var(--cfe-cream) !important; }
    .furniTabButton.active::after { display: none !important; }
    .furniTabsContent { padding: 0 !important; }
    .furniTabContent {
        padding: 20px !important;
        border-bottom: 1px solid rgba(26,37,64,.07) !important;
    }
}