
:root{--bg:#f6f1e7;--fg:#2b2620;--muted:#7a7060;--card:#fdfaf3;--border:#e0d6c4;
--primary:#4d6b3a;--primary-fg:#fbf7ee;--secondary:#ece3d2;--accent:#c8552a;--accent-soft:#e8dccc;}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--fg);line-height:1.6;font-feature-settings:"ss01","ss02"}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;letter-spacing:-.015em;font-weight:600;line-height:1.1}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.container{max-width:72rem;margin:0 auto;padding:0 1.5rem}
.container-sm{max-width:48rem;margin:0 auto;padding:0 1.5rem}
.header{position:sticky;top:0;z-index:40;background:rgba(246,241,231,.85);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;max-width:72rem;margin:0 auto}
.brand{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:var(--primary)}
.brand em{color:var(--accent);font-style:normal}
.nav{display:flex;gap:2rem;font-size:.875rem;color:var(--muted)}
.nav a:hover{color:var(--fg)}
@media(max-width:768px){.nav{display:none}}
.hero{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--bg),rgba(246,241,231,.85) 50%,rgba(246,241,231,.3))}
.hero-inner{position:relative;padding:6rem 1.5rem;max-width:72rem;margin:0 auto}
@media(min-width:768px){.hero-inner{padding:9rem 1.5rem}}
.eyebrow{font-size:.75rem;text-transform:uppercase;letter-spacing:.25em;color:var(--accent);font-weight:500}
.hero h1{font-size:3rem;margin-top:1rem;max-width:48rem}
@media(min-width:768px){.hero h1{font-size:4.5rem}}
.hero h1 em{color:var(--accent);font-style:normal}
.hero p{margin-top:1.5rem;max-width:36rem;font-size:1.125rem;color:var(--muted)}
.btn-row{margin-top:2rem;display:flex;gap:1rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.375rem;font-size:.875rem;font-weight:500;transition:all .2s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-primary:hover{opacity:.9}
.btn-outline{border-color:var(--border);background:transparent;color:var(--fg)}
.btn-outline:hover{background:var(--secondary)}
.section{padding:5rem 0}
.section-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3rem}
.section-header h2{font-size:2.25rem}
.section-header a{color:var(--accent);font-size:.875rem}
.section-header a:hover{text-decoration:underline}
.grid{display:grid;grid-template-columns:1fr;gap:4rem 2.5rem}
@media(min-width:768px){.grid-2{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.card{display:block;transition:transform .3s}
.card .img{overflow:hidden;border-radius:.375rem;aspect-ratio:4/3}
.card.featured .img{aspect-ratio:16/9}
@media(min-width:768px){.card.featured{grid-column:span 2}}
.card img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.card:hover img{transform:scale(1.05)}
.meta{margin-top:1.25rem;display:flex;gap:.75rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);font-weight:500;align-items:center}
.meta .dot,.meta .time{color:var(--muted);text-transform:none;letter-spacing:normal}
.card h3{margin-top:.75rem;font-size:1.5rem;color:var(--fg);transition:color .2s}
.card.featured h3{font-size:1.875rem}
@media(min-width:768px){.card.featured h3{font-size:2.25rem}}
.card:hover h3{color:var(--accent)}
.card p{margin-top:.75rem;color:var(--muted)}
.card .date{margin-top:1rem;font-size:.75rem;color:var(--muted)}
.page-header{padding:4rem 0 1rem}
.page-header h1{font-size:3rem;margin-top:.75rem}
@media(min-width:768px){.page-header h1{font-size:3.75rem}}
.page-header p{margin-top:1rem;max-width:36rem;font-size:1.125rem;color:var(--muted)}
.article{max-width:48rem;margin:0 auto;padding:4rem 1.5rem}
.article .back{font-size:.875rem;color:var(--muted)}
.article .back:hover{color:var(--accent)}
.article h1{margin-top:1rem;font-size:2.5rem}
@media(min-width:768px){.article h1{font-size:3.75rem}}
.article .lede{margin-top:1.5rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.25rem;color:var(--muted)}
.article .date{margin-top:1rem;font-size:.875rem;color:var(--muted)}
.article .cover{margin-top:2.5rem;aspect-ratio:16/10;overflow:hidden;border-radius:.375rem}
.article .body{margin-top:3rem}
.article .body p{font-size:1.125rem;line-height:1.8;color:rgba(43,38,32,.9);margin-bottom:1.5rem}
.article .body strong{color:var(--fg);font-weight:600}
.notice{margin-top:4rem;padding:1.5rem;border-radius:.375rem;background:rgba(236,227,210,.6);border:1px solid var(--border);font-size:.875rem;color:var(--muted)}
.notice strong{color:var(--fg)}
.related{max-width:72rem;margin:0 auto;padding:5rem 1.5rem;border-top:1px solid var(--border)}
.related h2{font-size:1.875rem;margin-bottom:2.5rem}
.footer{border-top:1px solid var(--border);margin-top:6rem;padding:3rem 1.5rem;font-size:.875rem;color:var(--muted)}
.footer-inner{max-width:72rem;margin:0 auto;display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.footer .brand-foot{font-family:'Cormorant Garamond',serif;font-size:1.125rem;color:var(--fg)}
.about{max-width:48rem;margin:0 auto;padding:5rem 1.5rem}
.about h1{font-size:3rem;margin-top:.75rem}
@media(min-width:768px){.about h1{font-size:3.75rem}}
.about .body{margin-top:2.5rem;font-size:1.125rem;line-height:1.7;color:rgba(43,38,32,.9)}
.about .body p{margin-bottom:1.5rem}
.about .body strong{font-weight:600}
.about .quote{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--accent);font-size:1.5rem;padding-top:1rem}
