/**
 * ═══════════════════════════════════════════════════════════════════════════
 * @DOSYA          product-page.css
 * @ETIKET         URUN-SAYFA — bireysel ürün detayı (tüm menu_layout’larda ortak)
 * @YUKLENME       layouts/public.php
 * @HTML           views/public/menu/product.php → .qm-product-page__*
 * @TEMA-RENK      --qm-primary, --qm-card-bg (Admin → Tema renkleri, inline :root)
 * @TEMA-PRESET    Gölge/köşe farkları → menu-layouts-product.css [PRESET: modern] vb.
 * @REHBER         assets/css/CSS-REHBER.md
 * ═══════════════════════════════════════════════════════════════════════════
 */

/* [FIX: PRESET-KATMANI] Bu dosya ürün detayının ortak iskeletidir.
   Görünüm/preset farkları menu-layouts-product.css içinde body.menu-layout-* üzerinden gelir. */

/* [ETIKET: URUN-SAYFA] Kök değişkenler — görsel oranı product.php inline --product-aspect */
.qm-product-page {
    --product-aspect: 4 / 3;
    --product-radius: var(--qm-radius, 1.25rem);
    --product-border: var(--qm-border);
    --product-muted: var(--qm-muted);
    --product-soft: var(--qm-primary-soft);
    --product-shadow: 0 18px 50px color-mix(in srgb, var(--qm-body-color) 10%, transparent);
    max-width: var(--qm-content-max, min(100%, 72rem));
    margin-inline: auto;
    padding: var(--qm-space-page, clamp(0.75rem, 2vw, 1.25rem));
    overflow-x: clip;
    color: var(--qm-body-color);
}

.qm-product-page,
.qm-product-page * {
    box-sizing: border-box;
}

.qm-product-page img,
.qm-product-page video {
    max-width: 100%;
}

/* [ETIKET: URUN-TOOLBAR] Geri / paylaş üst çubuğu */
.qm-product-page__topbar {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.9rem;
}

.qm-product-page__back,
.qm-product-page__share {
    border: var(--qm-product-surface-border, 1px solid var(--product-border));
    background: var(--qm-product-topbar-bg, color-mix(in srgb, var(--qm-card-bg) 94%, transparent));
    color: var(--qm-body-color);
    min-height: 42px;
    box-shadow: var(--qm-product-surface-shadow, 0 8px 24px color-mix(in srgb, var(--qm-body-color) 8%, transparent));
    backdrop-filter: var(--qm-tile-backdrop, none);
    -webkit-backdrop-filter: var(--qm-tile-backdrop, none);
    transition: var(--qm-transition, all 0.3s ease);
}

.qm-product-page__back:hover,
.qm-product-page__share:hover {
    color: var(--qm-primary);
    border-color: color-mix(in srgb, var(--qm-primary) 30%, var(--product-border));
    background: color-mix(in srgb, var(--qm-primary) 8%, var(--qm-card-bg));
}

.qm-product-page__back {
    min-width: 0;
    max-width: 76%;
}

.qm-product-page__back span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.qm-product-page__share {
    margin-left: auto;
    width: 42px;
    padding-inline: 0;
}

.qm-product-page__crumbs a {
    color: inherit;
    text-decoration: none;
}

/* [ETIKET: URUN-HERO] Ana hero — görsel + başlık + fiyat (preset: menu-layouts-product.css) */
.qm-product-page__hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    align-items: stretch;
    border: var(--qm-product-hero-border, 1px solid var(--product-border));
    border-left: var(--qm-product-hero-border-left, var(--qm-product-hero-border, 1px solid var(--product-border)));
    border-radius: var(--qm-radius, var(--product-radius));
    background: var(--qm-product-hero-bg, var(--qm-card-bg));
    box-shadow: var(--qm-product-hero-shadow, var(--product-shadow));
    overflow: hidden;
    transition:
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.qm-product-page__hero--no-media {
    grid-template-columns: 1fr;
}

.qm-product-page__figure {
    min-width: 0;
    margin: 0;
    background: var(--product-soft);
}

.qm-product-page__cover {
    width: 100%;
    height: clamp(260px, 38vw, 430px);
    aspect-ratio: var(--product-aspect);
    overflow: hidden;
    border-bottom: var(--qm-product-surface-border, none);
}

.qm-product-page__cover img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.qm-product-page__intro {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1rem;
    padding: clamp(1.1rem, 3vw, 2rem);
}

.qm-product-page__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    width: fit-content;
    max-width: 100%;
    padding: 0.38rem 0.68rem;
    border-radius: 999px;
    background: var(--product-soft);
    color: var(--qm-primary);
    border: 1px solid color-mix(in srgb, var(--qm-primary) 18%, transparent);
    font-size: 0.78rem;
    font-weight: 650;
}

.qm-product-page__title {
    margin: 0;
    font-size: clamp(1.55rem, 4vw, 2.55rem);
    line-height: 1.08;
    letter-spacing: -0.035em;
    overflow-wrap: anywhere;
    color: var(--qm-body-color);
}

.qm-product-page__lede {
    max-width: 58ch;
    margin: 0.7rem 0 0;
    color: var(--product-muted);
    font-size: clamp(0.95rem, 1.8vw, 1.05rem);
    line-height: 1.55;
}

.qm-product-page__purchase-row {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 0.25rem;
}

/* [ETIKET: URUN-FIYAT] Fiyat kutusu — [TEMA: RENK] --qm-primary */
.qm-product-page__price-box {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.1rem;
    min-width: min(100%, 180px);
    padding: 0.85rem 1rem;
    border: var(--qm-product-surface-border, 1px solid color-mix(in srgb, var(--qm-primary) 22%, var(--product-border)));
    border-radius: calc(var(--qm-radius-sm, var(--product-radius)) * 0.85);
    overflow: hidden;
    background: var(--qm-product-surface-bg, color-mix(in srgb, var(--qm-primary) 8%, var(--qm-card-bg)));
    box-shadow: var(--qm-product-surface-shadow, none);
    backdrop-filter: var(--qm-tile-backdrop, none);
    -webkit-backdrop-filter: var(--qm-tile-backdrop, none);
    background-clip: padding-box;
}

.qm-product-page__price-label {
    color: var(--product-muted);
    font-size: 0.75rem;
    font-weight: 650;
    text-transform: uppercase;
    letter-spacing: 0.055em;
}

.qm-product-page__price-old {
    color: var(--product-muted);
    font-size: 0.88rem;
    text-decoration: line-through;
}

.qm-product-page__price {
    margin: 0;
    font-size: clamp(1.45rem, 4vw, 2rem);
    font-weight: 800;
    line-height: 1.1;
    white-space: nowrap;
    color: var(--qm-primary);
}

.qm-product-page__flags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.qm-product-page__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    max-width: 100%;
    padding: 0.42rem 0.65rem;
    border-radius: 999px;
    border: var(--qm-product-surface-border, 1px solid var(--product-border));
    overflow: hidden;
    background: var(--qm-product-surface-bg, color-mix(in srgb, var(--qm-card-bg) 92%, var(--qm-primary)));
    box-shadow: var(--qm-product-surface-shadow, none);
    background-clip: padding-box;
    color: var(--qm-body-color);
    font-size: 0.82rem;
    font-weight: 650;
    line-height: 1;
}

.qm-product-page__badge i {
    font-size: 0.95em;
    color: var(--qm-primary);
}

/* [ETIKET: URUN-ICERIK] Açıklama, varyant, ekstra grid */
.qm-product-page__content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
    gap: clamp(0.9rem, 2vw, 1.25rem);
    align-items: start;
    margin-top: clamp(0.9rem, 2vw, 1.25rem);
}

.qm-product-page__main,
.qm-product-page__aside {
    min-width: 0;
}

.qm-product-page__aside {
    position: sticky;
    top: 1rem;
}

.qm-product-page__card {
    border: var(--qm-product-card-border, 1px solid var(--product-border));
    border-radius: var(--qm-radius-sm, calc(var(--product-radius) * 0.9));
    background: var(--qm-product-card-bg, var(--qm-card-bg));
    box-shadow: var(--qm-product-card-shadow, 0 12px 34px color-mix(in srgb, var(--qm-body-color) 6%, transparent));
    backdrop-filter: var(--qm-tile-backdrop, none);
    -webkit-backdrop-filter: var(--qm-tile-backdrop, none);
    overflow: hidden;
    transition:
        box-shadow 0.32s ease,
        border-color 0.32s ease;
}

.qm-product-page__card + .qm-product-page__card {
    margin-top: 0.9rem;
}

.qm-product-page__card-body {
    padding: clamp(1rem, 2vw, 1.35rem);
}

.qm-product-page__section-title {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin: 0 0 0.85rem;
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--qm-body-color);
}

.qm-product-page__icon {
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 34px;
    height: 34px;
    border-radius: var(--qm-radius-sm, 0.85rem);
    background: var(--qm-product-surface-bg, var(--product-soft));
    color: var(--qm-primary);
    border: var(--qm-product-surface-border, 1px solid color-mix(in srgb, var(--qm-primary) 14%, transparent));
    box-shadow: var(--qm-product-surface-shadow, none);
}

.qm-product-page__prose {
    color: var(--product-muted);
    font-size: 0.96rem;
    line-height: 1.7;
    overflow-wrap: anywhere;
}

.qm-product-page__list {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.qm-product-page__list-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    min-width: 0;
    padding: 0.78rem 0.85rem;
    border: var(--qm-product-surface-border, 1px solid var(--product-border));
    border-radius: var(--qm-radius-sm, calc(var(--product-radius) * 0.7));
    overflow: hidden;
    background: var(--qm-product-surface-bg, var(--product-soft));
    box-shadow: var(--qm-product-surface-shadow, none);
    background-clip: padding-box;
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

.qm-product-page__list-row:hover {
    border-color: color-mix(in srgb, var(--qm-primary) 24%, var(--product-border));
    background-color: color-mix(in srgb, var(--qm-primary) 8%, var(--qm-card-bg));
}

.qm-product-page__list-name {
    min-width: 0;
    overflow-wrap: anywhere;
    font-weight: 600;
}

.qm-product-page__list-price {
    flex: 0 0 auto;
    font-weight: 800;
    white-space: nowrap;
    color: var(--qm-primary);
}

.qm-product-page__info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.qm-product-page__info-tile {
    min-width: 0;
    padding: 0.85rem;
    border: var(--qm-product-surface-border, 1px solid var(--product-border));
    border-radius: var(--qm-radius-sm, calc(var(--product-radius) * 0.75));
    overflow: hidden;
    background: var(--qm-product-surface-bg, var(--product-soft));
    box-shadow: var(--qm-product-surface-shadow, none);
    background-clip: padding-box;
}

.qm-product-page__info-label {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--product-muted);
    font-size: 0.78rem;
    font-weight: 650;
}

.qm-product-page__info-label i {
    color: var(--qm-primary);
}

.qm-product-page__info-value {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.98rem;
    font-weight: 800;
    overflow-wrap: anywhere;
    color: var(--qm-body-color);
}

.qm-product-page__allergen-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.qm-product-page__notice {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 1rem;
    border: 1px solid color-mix(in srgb, var(--qm-secondary) 35%, transparent);
    border-radius: calc(var(--product-radius) * 0.75);
    background: color-mix(in srgb, var(--qm-secondary) 12%, var(--qm-card-bg));
}

.qm-product-page__video {
    margin-top: clamp(0.9rem, 2vw, 1.25rem);
}

/* [ETIKET: RESPONSIVE] Tablet / mobil kırılımlar */
@media (min-width: 992px) {
    .qm-product-page__hero:not(.qm-product-page__hero--no-media) {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, min(420px, 42vw));
    }
}

@media (max-width: 991.98px) {
    .qm-product-page {
        padding: 0.7rem;
    }

    .qm-product-page__hero,
    .qm-product-page__content {
        grid-template-columns: 1fr;
    }

    .qm-product-page__aside {
        position: static;
    }

    .qm-product-page__cover {
        height: clamp(220px, 58vw, 340px);
    }
}

@media (max-width: 575.98px) {
    .qm-product-page {
        padding: 0.55rem;
    }

    .qm-product-page__topbar {
        position: sticky;
        top: 0.5rem;
        z-index: 3;
        margin-bottom: 0.7rem;
    }

    .qm-product-page__hero,
    .qm-product-page__card {
        border-radius: calc(var(--product-radius) * 0.85);
    }

    .qm-product-page__cover {
        height: clamp(190px, 62vw, 285px);
    }

    .qm-product-page__intro {
        padding: 1rem;
        gap: 0.75rem;
    }

    .qm-product-page__purchase-row,
    .qm-product-page__price-box {
        width: 100%;
    }

    .qm-product-page__price-box {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
    }

    .qm-product-page__price-label,
    .qm-product-page__price-old {
        font-size: 0.72rem;
    }

    .qm-product-page__info-grid {
        grid-template-columns: 1fr;
    }

    .qm-product-page__list-row {
        align-items: flex-start;
        padding: 0.72rem;
    }
}

/* Kenarlık içi beyaz çizgi önleme */
.public-qm[class*="menu-layout-"] .qm-product-page__price-box,
.public-qm[class*="menu-layout-"] .qm-product-page__info-tile,
.public-qm[class*="menu-layout-"] .qm-product-page__list-row,
.public-qm[class*="menu-layout-"] .qm-product-page__badge,
.public-qm[class*="menu-layout-"] .qm-product-page__icon,
.public-qm[class*="menu-layout-"] .qm-product-modern .qm-price-panel,
.public-qm[class*="menu-layout-"] .qm-product-modern .qm-info-tile,
.public-qm[class*="menu-layout-"] .qm-product-modern .qm-sticky-actions {
    overflow: hidden;
    background-clip: padding-box;
}
