/* =========================================================================
   MODERN BÉZS BABAKOCSI WEBSHOP – 2025/2026 stílus
   Minimal – Clean – Premium – Bézs domináns
   ========================================================================= */

/* ==========================================================================
   1. VÁLTOZÓK – ÚJ PALETTA
   ========================================================================== */
:root {
    --color-bg-main:    #7c8f7a;       /* FŐ HÁTTÉR: Lágy zsályazöld (a kérésedre zöld háttér) */
    --color-bg-card:    #e9e4da;       /* KÁRTYÁK HÁTTERE: Világos homok/krém (szépen kiemelkedik a zöldből) */
    --color-bg-light:   #f5f2eb;       /* Egy még világosabb krém tónus a finom kontrasztokhoz */

    --color-text-main:  #1f3a2e;       /* FŐ SZÖVEG: Mély fenyőzöld (nagyon sötét, tökéletesen olvasható) */
    --color-text-light: #e9e4da;       /* VILÁGOS SZÖVEG: Homokszín (sötét hátterekre, pl. gombokba) */

    --color-accent:     #c7a29a;       /* Terrakotta/Dusty Rose (vonalakhoz, linkekhez, fókuszpontokhoz) */
    --color-accent-dark:#84564c;       /* Sötétebb terrakotta a linkek hover állapotához */

    --color-primary:    #4c6b4f;       /* KÖZÉPZÖLD: Gombok alapállapota, navigáció */
    --color-primary-dark: #1f3a2e;     /* Sötétzöld hover állapotokhoz */


    --color-border:     #4c6b4f;       /* A zsályazöldhöz passzoló, kicsit sötétebb zöldes szegély */
    --color-shadow:     0 8px 24px rgba(31, 58, 36, 0.08); /* Zöldes tónusú, finom árnyék */
    --color-shadow-hover: 0 16px 40px rgba(31, 58, 36, 0.15);

    --color-nav-link-color: #1f3a2e;   /* Sötétzöld menüpontok (mivel a háttér világosabb zöld) */
    --border-radius:    12px;
    --border-radius-lg: 20px;

    --font-heading:     "Coiny", Arial, sans-serif;
    --font-body:        "Inter", system-ui, -apple-system, sans-serif;
    --font-serif:       "Crimson Text", Georgia, serif;
}

.fs-5 {
     color: var(--color-text-light);
     text-shadow: 0 2px 2px rgba(31, 58, 36, 0.5);
     text-transform: uppercase;
     background: rgba(31, 58, 36, 0.7); /* Áttetsző mélyzöld háttér a neon helyett */
     padding: 4px 12px;
     border-radius: 4px;
     display: inline-block;
}


/* Alap beállítások */
html { scroll-behavior: smooth; }

body {
    font-family: var(--font-body);
    line-height: 1.68;
    font-size: 1.05rem;
    color: var(--color-text-main);
    background: var(--color-bg-main);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}


.body-box{
    background: var(--color-bg-card);
    color: var(--color-text-main);
}


.nav-link{
    color: var(--color-nav-link-color);  
}

main { flex: 1; }


.banner{
    width: 100%;
    height: 350px;
    background-size:cover;
    background-repeat: no-repeat;
    background-position: left;
    color:aliceblue;
}

/* ==========================================================================
   2. TIPOGRÁFIA
   ========================================================================== */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 400;
    color: var(--color-text-main);
    letter-spacing: -0.02em;
}

h1 { font-size: clamp(2.4rem, 5.5vw, 4.2rem); line-height: 1.05; }
h2 { font-size: clamp(1.9rem, 4.2vw, 3rem); }
h3 { font-size: 1.6rem; }
h4 { font-size: 1.35rem; }

p, li { color: var(--color-text-main);}

.lead{ 
    color: var(--color-text-main); 
    font-size: 1.1rem;
    font-weight: 700;
}

.page-title-column p { color: var(--color-text-main); }
.page-title-column li { color: var(--color-text-main); }

a {
    color: var(--color-text-main) !important; /* #1f3a2e */
    transition: var(--transition); /* Finom, lágy színátmenet */
    text-decoration:none;
}

a:hover { 
    color: var(--color-accent) !important; /* #c7a29a */
}
     

/* ==========================================================================
   3. GOMBOK – modern floating stílus
   ========================================================================== */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 1rem;
    padding: 0.9rem 1.9rem;
    border-radius: var(--border-radius);
    background: var(--color-accent);
    color: var(--color-bg-card); /* Világos krém színű szöveg */
    border: none;
    box-shadow: var(--color-shadow);
    transition: background-color 0.3s ease, color 0.3s ease;
        /* Stílus finomítás: modern nagybetűs gombok, pici betűközzel */
    text-transform: uppercase;
    letter-spacing: 1px;
}

.btn:hover {
    box-shadow: var(--color-shadow-hover);
    background: var(--color-text-main);
    color: var(--color-accent);
}

.btn:active { transform: translateY(0); }

.btn-outline {
    background: transparent;
    border: 2px solid var(--color-accent);
    color: var(--color-text-main);
}


.btn-success {
    background: var(--color-accent)!important;
    border: 2px solid var(--color-accent)!important;
    color: var(--color-text-main)!important;
}

.btn-success:hover,
button[type="submit"]:hover,
input[type="submit"]:hover {
    background-color: var(--color-text-main) !important; /* Hoverre középzöld: #4c6b4f */
    color: var(--color-accent)!important;
}

.btn-secondary{
    background: var(--color-accent)!important;
    border: 2px solid var(--color-accent)!important;
    color: var(--color-text-main)!important;
}


.btn-secondary:hover,
[type=button]:hover,
[type=reset]:hover,
[type=submit]:hover {
    background-color: var(--color-text-main) !important; /* Hoverre középzöld: #4c6b4f */
    color: var(--color-accent)!important;
}

/* ==========================================================================
   4. KÁRTYÁK – modern, térkitöltő, hover lift
   ========================================================================== */
.card,
.product-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    box-shadow: var(--color-shadow);
    display: flex;
    flex-direction: column;
    height: 100% !important; /* Így az oszlopok egyforma magasak lesznek */
}

/* JAVÍTÁS: Rávegyük az oszlopokat, hogy a bennük lévő section is nyúljon meg */
.col-md-4 {
    display: flex !important;
    flex-direction: column !important;
}

/* Javítjuk a köztes <section> elemet, hogy kitöltse a teljes magasságot */
.col-md-4 > section {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    height: 100% !important;
}

/* Biztosítjuk, hogy maga a kártya is kitöltse a megnyújtott section-t */
.col-md-4 > section > .card {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
}

.card-img-top,
.card-img-container {
    width: 100%;
    aspect-ratio: 4 / 3;          /* modernebb, kevésbé négyzetes */
    object-fit: cover;
    background: var(--color-bg-main); 
}

.card-body {
    flex: 1 1 auto;
    padding: 1.4rem 1.5rem;
    display: flex;
    flex-direction: column;
}

.card-title {
    text-align: center !important; /* EZ A SOR IGAZÍTJA KÖZÉPRE A CÍMET */
    margin: 0 0 0.6rem;
    color: var(--color-text-main)!important;  /* Mélyzöld főcím: #1f3a2e */
    font-weight: 600;
}


/* 1. A kártya címében lévő link színe alaphelyzetben (mélyzöld) */
.card-title a {
    color: var(--color-text-main) !important; /* #1f3a2e */
    transition: var(--transition); /* Finom, lágy színátmenet */
}

/* 2. Hover (rámutatási) állapot a címre (meleg terrakotta) */
.card-title a:hover {
    color: var(--color-accent) !important; /* #c7a29a */
}

.card-text { 
    color: var(--color-text-main)!important;
 }


/* Full-width / térkitöltő konténerek */
.container-wide {
    width: 100%;
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

.section-padding {
    padding: 5rem 0;
}

.section-bg-light { background: var(--color-bg-light); }

/* ==========================================================================
   5. HEADER / NAV / HERO
   ========================================================================== */
.navbar {
    background: var(--color-text-main); 
    backdrop-filter: blur(12px);
    border-bottom: 4px solid var(--color-accent) !important; 
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}

.navbar-brand {
    font-weight: 700;
    font-size: 1.6rem;
    color: var(--color-bg-card);
    transition: var(--transition); /* Finom átmenet a hover hatáshoz */
}

.nav-link {
    font-weight: 500 !important;
    color: var(--color-bg-card) !important; /* Krém színű szöveg (#e9e4da) */
    transition: var(--transition); /* Finom átmenet a hover hatáshoz */
}

.nav-link:hover,
.nav-link.active { 
    color: var(--color-accent)!important;
}

.hero {
    position: relative;
    min-height: 70vh;
    background: linear-gradient(rgba(0,0,0,0.18), rgba(0,0,0,0.38)),
                url('hero-babakocsi.jpg') center/cover no-repeat;
    color: white;
    display: flex;
    align-items: center;
}

.hero-content {
    max-width: 900px;
    padding: 2rem;
}

.card-img-bg{
    background-size: contain;         /* kitölti a teret, levágja a felesleget */
    background-position: center;
    background-repeat: no-repeat;
}

.card-img-container {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;           /* vagy 3 / 4, 1 / 1, 5 / 4 – termékfotóktól függ */
    background-color: #ffffff;      /* lágy bézs fallback szín */
    background-size: contain;         /* kitölti a teret, levágja a felesleget */
    background-position: center;
    background-repeat: no-repeat;
    border-radius: var(--border-radius-lg);
    overflow: hidden;               /* fontos – ha van overlay vagy hover */
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}


/* Ha van overlay szöveg vagy ikon a képen */
.card-img-container::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 60%, rgba(0,0,0,0.35) 100%);
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
}

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



/* ==========================================================================
   7. LÁBLÉC
   ========================================================================== */
footer {
    background: var(--color-text-main);
    color: var(--color-text-light);
    margin-top: auto;
}

footer a { 
    color:var(--color-text-light);
 }

footer a:hover { color: var(--color-accent); }


/* ==========================================================================
   MOBILE BOTTOM NAVIGATION BAR
   Csak mobil nézetben jelenik meg – fix alul
   ========================================================================== */

/* Alapértelmezett: rejtve */
.mobile-footer-nav {
    display: none;
}

/* Csak 991px alatt (lg breakpoint alatt) jelenítjük meg */
@media (max-width: 991.98px) {
    .mobile-footer-nav {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        height: 68px;                   /* modernebb magasság – kényelmesebb ujjnak */
        background-color: #ffffff;
        border-top: 1px solid var(--color-accent);  /* lágy bézs keret */
        box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.06);
        z-index: 1030;                  /* navbar alatt ne legyen, de tartalom felett igen */
        justify-content: space-around;
        align-items: center;
        padding: 0 8px;
        backdrop-filter: blur(10px);    /* ha áttetsző hatást akarsz */
        -webkit-backdrop-filter: blur(10px);
    }

    /* iPhone notch / dynamic island / safe-area kompatibilitás */
    @supports (padding-bottom: env(safe-area-inset-bottom)) {
        .mobile-footer-nav {
            padding-bottom: env(safe-area-inset-bottom);
            height: calc(68px + env(safe-area-inset-bottom));
        }
    }

    body {
        /* Ne engedjük, hogy a tartalom alá fusson a sáv */
        padding-bottom: calc(68px + env(safe-area-inset-bottom));
    }
}

/* Egy-egy ikon + szöveg konténer */
.mobile-nav-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    color: var(--color-text-main);
    font-size:1rem;             /* kicsi, de olvasható szöveg */
    font-weight: 500;
    line-height: 1.1;
    text-align: center;
    padding: 6px 4px;
    transition: color 0.2s ease, transform 0.15s ease;
    user-select: none;
    -webkit-tap-highlight-color: transparent; } /* iOS csúnya highlight eltüntetése */

.mobile-nav-link:hover,
.mobile-nav-link.active {
    color: var(--color-accent); /* #a67c52 vagy a fő színed */
}

.mobile-nav-link svg,
.mobile-nav-link img {
    width: 26px;
    height: 26px;
    margin-bottom: 3px;
    transition: transform 0.2s ease;
}

.mobile-nav-link:hover svg,
.mobile-nav-link.active svg {
    transform: scale(1.12);
}

/* Ha van badge (pl. kosárban lévő termékek száma) */
.mobile-nav-link .badge {
    position: absolute;
    top: 4px;
    right: calc(50% - 14px);
    font-size: 0.58rem;
    padding: 2px 5px;
    min-width: 16px;
    height: 16px;
    line-height: 12px;
    border-radius: 10px;
}
.card-title-on-image {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;           /* még mindig kell a clamp-hez */
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    max-height: calc(1.8em * 3);    /* line-height × sorok száma */
}

/* ==========================================================================
   8. RESZPONZÍV FINOMHANGOLÁS
   ========================================================================== */
@media (max-width: 992px) {
    .section-padding { padding: 3.5rem 0; }
    h1 { font-size: 3.2rem; }
        .banner{
            width: 100%;
          
            background-size:cover;
            background-repeat: no-repeat;
            background-position: left;
            color:aliceblue;

}
}

@media (max-width: 768px) {
    body { font-size: 1.02rem; }
    .product-grid { gap: 1.8rem 1.2rem; }
    .btn { padding: 0.85rem 1.6rem; }

    .banner{
            width: 100%;
          
            background-size:cover;
            background-repeat: no-repeat;
            background-position: left;
            color:aliceblue;

}
}

@media (max-width: 576px) {
    .card-title-on-image {
        -webkit-line-clamp: 2;
        line-clamp: 2;
        max-height: calc(1.4em * 2);
        font-size: 0.9rem;
        }
            .banner{
            width: 100%;
             height: 350px;
            background-size:cover;
            background-repeat: no-repeat;
            background-position: left;
            color:aliceblue;

}
}


/* ==========================================================================
   0. GLOBÁLIS TISZTÍTÁS (SZÜRKE VONALAK ÉS KERETEK ELTÜNTETÉSE)
   ========================================================================== */
/* Ez a rész kisöpri a Bootstrap összes gyári vékony szürke vonalát mindenhol */
hr, .hr, .border, .border-top, .border-bottom, .card, .list-group-item, .bg-light {
    border: none !important;
    border-width: 0 !important;
    outline: none !important;
    box-shadow: none !important;
}


/* Ha pseudo-elem (::after/::before) */
*:after, *:before {
    background-color: transparent !important;
    display: none !important;
}

/* Ha egy üres div a vonal */
div[class*="separator"], div[class*="line"], hr {
    display: none !important;
    height: 0 !important;
}

.form-control{           
    font-family: var(--font-body);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 1rem;
    letter-spacing: 0.5px;
    border: 1.5px solid var(--color-primary)!important;
}

.form-label{
    font-family: var(--font-heading) !important;
    color: var(--color-text-main) !important;
}

.form-select{
    background-color: var(--color-bg-card)!important;
    border: 1.5px solid var(--color-primary)!important;
}

.text-danger{
    color: rgba(var(--bs-danger-rgb),var(--bs-text-opacity)) !important;
}


.table-responsive{
    border: 1.5px solid var(--color-primary)!important;
}

.table-light{
    background-color: var(--color-bg-card)!important;
    border: 1.5px solid var(--color-primary)!important;
}

.input-group-text{
    border: 1.5px solid var(--color-primary)!important;
    color: var(--bs-text-opacity)!important;
}


/* ==========================================================================
   ALKATEGÓRIÁK SZEKCIÓ FORMÁZÁSA (KATEGÓRIA OLDAL)
   ========================================================================== */

/* 1. Az "Alkategóriák..." cím formázása (H3 stílus átvétele a H2-re) */
main h2,
main .description p:first-of-type,
main .page-title-column h1 + p { /* ÚJ: Csak az h1 után álló p elemet jelöli ki! */
    font-family: var(--font-heading) !important;
    color: var(--color-text-main) !important;
    font-size: 1.3rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1rem !important;
    /* Elválasztó vonal */
    border-bottom: 2px solid var(--color-bg-main) !important; 
    padding-bottom: 12px !important;
    margin-top: 3.5rem !important;
    margin-bottom: 2rem !important;
    position: relative !important;
    display: block !important;
    width: 100% !important;
    text-align: left !important;
}

/* Arculati barna díszítőcsík az Alkategóriák és egyéb címek alá */
main h2::after,
main .description p:first-of-type::after,
main .page-title-column h1 + p::after { 
    content: "" !important;
    display: block !important;
    width: 100px !important;            /* JAVÍTÁS: 80px helyett 100px a jobb arányokért */
    height: 4px !important;             /* JAVÍTÁS: 3px helyett 4px a hangsúlyosabb megjelenésért */
    background-color: var(--color-accent) !important;
    position: absolute !important;
    bottom: -2px !important;
    left: 0 !important;
    border-radius: 2px;
}



main h3, 
main h3, 
.category-view h3, 
.subcategory-title, 
main .col-12 h3 {
    font-family: var(--font-heading) !important;
    color: var(--color-text-main) !important;
    font-size: 1.4rem !important;
    font-weight: 400 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1rem !important;
    /* JAVÍTÁS: A krém helyett a lágy zsályazölddel (#7c8f7a) tökéletesen látszódni fog a vonal! */
    border-bottom: 2px solid var(--color-bg-main) !important; 
    padding-bottom: 12px !important;
    margin-top: 3.5rem !important;
    margin-bottom: 2rem !important;
    position: relative !important;
    display: block !important;
    width: 100% !important;
    text-align: left !important;
}

/* Arculati barna díszítőcsík az Alkategóriák, h3-ak és egyéb kiemelt leírások cím alá */
main h3::after,
main .description p:first-of-type::after,
main .page-title-column h1 + p::after,
main h3::after { /* JAVÍTÁS: Itt is kivettük a :not() szigorítást */
    content: "" !important;
    display: block !important;
    width: 100px !important;
    height: 4px !important;
    background-color: var(--color-accent) !important;
    position: absolute !important;
    bottom: -2px !important;
    left: 0 !important;
    border-radius: 2px;
}


.mb-3.display-4.fw-bold, .h2{
    color: #ffffff !important;
}

.col-lg-6.col-md-12.mb-4.mb-md-0 .text-uppercase{
    color: var(--color-text-light);
}