/*
 * Product detail (PDP) - matched to the Figma "Shop / Product detail" screen
 * (file 1T8btiNYCKtIVdcZHZ3xa8). Loaded only on the product page.
 */

.pdp__top {
    display: grid;
    grid-template-columns: minmax(0, 0.7fr) minmax(0, 1fr);
    gap: 48px;
    align-items: start;
}

@media (max-width: 880px) {
    .pdp__top {
        grid-template-columns: minmax(0, 1fr);
        gap: 32px;
    }
}

/* ============================================================ Gallery */

.pdp-gallery {
    position: sticky;
    top: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

@media (max-width: 880px) {
    .pdp-gallery {
        position: static;
    }
}

.pdp-gallery__stage {
    position: relative;
    aspect-ratio: 1 / 1;
    background: var(--color-bg-surface);
    border: 1px solid var(--color-border-default);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.pdp-gallery__img {
    position: absolute;
    inset: 0;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding: 24px;
    object-fit: contain;
    opacity: 0;
    transition: opacity 200ms ease;
    mix-blend-mode: multiply;
}

.pdp-gallery__img.is-active {
    opacity: 1;
}

.pdp-gallery__placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.pdp-gallery__placeholder .ui-icon {
    color: var(--color-border-strong);
}

.pdp-gallery__thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.pdp-gallery__thumb {
    width: 72px;
    height: 72px;
    padding: 0;
    border: 1.5px solid var(--color-border-default);
    border-radius: var(--radius-md);
    background-color: var(--color-bg-surface);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 78%;
    background-blend-mode: multiply;
    cursor: pointer;
    transition: border-color 150ms ease;
}

.pdp-gallery__thumb:hover {
    border-color: var(--color-border-strong);
}

.pdp-gallery__thumb.is-active {
    border-color: var(--color-bg-brand);
}

/* ============================================================ Summary */

.pdp-summary {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.pdp-summary__brand {
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.pdp-summary__brand + .pdp-summary__title {
    margin-top: -12px;
}

.pdp-summary__title {
    margin: 0;
    font-size: var(--text-3xl);
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.6px;
    color: var(--color-text-primary);
}

.pdp-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 36px;
    margin: 0;
}

.pdp-meta__item {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.pdp-meta dt {
    font-size: var(--text-2xs);
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.pdp-meta dd {
    margin: 0;
    font-size: var(--text-md);
    font-weight: 500;
    color: var(--color-text-primary);
}

.pdp-stock {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
}

.pdp-stock__note {
    font-size: var(--text-base);
    color: var(--color-text-secondary);
}

/* ============================================================ Buy card */

.pdp-buy {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-top: 4px;
    padding: 22px;
    background: var(--color-bg-surface);
    border: 1px solid var(--color-border-default);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.pdp-buy__price {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pdp-buy__amount {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 8px;
}

.pdp-buy__amount strong {
    font-size: var(--text-4xl);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -1px;
    color: var(--color-text-primary);
}

.pdp-buy__was {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.pdp-buy__per {
    font-size: var(--text-md);
    color: var(--color-text-muted);
}

.pdp-buy__vat {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.pdp-buy__onrequest {
    margin: 0;
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-text-primary);
}

.pdp-buy__hint,
.pdp-buy__gate-sub {
    margin: 0;
    font-size: var(--text-base);
    color: var(--color-text-secondary);
}

.pdp-buy__gate-sub a,
.pdp-buy__hint a {
    color: var(--color-text-brand);
    font-weight: 500;
}

.pdp-buy--gate {
    gap: 14px;
}

.pdp-buy__gate {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    font-size: var(--text-md);
    color: var(--color-text-secondary);
}

.pdp-buy__gate .ui-icon {
    flex: 0 0 auto;
    color: var(--color-text-muted);
}

/* Staffel table */
.pdp-staffel {
    border: 1px solid var(--color-border-default);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.pdp-staffel__title {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0;
    padding: 10px 14px;
    background: var(--color-bg-subtle);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--color-text-secondary);
}

.pdp-staffel__title .ui-icon {
    color: var(--color-text-brand);
}

.pdp-staffel table {
    width: 100%;
    border-collapse: collapse;
}

.pdp-staffel thead th {
    padding: 8px 14px;
    font-size: var(--text-2xs);
    font-weight: 600;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--color-text-muted);
    text-align: right;
    border-bottom: 1px solid var(--color-border-default);
}

.pdp-staffel thead th:first-child {
    text-align: left;
}

.pdp-staffel tbody td {
    padding: 9px 14px;
    font-size: var(--text-base);
    color: var(--color-text-primary);
    text-align: right;
    border-bottom: 1px solid var(--color-border-default);
}

.pdp-staffel tbody td:first-child {
    text-align: left;
    color: var(--color-text-secondary);
}

.pdp-staffel tbody tr:last-child td {
    border-bottom: 0;
}

.pdp-staffel tbody tr:hover td {
    background: var(--color-bg-brand-subtle);
}

.pdp-staffel__save {
    font-weight: 600;
    color: var(--color-status-success-fg);
}

/* Quantity + actions */
.pdp-buy__row {
    display: flex;
    gap: 12px;
}

/* .pdp-qty stepper styles live in shop/pages.css (shared with the cart). */

.pdp-buy__submit {
    flex: 1 1 auto;
}

.pdp-buy__backorder {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0;
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
}

.pdp-buy__backorder .ui-icon {
    color: var(--color-text-muted);
}

.pdp-buy__datasheet {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 2px;
    font-size: var(--text-base);
    font-weight: 500;
    color: var(--color-text-brand);
    text-decoration: none;
}

.pdp-buy__datasheet:hover {
    text-decoration: underline;
}

.pdp-buy__datasheet em {
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    background: var(--color-bg-brand-subtle);
    font-size: var(--text-2xs);
    font-style: normal;
    font-weight: 600;
}

/* ============================================================ Description
   Open editorial copy rather than a boxed drawer: detached from the buy area
   with a hairline rule and set at a comfortable reading measure, so the
   omschrijving reads as prose - distinct from the spec/datasheet cards below. */

.pdp-description {
    margin-top: 48px;
    padding-top: 40px;
    border-top: 1px solid var(--color-border-default);
}

.pdp-description + .pdp-accordions {
    margin-top: 40px;
}

.pdp-description__title {
    margin: 0 0 14px;
    font-size: var(--text-2xl);
    font-weight: 700;
    letter-spacing: -0.4px;
    color: var(--color-text-primary);
}

/* ============================================================ Accordions */

.pdp-accordions {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 44px;
}

.pdp-acc {
    background: var(--color-bg-surface);
    border: 1px solid var(--color-border-default);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.pdp-acc__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px;
    list-style: none;
    cursor: pointer;
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text-primary);
}

.pdp-acc__head::-webkit-details-marker {
    display: none;
}

.pdp-acc__chev {
    color: var(--color-text-muted);
    transition: transform 200ms ease;
}

.pdp-acc[open] .pdp-acc__chev {
    transform: rotate(180deg);
}

.pdp-acc__body {
    padding: 0 22px 22px;
}

.pdp-specs {
    width: 100%;
    border-collapse: collapse;
}

.pdp-specs tr {
    border-top: 1px solid var(--color-border-default);
}

.pdp-specs th {
    width: 38%;
    padding: 11px 0;
    font-size: var(--text-base);
    font-weight: 500;
    text-align: left;
    color: var(--color-text-secondary);
}

.pdp-specs td {
    padding: 11px 0;
    font-size: var(--text-base);
    color: var(--color-text-primary);
}

.pdp-prose {
    /* One full-width block, aligned with the spec table below - not a narrow
       left strip and not split into columns. */
    font-size: var(--text-md);
    line-height: 1.75;
    color: var(--color-text-secondary);
}

.pdp-docs {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.pdp-docs a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border: 1px solid var(--color-border-default);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    font-weight: 500;
    color: var(--color-text-primary);
    text-decoration: none;
}

.pdp-docs a:hover {
    border-color: var(--color-border-strong);
    background: var(--color-bg-subtle);
}

.pdp-docs a .ui-icon:first-child {
    color: var(--color-text-brand);
}

.pdp-docs__dl {
    margin-left: auto;
    color: var(--color-text-muted);
}

/* ============================================================ Small screens */

@media (max-width: 420px) {
    /* On very narrow phones the order button can't sit beside the stepper
       without clipping its label - drop it onto its own full-width row. */
    .pdp-buy__row {
        flex-wrap: wrap;
    }

    .pdp-buy__submit {
        flex: 1 1 100%;
    }

    .pdp-description {
        margin-top: 36px;
        padding-top: 32px;
    }
}
