@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Crimson+Text:ital,wght@0,400;0,600;1,400&family=Nunito+Sans:wght@300;400;600;700&family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;1,8..60,400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
--forest:#1d3d2e;
--forest-light:#2a5242;
--forest-mid:#3a6b56;
--cream:#f4efe3;
--cream-dark:#ede7d8;
--cream-darker:#e3dcc9;
--text-dark:#1e1a0f;
--text-body:#3d3520;
--text-light:#6b5f4a;
--accent:#5b8c5a;
--accent-hover:#4a7249;
--terracotta:#b86040;
--gold:#c9a84c;
--border:#d6cdb8;
--shadow:rgba(30,26,15,.12);
--radius:4px;
}
html{scroll-behavior:smooth;font-size:16px}
body{
font-family:'Crimson Text',Georgia,serif;
background-color:var(--cream);
color:var(--text-body);
line-height:1.7;
min-height:100vh;
}

a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-hover)}
img{max-width:100%;height:auto;display:block}

h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;color:var(--text-dark);line-height:1.25;font-weight:700}
h1{font-size:clamp(1.9rem,4vw,3rem)}
h2{font-size:clamp(1.4rem,3vw,2.1rem)}
h3{font-size:clamp(1.15rem,2.5vw,1.5rem)}
h4{font-size:1.1rem}

p{margin-bottom:1.2em}
p:last-child{margin-bottom:0}

.container{width:100%;max-width:1180px;margin:0 auto;padding:0 24px}
.section{padding:64px 0}

.btn{
display:inline-block;
font-family:'Nunito Sans',sans-serif;
font-size:.875rem;
font-weight:600;
letter-spacing:.04em;
padding:10px 24px;
border-radius:var(--radius);
border:2px solid transparent;
cursor:pointer;
transition:all .22s;
text-decoration:none;
}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}
.btn-outline{background:transparent;color:var(--forest);border-color:var(--forest)}
.btn-outline:hover{background:var(--forest);color:#fff}
.btn-ghost{background:transparent;color:var(--cream);border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff}

.tag{
display:inline-block;
font-family:'Nunito Sans',sans-serif;
font-size:.72rem;
font-weight:700;
letter-spacing:.1em;
text-transform:uppercase;
padding:3px 10px;
border-radius:2px;
background:var(--accent);
color:#fff;
}
.tag-outline{background:transparent;border:1px solid var(--accent);color:var(--accent)}

.meta{
font-family:'Nunito Sans',sans-serif;
font-size:.82rem;
color:var(--text-light);
}

#page-loader{
position:fixed;inset:0;
z-index:9999;
background:var(--forest);
display:flex;align-items:center;justify-content:center;
transition:opacity .5s ease, visibility .5s ease;
}
#page-loader.hidden{opacity:0;visibility:hidden}
.loader-leaf{
width:48px;height:48px;
border-radius:0 50% 0 50%;
background:var(--accent);
animation:leafPulse 1s ease-in-out infinite alternate;
}
@keyframes leafPulse{from{transform:scale(.85) rotate(-10deg)}to{transform:scale(1.1) rotate(10deg)}}

#site-header{
position:sticky;top:0;z-index:100;
background:var(--forest);
border-bottom:1px solid var(--forest-light);
box-shadow:0 2px 12px rgba(0,0,0,.25);
}
.header-inner{
display:flex;align-items:center;justify-content:space-between;
padding:14px 24px;
max-width:1180px;margin:0 auto;
}
.site-logo{
display:flex;align-items:center;gap:10px;
text-decoration:none;
}
.logo-icon{
width:38px;height:38px;
background:var(--accent);
border-radius:0 50% 0 50%;
display:flex;align-items:center;justify-content:center;
font-size:1.1rem;
flex-shrink:0;
}
.logo-icon svg{width:22px;height:22px;fill:#fff}
.logo-text{
font-family:'Playfair Display',serif;
font-size:1.1rem;
font-weight:700;
color:#fff;
line-height:1.2;
}
.logo-sub{
font-family:'Nunito Sans',sans-serif;
font-size:.62rem;
letter-spacing:.12em;
text-transform:uppercase;
color:rgba(255,255,255,.55);
display:block;
}
.site-nav{display:flex;align-items:center;gap:6px}
.site-nav a{
font-family:'Nunito Sans',sans-serif;
font-size:.82rem;
font-weight:600;
letter-spacing:.04em;
color:rgba(255,255,255,.8);
padding:7px 13px;
border-radius:var(--radius);
transition:all .2s;
}
.site-nav a:hover,.site-nav a.active{color:#fff;background:rgba(255,255,255,.1)}
.burger-btn{
display:none;
background:none;border:none;
cursor:pointer;
padding:6px;
flex-direction:column;gap:5px;
}
.burger-btn span{
display:block;width:24px;height:2px;
background:#fff;
border-radius:2px;
transition:all .25s;
}
.burger-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger-btn.open span:nth-child(2){opacity:0}
.burger-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{
display:none;
position:fixed;
top:0;right:-100%;
width:min(320px,90vw);height:100vh;
background:var(--forest);
z-index:200;
padding:80px 32px 32px;
transition:right .3s ease;
overflow-y:auto;
box-shadow:-4px 0 24px rgba(0,0,0,.3);
}
.mobile-nav.open{right:0}
.mobile-nav-close{
position:absolute;top:20px;right:20px;
background:none;border:none;
color:#fff;font-size:1.4rem;cursor:pointer;
width:36px;height:36px;
display:flex;align-items:center;justify-content:center;
}
.mobile-nav h3{
font-family:'Nunito Sans',sans-serif;
font-size:.7rem;
letter-spacing:.14em;
text-transform:uppercase;
color:rgba(255,255,255,.4);
margin-bottom:20px;
}
.mobile-nav a{
display:block;
font-family:'Nunito Sans',sans-serif;
font-size:1rem;
font-weight:600;
color:rgba(255,255,255,.85);
padding:11px 0;
border-bottom:1px solid rgba(255,255,255,.08);
transition:color .2s;
}
.mobile-nav a:hover{color:#fff}
.mobile-nav-overlay{
display:none;
position:fixed;inset:0;
z-index:190;
background:rgba(0,0,0,.5);
}
.mobile-nav-overlay.open{display:block}

.hero-section{
background:var(--forest);
overflow:hidden;
}
.hero-inner{
display:grid;
grid-template-columns:1fr 1fr;
min-height:520px;
}
.hero-content{
display:flex;flex-direction:column;justify-content:center;
padding:72px 48px 72px 24px;
max-width:580px;
justify-self:end;
width:100%;
}
.hero-kicker{
font-family:'Nunito Sans',sans-serif;
font-size:.72rem;
font-weight:700;
letter-spacing:.14em;
text-transform:uppercase;
color:var(--gold);
margin-bottom:16px;
}
.hero-title{
font-family:'Playfair Display',serif;
color:#fff;
font-size:clamp(2rem,4.5vw,3.2rem);
font-weight:700;
line-height:1.18;
margin-bottom:18px;
}
.hero-title em{color:var(--gold);font-style:italic}
.hero-desc{
font-family:'Source Serif 4',serif;
font-size:1.05rem;
color:rgba(255,255,255,.72);
line-height:1.65;
margin-bottom:28px;
}
.hero-meta{
display:flex;align-items:center;gap:16px;
flex-wrap:wrap;
}
.hero-meta .meta{color:rgba(255,255,255,.5);font-size:.78rem}
.hero-image{
position:relative;
overflow:hidden;
}
.hero-image img{
width:100%;height:100%;
object-fit:cover;
}
.hero-image::after{
content:'';
position:absolute;inset:0;
background:linear-gradient(90deg,var(--forest) 0%,transparent 30%);
}

.articles-section{background:var(--cream)}
.section-head{
display:flex;align-items:flex-end;justify-content:space-between;
margin-bottom:40px;
gap:16px;
}
.section-label{
font-family:'Nunito Sans',sans-serif;
font-size:.72rem;
font-weight:700;
letter-spacing:.14em;
text-transform:uppercase;
color:var(--accent);
margin-bottom:8px;
}
.section-title{font-size:clamp(1.3rem,3vw,1.9rem)}
.articles-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:28px;
}
.article-card{
background:#fff;
border-radius:var(--radius);
overflow:hidden;
box-shadow:0 2px 12px var(--shadow);
display:flex;flex-direction:column;
transition:transform .22s,box-shadow .22s;
}
.article-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px var(--shadow)}
.card-image{
aspect-ratio:16/9;
overflow:hidden;
}
.card-image img{
width:100%;height:100%;
object-fit:cover;
transition:transform .4s;
}
.article-card:hover .card-image img{transform:scale(1.04)}
.card-body{
padding:22px;
display:flex;flex-direction:column;
flex:1;
}
.card-tag{margin-bottom:10px}
.card-title{
font-family:'Playfair Display',serif;
font-size:1.1rem;
line-height:1.3;
margin-bottom:10px;
color:var(--text-dark);
}
.card-title a{color:inherit;text-decoration:none}
.card-title a:hover{color:var(--accent)}
.card-excerpt{
font-size:.95rem;
color:var(--text-light);
line-height:1.6;
margin-bottom:16px;
flex:1;
}
.card-footer{
display:flex;align-items:center;justify-content:space-between;
padding-top:14px;
border-top:1px solid var(--border);
}
.card-read{
font-family:'Nunito Sans',sans-serif;
font-size:.78rem;
font-weight:700;
color:var(--accent);
letter-spacing:.04em;
}
.card-read:hover{color:var(--accent-hover)}

.intro-band{
background:var(--cream-dark);
border-top:1px solid var(--border);
border-bottom:1px solid var(--border);
padding:48px 0;
}
.intro-band-inner{
display:grid;
grid-template-columns:1fr 2px 1fr;
gap:48px;
align-items:start;
}
.intro-divider{background:var(--border)}
.intro-block h3{margin-bottom:12px}
.intro-block p{font-size:.98rem;color:var(--text-light)}
.intro-stat{
font-family:'Playfair Display',serif;
font-size:2.5rem;
font-weight:700;
color:var(--accent);
display:block;
margin-bottom:4px;
}

.article-hero{
position:relative;
height:420px;
overflow:hidden;
background:var(--forest);
}
.article-hero img{
width:100%;height:100%;
object-fit:cover;
opacity:.7;
}
.article-hero-overlay{
position:absolute;inset:0;
background:linear-gradient(0deg,rgba(29,61,46,.9) 0%,rgba(29,61,46,.3) 100%);
display:flex;flex-direction:column;justify-content:flex-end;
padding:48px;
}
.article-hero-overlay .tag{margin-bottom:12px}
.article-hero-overlay h1{color:#fff;margin-bottom:10px}
.article-hero-overlay .meta{color:rgba(255,255,255,.6)}

.article-layout{
display:grid;
grid-template-columns:1fr 300px;
gap:48px;
padding:56px 0;
}
.article-content{min-width:0}
.article-content h2{margin:2em 0 .6em;font-size:1.6rem}
.article-content h3{margin:1.6em 0 .5em;font-size:1.25rem;color:var(--forest)}
.article-content p{font-size:1.05rem;line-height:1.75;color:var(--text-body)}
.article-content ul,.article-content ol{
margin:1em 0 1.4em 1.4em;
}
.article-content li{
font-size:1.05rem;
line-height:1.65;
margin-bottom:.4em;
color:var(--text-body);
}
.article-content a{color:var(--accent);border-bottom:1px solid transparent}
.article-content a:hover{border-color:var(--accent)}
.article-content blockquote{
border-left:4px solid var(--accent);
margin:2em 0;
padding:18px 24px;
background:var(--cream-dark);
border-radius:0 var(--radius) var(--radius) 0;
}
.article-content blockquote p{
font-family:'Source Serif 4',serif;
font-size:1.15rem;
font-style:italic;
color:var(--text-dark);
margin:0;
}
.article-img-block{
margin:2em 0;
border-radius:var(--radius);
overflow:hidden;
}
.article-img-block img{width:100%;height:280px;object-fit:cover}
.article-img-caption{
font-family:'Nunito Sans',sans-serif;
font-size:.78rem;
color:var(--text-light);
padding:8px 0 0;
font-style:italic;
}

.sidebar{position:sticky;top:90px;align-self:start}
.sidebar-widget{
background:#fff;
border:1px solid var(--border);
border-radius:var(--radius);
padding:22px;
margin-bottom:22px;
}
.sidebar-widget h4{
font-size:.95rem;
margin-bottom:16px;
padding-bottom:10px;
border-bottom:1px solid var(--border);
}
.sidebar-links a{
display:block;
font-family:'Nunito Sans',sans-serif;
font-size:.85rem;
color:var(--text-body);
padding:8px 0;
border-bottom:1px solid var(--border);
transition:color .2s;
}
.sidebar-links a:last-child{border-bottom:none;padding-bottom:0}
.sidebar-links a:hover{color:var(--accent)}
.sidebar-info p{
font-size:.85rem;
color:var(--text-light);
line-height:1.6;
}
.sidebar-info .meta{display:block;margin-bottom:6px}

.site-footer{background:var(--forest);color:rgba(255,255,255,.75);padding:56px 0 24px}
.footer-grid{
display:grid;
grid-template-columns:1.5fr 1fr 1fr;
gap:48px;
margin-bottom:40px;
}
.footer-brand .logo-text{font-size:1.2rem;margin-bottom:10px;display:block}
.footer-brand p{font-size:.88rem;color:rgba(255,255,255,.5);line-height:1.65;margin-bottom:16px}
.footer-col h4{
font-family:'Nunito Sans',sans-serif;
font-size:.7rem;
font-weight:700;
letter-spacing:.14em;
text-transform:uppercase;
color:rgba(255,255,255,.35);
margin-bottom:16px;
}
.footer-col a{
display:block;
font-size:.88rem;
color:rgba(255,255,255,.6);
padding:5px 0;
transition:color .2s;
}
.footer-col a:hover{color:#fff}
.footer-contact p{
font-size:.88rem;
color:rgba(255,255,255,.55);
margin-bottom:10px;
line-height:1.55;
}
.footer-contact strong{color:rgba(255,255,255,.8);font-weight:600}
.footer-bottom{
border-top:1px solid rgba(255,255,255,.1);
padding-top:22px;
display:flex;align-items:center;justify-content:space-between;
flex-wrap:wrap;
gap:10px;
}
.footer-bottom p,.footer-bottom a{font-size:.8rem;color:rgba(255,255,255,.35)}
.footer-bottom a:hover{color:rgba(255,255,255,.7)}
.footer-bottom-links{display:flex;gap:20px;flex-wrap:wrap}

.page-hero{
background:var(--forest);
padding:60px 0;
text-align:center;
}
.page-hero h1{color:#fff;margin-bottom:10px}
.page-hero p{
font-family:'Source Serif 4',serif;
color:rgba(255,255,255,.65);
font-size:1.05rem;
max-width:560px;
margin:0 auto;
}

.about-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:64px;
align-items:start;
padding:64px 0;
}
.about-image{border-radius:var(--radius);overflow:hidden}
.about-image img{width:100%;height:400px;object-fit:cover}
.about-content .section-label{margin-bottom:8px}
.about-content h2{margin-bottom:16px}
.about-content p{font-size:1rem;color:var(--text-light);margin-bottom:1em}
.expertise-list{
list-style:none;
margin:20px 0;
}
.expertise-list li{
display:flex;align-items:flex-start;gap:10px;
font-size:.95rem;
color:var(--text-body);
margin-bottom:10px;
}
.expertise-list li::before{
content:'';
flex-shrink:0;
width:8px;height:8px;
border-radius:50%;
background:var(--accent);
margin-top:7px;
}

.contact-layout{
display:grid;
grid-template-columns:1fr 1fr;
gap:64px;
padding:64px 0;
}
.contact-form-wrap h2{margin-bottom:8px}
.contact-form-wrap p{font-size:.95rem;color:var(--text-light);margin-bottom:28px}
.form-group{margin-bottom:18px}
.form-group label{
display:block;
font-family:'Nunito Sans',sans-serif;
font-size:.82rem;
font-weight:600;
color:var(--text-dark);
margin-bottom:6px;
}
.form-group input,.form-group textarea{
width:100%;
padding:11px 14px;
border:1.5px solid var(--border);
border-radius:var(--radius);
font-family:'Crimson Text',serif;
font-size:1rem;
color:var(--text-dark);
background:#fff;
transition:border-color .2s;
outline:none;
}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group textarea{height:130px;resize:vertical}
.form-submit{margin-top:8px}
.form-msg{
margin-top:14px;
padding:12px 16px;
border-radius:var(--radius);
font-family:'Nunito Sans',sans-serif;
font-size:.88rem;
display:none;
}
.form-msg.success{background:#e8f5e0;color:#2a5c1a;border:1px solid #b3d99a}
.form-msg.error{background:#fbe8e8;color:#7a1a1a;border:1px solid #e9a0a0}
.contact-info h3{margin-bottom:20px;font-size:1.2rem}
.contact-detail{
display:flex;align-items:flex-start;gap:14px;
margin-bottom:22px;
}
.contact-icon{
width:40px;height:40px;flex-shrink:0;
background:var(--cream-dark);
border-radius:50%;
display:flex;align-items:center;justify-content:center;
}
.contact-icon svg{width:18px;height:18px;fill:var(--accent)}
.contact-detail-text strong{
display:block;
font-family:'Nunito Sans',sans-serif;
font-size:.82rem;
font-weight:700;
color:var(--text-dark);
margin-bottom:3px;
}
.contact-detail-text span,.contact-detail-text a{
font-size:.95rem;
color:var(--text-light);
}

.policy-content{
max-width:760px;
margin:0 auto;
padding:56px 0;
}
.policy-content h2{margin:2em 0 .6em;font-size:1.4rem}
.policy-content h3{margin:1.5em 0 .4em;font-size:1.1rem;color:var(--forest)}
.policy-content p,.policy-content li{
font-size:1rem;
line-height:1.75;
color:var(--text-body);
margin-bottom:.8em;
}
.policy-content ul{margin-left:1.4em;margin-bottom:1em}

#cookie-banner{
position:fixed;bottom:0;left:0;right:0;
z-index:500;
background:var(--forest);
border-top:1px solid var(--forest-light);
padding:18px 24px;
display:none;
}
.cookie-inner{
max-width:1180px;margin:0 auto;
display:flex;align-items:center;justify-content:space-between;
gap:20px;
flex-wrap:wrap;
}
.cookie-text{
font-family:'Nunito Sans',sans-serif;
font-size:.83rem;
color:rgba(255,255,255,.8);
line-height:1.5;
}
.cookie-text a{color:var(--gold);text-decoration:underline}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
.cookie-btn{
font-family:'Nunito Sans',sans-serif;
font-size:.78rem;
font-weight:700;
padding:8px 18px;
border-radius:var(--radius);
cursor:pointer;
border:none;
transition:all .2s;
}
.cookie-accept{background:var(--accent);color:#fff}
.cookie-accept:hover{background:var(--accent-hover)}
.cookie-reject{background:transparent;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.25)}
.cookie-reject:hover{background:rgba(255,255,255,.08);color:#fff}

@media(max-width:980px){
.hero-inner{grid-template-columns:1fr}
.hero-image{height:300px}
.hero-image::after{background:none}
.hero-content{max-width:100%;padding:48px 24px;justify-self:auto}
.articles-grid{grid-template-columns:1fr 1fr}
.footer-grid{grid-template-columns:1fr 1fr}
.intro-band-inner{grid-template-columns:1fr;gap:28px}
.intro-divider{display:none}
.about-grid{grid-template-columns:1fr;gap:32px}
.contact-layout{grid-template-columns:1fr;gap:40px}
.article-layout{grid-template-columns:1fr}
.sidebar{position:static}
.article-hero-overlay{padding:28px 24px}
.article-hero{height:300px}
}
@media(max-width:700px){
.articles-grid{grid-template-columns:1fr}
.footer-grid{grid-template-columns:1fr}
.section-head{flex-direction:column;align-items:flex-start}
.site-nav{display:none}
.burger-btn{display:flex}
.header-inner{padding:12px 20px}
.hero-content{padding:36px 20px}
.hero-title{font-size:1.8rem}
.section{padding:40px 0}
.footer-bottom{flex-direction:column;align-items:flex-start}
}
