/* ============================================================
   assets/css/product-detail.css
   CSS halaman product-detail.php
   Dipindah dari inline ke file terpisah (Juni 2026)
   Diload via <link> di homepage_head.php atau product-detail.php
   ============================================================ */

.product-detail-hero{
    padding-top:5.8rem;
}
.product-detail-spa-host{
    margin-top:1rem;
}

/* Desktop marketplace: keep the visual/product guidance present beside long details. */
.mkt-media-guide{
    display:none;
}
.mkt-detail-canvas{
    display:none;
}

@media (min-width: 1024px){
    body.theme-marketplace-architect .product-detail-media,
    body.theme-homepage-marketplace .product-detail-media{
        position:relative;
    }
    body.theme-marketplace-architect .mkt-media-guide,
    body.theme-homepage-marketplace .mkt-media-guide{
        width:100%;
        margin-top:.4rem;
        padding:.75rem .85rem;
        display:grid;
        grid-template-columns:auto minmax(0,1fr) auto;
        align-items:center;
        gap:.65rem;
        border:1px solid rgba(28,54,100,.12);
        border-radius:14px;
        background:linear-gradient(145deg,#fff,rgba(244,247,255,.94));
        box-shadow:0 16px 38px rgba(15,30,61,.08);
    }
    .mkt-media-guide-icon{
        width:32px;
        height:32px;
        display:grid;
        place-items:center;
        border-radius:50%;
        background:rgba(240,90,36,.1);
        color:var(--brass,#F05A24);
    }
    .mkt-media-guide-icon svg{
        width:17px;
        height:17px;
    }
    .mkt-media-guide-copy{
        display:grid;
        gap:.22rem;
    }
    .mkt-media-guide-copy strong{
        color:var(--charcoal,#0F1E3D);
        font-size:.84rem;
    }
    .mkt-media-guide-copy span{
        display:none;
    }
    .mkt-media-guide a{
        min-height:34px;
        padding:0 .85rem;
        display:flex;
        align-items:center;
        justify-content:center;
        border-radius:999px;
        background:var(--espresso,#1C3664);
        color:#fff;
        font-size:.62rem;
        font-weight:700;
        letter-spacing:.06em;
        text-decoration:none;
        text-transform:uppercase;
        transition:transform .2s ease,background .2s ease;
    }
    .mkt-media-guide a:hover{
        transform:translateY(-1px);
        background:var(--brass,#F05A24);
    }
    body.theme-marketplace-architect .mkt-detail-canvas,
    body.theme-homepage-marketplace .mkt-detail-canvas{
        display:block;
        margin-top:clamp(.75rem,1.5vw,1.25rem);
        padding:clamp(1.4rem,3vw,2.5rem);
        border:1px solid rgba(28,54,100,.1);
        border-radius:24px;
        background:rgba(255,255,255,.72);
        box-shadow:0 24px 70px rgba(15,30,61,.08);
    }
    .mkt-detail-canvas-head{
        display:grid;
        grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);
        align-items:end;
        gap:2rem;
        margin-bottom:1.5rem;
        padding-bottom:1.25rem;
        border-bottom:1px solid rgba(28,54,100,.1);
    }
    .mkt-detail-canvas-head span{
        color:var(--brass,#F05A24);
        font-size:.68rem;
        font-weight:800;
        letter-spacing:.14em;
        text-transform:uppercase;
    }
    .mkt-detail-canvas-head h2{
        max-width:680px;
        margin:.35rem 0 0;
        color:var(--charcoal,#0F1E3D);
        font-size:clamp(1.55rem,2.8vw,2.55rem);
        line-height:1.08;
    }
    .mkt-detail-canvas-head p{
        margin:0;
        color:var(--taupe,#51627F);
        font-size:.86rem;
        line-height:1.75;
    }
    .mkt-detail-canvas-grid{
        display:grid;
        grid-template-columns:repeat(2,minmax(0,1fr));
        gap:1rem;
        align-items:start;
    }
    .mkt-detail-canvas-grid > *{
        min-width:0;
        margin:0;
    }
    .mkt-detail-canvas-grid .is-desc,
    .mkt-detail-canvas-grid .product-detail-offer,
    .mkt-detail-canvas-grid .product-detail-share,
    .mkt-detail-canvas-grid .mkt-buy-flow{
        grid-column:1/-1;
    }
    .mkt-detail-canvas-grid .product-info-block{
        padding:1.25rem;
        border:1px solid rgba(28,54,100,.1);
        border-radius:16px;
        background:#fff;
    }
    .mkt-detail-canvas-grid .mkt-preview-pages{
        grid-template-columns:repeat(4,minmax(0,1fr));
    }
    .mkt-detail-canvas-grid .mkt-tier-cards{
        display:grid;
        grid-template-columns:1fr;
    }
    .mkt-detail-canvas-grid .is-pdf-tiers,
    .mkt-detail-canvas-grid .mkt-preview-block{
        height:100%;
    }
    .mkt-detail-canvas-grid .is-pdf-tiers > .mkt-estimasi-block{
        height:auto;
        margin-top:1.25rem;
        padding:1.15rem 0 0;
        border:0;
        border-top:1px solid rgba(28,54,100,.1);
        border-radius:0;
        box-shadow:none;
        background:transparent;
    }
    .mkt-detail-canvas-grid .mkt-preview-pages{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
    .mkt-detail-canvas-grid .mkt-preview-page-img{
        aspect-ratio:4/3;
    }
    .mkt-detail-canvas-grid .is-desc .product-detail-desc{
        columns:2;
        column-gap:3rem;
        column-rule:1px solid rgba(28,54,100,.08);
    }
    .mkt-detail-canvas-grid .product-detail-offer{
        grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);
        align-items:center;
        padding:1.5rem;
    }
    .mkt-detail-canvas-grid .product-detail-offer-actions{
        grid-column:2;
    }
    .mkt-detail-canvas-grid .product-detail-share{
        display:flex;
        align-items:center;
        justify-content:space-between;
        gap:1rem;
        padding:1rem 0 0;
    }
    .mkt-detail-canvas-grid .product-detail-share-label{
        margin:0;
    }
    .mkt-detail-canvas-grid .product-detail-share-status{
        display:none;
    }
}

@media (max-width: 768px){
    .product-detail-hero{
        padding-top:4.8rem;
    }
    .mkt-preview-pages{
        display:flex;
        gap:.75rem;
        margin-inline:-.25rem;
        padding:.15rem .25rem .65rem;
        overflow-x:auto;
        overflow-y:hidden;
        scroll-snap-type:x mandatory;
        scroll-padding-inline:.25rem;
        overscroll-behavior-x:contain;
        scrollbar-width:none;
        -webkit-overflow-scrolling:touch;
    }
    .mkt-preview-pages::-webkit-scrollbar{
        display:none;
    }
    .mkt-preview-page{
        flex:0 0 min(86%,320px);
        scroll-snap-align:start;
    }
    .mkt-preview-page-img{
        aspect-ratio:4/3;
        min-height:0;
    }
    .mkt-preview-page-img svg{
        width:28px;
        height:28px;
    }
    .mkt-preview-teaser::after{
        content:'Geser untuk melihat sampel lainnya';
        display:block;
        margin:.1rem 0 .65rem;
        color:var(--taupe,#5A7099);
        font-size:.66rem;
        letter-spacing:.04em;
        text-align:center;
    }
}

.product-detail-offer{
    margin-top:1rem;
    padding:1rem 1.05rem;
    border-radius:1.15rem;
    border:1px solid rgba(184,148,95,.22);
    background:linear-gradient(145deg,rgba(255,250,243,.96),rgba(246,238,226,.94));
    display:grid;
    gap:.85rem;
}
.product-detail-offer-copy{
    display:grid;
    gap:.35rem;
}
.product-detail-offer-kicker{
    font-size:.74rem;
    color:var(--brass);
    letter-spacing:.1em;
    text-transform:uppercase;
    font-weight:700;
}
.product-detail-offer-copy h2{
    margin:0;
    font-size:1.08rem;
    line-height:1.45;
    color:var(--espresso);
}
.product-detail-offer-copy p{
    margin:0;
    font-size:.9rem;
    line-height:1.7;
    color:var(--taupe);
}
.product-detail-offer-points{
    display:flex;
    flex-wrap:wrap;
    gap:.55rem;
}
.product-detail-offer-points span{
    display:inline-flex;
    align-items:center;
    min-height:34px;
    padding:0 .8rem;
    border-radius:999px;
    background:rgba(255,255,255,.72);
    border:1px solid rgba(90,74,60,.1);
    color:var(--espresso);
    font-size:.73rem;
    letter-spacing:.05em;
    text-transform:uppercase;
    font-weight:600;
}
.product-detail-offer-actions{
    display:flex;
    flex-wrap:wrap;
    gap:.65rem;
}
.product-detail-offer-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:0 1rem;
    border-radius:999px;
    text-decoration:none;
    font-size:.76rem;
    letter-spacing:.06em;
    text-transform:uppercase;
    font-weight:700;
    transition:transform .2s ease,background .2s ease,border-color .2s ease,color .2s ease;
}
.product-detail-offer-btn:hover{
    transform:translateY(-1px);
}
.product-detail-offer-btn.is-primary{
    background:var(--espresso);
    border:1px solid var(--espresso);
    color:var(--linen);
}
.product-detail-offer-btn.is-secondary{
    background:transparent;
    border:1px solid rgba(90,74,60,.18);
    color:var(--espresso);
}
.product-detail-share{
    margin-top:1rem;
    padding-top:1rem;
    border-top:1px solid rgba(90,74,60,.12);
}
.product-detail-share-label{
    font-size:.78rem;
    color:var(--taupe);
    letter-spacing:.08em;
    text-transform:uppercase;
    margin-bottom:.65rem;
}
.product-detail-share-actions{
    display:flex;
    flex-wrap:wrap;
    gap:.65rem;
}
.product-detail-share-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.45rem;
    min-height:42px;
    padding:0 .95rem;
    border:1px solid var(--linen-dk);
    border-radius:999px;
    background:#fff;
    color:var(--espresso);
    font-size:.76rem;
    letter-spacing:.06em;
    text-transform:uppercase;
    font-weight:600;
    transition:transform .2s ease,border-color .2s ease,color .2s ease,background .2s ease;
}
.product-detail-share-icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:1rem;
    height:1rem;
    line-height:1;
    flex-shrink:0;
}
.product-detail-share-icon svg{
    width:100%;
    height:100%;
    display:block;
}
.product-detail-share-btn:hover{
    border-color:var(--brass);
    color:var(--brass);
    transform:translateY(-1px);
}
.product-detail-share-btn.is-whatsapp{ color:#1f7a4f; }
.product-detail-share-btn.is-telegram{ color:#1f6ea6; }
.product-detail-share-status{
    min-height:1.15rem;
    margin-top:.55rem;
    font-size:.78rem;
    color:var(--taupe);
}
@media (max-width: 768px){
    .product-detail-offer{
        padding:.95rem;
    }
    .product-detail-offer-actions{
        display:grid;
        grid-template-columns:1fr;
    }
    .product-detail-offer-btn{
        width:100%;
    }
    .product-detail-share-actions{
        display:grid;
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
    .product-detail-share-btn{
        width:100%;
        min-height:46px;
        padding:.7rem .8rem;
        flex-direction:column;
        gap:.3rem;
        font-size:.67rem;
        letter-spacing:.04em;
    }
    .product-detail-share-icon{
        width:1.05rem;
        height:1.05rem;
    }
}

@media (max-width: 480px){
    .product-detail-share-actions{
        grid-template-columns:1fr;
    }
}

/* ── Wishlist button — product detail page ───────────────────── */
.product-detail-wishlist-btn {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .62rem 1.1rem;
    border: 1.5px solid rgba(0,0,0,.15);
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
    font-family: inherit;
    font-size: .88rem;
    font-weight: 500;
    color: var(--taupe, #6B7280);
    transition: all .2s;
    white-space: nowrap;
    position: relative;
}
.product-detail-wishlist-btn:hover {
    border-color: #CC2B35;
    color: #CC2B35;
    background: rgba(204,43,53,.04);
}
.product-detail-wishlist-btn.wa-wl-liked {
    border-color: #CC2B35;
    background: rgba(204,43,53,.06);
    color: #CC2B35;
    font-weight: 600;
}
.product-detail-wishlist-btn.wa-wl-liked svg { fill: #CC2B35; stroke: #CC2B35; }
.product-detail-wishlist-btn.wa-wl-liked .pdt-wl-label::before { content: 'Tersimpan'; }
.product-detail-wishlist-btn:not(.wa-wl-liked) .pdt-wl-label::before { content: 'Simpan'; }
.pdt-wl-label { pointer-events: none; }
.pdt-wl-count {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 18px; height: 18px; padding: 0 3px;
    background: #CC2B35; color: #fff;
    border-radius: 999px; font-size: .65rem; font-weight: 700;
}
@keyframes wlBounce2{0%,100%{transform:scale(1)}40%{transform:scale(1.35)}70%{transform:scale(.9)}}
.wa-wl-bounce2 { animation: wlBounce2 .4s ease; }

/* ── Marketplace Design Detail — Specs, Estimasi & Deliverables ── */

/* Estimasi biaya bangun */
.mkt-estimasi-block { border-top: 1px solid rgba(28,54,100,.08); padding-top: 1.1rem; }
.mkt-estimasi-wrap { margin-top: .6rem; }
.mkt-estimasi-luas { font-size: .85rem; color: var(--taupe, #5A7099); margin-bottom: .75rem; }
.mkt-estimasi-luas strong { color: var(--charcoal, #0F1E3D); }
.mkt-estimasi-options { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: .75rem; }
.mkt-est-btn {
    flex: 1; min-width: 90px;
    display: flex; flex-direction: column; align-items: center; gap: .15rem;
    padding: .55rem .5rem;
    border: 1.5px solid rgba(28,54,100,.15);
    border-radius: 8px;
    background: #fff;
    cursor: pointer; font-family: inherit;
    font-size: .82rem; font-weight: 600;
    color: var(--espresso, #1C3664);
    transition: all .2s;
}
.mkt-est-btn span { font-size: .65rem; font-weight: 400; color: var(--taupe, #5A7099); }
.mkt-est-btn:hover { border-color: var(--espresso, #1C3664); background: var(--linen, #F4F7FF); }
.mkt-est-active { border-color: var(--espresso, #1C3664) !important; background: var(--espresso, #1C3664) !important; color: #fff !important; }
.mkt-est-active span { color: rgba(255,255,255,.7) !important; }
.mkt-estimasi-result {
    display: flex; flex-direction: column; gap: .2rem;
    padding: .85rem 1rem;
    background: var(--linen, #F4F7FF);
    border: 1px solid rgba(28,54,100,.1);
    border-radius: 10px;
}
.mkt-est-label { font-size: .7rem; text-transform: uppercase; letter-spacing: .08em; color: var(--taupe, #5A7099); }
.mkt-est-range { font-size: 1.15rem; font-weight: 800; color: var(--espresso, #1C3664); }
.mkt-est-note { font-size: .68rem; color: var(--taupe, #5A7099); font-style: italic; }


.mkt-specs-block { border-top: 1px solid rgba(28,54,100,.08); padding-top: 1.1rem; }

.mkt-specs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: .75rem;
    margin-top: .6rem;
}
.mkt-spec-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: .3rem;
    padding: .75rem .5rem;
    background: var(--linen, #F4F7FF);
    border: 1px solid rgba(28,54,100,.1);
    border-radius: 12px;
}
.mkt-spec-card svg {
    width: 22px; height: 22px;
    color: var(--espresso, #1C3664);
    flex-shrink: 0;
}
.mkt-spec-card-val {
    font-size: .92rem;
    font-weight: 700;
    color: var(--charcoal, #0F1E3D);
    line-height: 1.2;
}
.mkt-spec-card-lbl {
    font-size: .65rem;
    font-weight: 500;
    color: var(--taupe, #5A7099);
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* Deliverables */
.mkt-deliverables-block { border-top: 1px solid rgba(28,54,100,.08); padding-top: 1.1rem; }
.mkt-deliverables {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .6rem;
    margin-top: .6rem;
}
.mkt-deliverable {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    padding: .7rem .8rem;
    background: var(--linen, #F4F7FF);
    border: 1px solid rgba(28,54,100,.08);
    border-radius: 10px;
}
.mkt-deliverable svg {
    width: 20px; height: 20px;
    flex-shrink: 0;
    color: var(--brass, #CC2B35);
    margin-top: .1rem;
}
.mkt-deliverable div { display: flex; flex-direction: column; gap: .1rem; }
.mkt-deliverable strong { font-size: .83rem; color: var(--charcoal, #0F1E3D); }
.mkt-deliverable span { font-size: .72rem; color: var(--taupe, #5A7099); }

/* ── Tier cards (radio, 1 pilihan) ──────────────────────────── */
.mkt-tier-cards {
    display: flex;
    flex-direction: column;
    gap: .6rem;
    margin-top: .5rem;
}
.mkt-tier-card {
    position: relative;
    display: block;
    padding: .9rem 1rem;
    border: 2px solid rgba(28,54,100,.12);
    border-radius: 12px;
    background: #fff;
    cursor: pointer;
    transition: border-color .2s, box-shadow .2s, background .2s;
}
.mkt-tier-card:hover { border-color: rgba(28,54,100,.3); background: var(--linen, #F4F7FF); }
.mkt-tier-card--active {
    border-color: var(--espresso, #1C3664) !important;
    background: var(--linen, #F4F7FF);
    box-shadow: 0 0 0 3px rgba(28,54,100,.08);
}
.mkt-tier-radio {
    position: absolute;
    opacity: 0;
    width: 0; height: 0;
}
.mkt-tier-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
    margin-bottom: .5rem;
}
.mkt-tier-card-name {
    font-size: .95rem;
    font-weight: 700;
    color: var(--charcoal, #0F1E3D);
}
.mkt-tier-card--active .mkt-tier-card-name::before {
    content: '✓ ';
    color: var(--espresso, #1C3664);
}
.mkt-tier-card-price {
    font-size: .95rem;
    font-weight: 800;
    color: var(--brass, #CC2B35);
    white-space: nowrap;
}
.mkt-tier-card-desc {
    font-size: .78rem;
    color: var(--taupe, #5A7099);
    margin: 0 0 .5rem;
    line-height: 1.5;
}
.mkt-tier-card-includes {
    list-style: none;
    padding: 0; margin: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .2rem .5rem;
}
.mkt-tier-card-includes li {
    display: flex;
    align-items: center;
    gap: .3rem;
    font-size: .75rem;
    color: var(--taupe, #5A7099);
}
.mkt-tier-card-includes svg {
    width: 12px; height: 12px;
    flex-shrink: 0;
    color: var(--espresso, #1C3664);
}
.mkt-tier-card--active .mkt-tier-card-includes svg { color: var(--brass, #CC2B35); }

/* Flow alur beli */
.mkt-buy-flow {
    display: flex;
    align-items: center;
    gap: .3rem;
    flex-wrap: wrap;
    margin-top: .85rem;
    padding: .65rem .85rem;
    background: rgba(28,54,100,.04);
    border: 1px solid rgba(28,54,100,.1);
    border-radius: 10px;
}
.mkt-flow-step {
    display: flex;
    align-items: center;
    gap: .35rem;
    font-size: .72rem;
    font-weight: 600;
    color: var(--taupe, #5A7099);
}
.mkt-flow-step span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px; height: 18px;
    border-radius: 50%;
    background: var(--espresso, #1C3664);
    color: #fff;
    font-size: .65rem;
    font-weight: 700;
    flex-shrink: 0;
}
.mkt-flow-step--last { color: var(--espresso, #1C3664); font-weight: 700; }
.mkt-flow-step--last span { background: var(--brass, #CC2B35); }
.mkt-buy-flow > svg { width: 14px; height: 14px; color: rgba(28,54,100,.3); flex-shrink: 0; }

/* Preview sampel dokumen */
.mkt-preview-block { border-top: 1px solid rgba(28,54,100,.08); padding-top: 1.1rem; }
.mkt-preview-teaser { margin-top: .6rem; }
.mkt-preview-pages {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .6rem;
    margin-bottom: .75rem;
}
.mkt-preview-page {
    display: flex; flex-direction: column; align-items: center; gap: .35rem;
    font-size: .68rem; color: var(--taupe, #5A7099); text-align: center;
}
.mkt-preview-page-img {
    position: relative;
    width: 100%; aspect-ratio: 0.707;
    background: var(--linen, #F4F7FF);
    border: 1px solid rgba(28,54,100,.12);
    border-radius: 6px;
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}
.mkt-preview-page-img svg { width: 32px; height: 32px; color: rgba(28,54,100,.25); }
.mkt-preview-watermark {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: .6rem; font-weight: 900;
    letter-spacing: .2em; color: rgba(204,43,53,.18);
    transform: rotate(-30deg);
    pointer-events: none;
}
.mkt-preview-locked .mkt-preview-page-img {
    background: rgba(28,54,100,.06);
    border-style: dashed;
}
.mkt-preview-locked .mkt-preview-page-img svg { color: rgba(28,54,100,.3); width: 24px; height: 24px; }
.mkt-preview-note {
    display: flex; align-items: flex-start; gap: .4rem;
    font-size: .75rem; color: var(--taupe, #5A7099);
    background: rgba(204,43,53,.04);
    border: 1px solid rgba(204,43,53,.12);
    border-radius: 8px; padding: .65rem .85rem;
    line-height: 1.5;
}
.mkt-preview-note svg { width: 15px; height: 15px; flex-shrink: 0; color: var(--brass, #CC2B35); margin-top: .1rem; }

@media (max-width: 768px) {
    .mkt-preview-pages {
        display: flex;
        grid-template-columns: none;
    }
    .mkt-preview-page-img {
        aspect-ratio: 4 / 3;
    }
}

/* Marketplace sticky CTA */
.mkt-sticky-cta { background: var(--espresso, #1C3664) !important; }
.mkt-sticky-btn {
    background: var(--brass, #CC2B35) !important;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .65rem 1.2rem;
    border-radius: 8px;
    color: #fff;
    font-size: .88rem;
    font-weight: 700;
    transition: background .2s;
    white-space: nowrap;
}
.mkt-sticky-btn:hover { background: #A51F27 !important; }

@media (max-width: 640px) {
    .mkt-deliverables { grid-template-columns: 1fr; }
    .mkt-specs-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
