:root {
    --brand: #4BB29E;
    --brand-600: #3ea490;
    --ink: #1b1f23;
    --paper: #fff;
}

html {
    scroll-behavior: smooth
}

body {
    font-family: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    color: var(--ink);
    background: var(--paper)
}

h1,
h2,
h3,
h4 {
    font-family: "Playfair Display", serif
}

.text-brand {
    color: var(--brand)
}

.navbar {
    --bs-navbar-padding-y: .75rem;
    background: rgba(255, 255, 255, .9);
    backdrop-filter: saturate(140%) blur(8px);
    box-shadow: 0 2px 0 rgba(0, 0, 0, .04)
}

.navbar-brand img {
    height: 40px
}

.nav-link.active,
.nav-link:hover {
    color: var(--brand) !important
}

.hero-wrap {
    margin-top: 72px
}

.carousel-caption {
    background: rgba(0, 0, 0, .45);
    border-radius: 14px;
    padding: .75rem 1rem
}

.btn-brand {
    background: var(--brand);
    color: #fff;
    border: none;
    border-radius: 999px;
    padding: .65rem 1.2rem;
    font-weight: 700
}

.btn-brand:hover {
    background: var(--brand-600);
    color: #fff
}

.btn-outline-brand {
    border: 2px solid var(--brand);
    color: var(--brand);
    border-radius: 999px;
    padding: .55rem 1.1rem;
    font-weight: 700
}

.btn-outline-brand:hover {
    background: var(--brand);
    color: #fff
}

section {
    padding: 64px 0
}

.section-eyebrow {
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--brand);
    font-weight: 800;
    font-size: .85rem
}

.product-card {
    border: 1px solid #eef2f4;
    border-radius: 18px;
    overflow: hidden;
    transition: transform .2s, box-shadow .2s
}

.product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, .08)
}

.badge-menta {
    background: var(--brand);
    color: #fff
}

.gallery img {
    border-radius: 16px;
    object-fit: cover;
    width: 100%;
    height: 100%
}

.page-hero {
    margin-top: 72px;
    padding: 64px 0;
    background: linear-gradient(180deg, #f9fffd, #ffffff)
}

.page-hero h1 {
    margin: 0
}

footer {
    background: #0e1113;
    color: #cdd5dc
}

footer a {
    color: #e6fffa;
    text-decoration: none;
}

footer a:hover {
    text-decoration: underline;
}

footer a:hover {
    text-decoration: underline
}

.map-embed {
    min-height: 260px;
    border: 0;
    width: 100%;
    border-radius: 12px
}


.carousel-inner img {
    width: 100%;
    height: 850px;
    object-fit: cover;
    max-width: 1920px;
    margin: 0 auto;
}

.product-card img {
    width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    object-fit: cover;
    display: block;
}

.filter-btn.active,
.filter-btn.btn-brand {
    background: var(--brand);
    color: #fff;
    border-color: var(--brand);
}

.img-hero-fixed {
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    border-radius: 1rem;
    display: block;
}

.gallery img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 12px;
    display: block;
}