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

.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-fill, 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: 1fr 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(4, 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; }

/* 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(3, 1fr); }
}
</style>
