
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { min-height: 100vh; line-height: 1.6; }
img { display: block; max-width: 100%; height: auto; }
a { text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }

@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@400;600&family=Nunito:wght@400;600;700&display=swap');
:root { --leaf-bg: #f0f7f0; --leaf-green: #2d6a4f; --leaf-green-lt: #52b788; --leaf-brown: #6b4c3b;
  --leaf-text: #1b4332; --leaf-font-hand: 'Caveat', cursive; --leaf-font: 'Nunito', sans-serif; }
body { font-family: var(--leaf-font); background: var(--leaf-bg); color: var(--leaf-text); }
.leaf-shell { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
.leaf-top { padding: 20px 0; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.leaf-logo { font-family: var(--leaf-font-hand); font-size: 2rem; color: var(--leaf-green); }
.leaf-nav ul { display: flex; gap: 20px; flex-wrap: wrap; }
.leaf-nav a { color: var(--leaf-text); font-weight: 600; border-radius: 20px; padding: 6px 16px; transition: background 0.3s; }
.leaf-nav a:hover { background: var(--leaf-green-lt); color: #fff; }
.leaf-cta { background: var(--leaf-green); color: #fff; border-radius: 30px; padding: 10px 24px; font-weight: 700; }
.leaf-cta:hover { background: var(--leaf-green-lt); }
.leaf-banner { background: var(--leaf-green); color: #fff; border-radius: 60% 40% 50% 50% / 50% 60% 40% 50%;
  padding: 60px 40px; margin: 32px 0; text-align: center; }
.leaf-banner h1 { font-family: var(--leaf-font-hand); font-size: clamp(2rem, 5vw, 3.5rem); margin-bottom: 8px; }
.leaf-zone { padding: 40px 0; }
.leaf-zone__title { font-family: var(--leaf-font-hand); font-size: 1.8rem; color: var(--leaf-green); margin-bottom: 20px; }
.leaf-mosaic { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
.leaf-blob { background: #fff; border-radius: 30% 70% 60% 40% / 50% 40% 60% 50%; padding: 20px;
  box-shadow: 0 4px 20px rgba(45,106,79,0.1); transition: transform 0.3s; }
.leaf-blob:hover { transform: rotate(-1deg) scale(1.02); }
.leaf-note { background: #fff8e7; border-radius: 16px; padding: 20px; border: 2px dashed var(--leaf-green-lt); }
.leaf-copy { line-height: 1.8; color: #40916c; }
.leaf-copy h2 { font-family: var(--leaf-font-hand); color: var(--leaf-green); font-size: 1.5rem; margin: 1em 0 0.5em; }
.leaf-showcase { display: flex; gap: 32px; flex-wrap: wrap; padding: 40px 0; }
.leaf-showcase__photo { flex: 1; min-width: 280px; }
.leaf-showcase__photo img { border-radius: 40% 60% 50% 50% / 60% 40% 60% 40%; width: 100%; }
.leaf-showcase__thumbs { display: flex; gap: 8px; margin-top: 12px; }
.leaf-showcase__info { flex: 1; min-width: 280px; }
.leaf-showcase__name { font-family: var(--leaf-font-hand); font-size: 2.2rem; color: var(--leaf-green); }
.leaf-showcase__price { font-size: 1.3rem; font-weight: 700; color: var(--leaf-brown); margin: 12px 0; }
.leaf-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 20px 0; }
.leaf-specs span { background: #d8f3dc; border-radius: 12px; padding: 8px 12px; font-size: 0.9rem; }
.leaf-book { display: inline-block; background: var(--leaf-green); color: #fff; border-radius: 30px;
  padding: 12px 28px; font-weight: 700; }
.leaf-trail { font-size: 0.85rem; color: #40916c; padding: 16px 0; display: flex; gap: 8px; flex-wrap: wrap; }
.leaf-trail a { color: var(--leaf-green); font-weight: 600; }
.leaf-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.leaf-paging { display: flex; justify-content: center; gap: 8px; padding: 24px 0; }
.leaf-story { max-width: 720px; margin: 0 auto; padding: 40px 0; }
.leaf-story__head { font-family: var(--leaf-font-hand); font-size: 2.4rem; color: var(--leaf-green); }
.leaf-story__when { color: var(--leaf-brown); font-size: 0.9rem; margin: 12px 0 24px; }
.leaf-story__text { line-height: 1.9; }
.leaf-root { background: var(--leaf-green); color: #fff; margin-top: 60px; padding: 40px 0 20px;
  border-radius: 40px 40px 0 0; }
.leaf-root__cols { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 24px; margin-bottom: 24px; }
.leaf-root__about { font-size: 0.9rem; opacity: 0.85; line-height: 1.7; }
.leaf-root__areas a { color: #b7e4c7; font-size: 0.85rem; display: inline-block; margin: 2px 6px 2px 0; }
.leaf-root__bar { border-top: 1px solid rgba(255,255,255,0.2); padding-top: 16px; font-size: 0.8rem;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
@media (max-width: 768px) { .leaf-root__cols { grid-template-columns: 1fr; } .leaf-showcase { flex-direction: column; } }
.lf-m1 { margin: 2px; }
.lf-p1 { padding: 2px; }
.lf-gap1 { gap: 1px; }
.lf-w1 { width: 5px; max-width: 100%; }
.lf-fw4 { font-weight: 400; }
.lf-op1 { opacity: 0.1; }
.lf-m2 { margin: 4px; }
.lf-p2 { padding: 4px; }
.lf-gap2 { gap: 2px; }
.lf-w2 { width: 10px; max-width: 100%; }
.lf-m3 { margin: 6px; }
.lf-p3 { padding: 6px; }
.lf-gap3 { gap: 3px; }
.lf-w3 { width: 15px; max-width: 100%; }
.lf-m4 { margin: 8px; }
.lf-p4 { padding: 8px; }
.lf-gap4 { gap: 4px; }
.lf-w4 { width: 20px; max-width: 100%; }
.lf-m5 { margin: 10px; }
.lf-p5 { padding: 10px; }
.lf-gap5 { gap: 5px; }
.lf-w5 { width: 25px; max-width: 100%; }
.lf-m6 { margin: 12px; }
.lf-p6 { padding: 12px; }
.lf-gap6 { gap: 6px; }
.lf-w6 { width: 30px; max-width: 100%; }
.lf-fw5 { font-weight: 500; }
.lf-op2 { opacity: 0.2; }
.lf-m7 { margin: 14px; }
.lf-p7 { padding: 14px; }
.lf-gap7 { gap: 7px; }
.lf-w7 { width: 35px; max-width: 100%; }
.lf-m8 { margin: 16px; }
.lf-p8 { padding: 16px; }
.lf-gap8 { gap: 8px; }
.lf-w8 { width: 40px; max-width: 100%; }
.lf-m9 { margin: 18px; }
.lf-p9 { padding: 18px; }
.lf-gap9 { gap: 9px; }
.lf-w9 { width: 45px; max-width: 100%; }
.lf-m10 { margin: 20px; }
.lf-p10 { padding: 20px; }
.lf-gap10 { gap: 10px; }
.lf-w10 { width: 50px; max-width: 100%; }
.lf-m11 { margin: 22px; }
.lf-p11 { padding: 22px; }
.lf-gap11 { gap: 11px; }
.lf-w11 { width: 55px; max-width: 100%; }
.lf-fw6 { font-weight: 600; }
.lf-op3 { opacity: 0.3; }
.lf-m12 { margin: 24px; }
.lf-p12 { padding: 24px; }
.lf-gap12 { gap: 12px; }
.lf-w12 { width: 60px; max-width: 100%; }
.lf-m13 { margin: 26px; }
.lf-p13 { padding: 26px; }
.lf-gap13 { gap: 13px; }
.lf-w13 { width: 65px; max-width: 100%; }
.lf-m14 { margin: 28px; }
.lf-p14 { padding: 28px; }
.lf-gap14 { gap: 14px; }
.lf-w14 { width: 70px; max-width: 100%; }
.lf-m15 { margin: 30px; }
.lf-p15 { padding: 30px; }
.lf-gap15 { gap: 15px; }
.lf-w15 { width: 75px; max-width: 100%; }
.lf-m16 { margin: 32px; }
.lf-p16 { padding: 32px; }
.lf-gap16 { gap: 16px; }
.lf-w16 { width: 80px; max-width: 100%; }
.lf-fw7 { font-weight: 700; }
.lf-op4 { opacity: 0.4; }
.lf-m17 { margin: 34px; }
.lf-p17 { padding: 34px; }
.lf-gap17 { gap: 17px; }
.lf-w17 { width: 85px; max-width: 100%; }
.lf-m18 { margin: 36px; }
.lf-p18 { padding: 36px; }
.lf-gap18 { gap: 18px; }
.lf-w18 { width: 90px; max-width: 100%; }
.lf-m19 { margin: 38px; }
.lf-p19 { padding: 38px; }
.lf-gap19 { gap: 19px; }
.lf-w19 { width: 95px; max-width: 100%; }
.lf-m20 { margin: 40px; }
.lf-p20 { padding: 40px; }
.lf-gap20 { gap: 20px; }
.lf-w20 { width: 100px; max-width: 100%; }
.lf-m21 { margin: 42px; }
.lf-p21 { padding: 42px; }
.lf-gap21 { gap: 21px; }
.lf-w21 { width: 105px; max-width: 100%; }
.lf-fw8 { font-weight: 800; }
.lf-op5 { opacity: 0.5; }
.lf-m22 { margin: 44px; }
.lf-p22 { padding: 44px; }
.lf-gap22 { gap: 22px; }
.lf-w22 { width: 110px; max-width: 100%; }
.lf-m23 { margin: 46px; }
.lf-p23 { padding: 46px; }
.lf-gap23 { gap: 23px; }
.lf-w23 { width: 115px; max-width: 100%; }
.lf-m24 { margin: 48px; }
.lf-p24 { padding: 48px; }
.lf-gap24 { gap: 24px; }
.lf-w24 { width: 120px; max-width: 100%; }
.lf-m25 { margin: 50px; }
.lf-p25 { padding: 50px; }
.lf-gap25 { gap: 25px; }
.lf-w25 { width: 125px; max-width: 100%; }
.lf-m26 { margin: 52px; }
.lf-p26 { padding: 52px; }
.lf-gap26 { gap: 26px; }
.lf-w26 { width: 130px; max-width: 100%; }
.lf-fw9 { font-weight: 900; }
.lf-op6 { opacity: 0.6; }
.lf-m27 { margin: 54px; }
.lf-p27 { padding: 54px; }
.lf-gap27 { gap: 27px; }
.lf-w27 { width: 135px; max-width: 100%; }
.lf-m28 { margin: 56px; }
.lf-p28 { padding: 56px; }
.lf-gap28 { gap: 28px; }
.lf-w28 { width: 140px; max-width: 100%; }
.lf-m29 { margin: 58px; }
.lf-p29 { padding: 58px; }
.lf-gap29 { gap: 29px; }
.lf-w29 { width: 145px; max-width: 100%; }
.lf-m30 { margin: 60px; }
.lf-p30 { padding: 60px; }
.lf-gap30 { gap: 30px; }
.lf-w30 { width: 150px; max-width: 100%; }
.lf-m31 { margin: 62px; }
.lf-p31 { padding: 62px; }
.lf-gap31 { gap: 31px; }
.lf-w31 { width: 155px; max-width: 100%; }
.lf-fw10 { font-weight: 1000; }
.lf-op7 { opacity: 0.7; }
.lf-m32 { margin: 64px; }
.lf-p32 { padding: 64px; }
.lf-gap32 { gap: 32px; }
.lf-w32 { width: 160px; max-width: 100%; }
.lf-m33 { margin: 66px; }
.lf-p33 { padding: 66px; }
.lf-gap33 { gap: 33px; }
.lf-w33 { width: 165px; max-width: 100%; }
.lf-m34 { margin: 68px; }
.lf-p34 { padding: 68px; }
.lf-gap34 { gap: 34px; }
.lf-w34 { width: 170px; max-width: 100%; }
.lf-m35 { margin: 70px; }
.lf-p35 { padding: 70px; }
.lf-gap35 { gap: 35px; }
.lf-w35 { width: 175px; max-width: 100%; }
.lf-m36 { margin: 72px; }
.lf-p36 { padding: 72px; }
.lf-gap36 { gap: 36px; }
.lf-w36 { width: 180px; max-width: 100%; }
.lf-fw11 { font-weight: 1100; }
.lf-op8 { opacity: 0.8; }
.lf-m37 { margin: 74px; }
.lf-p37 { padding: 74px; }
.lf-gap37 { gap: 37px; }
.lf-w37 { width: 185px; max-width: 100%; }
.lf-m38 { margin: 76px; }
.lf-p38 { padding: 76px; }
.lf-gap38 { gap: 38px; }
.lf-w38 { width: 190px; max-width: 100%; }
.lf-m39 { margin: 78px; }
.lf-p39 { padding: 78px; }
.lf-gap39 { gap: 39px; }
.lf-w39 { width: 195px; max-width: 100%; }
.lf-m40 { margin: 80px; }
.lf-p40 { padding: 80px; }
.lf-gap40 { gap: 40px; }
.lf-w40 { width: 200px; max-width: 100%; }
.lf-m41 { margin: 82px; }
.lf-p41 { padding: 82px; }
.lf-gap41 { gap: 41px; }
.lf-w41 { width: 205px; max-width: 100%; }
.lf-fw12 { font-weight: 1200; }
.lf-op9 { opacity: 0.9; }
.lf-m42 { margin: 84px; }
.lf-p42 { padding: 84px; }
.lf-gap42 { gap: 42px; }
.lf-w42 { width: 210px; max-width: 100%; }
.lf-m43 { margin: 86px; }
.lf-p43 { padding: 86px; }
.lf-gap43 { gap: 43px; }
.lf-w43 { width: 215px; max-width: 100%; }
.lf-m44 { margin: 88px; }
.lf-p44 { padding: 88px; }
.lf-gap44 { gap: 44px; }
.lf-w44 { width: 220px; max-width: 100%; }
.lf-m45 { margin: 90px; }
.lf-p45 { padding: 90px; }
.lf-gap45 { gap: 45px; }
.lf-w45 { width: 225px; max-width: 100%; }