/* ============================================================
   product.css — Toon Pop Ürün Detay Sayfası
   ────────────────────────────────────────────────────────────
   View:    views/product.php
   Class:   br-hero, br-product-*, br-price-*, br-qty-*, br-variants-*
============================================================ */


/* ============================================================
   PAGE WRAPPER
============================================================ */
.br-page-container--narrow {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 16px 24px;
}
.br-page-container--narrow-tall {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 16px;
}


/* ============================================================
   HERO — Ürün başlık alanı (no image versiyon: büyük letter)
============================================================ */
.br-hero {
    background: var(--br-yellow);
    background-image: var(--br-halftone-mid);
    background-size: var(--br-halftone-size-lg);
    border: var(--br-border-thick);
    border-radius: var(--br-radius-lg);
    padding: 36px 24px 28px;
    text-align: center;
    margin: 16px 0 20px;
    box-shadow: var(--br-shadow-md);
    position: relative;
}
@media (min-width: 768px) {
    .br-hero { padding: 56px 32px 40px; }
}

.br-hero-with-image {
    background: var(--br-bg-3);
    padding: 0;
    overflow: hidden;
}
.br-hero-with-image img {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    display: block;
    border-bottom: 3px solid var(--br-wine);
}
.br-hero-with-image .br-hero-content {
    padding: 24px;
}

/* Top rule (kategori/etiket çizgisi) */
.br-hero-rule-top {
    width: 80px;
    height: 4px;
    margin: 0 auto 12px;
    background: var(--br-wine);
    border-radius: 2px;
    position: relative;
}
.br-hero-rule-top::before,
.br-hero-rule-top::after {
    content: '';
    position: absolute;
    top: 0;
    width: 4px;
    height: 4px;
    border-radius: 2px;
    background: var(--br-gold);
}
.br-hero-rule-top::before { left: -12px; }
.br-hero-rule-top::after { right: -12px; }

/* Category eyebrow */
.br-hero-category {
    display: inline-block;
    font-family: var(--br-font-mono);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--br-wine);
    background: var(--br-white);
    border: 2px solid var(--br-wine);
    border-radius: var(--br-radius-pill);
    box-shadow: 2px 2px 0 var(--br-wine);
    padding: 4px 12px;
    margin-bottom: 14px;
}

/* Büyük letter (görsel yoksa) */
.br-hero-letter {
    display: block;
    margin: 0 auto 12px;
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: clamp(80px, 18vw, 140px);
    line-height: 1;
    color: var(--br-wine);
    text-transform: uppercase;
}

/* Signature/featured rozet */
.br-hero-signature {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--br-gold);
    color: var(--br-white);
    border: 2px solid var(--br-wine);
    border-radius: var(--br-radius-sm);
    box-shadow: 2px 2px 0 var(--br-wine);
    padding: 4px 12px;
    margin-top: 8px;
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}


/* ============================================================
   PRODUCT TITLE & DESCRIPTION
============================================================ */
.br-product-title {
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: clamp(1.625rem, 4vw, 2.25rem);
    line-height: 1;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color: var(--br-white);
    -webkit-text-stroke: 2px var(--br-wine);
    text-shadow: 4px 4px 0 var(--br-gold);
    margin: 0 0 12px;
}
@media (min-width: 768px) {
    .br-product-title {
        -webkit-text-stroke: 2.5px var(--br-wine);
        text-shadow: 5px 5px 0 var(--br-gold);
    }
}

.br-product-subtitle {
    font-family: var(--br-font-display);
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--br-wine);
    margin: 0 0 16px;
    line-height: 1.4;
}

.br-description-block {
    margin: 24px 0;
    padding: 18px 20px;
    background: var(--br-white);
    border: var(--br-border);
    border-radius: var(--br-radius-md);
    box-shadow: var(--br-shadow-sm);
}
.br-product-description {
    font-size: 0.9375rem;
    color: var(--br-wine);
    line-height: 1.65;
    margin: 0;
}


/* ============================================================
   TTS (DİNLE) BUTTON — Toon Pop comic
============================================================ */
.br-listen-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--br-yellow);
    color: var(--br-wine);
    border: var(--br-border);
    border-radius: var(--br-radius-md);
    box-shadow: var(--br-shadow-sm);
    padding: 10px 18px;
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 13px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
    margin-top: 12px;
}
.br-listen-btn:hover {
    transform: translate(-1px, -1px);
    box-shadow: var(--br-shadow-hover);
}
.br-listen-btn:active {
    transform: translate(1px, 1px);
    box-shadow: 2px 2px 0 var(--br-wine);
}
.br-listen-btn[aria-pressed="true"] {
    background: var(--br-gold);
    color: var(--br-white);
    box-shadow: 3px 3px 0 var(--br-yellow);
}
.br-listen-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none !important;
}

/* TTS source card (DİNLE'nin altındaki orijinal text kaynağı) */
.br-tts-source-card {
    margin: 16px 0;
    padding: 14px 16px;
    background: var(--br-cream);
    border: 2px dashed var(--br-wine-line);
    border-radius: var(--br-radius-md);
}
.br-tts-source-title {
    font-family: var(--br-font-mono);
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--br-wine-light);
    margin: 0 0 6px;
}
.br-tts-source-meta {
    font-size: 0.8125rem;
    color: var(--br-wine);
    line-height: 1.5;
    margin: 0;
}


/* ============================================================
   PRICE BLOCK — Comic siyah zemin + sarı fiyat
============================================================ */
.br-price-block {
    background: var(--br-wine);
    color: var(--br-yellow);
    border: var(--br-border-thick);
    border-radius: var(--br-radius-lg);
    box-shadow: var(--br-shadow-md);
    padding: 18px 22px;
    margin: 20px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.br-price-int {
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 2rem;
    color: var(--br-yellow);
    line-height: 1;
}
.br-price-frac {
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 1rem;
    color: var(--br-yellow);
    margin-left: 1px;
    line-height: 1;
}
.br-price-currency {
    font-family: var(--br-font-display);
    font-weight: 700;
    font-size: 1rem;
    color: var(--br-cream-soft);
    margin-left: 4px;
    line-height: 1;
}

.br-price-total {
    font-family: var(--br-font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--br-cream-soft);
    text-transform: uppercase;
}

.br-price-ask-waiter {
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 1rem;
    color: var(--br-yellow);
    background: transparent;
    border: 2px solid var(--br-yellow);
    border-radius: var(--br-radius-sm);
    padding: 8px 16px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.3;
}


/* ============================================================
   VARIANTS BLOCK
============================================================ */
.br-variants-block {
    margin: 24px 0;
}
.br-variants-block .variant-group {
    margin-bottom: 18px;
}
.br-variants-block .variant-group:last-child { margin-bottom: 0; }

.br-variants-block label {
    display: block;
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--br-wine);
    margin-bottom: 10px;
}

.br-required-mark {
    display: inline-block;
    background: var(--br-gold);
    color: var(--br-white);
    border: 1.5px solid var(--br-wine);
    border-radius: 4px;
    padding: 1px 6px;
    font-family: var(--br-font-display);
    font-weight: 700;
    font-size: 9px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-left: 6px;
    vertical-align: middle;
}

/* Variant option button (radio/checkbox alternatif) */
.variant-option,
.br-variants-block .variant-option {
    background: var(--br-white);
    border: 2px solid var(--br-wine);
    border-radius: var(--br-radius-md);
    box-shadow: 2px 2px 0 var(--br-wine);
    padding: 10px 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    transition: transform 0.15s, box-shadow 0.15s;
    margin-bottom: 8px;
    font-family: var(--br-font-sans);
}
.variant-option:hover {
    transform: translate(-1px, -1px);
    box-shadow: 3px 3px 0 var(--br-wine);
}
.variant-option.selected,
.variant-option[aria-checked="true"] {
    background: var(--br-yellow);
    box-shadow: 3px 3px 0 var(--br-gold);
}

.br-variant-desc-muted {
    font-family: var(--br-font-mono);
    font-size: 11px;
    color: var(--br-wine-light);
    letter-spacing: 0.04em;
}
.br-variant-price-adj {
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 13px;
    color: var(--br-gold);
}


/* ============================================================
   QUANTITY ROW
============================================================ */
.br-qty-row {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 24px 0;
    padding: 14px 16px;
    background: var(--br-cream);
    border: 2px solid var(--br-wine);
    border-radius: var(--br-radius-md);
    box-shadow: var(--br-shadow-sm);
}
.br-qty-label {
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--br-wine);
    flex: 1;
}
.br-qty-control {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--br-white);
    border: 2px solid var(--br-wine);
    border-radius: var(--br-radius-pill);
    box-shadow: 2px 2px 0 var(--br-wine);
    padding: 4px;
}
.br-qty-btn {
    width: 32px;
    height: 32px;
    background: var(--br-yellow);
    color: var(--br-wine);
    border: 2px solid var(--br-wine);
    border-radius: var(--br-radius-pill);
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: transform 0.1s;
}
.br-qty-btn:hover {
    background: var(--br-gold);
    color: var(--br-white);
}
.br-qty-btn:active {
    transform: scale(0.95);
}
.br-qty-btn-plus {
    background: var(--br-gold);
    color: var(--br-white);
}
.br-qty-btn-plus:hover {
    background: var(--br-gold-dark);
}
.br-qty-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    transform: none !important;
}
.br-qty-value {
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 18px;
    min-width: 32px;
    text-align: center;
    color: var(--br-wine);
}


/* ============================================================
   CTA — Sepete ekle butonu
============================================================ */
.br-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: var(--br-gold);
    color: var(--br-white);
    border: var(--br-border-thick);
    border-radius: var(--br-radius-md);
    box-shadow: var(--br-shadow-md);
    padding: 16px 24px;
    font-family: var(--br-font-display);
    font-weight: 800;
    font-size: 16px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
    line-height: 1.2;
    gap: 10px;
    margin-top: 16px;
}
.br-cta:hover {
    background: var(--br-gold-dark);
    color: var(--br-white);
    transform: translate(-2px, -2px);
    box-shadow: var(--br-shadow-lg);
    text-decoration: none;
}
.br-cta:active {
    transform: translate(2px, 2px);
    box-shadow: 3px 3px 0 var(--br-wine);
}
.br-cta:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none !important;
}


/* ============================================================
   SECONDARY (geri/menü linki)
============================================================ */
.br-secondary,
.br-secondary--narrow,
.br-secondary--narrow-tall {
    margin: 28px auto 0;
    text-align: center;
}
.br-secondary--narrow,
.br-secondary--narrow-tall {
    max-width: 400px;
}
.br-secondary-row {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
}
.br-secondary a,
.br-secondary--narrow a,
.br-secondary--narrow-tall a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background: var(--br-white);
    color: var(--br-wine);
    border: var(--br-border);
    border-radius: var(--br-radius-md);
    box-shadow: var(--br-shadow-sm);
    padding: 10px 20px;
    font-family: var(--br-font-display);
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    transition: transform 0.15s, box-shadow 0.15s;
}
.br-secondary a:hover,
.br-secondary--narrow a:hover,
.br-secondary--narrow-tall a:hover {
    background: var(--br-yellow);
    transform: translate(-1px, -1px);
    box-shadow: var(--br-shadow-hover);
    color: var(--br-wine);
    text-decoration: none;
}


/* ============================================================
   EMPTY MESSAGE
============================================================ */
.br-empty-msg {
    text-align: center;
    padding: 32px 16px;
    color: var(--br-wine-light);
    font-size: 0.9375rem;
    font-style: italic;
}
