/* JELU — Organic & healthy. Vert sage pâle + cream. */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
    --j-mint: #d4e5d4;
    --j-mint-soft: #e6efe2;
    --j-mint-deep: #b8d2b8;
    --j-cream: #f5f7e8;
    --j-cream-soft: #fafce8;
    --j-green: #2d5a3d;
    --j-green-deep: #1f4029;
    --j-green-light: #4d7d5a;
    --j-text: #1a2a1f;
    --j-text-mute: #6a7a6a;
    --j-line: #d8e0d4;
    --j-font-display: 'Cormorant Garamond', Georgia, serif;
    --j-font-body: 'Inter', system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--j-mint-soft); color: var(--j-text); font-family: var(--j-font-body); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: opacity .25s ease; }
button { background: 0; border: 0; cursor: pointer; font: inherit; color: inherit; }
ul { list-style: none; padding: 0; }

/* HEADER */
.j-header { background: var(--j-mint-soft); padding: 1.25rem 2.5rem; }
.j-header__inner { display: flex; align-items: center; justify-content: space-between; max-width: 1300px; margin: 0 auto; gap: 2rem; }
.j-logo { display: flex; align-items: center; gap: .35rem; font-family: var(--j-font-display); font-size: 1.65rem; font-weight: 700; color: var(--j-green); }
.j-logo__leaf { font-size: 1rem; }
.j-nav ul { display: flex; gap: 1.85rem; }
.j-nav a { font-size: .92rem; color: var(--j-text); font-weight: 500; }
.j-nav a:hover, .j-nav a.is-active { color: var(--j-green); font-weight: 600; }

/* BUTTONS */
.j-btn { display: inline-flex; align-items: center; gap: .35rem; padding: .85rem 1.85rem; border-radius: 999px; font-size: .85rem; font-weight: 600; cursor: pointer; transition: all .25s ease; border: 1.5px solid transparent; }
.j-btn--green { background: var(--j-green); color: #fff; border-color: var(--j-green); }
.j-btn--green:hover { background: var(--j-green-deep); }
.j-btn--cream { background: var(--j-cream); color: var(--j-green); }
.j-btn--cream:hover { background: #fff; }
.j-btn--round { padding: .85rem 1.5rem; }

.j-section-title { font-family: var(--j-font-display); font-size: clamp(1.85rem, 3.5vw, 2.5rem); font-weight: 700; line-height: 1.15; color: var(--j-text); margin-bottom: 1.5rem; text-align: center; }
.j-section-title--light { color: #fff; }

/* HERO */
.j-hero { background: var(--j-mint-soft); padding: 1.5rem 2.5rem 3.5rem; position: relative; overflow: hidden; }
.j-hero__inner { max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.05fr; gap: 3rem; align-items: center; position: relative; }
.j-hero__title { font-family: var(--j-font-display); font-size: clamp(2.5rem, 5vw, 4rem); font-weight: 700; line-height: 1; letter-spacing: -.02em; margin-bottom: 1.25rem; color: var(--j-text); }
.j-hero__lead { color: var(--j-text-mute); font-size: 1rem; line-height: 1.7; max-width: 420px; margin-bottom: 2rem; }
.j-hero__bowl { aspect-ratio: 1; max-width: 540px; margin-left: auto; }
.j-hero__bowl img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; box-shadow: 0 30px 60px rgba(45,90,61,.18); }
.j-hero__bowl-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--j-mint-deep) 0%, var(--j-green-light) 100%); border-radius: 50%; }
.j-hero__leaf { position: absolute; font-size: 2rem; opacity: .6; }
.j-hero__leaf--1 { top: 5%; left: 50%; }
.j-hero__leaf--2 { top: 60%; right: 5%; transform: rotate(45deg); }
.j-hero__leaf--3 { bottom: 10%; left: 5%; transform: rotate(-30deg); }
@media (max-width: 800px) { .j-hero__inner { grid-template-columns: 1fr; } }

/* SEARCH bar */
.j-search { background: var(--j-mint-soft); padding: 0 2.5rem 3rem; }
.j-search__inner { max-width: 1100px; margin: 0 auto; background: var(--j-cream); border-radius: 999px; padding: .75rem; display: flex; align-items: center; gap: .5rem; box-shadow: 0 8px 30px rgba(45,90,61,.08); }
.j-search__field { flex: 1; display: flex; align-items: center; gap: .85rem; padding: .5rem 1rem; }
.j-search__field small { display: block; font-size: .7rem; color: var(--j-text-mute); }
.j-search__field strong { display: block; font-size: .9rem; color: var(--j-text); }
.j-search__icon { width: 32px; height: 32px; border-radius: 50%; background: var(--j-mint-soft); display: inline-flex; align-items: center; justify-content: center; color: var(--j-green); }
.j-search__field select { border: 0; background: transparent; font-size: .9rem; color: var(--j-text); cursor: pointer; }
.j-search__inner .j-btn { white-space: nowrap; }
@media (max-width: 800px) { .j-search__inner { flex-direction: column; border-radius: 24px; padding: 1rem; gap: 1rem; } }

/* WHAT */
.j-what { background: #fff; padding: clamp(3rem, 6vw, 5rem) 2.5rem; }
.j-what__inner { max-width: 1100px; margin: 0 auto; }
.j-what__split { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; margin-top: 3rem; }
.j-what__text p { color: var(--j-text-mute); font-size: .95rem; line-height: 1.85; margin-bottom: 1.85rem; }
.j-what__photo { aspect-ratio: 4/3; border-radius: 16px; overflow: hidden; background: var(--j-mint-soft); }
.j-what__photo img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 800px) { .j-what__split { grid-template-columns: 1fr; gap: 2rem; } }

/* CARDS */
.j-cards { background: #fff; padding: clamp(3rem, 5vw, 4rem) 2.5rem; }
.j-cards__inner { max-width: 1100px; margin: 0 auto; }
.j-cards__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.85rem; }
.j-cards__card { background: var(--j-mint-soft); padding: 2rem 1.85rem; border-radius: 24px; text-align: left; transition: transform .3s ease; }
.j-cards__card:hover { transform: translateY(-3px); }
.j-cards__icon { display: inline-block; width: 40px; height: 40px; border-radius: 50%; background: #fff; line-height: 40px; text-align: center; color: var(--j-green); margin-bottom: 1rem; }
.j-cards__card h3 { font-family: var(--j-font-display); font-size: 1.25rem; font-weight: 700; margin-bottom: .65rem; }
.j-cards__card p { font-size: .88rem; color: var(--j-text-mute); line-height: 1.65; margin-bottom: 1.25rem; }
.j-cards__link { color: var(--j-green); font-size: .85rem; font-weight: 600; padding-top: .85rem; border-top: 1px dashed var(--j-mint-deep); display: block; }
@media (max-width: 800px) { .j-cards__grid { grid-template-columns: 1fr; } }

/* RESERVATION */
.j-reservation { background: var(--j-mint-deep); padding: clamp(3rem, 6vw, 5rem) 2.5rem; text-align: center; }
.j-reservation__inner { max-width: 1100px; margin: 0 auto; }
.j-reservation__lead { color: rgba(255,255,255,.85); font-size: 1rem; line-height: 1.7; max-width: 600px; margin: 0 auto 2.5rem; }
.j-reservation__bar { display: flex; gap: 1rem; justify-content: center; align-items: center; flex-wrap: wrap; }
.j-reservation__chip { background: rgba(255,255,255,.15); padding: .85rem 1.25rem; border-radius: 999px; display: inline-flex; align-items: center; gap: .65rem; color: #fff; font-size: .85rem; font-weight: 500; }
.j-reservation__chip span { opacity: .85; }
.j-reservation__chip strong { font-weight: 700; }
.j-section-title--light { color: #fff; }

/* FOOTER */
.j-footer { background: var(--j-green-deep); color: rgba(255,255,255,.7); padding: 3rem 2.5rem 1.5rem; }
.j-footer__inner { max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2.5rem; padding-bottom: 2.5rem; }
.j-footer__brand h4 { font-family: var(--j-font-display); font-size: 1.5rem; color: #fff; margin-bottom: .5rem; }
.j-footer__brand p { font-size: .88rem; line-height: 1.7; }
.j-footer h5 { color: #fff; font-size: .82rem; margin-bottom: .85rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 600; }
.j-footer ul li { margin-bottom: .35rem; font-size: .88rem; }
.j-footer a { color: rgba(255,255,255,.85); }
.j-footer a:hover { color: #fff; }
.j-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); padding-top: 1.25rem; text-align: center; font-size: .82rem; color: rgba(255,255,255,.5); }
@media (max-width: 800px) { .j-footer__inner { grid-template-columns: 1fr 1fr; } }

.preview-banner { background: var(--j-green); color: #fff; text-align: center; padding: .5rem; font-weight: 600; font-size: .82rem; }
[x-cloak] { display: none !important; }
