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


/* NEWSLETTER BANNER */
.newsletter-banner{
  grid-column:1/-1;
  background:var(--dark);border-radius:2px;
  padding:2rem 2.5rem;
  display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;
}
.nl-icon{font-size:1.8rem;flex-shrink:0}
.nl-text{flex:1;min-width:200px}
.nl-title{font-family:var(--serif);font-size:1.2rem;font-weight:300;color:#fff;margin-bottom:.3rem}
.nl-text p{font-size:.83rem;color:rgba(255,255,255,.5);line-height:1.6}
.nl-form{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
.nl-input{padding:.65rem 1rem;font-size:.83rem;font-family:var(--sans);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:2px;color:#fff;width:220px;outline:none;transition:border-color .15s}
.nl-input::placeholder{color:rgba(255,255,255,.35)}
.nl-input:focus{border-color:rgba(255,255,255,.5)}
.nl-btn{padding:.65rem 1.4rem;background:var(--red);color:#fff;font-size:.72rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;border:none;border-radius:2px;cursor:pointer;white-space:nowrap;transition:background .15s;font-family:var(--sans)}
.nl-btn:hover{background:var(--red2)}

/* NO RESULTS */
.no-results{grid-column:1/-1;text-align:center;padding:4rem 2rem;color:var(--muted);font-size:.9rem}
.no-results span{font-family:var(--serif);font-size:2rem;display:block;margin-bottom:.5rem;color:var(--bdr)}

/* SIDEBAR */
.sidebar{position:sticky;top:88px}
@media(max-width:1000px){.sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:16px}}
@media(max-width:600px){.sidebar{grid-template-columns:1fr}}

.sb-box{background:#fff;border:1px solid var(--bdr);border-radius:2px;padding:1.4rem;margin-bottom:16px}
@media(max-width:1000px){.sb-box{margin-bottom:0}}

.sb-ttl{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:7px;margin-bottom:1.1rem}
.sb-ttl::before{content:"";width:14px;height:1px;background:var(--red)}

/* Categories */
.sb-cats{list-style:none}
.sb-cats li{margin-bottom:3px}
.sb-cats a{display:flex;align-items:center;justify-content:space-between;padding:.4rem .7rem;font-size:.82rem;color:var(--muted);border-left:2px solid transparent;border-radius:0 2px 2px 0;transition:all .15s;cursor:pointer}
.sb-cats a:hover,.sb-cats a.active{color:var(--red);border-left-color:var(--red);background:rgba(109,26,52,.04)}
.sb-count{font-size:.7rem;color:var(--muted);background:var(--cream2);padding:1px 6px;border-radius:8px}

/* Recent Posts */
.sb-post{display:flex;gap:10px;align-items:flex-start;margin-bottom:1rem;text-decoration:none;transition:opacity .15s}
.sb-post:hover{opacity:.75}
.sb-post:last-child{margin-bottom:0}
.sb-post-img{width:60px;height:44px;object-fit:cover;border-radius:2px;flex-shrink:0}
.sb-post-body{min-width:0}
.sb-cat{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:2px}
.sb-title{font-size:.8rem;color:var(--dark);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* CTA Box */
.sb-cta-box{background:var(--dark);border-radius:2px;padding:1.5rem}
.sb-cta-box p{font-size:.83rem;color:rgba(255,255,255,.5);line-height:1.6;margin-bottom:1rem}
.sb-cta-btn{display:block;text-align:center;padding:.7rem;background:var(--red);color:#fff;font-size:.72rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;border-radius:2px;transition:background .15s}
.sb-cta-btn:hover{background:var(--red2)}
.sb-cta-title{font-family:var(--serif);font-size:1.15rem;font-weight:300;color:#fff;margin-bottom:.5rem;line-height:1.3}

/* FOOTER */
footer{background:var(--dark);padding:4rem 5% 2rem}
.fgrid{max-width:1260px;margin:0 auto 3rem;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}
@media(max-width:800px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.fgrid{grid-template-columns:1fr}}
.fbrand p{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.75;max-width:280px;margin-top:.7rem}
.fsoc{display:flex;gap:10px;margin-top:1rem}
.fsoc a{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:500;color:rgba(255,255,255,.5);transition:all .15s}
.fsoc a:hover{border-color:rgba(255,255,255,.4);color:#fff}
.fcol h4{font-size:.63rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem}
.fcol ul{list-style:none}
.fcol ul li{margin-bottom:.5rem}
.fcol ul li a{font-size:.83rem;color:rgba(255,255,255,.5);transition:color .15s}
.fcol ul li a:hover{color:#fff}
.fbot{max-width:1260px;margin:0 auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.fcopy{font-size:.76rem;color:rgba(255,255,255,.25)}
.flinks{display:flex;gap:1.5rem}
.flinks a{font-size:.73rem;color:rgba(255,255,255,.3);transition:color .15s}
.flinks a:hover{color:rgba(255,255,255,.7)}

/* MOBILE */
@media(max-width:1024px){
  .nav-links,.nav-cta{display:none}
  .nav-hbg{display:flex}
  .nav-inner{padding:0 20px}
  .nav-logo{margin-right:0}
  #mob-p{display:none;background:#fff;border-top:1px solid var(--bdr);box-shadow:0 8px 24px rgba(0,0,0,.1)}
  #mob-p.open{display:block}
  .mob-it{display:flex;align-items:center;justify-content:space-between;padding:13px 20px;font-size:14px;color:var(--dark);border-bottom:1px solid var(--bdr);cursor:pointer;background:none;border-left:none;border-right:none;border-top:none;width:100%;text-align:left;font-family:var(--sans);transition:background .12s}
  .mob-it:hover{background:var(--cream)}
  .mob-sub{display:none;background:var(--cream);border-bottom:1px solid var(--bdr)}
  .mob-sub.open{display:block}
  .mob-sub a{display:block;padding:9px 20px 9px 36px;font-size:13px;color:var(--muted)}
  .mob-cta{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 20px;background:var(--cream)}
  .mob-cta a{justify-content:center;text-align:center;padding:10px;font-size:12px;font-weight:500;border-radius:2px}
  .mob-cb{background:var(--red);color:#fff}
  .mob-cg{color:var(--red);border:1px solid rgba(109,26,52,.3)}
  .mob-arr{width:8px;height:8px;border-right:1.5px solid var(--muted);border-bottom:1.5px solid var(--muted);transform:rotate(45deg);flex-shrink:0}
  .mob-it.open .mob-arr{transform:rotate(225deg);border-color:var(--acc)}
}
@media(max-width:768px){
  .banner{height:100vh;background-attachment:scroll}
  .banner-logo{top:16px;right:20px}
  .banner-logo img{height:50px}
}