:root{
  --bg:hsl(40,30%,98%); --fg:hsl(200,30%,12%); --muted:hsl(200,12%,42%);
  --primary:hsl(178,65%,32%); --primary-glow:hsl(180,70%,45%); --primary-fg:hsl(40,30%,98%);
  --secondary:hsl(38,40%,92%); --accent:hsl(38,70%,60%); --border:hsl(200,20%,88%);
  --card:#fff; --shadow-soft:0 10px 40px -12px hsl(200 50% 20% / .18);
  --shadow-card:0 4px 20px -6px hsl(200 50% 20% / .12);
  --radius:.75rem;
}
*{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;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;letter-spacing:-.01em;line-height:1.15}
.eyebrow{letter-spacing:.3em;font-size:.72rem;font-weight:600;color:var(--primary);margin-bottom:1rem;text-transform:uppercase}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:hsla(40,30%,98%,.92);backdrop-filter:blur(10px);box-shadow:var(--shadow-soft);transition:all .3s}
.header-inner{max-width:100%;padding:1rem 2.5rem;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:.75rem}
.brand-mark{width:44px;height:44px;border-radius:50%;background:var(--primary);color:var(--primary-fg);display:grid;place-items:center;font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:600;box-shadow:var(--shadow-soft)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-title{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:600}
.brand-sub{font-size:.62rem;letter-spacing:.25em;color:var(--primary);font-weight:600}
.brand-light .brand-title,.brand-light .brand-sub{color:#fff}
.brand-light .brand-sub{color:var(--primary-glow)}
.nav-desktop{display:flex;align-items:center;gap:2.5rem}
.nav-desktop a{font-size:.9rem;font-weight:500;color:hsl(200,30%,18%);transition:color .3s}
.nav-desktop a:hover{color:var(--primary)}
.btn-pill{background:var(--primary);color:var(--primary-fg)!important;padding:.65rem 1.75rem;border-radius:9999px;box-shadow:var(--shadow-soft)}
.btn-pill:hover{opacity:.9}
.nav-toggle{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--fg)}
.nav-mobile{display:none;flex-direction:column;background:var(--bg);border-top:1px solid var(--border);padding:1rem 2.5rem;gap:.75rem}
.nav-mobile.open{display:flex}
@media(max-width:820px){.nav-desktop{display:none}.nav-toggle{display:block}.header-inner{padding:1rem 1.25rem}}

/* Hero carousel — full screen full width */
.hero-carousel{position:relative;width:100vw;height:100vh;min-height:600px;overflow:hidden;margin-left:calc(50% - 50vw)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,hsla(200,50%,8%,.1) 0%,hsla(200,50%,8%,.6) 100%)}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:#fff;padding:0 1.5rem;text-shadow:0 2px 24px hsla(200,50%,8%,.5)}
.hero-content .eyebrow{color:#fff;opacity:.95}
.hero-content h1{font-size:clamp(2.25rem,5.5vw,4.5rem);font-weight:600;max-width:1100px;margin-bottom:1.25rem}
.hero-sub{font-size:clamp(1rem,1.4vw,1.3rem);max-width:760px;margin-bottom:2rem;opacity:.95}
.btn-primary{display:inline-block;background:var(--primary);color:var(--primary-fg);padding:.95rem 2.25rem;border-radius:9999px;font-weight:500;border:0;cursor:pointer;box-shadow:var(--shadow-soft);transition:transform .3s}
.btn-primary:hover{transform:translateY(-2px)}
.hero-nav{position:absolute;top:50%;transform:translateY(-50%);background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.3);color:#fff;width:48px;height:48px;border-radius:50%;font-size:1.6rem;cursor:pointer;backdrop-filter:blur(8px)}
.hero-nav.prev{left:1.5rem} .hero-nav.next{right:1.5rem}
.hero-nav:hover{background:hsla(0,0%,100%,.3)}
.hero-dots{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;gap:.6rem}
.dot{width:10px;height:10px;border-radius:50%;border:0;background:hsla(0,0%,100%,.4);cursor:pointer;transition:all .3s}
.dot.active{background:#fff;width:30px;border-radius:5px}

/* Page head (non-home) */
body:not(.home) .site-header{position:sticky}
.page-head{padding:7rem 1.5rem 2rem;text-align:center;max-width:760px;margin:0 auto}
.page-head h1{font-size:clamp(2.25rem,4vw,3.25rem);font-weight:600}

/* Sections — full width */
.section-fullwidth{width:100vw;margin-left:calc(50% - 50vw);padding:5rem 1.25rem}
.section-head{max-width:820px;margin:0 auto 4rem;text-align:center;padding:0 1.25rem}
.section-head h2{font-size:clamp(2rem,3.5vw,3rem);font-weight:600;margin-bottom:1rem}
.section-head .lede{color:var(--muted);font-size:1.1rem}

/* Blog grid — full width edge-to-edge, one per row, image on top */
.blog-grid{display:grid;gap:2.5rem}
.blog-grid-fullwidth{grid-template-columns:1fr;width:100%;max-width:none}
.post-card{background:var(--card);border-radius:1rem;overflow:hidden;box-shadow:var(--shadow-card);transition:all .35s;display:block}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.post-thumb{display:block;width:100%;overflow:hidden;aspect-ratio:21/9}
.post-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.post-card:hover .post-thumb img{transform:scale(1.04)}
.post-body{padding:2.5rem 3rem}
.post-meta{display:flex;gap:1rem;color:var(--muted);font-size:.85rem;margin-bottom:1rem}
.post-body h3{font-size:2rem;font-weight:600;margin-bottom:1rem;line-height:1.25}
.post-body h3 a:hover{color:var(--primary)}
.post-body p{color:var(--muted);font-size:1.05rem;margin-bottom:1.5rem;line-height:1.7;max-width:900px}
@media(max-width:760px){.post-thumb{aspect-ratio:4/3}.post-body{padding:1.75rem}.post-body h3{font-size:1.4rem}}
.read-more{color:var(--primary);font-weight:500;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem;transition:gap .3s}
.read-more:hover{gap:.75rem}

/* About */
.about-band{background:hsla(38,40%,92%,.6);padding:5rem 2.5rem}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;max-width:1280px;margin:0 auto;align-items:center}
.about-img{position:relative}
.about-img img{aspect-ratio:4/5;object-fit:cover;border-radius:1rem;box-shadow:var(--shadow-soft)}
.about-stat{position:absolute;bottom:-2rem;right:-2rem;width:160px;height:160px;border-radius:1rem;background:var(--primary);color:var(--primary-fg);padding:1.5rem;box-shadow:var(--shadow-soft)}
.stat-num{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:600}
.stat-label{font-size:.7rem;letter-spacing:.2em;margin-top:.5rem;opacity:.9}
.about-grid h2{font-size:clamp(2rem,3.5vw,3rem);font-weight:600;margin-bottom:1.25rem;line-height:1.15}
.about-grid p{color:var(--muted);font-size:1.05rem;margin-bottom:1.25rem}
@media(max-width:820px){.about-grid{grid-template-columns:1fr}.about-stat{display:none}}

/* Contact */
.contact-section{max-width:680px;margin:0 auto;padding:3rem 1.5rem 5rem}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.contact-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:500}
.contact-form input,.contact-form textarea{padding:.85rem 1rem;border:1px solid var(--border);border-radius:.6rem;font-family:inherit;font-size:1rem;background:#fff}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--primary);outline-offset:0;border-color:transparent}

/* Legal */
.legal-content{max-width:780px;margin:0 auto;padding:2rem 1.5rem 5rem}
.legal-content h2{font-size:1.5rem;margin:2rem 0 .75rem;font-weight:600}
.legal-content p{color:var(--muted);margin-bottom:1rem}

/* Post page */
.post-article{background:var(--bg)}
.post-hero{position:relative;width:100vw;height:70vh;min-height:480px;margin-left:calc(50% - 50vw);overflow:hidden}
.post-hero img{width:100%;height:100%;object-fit:cover}
.post-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,hsla(200,50%,8%,.2) 0%,hsla(200,50%,8%,.7) 100%)}
.post-hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:0 2.5rem 4rem;color:#fff;max-width:1100px;margin:0 auto;text-shadow:0 2px 24px hsla(200,50%,8%,.5)}
.post-hero-content .eyebrow{color:#fff;opacity:.95}
.post-hero-content h1{font-size:clamp(2rem,4.5vw,3.75rem);font-weight:600;margin-bottom:1rem;max-width:900px}
.post-sub{font-size:1.2rem;opacity:.95;margin-bottom:1.25rem;max-width:760px}
.post-meta.light{color:#fff;opacity:.9}
.post-content{max-width:760px;margin:0 auto;padding:4rem 1.5rem}
.post-content section{margin-bottom:2.5rem}
.post-content h2{font-size:1.75rem;font-weight:600;margin-bottom:1rem;color:var(--fg)}
.post-content p{font-size:1.08rem;color:hsl(200,20%,25%);margin-bottom:1rem;line-height:1.75}
.post-nav{max-width:1100px;margin:0 auto;padding:2rem 1.5rem 5rem;display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;border-top:1px solid var(--border)}
.post-nav-link{padding:1rem;font-size:.9rem;color:var(--muted);transition:color .3s}
.post-nav-link.right{text-align:right}.post-nav-link.center{text-align:center;color:var(--primary);font-weight:500}
.post-nav-link:hover{color:var(--primary)}
@media(max-width:700px){.post-nav{grid-template-columns:1fr;text-align:center}.post-nav-link.right{text-align:center}}

/* Footer */
.site-footer{background:var(--fg);color:var(--bg)}
.footer-grid{padding:5rem 2.5rem;display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;max-width:1400px;margin:0 auto}
.footer-brand p{color:hsla(40,30%,98%,.7);font-size:.9rem;max-width:420px;margin:1.25rem 0}
.footer-mail{color:hsla(40,30%,98%,.8);font-size:.9rem;display:inline-flex;gap:.5rem;align-items:center}
.site-footer h4{font-family:'Playfair Display',serif;font-size:1.15rem;margin-bottom:1.25rem}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.site-footer ul a{color:hsla(40,30%,98%,.7);font-size:.9rem}
.site-footer ul a:hover{color:var(--bg)}
.footer-bottom{border-top:1px solid hsla(40,30%,98%,.1);padding:1.5rem;text-align:center;font-size:.75rem;color:hsla(40,30%,98%,.5)}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr;padding:3rem 1.5rem}}
