/* RUMPUT — Paysagiste / jardinage, vert vif sur creme chaud */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Bebas+Neue&display=swap');

:root {
    --rt-green: #65a30d;
    --rt-green-deep: #4d7c0f;
    --rt-green-soft: #e6f1d4;
    --rt-cream: #fdf6ee;
    --rt-cream-deep: #f3e8d6;
    --rt-brown: #3d2818;
    --rt-brown-soft: #5b3e2a;
    --rt-sage: #9eb39a;
    --rt-white: #ffffff;
    --rt-text: #2a1c10;
    --rt-text-mute: #6b5a48;
    --rt-line: #ebe1cf;
    --rt-font: 'Manrope', system-ui, sans-serif;
    --rt-display: 'Bebas Neue', 'Manrope', system-ui, sans-serif;
}

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

.rt-eyebrow { display: inline-block; color: var(--rt-green); font-size: .82rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1rem; }
.rt-section-title { font-family: var(--rt-display); font-size: clamp(2rem, 4.5vw, 3.4rem); font-weight: 400; line-height: 1.05; color: var(--rt-brown); letter-spacing: .01em; text-transform: uppercase; margin-bottom: 1rem; }

.rt-btn { display: inline-flex; align-items: center; justify-content: center; padding: .9rem 1.85rem; border-radius: 999px; font-size: .85rem; font-weight: 700; letter-spacing: .02em; transition: all .25s; cursor: pointer; }
.rt-btn--lg { padding: 1.05rem 2.2rem; font-size: .9rem; }
.rt-btn--green { background: var(--rt-green); color: var(--rt-cream); }
.rt-btn--green:hover { background: var(--rt-green-deep); transform: translateY(-2px); }
.rt-btn--cream { background: var(--rt-cream); color: var(--rt-brown); }
.rt-btn--cream:hover { background: var(--rt-white); transform: translateY(-2px); }
.rt-btn--brown { background: var(--rt-brown); color: var(--rt-cream); }
.rt-btn--brown:hover { background: var(--rt-brown-soft); transform: translateY(-2px); }

/* HEADER cream sticky */
.rt-header { position: sticky; top: 0; z-index: 50; background: var(--rt-cream); border-bottom: 1px solid var(--rt-line); padding: 1rem 2.5rem; }
.rt-header__inner { display: flex; align-items: center; justify-content: space-between; max-width: 1300px; margin: 0 auto; gap: 2rem; }
.rt-logo { display: inline-flex; align-items: center; gap: .55rem; font-weight: 800; font-size: 1.45rem; color: var(--rt-green); letter-spacing: -.01em; }
.rt-logo__leaf { font-size: 1.55rem; }
.rt-logo__name { color: var(--rt-green); }
.rt-nav ul { display: flex; gap: 1.85rem; }
.rt-nav a { font-size: .88rem; color: var(--rt-brown); font-weight: 500; transition: color .25s; }
.rt-nav a:hover { color: var(--rt-green); }
.rt-nav a.is-active { color: var(--rt-green); font-weight: 700; }

/* HERO photo background, centered text */
.rt-hero { position: relative; min-height: 78vh; padding: 7rem 2.5rem 8rem; background-color: var(--rt-brown); background-size: cover; background-position: center; display: flex; align-items: center; justify-content: center; text-align: center; color: var(--rt-cream); }
.rt-hero__inner { max-width: 880px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 1.4rem; }
.rt-hero__eyebrow { display: inline-block; color: var(--rt-cream); background: rgba(101, 163, 13, .85); padding: .35rem 1.1rem; border-radius: 999px; font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.rt-hero__title { font-family: var(--rt-display); font-size: clamp(2.6rem, 6vw, 5rem); font-weight: 400; line-height: 1; letter-spacing: .015em; text-transform: uppercase; color: var(--rt-cream); max-width: 14ch; }
.rt-hero__lead { color: rgba(253, 246, 238, .9); max-width: 560px; font-size: 1.02rem; }

/* SERVICES BAND light green */
.rt-services { background: var(--rt-green-soft); padding: clamp(3rem, 5vw, 4.5rem) 2.5rem; }
.rt-services__inner { max-width: 1180px; margin: 0 auto; }
.rt-services__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }
.rt-services__card { text-align: center; padding: 1rem .5rem; }
.rt-services__icon { display: inline-flex; align-items: center; justify-content: center; width: 76px; height: 76px; border-radius: 50%; background: var(--rt-white); color: var(--rt-green); font-size: 1.85rem; margin-bottom: 1.1rem; box-shadow: 0 6px 20px rgba(61, 40, 24, .08); }
.rt-services__name { font-size: 1.1rem; font-weight: 700; color: var(--rt-brown); margin-bottom: .5rem; }
.rt-services__desc { color: var(--rt-text-mute); font-size: .88rem; line-height: 1.6; }

/* EXPERTISE white split */
.rt-expertise { background: var(--rt-white); padding: clamp(3.5rem, 6vw, 6rem) 2.5rem; }
.rt-expertise__inner { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.rt-expertise__visual { aspect-ratio: 4/5; background-color: var(--rt-sage); background-size: cover; background-position: center; border-radius: 18px; max-width: 480px; }
.rt-expertise__lead { color: var(--rt-text-mute); margin: 1rem 0 2rem; line-height: 1.75; }
.rt-expertise__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; padding-top: 1.5rem; border-top: 1px solid var(--rt-line); }
.rt-stat { display: flex; flex-direction: column; gap: .25rem; }
.rt-stat__value { font-family: var(--rt-display); font-size: 2.4rem; color: var(--rt-green); line-height: 1; letter-spacing: .01em; }
.rt-stat__label { font-size: .82rem; color: var(--rt-text-mute); font-weight: 500; letter-spacing: .04em; text-transform: uppercase; }

/* HOUSE light green section */
.rt-house { background: var(--rt-green-soft); padding: clamp(3.5rem, 6vw, 6rem) 2.5rem; }
.rt-house__inner { max-width: 1180px; margin: 0 auto; }
.rt-house__head { max-width: 720px; margin-bottom: 3rem; }
.rt-house__lead { color: var(--rt-text-mute); font-size: 1rem; }
.rt-house__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; }
.rt-house__list { display: flex; flex-direction: column; gap: 1.4rem; }
.rt-house__feature { display: flex; gap: 1rem; align-items: flex-start; padding: 1.1rem 1.2rem; background: var(--rt-white); border-radius: 14px; box-shadow: 0 4px 16px rgba(61, 40, 24, .05); }
.rt-house__check { flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 50%; background: var(--rt-green); color: var(--rt-cream); font-size: .9rem; font-weight: 800; }
.rt-house__feature-title { font-size: 1.05rem; font-weight: 700; color: var(--rt-brown); margin-bottom: .25rem; }
.rt-house__feature-desc { font-size: .88rem; color: var(--rt-text-mute); line-height: 1.55; }
.rt-house__visual { aspect-ratio: 4/5; background-color: var(--rt-sage); background-size: cover; background-position: center; border-radius: 18px; }

/* CTA bright green */
.rt-cta { background: var(--rt-green); padding: clamp(3rem, 5vw, 5rem) 2.5rem; text-align: center; }
.rt-cta__inner { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 1.8rem; }
.rt-cta__title { font-family: var(--rt-display); font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 400; line-height: 1.05; letter-spacing: .015em; text-transform: uppercase; color: var(--rt-cream); }

/* FOOTER dark brown 4-col */
.rt-footer { background: var(--rt-brown); color: rgba(253, 246, 238, .8); padding: clamp(3rem, 5vw, 4.5rem) 2.5rem 1.8rem; }
.rt-footer__inner { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 3rem; }
.rt-footer__col h4 { font-size: .82rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--rt-cream); margin-bottom: 1.1rem; }
.rt-footer__logo { display: inline-flex; align-items: center; gap: .5rem; font-weight: 800; font-size: 1.45rem; color: var(--rt-cream); margin-bottom: 1rem; }
.rt-footer__leaf { color: var(--rt-green); font-size: 1.55rem; }
.rt-footer__tagline { font-size: .9rem; line-height: 1.65; color: rgba(253, 246, 238, .7); max-width: 320px; }
.rt-footer__links li, .rt-footer__contact li { padding: .25rem 0; font-size: .9rem; }
.rt-footer__links a:hover, .rt-footer__contact a:hover { color: var(--rt-green); }
.rt-footer__divider { display: block; max-width: 1180px; margin: 2.5rem auto 1.5rem; height: 2px; background: var(--rt-green); border-radius: 2px; }
.rt-footer__bottom { max-width: 1180px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; gap: 1rem; font-size: .82rem; color: rgba(253, 246, 238, .55); }
.rt-footer__socials { letter-spacing: .15em; }

/* Contact page (fallback styling minimal) */
.contact-page { background: var(--rt-cream); padding: clamp(3rem, 5vw, 5rem) 2.5rem; }
.contact-page .container.two-col { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.1fr; gap: 3rem; }
.contact-page h1 { font-family: var(--rt-display); font-size: clamp(2.2rem, 4vw, 3rem); color: var(--rt-brown); text-transform: uppercase; margin-bottom: 1.2rem; }
.contact-page p { color: var(--rt-text-mute); margin-bottom: .5rem; }
.contact-form { display: flex; flex-direction: column; gap: .9rem; }
.contact-form label { display: flex; flex-direction: column; gap: .35rem; font-size: .85rem; color: var(--rt-brown); font-weight: 600; }
.contact-form input, .contact-form select, .contact-form textarea { padding: .75rem .95rem; border: 1px solid var(--rt-line); border-radius: 10px; background: var(--rt-white); font: inherit; color: var(--rt-text); }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { outline: none; border-color: var(--rt-green); }
.contact-form .hp { position: absolute; left: -9999px; }
.contact-form .btn, .contact-form button { background: var(--rt-green); color: var(--rt-cream); padding: .9rem 1.85rem; border-radius: 999px; font-weight: 700; align-self: flex-start; }
.contact-form button:hover { background: var(--rt-green-deep); }
.flash { padding: .85rem 1rem; border-radius: 10px; margin-bottom: 1rem; font-size: .9rem; }
.flash-success { background: var(--rt-green-soft); color: var(--rt-green-deep); }
.flash-error { background: #fde8e8; color: #9b1c1c; }

.not-found { padding: clamp(4rem, 8vw, 8rem) 2.5rem; text-align: center; }
.not-found h1 { font-family: var(--rt-display); font-size: clamp(2rem, 5vw, 3.5rem); color: var(--rt-brown); text-transform: uppercase; margin-bottom: 1rem; }
.not-found p { color: var(--rt-text-mute); margin-bottom: 1.5rem; }
.not-found .btn { display: inline-flex; padding: .9rem 1.85rem; border-radius: 999px; background: var(--rt-green); color: var(--rt-cream); font-weight: 700; }

.preview-banner { background: var(--rt-green); color: var(--rt-cream); text-align: center; padding: .55rem; font-weight: 700; font-size: .82rem; letter-spacing: .04em; }
[x-cloak] { display: none !important; }

/* Responsive 800px */
@media (max-width: 800px) {
    .rt-header { padding: .85rem 1.25rem; }
    .rt-header__inner { gap: 1rem; }
    .rt-nav { display: none; }
    .rt-hero { padding: 5rem 1.5rem 6rem; min-height: 60vh; }
    .rt-services { padding: 2.5rem 1.5rem; }
    .rt-services__grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
    .rt-expertise { padding: 3rem 1.5rem; }
    .rt-expertise__inner { grid-template-columns: 1fr; gap: 2rem; }
    .rt-expertise__visual { max-width: 100%; aspect-ratio: 4/3; }
    .rt-expertise__stats { gap: .5rem; }
    .rt-stat__value { font-size: 1.85rem; }
    .rt-house { padding: 3rem 1.5rem; }
    .rt-house__grid { grid-template-columns: 1fr; gap: 2rem; }
    .rt-house__visual { aspect-ratio: 4/3; }
    .rt-cta { padding: 3rem 1.5rem; }
    .rt-footer { padding: 2.5rem 1.5rem 1.5rem; }
    .rt-footer__inner { grid-template-columns: 1fr 1fr; gap: 2rem; }
    .rt-footer__bottom { flex-direction: column; text-align: center; }
    .contact-page { padding: 2.5rem 1.5rem; }
    .contact-page .container.two-col { grid-template-columns: 1fr; gap: 2rem; }
}
