/* ═══════════════════════════════════════════════
   Mangrove Product Pages — Styles
   Matched to Phire Group theme tokens & conventions
   Pattern reference: mmh-styles.css (Media Hub plugin)
   ═══════════════════════════════════════════════ */

/* Inherit Phire's CSS variables, with fallbacks for safety */
.mpp-product {
    --mpp-varpad: 0px;
}

/* ─── Reset specific to the plugin's container ─── */
.mpp-product,
.mpp-product * {
    box-sizing: border-box;
}

.mpp-product {
    color: var(--color-dark-gray, #3f3a35);
    font-size: 16px;
    line-height: 1.55;
    letter-spacing: 0.5px;
}

.mpp-product img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* Section heading shared style — matches theme's section heading patterns */
.mpp-section-heading {
    font-size: calc(var(--html-line-height, 1.5) / var(--html-font-size, 1) * 1.5 * 1rem);
    font-weight: 400;
    font-family: aktiv-grotesk-extended, sans-serif;
    line-height: 1.3;
    letter-spacing: 0.5px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0 0 32px 0;
    text-transform: none; /* Override theme's heading uppercase */
}

/* Image placeholder — used while real images are pending */
.mpp-image-placeholder {
    width: 100%;
    height: 100%;
    min-height: 240px;
    background: linear-gradient(135deg, #d7d0bf 0%, #e8e4dd 100%);
    border-radius: 6px;
}

/* ═══════════════════════════════════════════════
   1. HERO SECTION
   ═══════════════════════════════════════════════ */
.mpp-hero {
    padding-block: 50px 60px;
    padding-inline: 12px;
}

.mpp-hero-wrap {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
    /* Shaded panel treatment matching the Figma — uses Phire's warm cream */
    background-color: #ede7de;
    border-radius: 6px;
    padding: 24px;
}

.mpp-hero-image {
    background: #f5f1ec;
    border-radius: 6px;
    overflow: hidden;
}

.mpp-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 1 / 1;
}

.mpp-hero-image .mpp-image-placeholder {
    aspect-ratio: 1 / 1;
    min-height: auto;
}

.mpp-hero-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.mpp-designer {
    font-size: clamp(1.1rem, 2vw, 1.4rem);
    font-weight: 400;
    line-height: 1.3;
    color: var(--color-dark-gray, #3f3a35);
    margin: 8px 0 0;
    text-transform: none;
    font-style: normal;
}

.mpp-product-name {
    font-size: clamp(2rem, 5vw, 3.2rem);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -0.5px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0;
    text-transform: none; /* Override theme's heading uppercase */
    /* NOT aktiv-grotesk-extended — using inherited body font for product name to match Figma's softer headline treatment */
}

.mpp-summary-specs {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.mpp-summary-specs .mpp-spec-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.mpp-summary-specs .mpp-spec-label {
    font-size: 11px;
    font-family: aktiv-grotesk-extended, sans-serif;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: var(--color-green, #8b9a5d);
    margin: 0;
}

.mpp-summary-specs .mpp-spec-value {
    font-size: 16px;
    line-height: 1.55;
    letter-spacing: 0.5px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0;
}

.mpp-description p {
    font-size: 16px;
    line-height: 1.55;
    letter-spacing: 0.5px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0 0 1em 0;
}

.mpp-description p:last-child {
    margin-bottom: 0;
}

.mpp-cta-purchase {
    /* Inherits from theme's .cta class — added margin only */
    margin-top: 16px;
    align-self: flex-start;
    color: var(--color-dark-gray, #3f3a35);
    background-color: #fff;
    border: 1px solid var(--color-dark-gray, #3f3a35);
    text-decoration: none;
}

.mpp-cta-purchase:hover {
    background-color: var(--color-green, #8b9a5d);
    border-color: var(--color-green, #8b9a5d);
    color: #fff;
}

/* Hero — desktop layout */
@media (min-width: 768px) {
    .mpp-hero {
        padding-block: 60px 80px;
    }

.mpp-hero-wrap {
        grid-template-columns: 0.75fr 1fr;
        gap: 60px;
        align-items: start;
        padding: 40px;
    }
}

@media (min-width: 1024px) {
    .mpp-product {
        --mpp-varpad: calc(var(--html-line-height) / var(--html-font-size) * .75 * 1rem);
    }
    .mpp-hero {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
    .mpp-hero-wrap {
        gap: 80px;
        padding: 60px;
    }
}

@media (min-width: 1280px) {
    .mpp-product {
        --mpp-varpad: calc(var(--html-line-height) / var(--html-font-size) * 2 * 1rem);
    }
    .mpp-hero {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1680px) {
    .mpp-product {
        --mpp-varpad: calc(var(--html-line-height) / var(--html-font-size) * 3 * 1rem);
    }
    .mpp-hero {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1400px) {
    .mpp-hero-wrap {
        padding: 80px 100px;
    }
}

/* ═══════════════════════════════════════════════
   2. PRODUCT DETAILS SECTION
   ═══════════════════════════════════════════════ */
.mpp-details {
    padding-block: 40px 60px;
    padding-inline: 12px;
}

@media (min-width: 1024px) {
    .mpp-details {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1280px) {
    .mpp-details {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1680px) {
    .mpp-details {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

.mpp-details-wrap {
    /* Inherits width from parent's padding-inline */
}

.mpp-gallery {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    margin-bottom: 50px;
}

.mpp-gallery-item {
    margin: 0;
}

.mpp-gallery-image {
    position: relative;
    background: #f5f1ec;
    border-radius: 6px;
    overflow: hidden;
    aspect-ratio: 1 / 1;
}

.mpp-gallery-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mpp-gallery-image .mpp-image-placeholder {
    width: 100%;
    height: 100%;
    min-height: auto;
}

.mpp-gallery-label {
    position: absolute;
    bottom: 12px;
    left: 12px;
    background: rgba(63, 58, 53, 0.85);
    color: #fff;
    font-size: 11px;
    font-family: aktiv-grotesk-extended, sans-serif;
    text-transform: uppercase;
    letter-spacing: 2px;
    padding: 6px 12px;
    border-radius: 4px;
}

.mpp-specs-grid {
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
}

.mpp-spec-block {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.mpp-spec-label-lg {
    font-size: 11px;
    font-family: aktiv-grotesk-extended, sans-serif;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: var(--color-green, #8b9a5d);
    margin: 0;
}

.mpp-spec-value-lg {
    font-size: 16px;
    line-height: 1.55;
    letter-spacing: 0.5px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0;
}

@media (min-width: 768px) {
    .mpp-gallery {
        grid-template-columns: repeat(3, 1fr);
        gap: 80px;
        margin-bottom: 60px;
    }

    .mpp-specs-grid {
        grid-template-columns: 1fr 1fr;
        gap: 40px 60px;
    }
}

/* ═══════════════════════════════════════════════
   3. DOWNLOADS SECTION
   ═══════════════════════════════════════════════ */
.mpp-downloads {
    padding-block: 40px 60px;
    padding-inline: 12px;
}

@media (min-width: 1024px) {
    .mpp-downloads {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1280px) {
    .mpp-downloads {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1680px) {
    .mpp-downloads {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

.mpp-downloads-wrap {
    /* Inherits width from parent's padding-inline */
}

.mpp-downloads-tablist {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
    padding: 16px 24px;
    border: 1px solid #d4d7cd;
    border-radius: 6px;
    margin-bottom: 24px;
    background: rgb(241 237 232 / .4);
    overflow-x: auto;
}

.mpp-downloads-label {
    font-size: 11px;
    font-family: aktiv-grotesk-extended, sans-serif;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 2.5px;
    color: var(--color-dark-gray, #3f3a35);
    margin-right: 24px;
    flex-shrink: 0;
}

.mpp-tab-btn {
    background: transparent;
    border: 0;
    border-bottom: 2px solid transparent;
    color: var(--color-dark-gray, #3f3a35);
    padding: 8px 12px;
    font-family: inherit;
    font-size: 14px;
    line-height: 1.4;
    letter-spacing: 0.3px;
    cursor: pointer;
    transition: color 0.15s linear, border-color 0.15s linear;
    white-space: nowrap;
}

.mpp-tab-btn:hover {
    color: var(--color-green, #8b9a5d);
}

.mpp-tab-btn.active {
    color: var(--color-green, #8b9a5d);
    border-bottom-color: var(--color-green, #8b9a5d);
    font-weight: 500;
}

.mpp-tab-btn:focus-visible {
    outline: 2px solid var(--color-green, #8b9a5d);
    outline-offset: 2px;
}

.mpp-downloads-panels {
    border: 1px solid #d4d7cd;
    border-radius: 6px;
    background: rgb(241 237 232 / .4);
    min-height: 200px;
}

.mpp-tab-panel {
    padding: 40px;
    display: none;
}

.mpp-tab-panel.active {
    display: block;
}

.mpp-panel-content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    align-items: start;
}

.mpp-panel-text {
    flex: 1;
}

.mpp-panel-heading {
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.3px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0 0 16px 0;
    text-transform: none;
}

.mpp-panel-description {
    font-size: 16px;
    line-height: 1.55;
    letter-spacing: 0.5px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0;
    max-width: 700px;
}

.mpp-panel-action {
    flex-shrink: 0;
}

.mpp-cta-download,
.mpp-cta-inquire {
    /* Inherits from theme's .cta class */
    color: #fff;
    background-color: var(--color-green, #8b9a5d);
    border: 1px solid var(--color-green, #8b9a5d);
    text-decoration: none;
}

.mpp-cta-download:hover,
.mpp-cta-inquire:hover {
    background-color: var(--color-dark-gray, #3f3a35);
    border-color: var(--color-dark-gray, #3f3a35);
}

@media (min-width: 768px) {
    .mpp-tab-panel {
        padding: 50px;
    }

    .mpp-panel-content {
        grid-template-columns: 1fr auto;
        gap: 40px;
        align-items: center;
    }
}

/* ═══════════════════════════════════════════════
   4. RELATED PRODUCTS SECTION
   ═══════════════════════════════════════════════ */
.mpp-related {
    padding-block: 40px 80px;
    padding-inline: 12px;
}

@media (min-width: 1024px) {
    .mpp-related {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1280px) {
    .mpp-related {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

@media (min-width: 1680px) {
    .mpp-related {
        padding-inline: calc(28px + var(--mpp-varpad));
    }
}

.mpp-related-wrap {
    /* Inherits width from parent's padding-inline */
}

.mpp-related-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
}

.mpp-related-card {
    display: block;
    text-decoration: none;
    color: inherit;
    background: rgb(241 237 232 / .85);
    border: 1px solid #d4d7cd;
    border-radius: 6px;
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.mpp-related-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(63, 58, 53, 0.1);
}

.mpp-related-image {
    width: 100%;
    aspect-ratio: 4 / 3;
    background: #f5f1ec;
    overflow: hidden;
}

.mpp-related-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.mpp-related-card:hover .mpp-related-image img {
    transform: scale(1.04);
}

.mpp-related-info {
    padding: 24px;
}

.mpp-related-name {
    font-size: 1.5rem;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -0.3px;
    color: var(--color-dark-gray, #3f3a35);
    margin: 0 0 12px 0;
    text-transform: none;
}

.mpp-related-spec {
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 0.3px;
    color: var(--color-gray, #6c6867);
    margin: 0 0 4px 0;
}

@media (min-width: 768px) {
    .mpp-related-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 24px;
    }

    /* When only 1 related product, don't stretch to full width */
    .mpp-related-grid:has(.mpp-related-card:only-child) {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .mpp-related-grid:has(.mpp-related-card:only-child) .mpp-related-card {
        max-width: 400px;
    }
}

/* ═══════════════════════════════════════════════
   ACCESSIBILITY
   ═══════════════════════════════════════════════ */
.mpp-product .cta:focus-visible,
.mpp-product a:focus-visible {
    outline: 2px solid var(--color-green, #8b9a5d);
    outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
    .mpp-related-card,
    .mpp-related-image img,
    .mpp-tab-btn,
    .mpp-cta-purchase,
    .mpp-cta-download,
    .mpp-cta-inquire {
        transition: none;
    }
}
