/* ============================================================
   VARIABLES & RESET
============================================================ */

:root {
--color-bg: #eae5e0;
--color-dark: #2a3d2d;
--color-olive: #9bac6d;
--color-olive-dark: #7a8d52;
--color-cream: #eae5e0;
--color-white: #ffffff;
--color-text: #2a3d2d;
--color-text-muted: #6b7c6e;
--color-border: rgba(42,61,45,.12);
--font-display: 'DM Serif Display', Georgia, serif;
--font-ui: 'Syne', system-ui, sans-serif;
--font-body: 'DM Sans', system-ui, sans-serif;
--ease-out: cubic-bezier(0.16,1,0.3,1);
--ease-in-out: cubic-bezier(0.76,0,0.24,1);
--ease-elastic: cubic-bezier(0.34,1.56,0.64,1);
--radius-sm: 8px;
--radius-md: 16px;
--radius-lg: 32px;
--radius-xl: 64px;
--radius-organic: 60% 40% 55% 45% / 45% 55% 40% 60%;
--radius-organic-2: 45% 55% 40% 60% / 55% 40% 60% 45%;
--radius-organic-3: 55% 45% 60% 40% / 40% 60% 45% 55%;
--container-max: 1280px;
--container-narrow: 760px;
--container-px: clamp(1.25rem, 5vw, 4rem);
--section-py: clamp(5rem, 10vw, 9rem);
--header-h: 80px;
--transition-fast: 0.2s var(--ease-out);
--transition-base: 0.4s var(--ease-out);
--transition-slow: 0.7s var(--ease-out);
}

*,
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}

html {
font-size: 16px;
scroll-behavior: smooth;
-webkit-text-size-adjust: 100%;
}

body {
background-color: var(--color-bg);
color: var(--color-text);
font-family: var(--font-body);
font-size: clamp(1rem, 1.1vw, 1.125rem);
font-weight: 300;
line-height: 1.7;
overflow-x: hidden;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}

body.is-loading {
overflow: hidden;
}

body.menu-open {
overflow: hidden;
}

img,
svg,
video {
display: block;
max-width: 100%;
}

a {
color: inherit;
text-decoration: none;
}

ul,
ol {
list-style: none;
}

button {
background: none;
border: none;
cursor: pointer;
font-family: inherit;
}

input,
textarea,
select {
font-family: inherit;
}

/* ============================================================
   LAYOUT
============================================================ */

.container {
width: 100%;
max-width: var(--container-max);
margin-inline: auto;
padding-inline: var(--container-px);
}

.container--narrow {
max-width: var(--container-narrow);
}

.section {
padding-block: var(--section-py);
}

.section--dark {
background-color: var(--color-dark);
color: var(--color-cream);
}

.section--olive {
background-color: var(--color-olive);
color: var(--color-white);
}

.grid-2 {
display: grid;
grid-template-columns: 1fr 1fr;
gap: clamp(2rem, 5vw, 5rem);
}

.grid-3 {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: clamp(1.5rem, 3vw, 2.5rem);
}

.grid-4 {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: clamp(1.25rem, 2.5vw, 2rem);
}

.flex-center {
display: flex;
align-items: center;
justify-content: center;
}

.flex-between {
display: flex;
align-items: center;
justify-content: space-between;
}

/* ============================================================
   TYPOGRAPHY
============================================================ */

.display-title {
font-family: var(--font-display);
font-size: clamp(3rem, 7vw, 7.5rem);
font-weight: 400;
line-height: 1.05;
letter-spacing: -0.02em;
}

.display-title em {
font-style: italic;
color: var(--color-olive);
}

.section__title {
font-family: var(--font-display);
font-size: clamp(2rem, 4.5vw, 4.5rem);
font-weight: 400;
line-height: 1.1;
letter-spacing: -0.015em;
}

.section__title em {
font-style: italic;
color: var(--color-olive);
}

.label-tag {
font-family: var(--font-ui);
font-size: 0.75rem;
font-weight: 700;
letter-spacing: 0.15em;
text-transform: uppercase;
color: var(--color-olive);
margin-bottom: 1rem;
display: block;
}

.section--dark .label-tag {
color: var(--color-olive);
}

.section__subtitle {
font-size: clamp(1rem, 1.5vw, 1.25rem);
font-weight: 300;
color: var(--color-text-muted);
max-width: 52ch;
margin-top: 1.5rem;
}

.section--dark .section__subtitle {
color: rgba(234,229,224,.6);
}

.section__lead {
font-family: var(--font-display);
font-size: clamp(1.25rem, 2.5vw, 2rem);
font-weight: 400;
font-style: italic;
line-height: 1.4;
color: var(--color-text-muted);
max-width: 45ch;
}

/* ============================================================
   BUTTONS
============================================================ */

.btn {
display: inline-flex;
align-items: center;
gap: 0.75rem;
font-family: var(--font-ui);
font-size: 0.9rem;
font-weight: 600;
letter-spacing: 0.02em;
padding: 0.875rem 2rem;
border-radius: var(--radius-organic);
transition: border-radius var(--transition-slow), background-color var(--transition-base), color var(--transition-base), transform var(--transition-fast), box-shadow var(--transition-base);
position: relative;
overflow: hidden;
white-space: nowrap;
}

.btn::before {
content: '';
position: absolute;
inset: 0;
background: currentColor;
opacity: 0;
transition: opacity var(--transition-base);
pointer-events: none;
}

.btn:hover {
border-radius: var(--radius-organic-2);
transform: translateY(-2px);
}

.btn:hover::before {
opacity: 0.08;
}

.btn:active {
transform: translateY(0);
}

.btn svg {
width: 18px;
height: 18px;
flex-shrink: 0;
transition: transform var(--transition-base);
}

.btn:hover svg {
transform: translateX(4px);
}

.btn--primary {
background-color: var(--color-olive);
color: var(--color-white);
}

.btn--primary:hover {
background-color: var(--color-olive-dark);
box-shadow: 0 8px 32px rgba(155,172,109,.35);
}

.btn--dark {
background-color: var(--color-dark);
color: var(--color-cream);
}

.btn--dark:hover {
box-shadow: 0 8px 32px rgba(42,61,45,.3);
}

.btn--outline {
background-color: transparent;
color: var(--color-dark);
box-shadow: inset 0 0 0 1.5px var(--color-dark);
}

.btn--outline:hover {
background-color: var(--color-dark);
color: var(--color-cream);
box-shadow: inset 0 0 0 1.5px var(--color-dark);
}

.section--dark .btn--outline {
color: var(--color-cream);
box-shadow: inset 0 0 0 1.5px rgba(234,229,224,.4);
}

.section--dark .btn--outline:hover {
background-color: var(--color-cream);
color: var(--color-dark);
}

/* ============================================================
   SITE MAIN
============================================================ */

.site-main {
min-height: 100vh;
padding-top: var(--header-h);
}

/* ============================================================
   WYSIWYG / BLOG CONTENT
============================================================ */

.wysiwyg h1,
.wysiwyg h2,
.wysiwyg h3,
.wysiwyg h4 {
font-family: var(--font-display);
font-weight: 400;
line-height: 1.2;
margin-top: 2.5em;
margin-bottom: 0.75em;
}

.wysiwyg h2 {
font-size: clamp(1.5rem, 2.5vw, 2.25rem);
}

.wysiwyg h3 {
font-size: clamp(1.25rem, 2vw, 1.75rem);
}

.wysiwyg p {
margin-bottom: 1.5em;
}

.wysiwyg a {
color: var(--color-olive);
text-decoration: underline;
text-underline-offset: 3px;
}

.wysiwyg a:hover {
color: var(--color-olive-dark);
}

.wysiwyg ul,
.wysiwyg ol {
margin-bottom: 1.5em;
padding-left: 1.5em;
}

.wysiwyg ul {
list-style: none;
}

.wysiwyg ul li {
position: relative;
padding-left: 1.25em;
margin-bottom: 0.5em;
}

.wysiwyg ul li::before {
content: '';
position: absolute;
left: 0;
top: 0.6em;
width: 6px;
height: 6px;
border-radius: 50%;
background-color: var(--color-olive);
}

.wysiwyg ol {
list-style: decimal;
}

.wysiwyg blockquote {
border-left: 3px solid var(--color-olive);
padding-left: 2rem;
margin: 2.5rem 0;
font-family: var(--font-display);
font-size: clamp(1.1rem, 2vw, 1.5rem);
font-style: italic;
color: var(--color-text-muted);
}

.wysiwyg img {
border-radius: var(--radius-md);
margin: 2rem 0;
width: 100%;
height: auto;
object-fit: cover;
}

.wysiwyg strong {
font-weight: 500;
}

/* ============================================================
   TAG / SHARE / PAGINATION
============================================================ */

.tag-pill {
display: inline-block;
font-family: var(--font-ui);
font-size: 0.8rem;
font-weight: 600;
padding: 0.3rem 0.85rem;
border-radius: 100px;
background-color: var(--color-border);
color: var(--color-text-muted);
transition: background-color var(--transition-fast), color var(--transition-fast);
}

.tag-pill:hover {
background-color: var(--color-olive);
color: var(--color-white);
}

.share-btn {
font-family: var(--font-ui);
font-size: 0.85rem;
font-weight: 700;
letter-spacing: 0.05em;
text-transform: uppercase;
color: var(--color-text-muted);
transition: color var(--transition-fast);
}

.share-btn:hover {
color: var(--color-olive);
}

.pagination {
display: flex;
gap: 0.5rem;
justify-content: center;
margin-top: 4rem;
}

.pagination .page-numbers {
display: inline-flex;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
border-radius: 50%;
font-family: var(--font-ui);
font-weight: 600;
font-size: 0.9rem;
background-color: transparent;
color: var(--color-text);
border: 1.5px solid var(--color-border);
transition: all var(--transition-fast);
}

.pagination .page-numbers:hover,
.pagination .current {
background-color: var(--color-olive);
color: var(--color-white);
border-color: var(--color-olive);
}

/* ============================================================
   NO POSTS
============================================================ */

.no-posts {
text-align: center;
font-family: var(--font-display);
font-size: clamp(1.25rem, 2vw, 1.75rem);
font-style: italic;
color: var(--color-text-muted);
padding: 4rem 0;
}

/* ============================================================
   LOAD MORE
============================================================ */

.load-more-wrap {
display: flex;
justify-content: center;
margin-top: 4rem;
}

.load-more-btn.is-loading {
opacity: 0.6;
pointer-events: none;
}

/* ============================================================
   ARCHIVE HERO
============================================================ */

.archive-hero {
padding-top: calc(var(--section-py) + var(--header-h));
padding-bottom: var(--section-py);
text-align: center;
}

.archive-hero__subtitle {
font-size: clamp(1rem, 1.5vw, 1.25rem);
color: var(--color-text-muted);
max-width: 50ch;
margin-inline: auto;
margin-top: 1rem;
}

/* ============================================================
   POSTS GRID
============================================================ */

.posts-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
gap: 2rem;
}

.posts-grid--3 {
grid-template-columns: repeat(3, 1fr);
}

/* ============================================================
   SINGLE POST
============================================================ */

.single-post__hero {
padding-top: calc(var(--section-py) + var(--header-h));
padding-bottom: 3rem;
}

.single-post__meta {
display: flex;
align-items: center;
gap: 1.5rem;
margin-bottom: 1.5rem;
}

.single-post__reading-time {
font-family: var(--font-ui);
font-size: 0.8rem;
color: var(--color-text-muted);
}

.single-post__title {
max-width: 18ch;
}

.single-post__author-row {
display: flex;
align-items: center;
gap: 1.5rem;
margin-top: 2rem;
}

.single-post__date {
font-family: var(--font-ui);
font-size: 0.85rem;
color: var(--color-text-muted);
}

.single-post__cover {
position: relative;
height: clamp(300px, 55vw, 640px);
margin-top: 3rem;
border-radius: var(--radius-lg);
overflow: hidden;
}

.single-post__cover img {
width: 100%;
height: 100%;
object-fit: cover;
}

.single-post__cover-overlay {
position: absolute;
inset: 0;
background: linear-gradient(to bottom, transparent 60%, rgba(42,61,45,.15));
}

.single-post__body {
padding-block: var(--section-py);
}

.single-post__footer {
margin-top: 4rem;
padding-top: 2rem;
border-top: 1px solid var(--color-border);
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 1.5rem;
}

.single-post__tags {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
}

.single-post__share {
display: flex;
align-items: center;
gap: 1rem;
}

.single-post__share-label {
font-family: var(--font-ui);
font-size: 0.8rem;
text-transform: uppercase;
letter-spacing: 0.1em;
color: var(--color-text-muted);
}

.related-posts {
padding-block: var(--section-py);
}

.label-tag--link:hover {
color: var(--color-olive-dark);
}

/* ============================================================
   RESPONSIVE
============================================================ */

@media (max-width: 1024px) {
.grid-4 {
grid-template-columns: repeat(2, 1fr);
}
}

@media (max-width: 768px) {
.grid-2 {
grid-template-columns: 1fr;
}
.grid-3 {
grid-template-columns: 1fr;
}
.grid-4 {
grid-template-columns: repeat(2, 1fr);
}
.posts-grid--3 {
grid-template-columns: 1fr;
}
.single-post__title {
max-width: 100%;
}
.single-post__footer {
flex-direction: column;
align-items: flex-start;
}
}

@media (max-width: 480px) {
.grid-4 {
grid-template-columns: 1fr;
}
}
