/*
// =========================================================================
// FÁJL: css/style.css (TELJES, FRISSÍTETT VERZIÓ)
// =========================================================================
*/

/* ==========================================================================
   1. VÁLTOZÓK ÉS ALAPBEÁLLÍTÁSOK ("FARM CHARM" TÉMA)
   ========================================================================== */

:root {
    --color-primary-green: #5a9c47;
    --color-dark-green: #3e6b32;
    --color-accent: #ff7043;        /* Égetett narancs/terrakotta (vidám de nem neon) */
    --color-bg-body: #f4f1ea;       /* Reciklált papír szín */
    --color-bg-card: #ffffff;
    --color-text-main: #333333;
    --color-wood-brown: #8a5a2b;
    --color-text-dark: #413b35;
    --color-background: #e8f5e9;
    --color-light-gray: #e0e0e0;

    --font-headings: "Roboto", sans-serif;
    --font-body: "EB Garamond", serif;

    --border-radius: 8px;           /* Kisebb, praktikusabb lekerekítés */
    --box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    --border-style: 2px solid var(--color-bg-body);
    --transition-main: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-body);
    line-height: 1.7;
    font-size: 17px;
    color: var(--color-text-dark);
    background-color:  #e8f5e9;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main {
    flex: 1;
    padding-top: 0.5rem;
    padding-bottom: 2rem;
}

/* ==========================================================================
   2. TIPOGRÁFIA ÉS CÍMSOROK
   ========================================================================== */

h1, h2, h3, h4, h5, h6 {
    color: var(--color-primary-green);
    text-shadow: 1px 1px 0px var(--color-wood-brown);
    line-height: 1.3;
    font-weight: 700;
}

h1 {
    position: relative;
    display: block;
    margin-bottom: 2.5rem !important;
}
h1::after {
    content: '';
    display: block;
    width: 100%;
    height: 5px;
    background-color: var(--color-primary-green);
    border-radius: 4px;
    position: absolute;
}



.product-details h1 {
    font-size: 3rem;
}


h2 {
    text-shadow: 1px 1px 0px var(--color-wood-brown);
    background-color: #2e5126;
    color: #ffff;
    font-size: 1.4rem;
    align-items: center;
    font-weight: 800;
    display: block;
}




h1 + h2 {
    font-family: var(--font-heading);
    color: var(--color-secondary);
    font-weight: 700;
    color: #ffff;
    text-shadow: none;
}

h3, h4, h5, h6 {
    font-size: 1.1rem;
    text-shadow: 1px 1px 0px var(--color-wood-brown);
}


a{  color: var(--color-accent-red);
    text-decoration: none;
    font-weight: 400;
    transition: var(--transition-main);
}

    
a:hover {
    color: var(--color-dark-green);
}




/* ==========================================================================
   3. ÁLTALÁNOS LAYOUT ELEMEK
   ========================================================================== */

.blokk1 .container,
.blokk2 .container,
.blokk3 .container,
.blokk4 .container {
    padding: 2.5rem 2rem;
    border: 2px solid var(--color-wood-brown);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--box-shadow);
    background-color: white;
}

.blokk2 li {
    list-style: none;
    padding-left: 2.5rem;
    position: relative;
    margin-bottom: 0.5rem;
}
.blokk2 li::before {
    content: '🚜';
    font-size: 1.5rem;
    position: absolute;
    left: 0;
    top: 0;
}

hr {
    border: none;
    height: 3px;
    background-color: var(--color-dark-green);
    opacity: 0.5;
    border-radius: 2px;
}

.kategoria{
    background-color: var(--color-dark-green);
}

.card-text-invers{
    border: 2px solid var(--color-wood-brown);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--box-shadow);
    color: white;
}

.card-text-invers h2{
    color:#fff;
}
 


/* ==========================================================================
   4. GOMBOK
   ========================================================================== */

.btn {
    display: inline-block;
    font-weight: 700;
    font-family: var(--font-headings);
    font-size: 1.1rem;
    color: white;
    padding: 12px 28px;
    border: 2px solid var(--color-text-dark);
    border-bottom-width: 5px;
    border-radius: 8px;
    cursor: pointer;
    text-align: center;
    transition: var(--transition-main);
    text-shadow: 1px 1px 0 rgba(0,0,0,0.2);
}

.btn:hover {
    transform: translateY(-4px);
    border-bottom-width: 8px;
}

.btn:active {
    transform: translateY(1px);
    border-bottom-width: 5px;
}


/* Teljes magasságot kitöltő kártya */
.info-box,
.info-box.h-100 {
    display: flex;
    flex-direction: column;
    height: 100%; /* Biztosítja, hogy a flexbox kitöltse a teret */
}

.info-box .card-body {
    flex-grow: 1; /* Lehetővé teszi, hogy a card-body kitöltse a fennmaradó helyet */
}

/* Egyedi fejléc stílus */
.info-box-header {
    opacity: 90; /* Világosszürke háttér, mint a Bootstrap alapértelmezettje */
    border-bottom: 1px solid rgba(0, 0, 0, 0.125);
    padding: 1.25rem 1.5rem;
    display: block;
}

/* Címsor a fejlécben */
.info-box-head {
    font-weight: 300; /* Könnyedebb betűvastagság */
    color: #ffff; /* Sötétebb szövegszín */
    text-align: center;
    display: block;
}

/* Leíró szöveg */
.info-box-text {
    font-size: 1.1rem;
    color:#2e5126; /* Szürke szövegszín */
    font-weight: 700;
}

/* Gomb stílusának finomhangolása */
.info-box-button {
    padding: 0.75rem 1.5rem;
    font-size: 1.1rem;
    transition: background-color 0.2s ease-in-out, transform 0.2s ease;
}

.info-box-button:hover {
    transform: translateY(-2px); /* Enyhe emelkedő effektus hover-re */
}

/* Jobb oldali termékkártyák igazítása */
.info-box .col-lg-8 {
    display: flex;
    align-items: center; /* Vertikálisan középre igazítja a termékeket, ha kevesebb van */
}

.btn-secondary { background-color: var(--color-accent-red); }
.btn-secondary:hover {
    background-color: #a83c3c;
    border-color: #8b3131;
}

.btn-primary, .card .btn {
    background-color: var(--color-primary-green);
}

.btn-success { background-color: var(--color-dark-green); }

.btn-primary:hover,
.card .btn:hover {
    background-color: var(--color-dark-green);
    border-color: #2e5126;
}

.btn-outline,
.btn-white-outline,
.btn-outline-secondary,
.btn-outline-primary {
    background-color: transparent;
    color: var(--color-wood-brown);
    border-color: var(--color-wood-brown);
}

.btn-outline:hover,
.btn-white-outline:hover,
.btn-outline-secondary:hover,
.btn-outline-primary:hover {
    background-color: var(--color-wood-brown);
    color: white;
}

/* ==========================================================================
   5. KÁRTYÁK (CARD) ÉS KÉPNAGYÍTÓ MODAL
   ========================================================================== */

.card.product-card,
.card.h-100, 
.card{

    background-color: white;
    display: block;
    margin-bottom: 1rem;
}



.kat-card,
.img-fluid{
    border: 3px solid var(--color-light-gray);
    margin:0.5;
}

.kat-card-text{
    font-family: var(--font-body);
    color:#fff;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 1rem;
}
    
.lead.my-3{
    border: 2px solid var(--color-light-gray);
    background-color: white;
    display: block;
    margin-bottom: 1rem;
}



.card.product-card:hover,
.card.h-100:hover,
.card:hover,
.img-fluid.rounded{
    border-color:#ff7043;
}

.card-img-container {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    cursor: default;
}

.card-img-overlay {
    background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.3) 40%, rgba(0,0,0,0) 100%);
    opacity: 0;
    transition: var(--transition-main);
}
.product-card:hover .card-img-overlay {
    opacity: 1;
}

.card-icon-group {
    display: flex;
    gap: 0.5rem;
}
.card-icon {
    width: 40px;
    height: 40px;
    background-color: rgba(255, 255, 255, 0.85);
    border: 2px solid var(--color-dark-green);
    border-radius: 50%;
    color: var(--color-dark-green);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--transition-main);
    padding: 0;
}
.card-icon:hover {
    background-color: var(--color-wood-brown);
    color: white;
    transform: scale(1.1);
}
.card-icon.sale-icon {
    background-color: var(--color-accent-red);
    border-color: var(--color-text-dark);
    color: white;
}

.card-title-on-image{
    font-size: 1rem;
    line-height: 1.3;
    margin: 0;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.7);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.text-decoration-none{
    font-size: 1.1rem;
    line-height: 1.3;
    margin: 0;
    text-align: center;
    color: var(--color-primary-green);
    text-shadow: 1px 1px 0px var(--color-wood-brown);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.card-title-on-image a {
    color: #3e6b32;
    text-decoration: none;
}

.card-body-bottom {
    background-color: white;
}
.price-section {
    min-height: 40px;
    display: flex;
    padding-left: 0.5rem;
}

#imageModal .modal-content,
#galleryModal .modal-content {
    background-color: var(--color-background);
}
#galleryCarousel .carousel-inner {
    border-radius: var(--border-radius-lg);
    overflow: hidden;
}

/* ==========================================================================
   6. ŰRLAPOK ÉS BEVITELI MEZŐK
   ========================================================================== */

form {
    background-color: white;
    padding: 2.5rem;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--box-shadow);
}
#checkout-form {
    background: none; padding: 0; border: none; box-shadow: none;
}

.form-label {
    font-family: var(--font-headings);
    color: var(--color-dark-green);
    font-size: 1.2rem;
}

.form-control, .form-select {
    border: 2px solid var(--color-wood-brown);
    border-radius: 8px;
    padding: 10px 15px;
    background-color: #fcfcfc;
    transition: var(--transition-main);
}

.form-control:focus, .form-select:focus {
    border-color: var(--color-dark-green);
    box-shadow: 0 0 8px rgba(90, 156, 71, 0.3);
    background-color: white;
}

.alert {
    border-radius: var(--border-radius-lg);
    font-weight: 700;
}
.alert.alert-info {
    background-color: rgba(138, 90, 43, 0.05);
    border: 2px dashed var(--color-wood-brown);
    color: var(--color-text-dark);
}
.alert-success {
    background-color: rgba(90, 156, 71, 0.1);
    border: 2px solid var(--color-dark-green);
    color: var(--color-dark-green);
}
.alert-danger {
    background-color: rgba(201, 74, 74, 0.1);
    border: 2px solid var(--color-accent-red);
    color: var(--color-accent-red);
}

/* ==========================================================================
   7. HEADER (BANNER ÉS NAVIGÁCIÓ)
   ========================================================================== */

.hero-banner {
    width: 100%;
    max-height: 250px;
    overflow: hidden;
}
.hero-banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

header .navbar {
    background-color: #3e6b32;
    border-bottom: 4px solid var(--color-wood-brown);
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    box-shadow: var(--box-shadow);
}



.navbar-brand:hover {
    transform: scale(1.05); 
}

.navbar .nav-link {
    font-family: var(--font-headings);
    font-size: 1.1rem;
    color: #fff;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.7);
    margin: 0 0.5rem;
    padding: 0.5rem 1rem;
    border-radius: 8px;
    font-weight: 700;
}

.navbar .nav-item .nav-link:hover,
.navbar .nav-item .nav-link.active,
.navbar .nav-item.dropdown:hover > .nav-link {
    background-color: var(--color-primary-green);
    color: white;
    transform: translateY(-3px);
}

.dropdown-menu {
    background-color: var(--color-background);
    border: 2px solid var(--color-wood-brown);
    border-radius: var(--border-radius-lg);
    box-shadow: var(--box-shadow);
    padding: 0.5rem 0;
}

.dropdown-item {
    font-family: var(--font-body);
    font-weight: 700;
    color: var(--color-wood-brown);
    padding: 0.75rem 1.5rem;
}
.dropdown-item:hover {
    background-color: var(--color-primary-green);
    color: white;
}

header .badge {
    background-color: var(--color-accent-red) !important;
}

.navbar-toggler {
    border: 2px solid var(--color-wood-brown);
    border-radius: 8px;
}
.navbar-toggler:focus { box-shadow: 0 0 8px rgba(90, 156, 71, 0.3); }
.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(138, 90, 43, 1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ==========================================================================
   8. OLDALSPECIFIKUS STÍLUSOK (TERMÉK, KOSÁR, PÉNZTÁR)
   ========================================================================== */

.product-page-image,
.category-header-image,
.card-img-top.card-img-bg,
.background-image {
    /* Meglévő stílusok a kerethez */
    padding: 4px;
    box-shadow: var(--box-shadow);
    border-radius: var(--border-radius-lg) !important;
    
    /* Új stílusok a háttérképes megjelenítéshez */
    width: 100%;
    aspect-ratio: 1 / 1;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}

.product-details .lead { font-size: 1.25rem; color: var(--color-text-dark); opacity: 0.9; }
.product-details h4 { color: var(--color-dark-green); font-size: 2.5rem; margin-bottom: 1.5rem; }
.product-meta {
    background-color: rgba(138, 90, 43, 0.05);
    border-left: 4px solid var(--color-wood-brown);
    padding: 1rem 1.5rem;
    margin: 1.5rem 0;
    border-radius: 0 var(--border-radius-lg) var(--border-radius-lg) 0;
}
.product-meta p { margin-bottom: 0.5rem; }
.product-meta p strong { color: var(--color-text-dark); }
.product-description-container {
    margin-top: 3rem; padding-top: 2rem; border-top: 2px dashed var(--color-wood-brown);
}
.product-description-container h3 { text-align: center; margin-bottom: 2rem; transform: rotate(-1deg); }


.table {
    border: 2px solid var(--color-wood-brown);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    background-color: #fff;
}
.table thead { background-color: rgba(138, 90, 43, 0.05); }
.table th {
    font-family: var(--font-headings);
    color: var(--color-text-dark);
    border-bottom: 2px solid var(--color-wood-brown);
    padding: 1rem;
}
.table td { padding: 1rem; border-top: 1px solid var(--color-light-gray); }
.table img { border-radius: 8px; border: 1px solid var(--color-light-gray); }
.remove-from-cart {
    background-color: var(--color-accent-red);
    border-color: #a83c3c;
    border-radius: 50%; width: 32px; height: 32px;
    padding: 0; font-size: 1.4rem; line-height: 1;
    text-shadow: none; border-bottom-width: 3px;
}
.remove-from-cart:hover {
    background-color: #a83c3c; transform: translateY(-2px) rotate(90deg); border-bottom-width: 5px;
}
#grand-total { font-family: var(--font-headings); color: var(--color-dark-green); font-size: 1.8rem; }

.checkout-details .card { border: 2px solid var(--color-wood-brown); border-radius: var(--border-radius-lg); box-shadow: var(--box-shadow); }
.checkout-details .card-title { text-align: left; }
.checkout-summary .list-group {
    border: 2px solid var(--color-wood-brown); border-radius: var(--border-radius-lg);
    padding: 1rem; background: #fff; box-shadow: var(--box-shadow);
}
.checkout-summary .list-group-item { border: none; padding: 0.75rem 0.25rem; background: transparent; }
.checkout-summary .list-group-item:not(:last-child) { border-bottom: 1px dashed var(--color-light-gray); }
.checkout-summary .list-group-item:last-child { padding-top: 1rem; margin-top: 0.5rem; }
.checkout-summary .list-group-item:last-child strong { font-family: var(--font-headings); color: var(--color-dark-green); font-size: 1.5rem; }

.pagination { justify-content: center; margin-top: 2rem;  flex-wrap: wrap; }
.page-item .page-link {
    display: block; background-color: var(--color-background); color: var(--color-wood-brown);
    font-family: var(--font-headings); border: 2px solid var(--color-wood-brown);
    margin: 0 5px; border-radius: 8px; transition: var(--transition-main); padding: 10px 16px;
}
.page-item .page-link:hover { background-color: #f3efe6; transform: translateY(-3px); }
.page-item.active .page-link {
    background-color: var(--color-primary-green); border-color: var(--color-dark-green);
    color: white; transform: scale(1.1);
}
.page-item.disabled .page-link { background-color: #f0f0f0; color: #aaa; border-color: #ddd; }

.text-primary{
    color: var(--color-primary-green)!important;
}



/* ==========================================================================
   9. LÁBLÉC (FOOTER)
   ========================================================================== */

footer {
    background-color: var(--color-dark-green);
    color: var(--color-background);
    border-top: 4px solid var(--color-wood-brown);
    margin-top: auto;
}
footer h5 {
    font-family: var(--font-headings);
    color: var(--color-primary-green);
    transform: rotate(-1deg);
    display: inline-block;
    margin-bottom: 1rem;
}
footer p { line-height: 1.8; }
footer a,
footer a.text-white {
    color: var(--color-background) !important;
    font-weight: 700;
    text-decoration: none;
    transition: var(--transition-main);
    padding-bottom: 2px;
    border-bottom: 2px solid transparent;
}
footer a:hover,
footer a.text-white:hover {
    color: var(--color-accent-yellow) !important;
    border-bottom-color: var(--color-accent-yellow);
}
footer .text-center[style] { background-color: rgba(0, 0, 0, 0.2) !important; padding: 1rem; font-size: 0.9rem; }
footer .text-center a { border-bottom: 1px dotted var(--color-background); }
footer .text-center a:hover { border-bottom: 1px solid var(--color-accent-yellow); }

@media (min-width: 992px) {
    .footer-menu-columns { column-count: 2; column-gap: 2rem; }
}

/* ==========================================================================
   10. MOBIL NAVIGÁCIÓ (HEADER ÉS FOOTER)
   ========================================================================== */

.offcanvas {
    background-color: var(--color-background);
    border-right: 3px solid var(--color-wood-brown);
}
.offcanvas-header {
    border-bottom: 2px solid var(--color-wood-brown);
}
.offcanvas-title {
    font-family: var(--font-headings);
    color: var(--color-primary-green);
    transform: rotate(-1.5deg);
}
.mobile-offcanvas-menu {
    column-count: 2;
    column-gap: 1rem;
}
.mobile-offcanvas-menu li {
    padding: 0.5rem 0;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
}
.mobile-offcanvas-menu a {
    font-weight: 700;
    color: var(--color-text-dark);
    font-size: 0.95rem;
}
.mobile-offcanvas-menu a:hover {
    color: var(--color-primary-green);
}

.mobile-footer-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 65px;
    background-color: var(--color-background);
    border-top: 3px solid var(--color-wood-brown);
    box-shadow: 0 -5px 15px rgba(0, 0, 0, 0.08);
    display: flex;
    justify-content: space-around;
    align-items: center;
    z-index: 1030;
}
.mobile-nav-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--color-text-dark);
    font-size: 0.7rem;
    font-weight: 700;
    text-align: center;
    flex: 1;
    padding: 4px 0;
}
.mobile-nav-link:hover {
    color: var(--color-primary-green);
}
.mobile-nav-link svg {
    width: 26px;
    height: 26px;
    margin-bottom: 3px;
}

/* ==========================================================================
   11. RESZPONZIVITÁS
   ========================================================================== */
   
@media (max-width: 991.98px) {
    body {
        padding-bottom: 65px;
    }
    .hero-banner {
        display: none;
    }
}

@media (max-width: 768px) {
    body { font-size: 16px; }

    h1, h2 {
        text-shadow: 2px 2px 0px var(--color-wood-brown);
    }
    h3, h4, h5, h6 {
        text-shadow: 1px 1px 0px var(--color-wood-brown);
    }

    h1 {
        font-size: 2.2rem;
        margin-bottom: 2rem !important;
    }

    .blokk1 .container,
    .blokk2 .container,
    .blokk3 .container,
    .blokk4 .container { padding: 1.5rem 1rem; }
    
    footer .row > div { text-align: center; }

    .page-item { margin-bottom: 5px; }
    .page-item .page-link { padding: 8px 12px; margin: 0 3px; font-size: 0.9rem; }

    .table-responsive { border: none; }
    .table thead { display: none; }
    .table, .table tbody, .table tr, .table td { display: block; width: 100%; }
    .table tr { margin-bottom: 1.5rem; border: 2px solid var(--color-wood-brown); border-radius: var(--border-radius-lg); padding: 1rem; }
    .table td {
        border: none; padding-left: 0; padding-right: 0; text-align: right;
        display: flex; justify-content: space-between; align-items: center;
        border-bottom: 1px solid var(--color-light-gray);
        padding-bottom: 0.75rem; margin-bottom: 0.75rem;
    }
    .table tr td:last-child { border-bottom: none; margin-bottom: 0; }
    .table td::before { font-family: var(--font-headings); color: var(--color-text-dark); text-align: left; margin-right: 1rem; }
    .table tbody tr td:nth-of-type(3)::before { content: 'Bruttó ár'; }
    .table tbody tr td:nth-of-type(4)::before { content: 'Mennyiség'; }
    .table tbody tr td:nth-of-type(5)::before { content: 'Részösszeg'; }

    .table td:nth-of-type(1), .table td:nth-of-type(2), .table td:nth-of-type(6) { display: block; text-align: center; }
    .table td:nth-of-type(1) { width: 100px; margin: 0 auto 1rem auto; }
    .table td:nth-of-type(2) { font-weight: bold; font-size: 1.2rem; border-bottom: none; }
    .table td:nth-of-type(2) a { color: var(--color-text-dark); }
    .table td:nth-of-type(3) { border-top: 1px solid var(--color-light-gray); padding-top: 1rem;}
    .table td:nth-of-type(6) { padding-top: 1rem; }
    
    .table .quantity-input { width: 80px; margin-left: auto; }
}

@media (max-width: 480px) {
    h1, h2 {
        text-shadow: 1px 1px 0px var(--color-wood-brown);
    }
    h3, h4, h5, h6 {
        text-shadow: none;
    }

    .page-title-column {
        padding-left: 0;
        padding-right: 0;
    }
    
    h1 {
        font-size: 2rem;
        transform: none;
        text-align: center;
    }
    h1::after {
        width: 80%;
        left: 10%;
        transform: none;
    }

    .page-item .page-link { padding: 6px 10px; margin: 0 2px; }
    
    .pagination .page-item:first-child .page-link { font-size: 0; padding-left: 12px; padding-right: 12px; }
    .pagination .page-item:first-child .page-link::before { content: '«'; font-size: 1.1rem; }

    .pagination .page-item:last-child .page-link { font-size: 0; padding-left: 12px; padding-right: 12px; }
    .pagination .page-item:last-child .page-link::before { content: '»'; font-size: 1.1rem; }
}

/* ==========================================================================
   12. EGYÉNI TERMÉKKÁRTYA MÓDOSÍTÁSOK (FINOMHANGOLT VERZIÓ)
   ========================================================================== */

/* A képen lévő sötétítő réteg eltávolítása */
.card-img-overlay {
    background: none;
    opacity: 1;
}


.product-card:hover .card-img-overlay {
    opacity: 1;
}

/* 1. MÓDOSÍTÁS: Finom, áttűnő (gradient) háttér a címsornak */
.card-title-background {
    /* Ez a háttér alulról sötétebb és felfelé teljesen átlátszóvá válik. */
    /* Így a kép nagy része látható marad, de a szöveg mögött van kontraszt. */
    background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, transparent 100%);
    padding: 0.5rem;
    margin: 0 -0.5rem -0.5rem -0.5rem;
}

/* 2. MÓDOSÍTÁS: A címsor szövegének stílusosabbá és olvashatóbbá tétele */
.card-title-on-image {
    font-family: var(--font-headings); /* A címsorokhoz használt betűtípus */
    font-size: 1rem; /* Kicsit nagyobb, jobban olvasható betűméret */
    text-align: center;
    text-transform: uppercase; /* Nagybetűs stílus a jobb kiemelésért */
    letter-spacing: 0.5px;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.8);
}


.card-icon.sale-icon {
    font-weight: 700;
    font-size: 0.85rem;
}


.card-img-container[data-bs-toggle="modal"] {
    cursor: pointer;
}

/* Az árak rendezése és kiemelése */
.price-section {
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Hangsúlyosabb akciós ár */
.discounted-price {
    font-size: 1.1rem !important;
    padding-left: 0.5rem;
}

/* Halványabb eredeti ár */
.original-price {
    font-size: 0.9rem;
}

.body-box{
    background-color: #fff;
    border: 1px solid var(--color-wood-brown);
}

/* ==========================================================================
   14. KOSÁR OLDAL STÍLUSAI
   ========================================================================== */

/* A termékkép stílusa a kosárban (háttérképes megoldás) */
.cart-item-image {
    display: block;
    width: 100px;
    height: 100px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: var(--border-radius-lg); /* Illeszkedik az oldal dizájnjához */
    border: 2px solid var(--color-light-gray);
    transition: all 0.2s ease-in-out;
}

.cart-item-image:hover {
    transform: scale(1.05); /* Finom nagyítás hover-re */
    border-color: var(--color-wood-brown);
}