:root {
    --zoe-green: #163d2b;
    --zoe-green-2: #245c41;
    --zoe-gold: #c9a45d;
    --zoe-cream: #f7f2e9;
    --zoe-soft: #eef5ef;
    --zoe-terracotta: #b9704a;
    --zoe-text: #24332b;
    --zoe-muted: #6a756e;
    --zoe-white: #ffffff;
    --shadow-soft: 0 24px 70px rgba(22, 61, 43, 0.12);
}

* { box-sizing: border-box; }

body {
    color: var(--zoe-text);
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: #fff;
    padding-top: 76px;
}

a { color: var(--zoe-green-2); text-decoration: none; }
a:hover { color: var(--zoe-green); }

.navbar-zoe {
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(22, 61, 43, .08);
}

.navbar-brand { color: var(--zoe-green) !important; letter-spacing: -0.02em; }
.brand-mark {
    display: inline-grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: var(--zoe-green);
    color: white;
    margin-right: .35rem;
}

.nav-link { color: rgba(36, 51, 43, .78); font-weight: 600; }
.nav-link.active, .nav-link:hover { color: var(--zoe-green) !important; }

.btn-zoe {
    background: var(--zoe-green);
    color: white;
    border: 1px solid var(--zoe-green);
    border-radius: 999px;
    padding-inline: 1.25rem;
    font-weight: 700;
}
.btn-zoe:hover { background: var(--zoe-green-2); border-color: var(--zoe-green-2); color: white; }

.btn-outline-zoe {
    border: 1px solid rgba(22, 61, 43, .35);
    color: var(--zoe-green);
    border-radius: 999px;
    padding-inline: 1.25rem;
    font-weight: 700;
}
.btn-outline-zoe:hover { background: var(--zoe-green); border-color: var(--zoe-green); color: white; }

.btn-light-zoe {
    background: var(--zoe-soft);
    color: var(--zoe-green);
    border-radius: 999px;
    font-weight: 700;
}

.hero-section, .page-hero {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 80% 20%, rgba(201, 164, 93, .20), transparent 28%),
        linear-gradient(135deg, var(--zoe-cream), #fff 55%, var(--zoe-soft));
}

.min-vh-80 { min-height: 78vh; }
.section-padding { padding: 92px 0; }
.compact-hero { padding: 92px 0 74px; }
.product-detail-hero { padding: 92px 0; }

.eyebrow {
    color: var(--zoe-terracotta);
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    font-size: .75rem;
}
.eyebrow-light { color: var(--zoe-gold); }

.hero-visual-card {
    position: relative;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(22,61,43,.1);
    border-radius: 34px;
    padding: 2rem;
    box-shadow: var(--shadow-soft);
}

.floating-card {
    position: absolute;
    left: 2rem;
    bottom: 2rem;
    background: rgba(255,255,255,.9);
    border-radius: 20px;
    padding: 1rem 1.2rem;
    box-shadow: 0 18px 45px rgba(0,0,0,.08);
    display: grid;
    gap: .2rem;
}
.floating-card span { color: var(--zoe-muted); font-size: .9rem; }

.section-heading { max-width: 720px; }
.bg-soft { background: var(--zoe-soft); }
.bg-dark-zoe { background: linear-gradient(135deg, var(--zoe-green), #0f291d); }

.goal-card, .context-card, .wellbeing-card, .contact-panel, .info-panel, .sticky-cta-card, .responsible-box, .empty-state {
    background: white;
    border: 1px solid rgba(22,61,43,.08);
    border-radius: 26px;
    padding: 1.5rem;
    box-shadow: 0 16px 50px rgba(22,61,43,.07);
}
.goal-card {
    display: block;
    height: 100%;
    color: var(--zoe-text);
    transition: transform .2s ease, box-shadow .2s ease;
}
.goal-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft); color: var(--zoe-text); }
.goal-card p, .context-card p, .wellbeing-card p { color: var(--zoe-muted); margin-bottom: 0; }
.goal-icon {
    display: block;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--zoe-green), var(--zoe-gold));
    margin-bottom: 1rem;
}
.context-card h3 { font-size: 1.05rem; font-weight: 800; }

.product-card {
    border: 1px solid rgba(22,61,43,.09);
    border-radius: 26px;
    overflow: hidden;
    box-shadow: 0 15px 45px rgba(22,61,43,.07);
    transition: transform .2s ease, box-shadow .2s ease;
}
.product-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft); }
.product-image-wrap {
    display: block;
    background: linear-gradient(135deg, var(--zoe-cream), var(--zoe-soft));
    padding: 1.5rem;
}
.product-card img { height: 230px; object-fit: contain; }
.product-category {
    color: var(--zoe-terracotta);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.category-pills { display: flex; flex-wrap: wrap; gap: .6rem; }
.pill {
    border: 1px solid rgba(22,61,43,.16);
    color: var(--zoe-green);
    border-radius: 999px;
    padding: .6rem 1rem;
    font-weight: 700;
    background: white;
}
.pill.active, .pill:hover { background: var(--zoe-green); color: white; }

.detail-product-image {
    max-width: min(420px, 100%);
    background: white;
    border-radius: 34px;
    padding: 2rem;
    box-shadow: var(--shadow-soft);
}
.sticky-cta-card { position: sticky; top: 100px; }

.site-footer { background: #f8f8f5; border-top: 1px solid rgba(22,61,43,.08); }
.footer-links li { margin-bottom: .5rem; }
.footer-links a { color: var(--zoe-muted); }
.footer-links a:hover { color: var(--zoe-green); }

.lead-modal-content { border-radius: 28px; border: 0; box-shadow: var(--shadow-soft); }
.form-control, .form-select { border-radius: 14px; padding: .8rem 1rem; border-color: rgba(22,61,43,.16); }
.form-control:focus, .form-select:focus { border-color: var(--zoe-green-2); box-shadow: 0 0 0 .2rem rgba(36,92,65,.12); }

.map-wrap, .map-placeholder { border-radius: 24px; overflow: hidden; min-height: 360px; }
.map-placeholder {
    background: linear-gradient(135deg, var(--zoe-cream), var(--zoe-soft));
    display: grid;
    place-content: center;
    text-align: center;
    padding: 2rem;
    color: var(--zoe-muted);
}
.map-placeholder strong { color: var(--zoe-green); font-size: 1.2rem; }
.map-placeholder span { display: block; margin-top: .4rem; }

.not-found-section { min-height: 55vh; display: grid; place-items: center; }

@media (max-width: 991.98px) {
    body { padding-top: 68px; }
    .section-padding { padding: 68px 0; }
    .min-vh-80 { min-height: auto; padding: 70px 0; }
    .floating-card { position: static; margin-top: 1rem; }
}
