@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500&family=Inter:wght@400;500;600&display=swap');

* { box-sizing: border-box; border-color: #e6eee7; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: #fbfcf9;
  color: #33483d;
  font-family: "Inter", system-ui, sans-serif;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 { font-family: "Cormorant Garamond", "Playfair Display", serif; letter-spacing: -0.02em; font-weight: 500; margin: 0; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
img, video { max-width: 100%; }
button, input, textarea { font: inherit; }
.page { min-height: 100vh; display: flex; flex-direction: column; background: #fbfcf9; }
.main { flex: 1; }
.container { width: 100%; max-width: 1280px; margin: 0 auto; padding-left: 24px; padding-right: 24px; }
.container.small { max-width: 1152px; }
.text-kicker { font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; color: #70a77e; font-weight: 500; }
.text-muted { color: #758378; }
.text-balance { text-wrap: balance; }
.lead { font-size: 18px; line-height: 1.75; }
.btn-row { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 40px; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 16px 28px; border-radius: 999px; font-weight: 500; transition: all 0.3s ease; border: 1px solid transparent; cursor: pointer; }
.btn-primary { background: #70a77e; color: #fff; }
.btn-primary:hover { box-shadow: 0 10px 40px -15px rgba(85, 145, 101, 0.35); }
.btn-secondary { background: rgba(255,255,255,0.6); color: #33483d; border-color: #e6eee7; backdrop-filter: blur(8px); }
.btn-secondary:hover { border-color: #70a77e; }
.btn-card { background: #fff; color: #70a77e; }
.btn-card:hover { transform: scale(1.02); }
.icon { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.icon.small { width: 16px; height: 16px; }
.icon.medium { width: 24px; height: 24px; }
.icon.large { width: 28px; height: 28px; }
.header { position: fixed; top: 0; left: 0; right: 0; z-index: 50; transition: all 0.5s ease; }
.header.scrolled, .mobile-panel { background: rgba(255,255,255,0.75); backdrop-filter: blur(18px) saturate(140%); -webkit-backdrop-filter: blur(18px) saturate(140%); border-bottom: 1px solid rgba(230,238,231,0.7); }
.header-inner { height: 96px; display: flex; align-items: center; justify-content: space-between; }
.logo-link { display: flex; align-items: center; gap: 12px; }
.logo { height: 80px; width: auto; transition: transform 0.5s ease; }
.logo-link:hover .logo { transform: scale(1.05); }
.desktop-nav { display: flex; align-items: center; gap: 40px; }
.nav-link { font-size: 14px; letter-spacing: 0.025em; color: #758378; transition: color 0.3s ease; }
.nav-link:hover, .nav-link.active { color: #70a77e; }
.nav-link.active { font-weight: 500; }
.nav-cta { padding: 10px 20px; border-radius: 999px; background: #70a77e; color: #fff; font-size: 14px; font-weight: 500; transition: all 0.3s ease; }
.nav-cta:hover { opacity: .9; box-shadow: 0 10px 40px -15px rgba(85, 145, 101, 0.35); }
.menu-btn { display: none; background: transparent; border: 0; color: #33483d; padding: 8px; cursor: pointer; }
.mobile-panel { display: none; border-top: 1px solid #e6eee7; }
.mobile-panel.open { display: flex; }
.mobile-menu { width: 100%; padding: 24px; display: flex; flex-direction: column; gap: 16px; }
.mobile-menu .nav-cta { text-align: center; padding: 12px 20px; }
.hero { position: relative; padding-top: 176px; padding-bottom: 144px; overflow: hidden; }
.page-hero { position: relative; padding-top: 144px; padding-bottom: 80px; overflow: hidden; }
.contact-hero { padding-bottom: 64px; }
.bg-video-wrap { position: absolute; inset: 0; z-index: -10; overflow: hidden; }
.bg-video-wrap video, .bg-video-wrap img { width: 100%; height: 100%; object-fit: cover; }
.bg-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(251,252,249,0.8), rgba(251,252,249,0.65), #fbfcf9); }
.bg-overlay.green { background: rgba(241,247,242,0.85); }
.hero-content { position: relative; max-width: 768px; }
.hero h1, .page-hero h1 { margin-top: 20px; font-size: 72px; line-height: 1.05; color: #33483d; max-width: 900px; }
.hero p.lead, .page-hero p.lead { margin-top: 24px; max-width: 580px; }
.floating-cards { position: absolute; right: 0; top: 40px; width: 420px; height: 460px; pointer-events: none; }
.float-card { position: absolute; border-radius: 24px; overflow: hidden; box-shadow: 0 10px 40px -15px rgba(85,145,101,.35); }
.float-card img { width: 100%; height: 100%; object-fit: cover; }
.float-card.one { top: 0; right: 48px; width: 224px; height: 288px; }
.float-card.two { bottom: 0; right: 0; width: 256px; height: 224px; }
.float-card.three { bottom: 80px; right: 224px; width: 176px; height: 176px; animation-delay: 1s; }
.section { padding: 96px 0; }
.section.large { padding: 128px 0; }
.section.compact { padding: 48px 0; }
.section.bottom { padding-top: 0; padding-bottom: 96px; }
.section.secondary { background: rgba(241,247,242,0.4); }
.section-head { max-width: 672px; margin-bottom: 64px; }
.section-head.center { text-align: center; margin-left: auto; margin-right: auto; margin-bottom: 56px; }
.section-head h2 { margin-top: 16px; font-size: 56px; color: #33483d; }
.section-head p { margin-top: 16px; line-height: 1.75; }
.card-row, .gallery-row, .service-row, .values-row, .stats-row, .contact-row, .split-row, .feature-row, .mosaic-row, .footer-row { display: flex; gap: 20px; }
.gallery-row { flex-wrap: wrap; gap: 12px; }
.gallery-row .gallery-item { flex: 1 1 220px; }
.gallery-item { border-radius: 16px; overflow: hidden; aspect-ratio: 1/1; }
.gallery-item.tall-mobile { aspect-ratio: 4/5; }
.gallery-item img, .image-box img, .mosaic-item img { width: 100%; height: 100%; object-fit: cover; }
.service-row { flex-wrap: wrap; }
.service-card { flex: 1 1 340px; min-width: 280px; border-radius: 16px; background: #fff; border: 1px solid #e6eee7; overflow: hidden; box-shadow: 0 4px 24px -8px rgba(70,110,82,.18); }
.service-img { height: 192px; overflow: hidden; }
.service-body { padding: 28px; }
.icon-box { height: 48px; width: 48px; border-radius: 12px; background: #e5f2e8; color: #70a77e; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; transition: all .3s ease; flex-shrink: 0; }
.service-card:hover .icon-box, .contact-card:hover .icon-box { background: #70a77e; color: #fff; }
.service-card h3 { font-size: 32px; margin-bottom: 8px; }
.service-card p, .reason-card p, .value-card p { font-size: 14px; color: #758378; line-height: 1.7; }
.split-row, .feature-row { align-items: center; gap: 48px; }
.split-images, .story-images { flex: 1 1 0; display: flex; gap: 12px; }
.split-text, .story-text { flex: 1 1 0; }
.image-box { border-radius: 16px; overflow: hidden; }
.image-box.big { flex: 1; aspect-ratio: 3/4; }
.image-stack { flex: 1; display: flex; flex-direction: column; gap: 12px; }
.image-stack .image-box { aspect-ratio: 1/1; }
.split-text h2, .story-text h2 { margin-top: 16px; font-size: 56px; }
.split-text p { margin-top: 20px; line-height: 1.75; }
.check-list { margin-top: 24px; display: flex; flex-direction: column; gap: 12px; }
.check-list li { display: flex; align-items: center; gap: 12px; }
.dot { width: 8px; height: 8px; border-radius: 999px; background: #70a77e; flex-shrink: 0; }
.why { position: relative; padding: 128px 0; overflow: hidden; }
.why-row { display: flex; align-items: flex-start; gap: 64px; }
.why-left { flex: 1; position: sticky; top: 128px; }
.why-left h2 { margin-top: 16px; font-size: 56px; }
.why-left p { margin-top: 20px; max-width: 448px; line-height: 1.75; }
.why-right { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.reason-card { display: flex; gap: 20px; padding: 24px; border-radius: 16px; border: 1px solid transparent; transition: all .3s ease; }
.reason-card:hover { background: #fff; border-color: #e6eee7; }
.reason-card .icon-box { border: 1px solid rgba(112,167,126,.3); background: #fff; margin: 0; }
.reason-card h3 { font-size: 28px; margin-bottom: 4px; }
.marquee-wrap { overflow: hidden; }
.marquee-track { display: flex; gap: 16px; width: max-content; animation: marquee 40s linear infinite; }
.marquee-img { width: 320px; height: 220px; border-radius: 16px; overflow: hidden; flex-shrink: 0; }
.marquee-img img { width: 100%; height: 100%; object-fit: cover; }
.partner-card { width: 260px; height: 140px; border-radius: 16px; border: 1px solid #e6eee7; background: #fff; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px; flex-shrink: 0; transition: all .3s ease; }
.partner-card:hover { border-color: rgba(112,167,126,.4); box-shadow: 0 10px 40px -15px rgba(85,145,101,.35); }
.partner-name { font-family: "Cormorant Garamond", "Playfair Display", serif; font-size: 32px; color: #33483d; letter-spacing: .025em; text-align: center; }
.partner-sub { margin-top: 8px; font-size: 12px; text-transform: uppercase; letter-spacing: .2em; color: #758378; text-align: center; }
.cta-card { position: relative; overflow: hidden; border-radius: 24px; padding: 80px 48px; text-align: center; }
.cta-card.simple { background: linear-gradient(135deg, #70a77e, rgba(112,167,126,.8)); padding: 64px 48px; }
.cta-bg { position: absolute; inset: 0; z-index: -10; }
.cta-bg img { width: 100%; height: 100%; object-fit: cover; }
.cta-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(112,167,126,.9), rgba(112,167,126,.7)); }
.cta-card h2 { max-width: 768px; margin: 0 auto; font-size: 56px; color: #fff; }
.cta-card.simple h2 { font-size: 44px; }
.cta-card p { margin: 16px auto 0; max-width: 576px; color: rgba(255,255,255,.8); }
.cta-card .btn { margin-top: 32px; }
.mosaic-row { height: 640px; gap: 12px; }
.mosaic-main { flex: 1 1 50%; border-radius: 24px; overflow: hidden; }
.mosaic-side { flex: 1 1 50%; display: flex; flex-direction: column; gap: 12px; }
.mosaic-line { flex: 1; display: flex; gap: 12px; }
.mosaic-item { flex: 1; border-radius: 24px; overflow: hidden; }
.story-text p { margin-top: 24px; font-size: 18px; color: #758378; line-height: 1.75; }
.stats-row { gap: 1px; background: #e6eee7; border-radius: 24px; overflow: hidden; border: 1px solid #e6eee7; }
.stat-card { flex: 1; background: #fff; padding: 40px; text-align: center; }
.stat-card strong { font-family: "Cormorant Garamond", "Playfair Display", serif; font-size: 64px; font-weight: 500; color: #70a77e; }
.stat-card span { margin-top: 8px; font-size: 14px; color: #758378; text-transform: uppercase; letter-spacing: .025em; }
.values-row { flex-wrap: wrap; }
.value-card { flex: 1 1 250px; padding: 32px; border-radius: 16px; border: 1px solid #e6eee7; background: #fff; }
.value-card h3 { margin-top: 20px; font-size: 28px; }
.value-card p { margin-top: 8px; }
.about-cta { position: relative; border-radius: 24px; overflow: hidden; border: 1px solid #e6eee7; padding: 64px 48px; text-align: center; }
.about-cta-bg { position: absolute; inset: 0; z-index: -10; }
.about-cta-bg img { width: 100%; height: 100%; object-fit: cover; }
.about-cta-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(229,242,232,.9), rgba(255,255,255,.95)); }
.about-cta h2 { font-size: 44px; color: #33483d; }
.about-cta .btn { margin-top: 32px; }
.contact-gallery .gallery-item { aspect-ratio: 1/1; }
.contact-row { align-items: flex-start; gap: 40px; }
.contact-cards { flex: 2; display: flex; flex-direction: column; gap: 16px; }
.contact-card { padding: 24px; border-radius: 16px; border: 1px solid #e6eee7; background: #fff; display: flex; align-items: flex-start; gap: 16px; transition: border-color .3s ease; }
.contact-card:hover { border-color: rgba(112,167,126,.4); }
.contact-card .icon-box { height: 44px; width: 44px; margin: 0; }
.contact-card small { font-size: 12px; text-transform: uppercase; letter-spacing: .12em; color: #758378; }
.contact-card p { margin-top: 4px; color: #33483d; word-break: break-word; }
.contact-form { flex: 3; padding: 40px; border-radius: 24px; background: #fff; border: 1px solid #e6eee7; box-shadow: 0 4px 24px -8px rgba(70,110,82,.18); }
.form-row { display: flex; gap: 20px; }
.field { flex: 1; margin-bottom: 20px; }
.field.full { flex-basis: 100%; }
.form-row.wrap { flex-wrap: wrap; }
label { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: #758378; }
input, textarea { margin-top: 8px; width: 100%; border-radius: 12px; border: 1px solid #e6eee7; background: #fbfcf9; padding: 12px 16px; color: #33483d; outline: none; transition: border-color .3s ease; }
textarea { resize: none; min-height: 132px; }
input:focus, textarea:focus { border-color: #70a77e; }
.error { margin-top: 4px; font-size: 12px; color: #d33b2e; min-height: 16px; }
.success { margin-bottom: 24px; display: none; align-items: center; gap: 12px; padding: 16px; border-radius: 12px; background: rgba(229,242,232,.6); color: #70a77e; }
.success.show { display: flex; }
.footer { border-top: 1px solid #e6eee7; background: rgba(241,247,242,0.4); margin-top: 96px; }
.footer-main { padding: 64px 0; }
.footer-row { gap: 48px; }
.footer-brand { flex: 2; }
.footer-col { flex: 1; }
.footer-logo { height: 80px; width: auto; }
.footer p { margin-top: 24px; max-width: 448px; color: #758378; line-height: 1.75; }
.footer .slogan { margin-top: 16px; font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: #70a77e; }
.footer h4 { font-family: "Inter", system-ui, sans-serif; font-size: 14px; font-weight: 500; color: #33483d; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 16px; }
.footer ul { display: flex; flex-direction: column; gap: 12px; color: #758378; font-size: 14px; }
.footer li { display: flex; align-items: flex-start; gap: 8px; }
.footer a:hover { color: #70a77e; }
.footer-bottom { border-top: 1px solid #e6eee7; }
.footer-bottom-inner { padding: 24px; display: flex; justify-content: space-between; align-items: center; gap: 8px; color: #758378; font-size: 12px; }
.footer-bottom-inner p { margin: 0; }
.footer-bottom-inner a { color: #70a77e; font-weight: 500; }
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 1s cubic-bezier(0.22,1,0.36,1), transform 1s cubic-bezier(0.22,1,0.36,1); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }
.reveal-delay-5 { transition-delay: .5s; }
.float-slow { animation: float 8s ease-in-out infinite; }
.float-slower { animation: float 12s ease-in-out infinite; }
.shimmer { background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,.6) 50%, transparent 70%); background-size: 200% 100%; animation: shimmer 3s linear infinite; }
.img-zoom { overflow: hidden; }
.img-zoom > img { transition: transform 1.2s cubic-bezier(0.22,1,0.36,1); }
.img-zoom:hover > img { transform: scale(1.06); }
.tilt-card { transition: transform .6s cubic-bezier(0.22,1,0.36,1), box-shadow .6s cubic-bezier(0.22,1,0.36,1); }
.tilt-card:hover { transform: translateY(-6px) rotate(-.3deg); box-shadow: 0 10px 40px -15px rgba(85,145,101,.35); }
.arrow-move { transition: transform .3s ease; }
.btn:hover .arrow-move { transform: translateX(4px); }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }
@media (max-width: 1024px) {
  .container { padding-left: 24px; padding-right: 24px; }
  .floating-cards { display: none; }
  .hero h1, .page-hero h1 { font-size: 60px; }
  .split-row, .feature-row, .why-row, .contact-row, .footer-row { flex-direction: column; }
  .why-left { position: static; }
  .mosaic-row { height: auto; flex-direction: column; }
  .mosaic-main { aspect-ratio: 16/10; }
  .mosaic-side { min-height: 420px; }
}
@media (max-width: 768px) {
  .desktop-nav { display: none; }
  .menu-btn { display: flex; align-items: center; justify-content: center; }
  .logo { height: 64px; }
  .header-inner { height: 96px; }
  .hero { padding-top: 128px; padding-bottom: 96px; }
  .page-hero { padding-top: 136px; }
  .hero h1, .page-hero h1 { font-size: 48px; }
  .section.large { padding: 96px 0; }
  .section { padding: 80px 0; }
  .section-head h2, .split-text h2, .story-text h2, .why-left h2 { font-size: 44px; }
  .gallery-row .gallery-item { flex-basis: calc(50% - 6px); }
  .service-card { flex-basis: 100%; }
  .split-row, .feature-row { gap: 32px; }
  .stats-row { flex-wrap: wrap; }
  .stat-card { flex-basis: calc(50% - 1px); }
  .form-row { flex-direction: column; gap: 0; }
  .contact-form { padding: 32px 24px; }
  .cta-card, .cta-card.simple, .about-cta { padding: 48px 24px; }
  .cta-card h2 { font-size: 42px; }
  .cta-card.simple h2, .about-cta h2 { font-size: 34px; }
  .footer-bottom-inner { flex-direction: column; text-align: center; }
}
@media (max-width: 520px) {
  .container { padding-left: 20px; padding-right: 20px; }
  .hero h1, .page-hero h1 { font-size: 40px; }
  .lead { font-size: 16px; }
  .btn { width: 100%; }
  .btn-row { flex-direction: column; }
  .section-head h2, .split-text h2, .story-text h2, .why-left h2 { font-size: 38px; }
  .gallery-row .gallery-item { flex-basis: 100%; }
  .split-images, .story-images, .mosaic-line { flex-direction: column; }
  .image-box.big, .image-stack .image-box, .mosaic-main, .mosaic-item { aspect-ratio: 4/3; }
  .mosaic-side { min-height: 0; }
  .stat-card { flex-basis: 100%; }
  .marquee-img { width: 260px; height: 190px; }
  .partner-card { width: 230px; }
}
