*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --olive:#4a5c2a;--olive-light:#6b7e3f;--olive-dark:#2f3b19;
  --cream:#faf7f0;--warm:#f2ead8;--sand:#e8dcc8;
  --text:#2a2a22;--muted:#6b6b5a;--border:#d4c9b0;
  --font-head:'Cormorant Garamond',serif;--font-body:'Jost',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--cream);color:var(--text);line-height:1.7;font-size:16px;overflow-x:hidden}
nav{position:fixed;top:0;left:0;width:100%;z-index:100;padding:1.2rem 2rem;display:flex;justify-content:space-between;align-items:center;background:rgba(250,247,240,0.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav-logo{font-family:var(--font-head);font-size:1.1rem;letter-spacing:.12em;color:var(--olive);font-weight:500;text-transform:uppercase;text-decoration:none}
.nav-links{display:flex;gap:0;list-style:none;align-items:center}
.nav-links > li{position:relative}
.nav-links > li > a{display:flex;align-items:center;gap:.35rem;text-decoration:none;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .25s;padding:.5rem 1.1rem;background:none;border:none;cursor:pointer;font-family:var(--font-body)}
.nav-links > li > a:hover,.nav-links > li > a.active{color:var(--olive)}
.nav-cta{background:var(--olive);color:#fff !important;padding:.55rem 1.4rem;border-radius:2px;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;transition:background .25s;margin-left:1rem}
.nav-cta:hover{background:var(--olive-dark)}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.3rem;background:none;border:none}
.nav-hamburger span{display:block;width:22px;height:1.5px;background:var(--olive);transition:all .3s}
.mobile-menu{display:none;position:fixed;top:60px;left:0;width:100%;background:var(--cream);border-bottom:1px solid var(--border);padding:1.5rem 2rem;z-index:99;flex-direction:column;gap:0}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:.6rem 0;transition:color .2s;border-top:1px solid var(--border)}
.mobile-menu a:first-child{border-top:none}
.mobile-menu a:hover{color:var(--olive)}
.mobile-cta{background:var(--olive);color:#fff !important;padding:.7rem 1.2rem;border-radius:2px;margin-top:1rem;text-align:center;border-top:none !important}
.page-wrap{padding-top:5rem}
.section-label{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--olive-light);margin-bottom:1.4rem;display:block}
/* HERO */
.hero{min-height:90vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:5rem}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--warm) 0%,var(--cream) 55%,#e8f0dc 100%);z-index:0}
.hero-pattern{position:absolute;inset:0;opacity:.06;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%234a5c2a' fill-opacity='1'%3E%3Cpath d='M30 0 Q35 15 30 30 Q25 15 30 0zM0 30 Q15 25 30 30 Q15 35 0 30zM60 30 Q45 25 30 30 Q45 35 60 30zM30 60 Q35 45 30 30 Q25 45 30 60z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");z-index:1}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;max-width:1100px;margin:0 auto;padding:0 2.5rem}
.hero-eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--olive-light);margin-bottom:1.2rem}
.hero h1{font-family:var(--font-head);font-size:clamp(2.8rem,5vw,4.2rem);font-weight:300;line-height:1.12;color:var(--olive-dark);margin-bottom:1.4rem}
.hero h1 em{font-style:italic;color:var(--olive-light)}
.hero-sub{font-size:.95rem;color:var(--muted);max-width:430px;line-height:1.8;margin-bottom:2.2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.btn-primary{background:var(--olive);color:#fff;padding:.85rem 2rem;border-radius:2px;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;transition:all .25s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--olive-dark);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--olive);padding:.85rem 2rem;border-radius:2px;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;border:1px solid var(--olive);transition:all .25s;cursor:pointer}
.btn-outline:hover{background:var(--olive);color:#fff}
.hero-visual{position:relative;display:flex;justify-content:center}
.hero-circle{width:380px;height:380px;border-radius:50%;background:linear-gradient(145deg,#d4e4b0,#b8d08a);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.hero-circle::before{content:'';position:absolute;inset:-20px;background:conic-gradient(from 0deg,transparent,rgba(74,92,42,.12),transparent,rgba(74,92,42,.08),transparent);animation:spin 18s linear infinite}
.hero-leaf-svg{position:relative;z-index:1}
@keyframes spin{to{transform:rotate(360deg)}}
.marquee-wrap{background:var(--olive);padding:.9rem 0;overflow:hidden}
.marquee-track{display:flex;gap:3rem;white-space:nowrap;animation:marquee 22s linear infinite}
.marquee-track span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.75)}
.marquee-track .dot{color:rgba(255,255,255,.35);font-size:.9rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mission{padding:5rem 2.5rem;text-align:center;max-width:820px;margin:0 auto}
.mission-quote{font-family:var(--font-head);font-size:clamp(1.1rem,2vw,1.4rem);font-style:italic;color:var(--muted);line-height:1.7;border-left:2px solid var(--olive-light);padding-left:1.6rem;text-align:left;max-width:680px;margin:0 auto}
/* PAGE HEADER */
.page-header{background:linear-gradient(135deg,var(--warm) 0%,var(--cream) 60%,#e8f0dc 100%);padding:4rem 2.5rem 3.5rem;text-align:center;position:relative;overflow:hidden}
.page-header-inner{position:relative;z-index:2;max-width:700px;margin:0 auto}
.page-header h1{font-family:var(--font-head);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:300;color:var(--olive-dark);line-height:1.2;margin-bottom:1rem}
.page-header h1 em{font-style:italic;color:var(--olive-light)}
.page-header p{font-size:.95rem;color:var(--muted);line-height:1.8;max-width:540px;margin:0 auto}
/* SERVICES */
.services{padding:4.5rem 2.5rem}
.section-header{text-align:center;max-width:600px;margin:0 auto 3.5rem}
.section-header h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:300;color:var(--olive-dark);line-height:1.3}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;max-width:1000px;margin:0 auto}
.service-card{background:var(--cream);border:1px solid var(--border);border-radius:4px;padding:2.2rem 1.8rem;transition:all .3s;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:var(--olive-light);transition:height .3s}
.service-card:hover::before{height:100%}
.service-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(74,92,42,.1)}
.service-icon{width:44px;height:44px;background:linear-gradient(135deg,#d4e4b0,#c0d898);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;font-size:1.3rem}
.service-card h3{font-family:var(--font-head);font-size:1.25rem;font-weight:500;color:var(--olive-dark);margin-bottom:.6rem}
.service-card p{font-size:.88rem;color:var(--muted);line-height:1.75}
.service-tag{display:inline-block;margin-top:1rem;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--olive-light);border:1px solid var(--olive-light);padding:.25rem .7rem;border-radius:2px}
/* ABOUT */
.about{padding:4.5rem 2.5rem}
.about-inner{max-width:1050px;margin:0 auto;display:grid;grid-template-columns:420px 1fr;gap:5rem;align-items:center}
.about-img-wrap{position:relative}
.about-img-frame{position:relative}
.about-img-frame::before{content:'';position:absolute;top:18px;left:18px;right:-18px;bottom:-18px;border:1.5px solid var(--border);border-radius:4px;z-index:0}
.about-img-frame img{position:relative;z-index:1;width:100%;height:520px;object-fit:cover;object-position:center top;border-radius:4px;display:block}
.about-badge{position:absolute;bottom:-1.2rem;right:-1.2rem;z-index:2;background:var(--olive);color:#fff;padding:1rem 1.3rem;border-radius:4px;text-align:center}
.about-badge-num{font-family:var(--font-head);font-size:1.8rem;font-weight:300;line-height:1;display:block}
.about-badge-text{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;opacity:.85;margin-top:.2rem;display:block}
.about-text h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:300;color:var(--olive-dark);line-height:1.25;margin-bottom:.3rem}
.about-text h2 em{font-style:italic;color:var(--olive-light)}
.about-name-title{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1.6rem;display:block}
.about-text p{font-size:.92rem;color:var(--muted);line-height:1.9;margin-bottom:1rem}
.about-creds{display:flex;flex-direction:column;gap:.75rem;margin-top:1.8rem;padding-top:1.8rem;border-top:1px solid var(--border)}
.cred{display:flex;align-items:flex-start;gap:1rem}
.cred-icon{width:36px;height:36px;background:linear-gradient(135deg,#d4e4b0,#c0d898);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;margin-top:.1rem}
.cred-text strong{display:block;font-size:.82rem;font-weight:500;color:var(--olive-dark);letter-spacing:.02em}
.cred-text span{font-size:.78rem;color:var(--muted)}
/* CONTACT */
.contact{padding:4.5rem 2.5rem;background:var(--olive-dark);color:#fff;min-height:70vh;display:flex;align-items:center}
.contact-inner{max-width:700px;margin:0 auto;text-align:center;width:100%}
.contact h2{font-family:var(--font-head);font-size:clamp(2rem,4vw,3rem);font-weight:300;line-height:1.25;margin-bottom:1rem;color:#fff}
.contact p{font-size:.92rem;color:rgba(255,255,255,.65);margin-bottom:2.5rem;line-height:1.8}
.contact-form{display:flex;flex-direction:column;gap:1rem;text-align:left}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-field{display:flex;flex-direction:column;gap:.35rem}
.form-field label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.form-field input,.form-field select,.form-field textarea{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:2px;padding:.7rem 1rem;color:#fff;font-family:var(--font-body);font-size:.88rem;outline:none;transition:border .2s}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,.3)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:rgba(255,255,255,.5)}
.form-field select option{background:#2f3b19;color:#fff}
.form-field textarea{resize:vertical;min-height:110px}
.submit-btn{background:var(--warm);color:var(--olive-dark);border:none;padding:.9rem 2.5rem;border-radius:2px;font-family:var(--font-body);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:all .25s;align-self:flex-start;margin-top:.5rem}
.submit-btn:hover{background:#fff;transform:translateY(-1px)}
footer{background:var(--olive-dark);border-top:1px solid rgba(255,255,255,.1);padding:2rem 2.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-logo{font-family:var(--font-head);font-size:.95rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.35);letter-spacing:.08em}
.footer-links{display:flex;gap:1.8rem}
.footer-links a{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:rgba(255,255,255,.75)}
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:none}
@media(max-width:768px){
  .hero-inner,.about-inner{grid-template-columns:1fr;gap:2.5rem}
  .hero-visual{display:none}
  .form-row{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-hamburger{display:flex}
  .about-img-frame img{height:380px}
  .about-badge{right:.5rem}
}
