:root{
  --teal-900:#053030;
  --teal-800:#064040;
  --teal-700:#0A5C5C;
  --teal-600:#1A7A7A;
  --teal-500:#2A9D9D;
  --sand-50:#FCF9F5;
  --sand-100:#F5F0E8;
  --sand-200:#EDE5D9;
  --sand-300:#DDD3C4;
  --terracotta:#D4744A;
  --terracotta-light:#DE8D68;
  --gold:#D4A84B;
  --gold-light:#E0BC6A;
  --charcoal:#1E1B18;
  --charcoal-soft:#2E2B28;
  --stone:#7A7268;
  --stone-light:#9E968C;
  --cream:#FFFCF5;
  --white:#FFFFFF;
  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:22px;
  --shadow-sm:0 2px 8px rgba(10,92,92,0.08);
  --shadow-md:0 10px 30px rgba(10,92,92,0.10);
  --shadow-lg:0 18px 54px rgba(10,92,92,0.12);
  --transition:0.32s cubic-bezier(0.4,0,0.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Outfit,sans-serif;
  color:var(--charcoal);
  background:var(--sand-50);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{
  font-family:"Playfair Display",Georgia,serif;
  color:var(--charcoal);
  line-height:1.18;
  letter-spacing:-0.02em;
}
a{
  color:var(--teal-700);
  text-decoration:none;
  transition:color var(--transition),opacity var(--transition);
}
a:hover{color:var(--teal-500)}
a:focus-visible,
button:focus-visible,
select:focus-visible,
input:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
}

/* Header */
.site-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  padding:0 2rem;
  padding-top:env(safe-area-inset-top,0px);
  transition:background .35s,box-shadow .35s,backdrop-filter .35s;
  background:transparent;
}
.site-header.scrolled{
  background:rgba(5,48,48,0.95);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 4px 20px rgba(0,0,0,0.2);
}
.header-inner{
  max-width:1280px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:.85rem 0;
}
.logo-link{
  display:flex;
  align-items:center;
  gap:.75rem;
  text-decoration:none;
  color:#FFFCF5;
}
.logo-icon{
  width:40px;
  height:40px;
  background:var(--teal-700);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.1rem;
  color:#FFFCF5;
  flex-shrink:0;
  box-shadow:0 8px 20px rgba(0,0,0,0.12);
}
.logo-text{line-height:1.1}
.logo-h1{
  margin:0;
  font-family:"Playfair Display",Georgia,serif;
  font-size:1.3rem;
  font-weight:600;
  letter-spacing:-.02em;
  color:inherit;
}
.logo-text span{
  display:block;
  font-size:.65rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  opacity:.7;
  font-weight:300;
}
.main-nav{
  display:flex;
  align-items:center;
  gap:.5rem;
}
.main-nav a{
  color:rgba(252,249,245,0.8);
  text-decoration:none;
  padding:.45rem 1rem;
  font-size:.82rem;
  border-radius:var(--radius-sm);
  transition:all .35s;
}
.main-nav a:hover{
  color:#FFFCF5;
  background:rgba(255,255,255,0.08);
}
.header-actions{
  display:flex;
  align-items:center;
  gap:.75rem;
}
.header-btn-gold{
  background:var(--gold);
  color:var(--charcoal);
  border:none;
  padding:.5rem 1.25rem;
  border-radius:var(--radius-sm);
  font-size:.8rem;
  font-weight:500;
  cursor:pointer;
  text-decoration:none;
  font-family:inherit;
  white-space:nowrap;
}
.header-btn-ghost{
  background:transparent;
  color:#FFFCF5;
  border:1px solid rgba(252,249,245,0.25);
  padding:.5rem 1.1rem;
  border-radius:var(--radius-sm);
  font-size:.8rem;
  cursor:pointer;
  text-decoration:none;
  font-family:inherit;
}

/* Blog listing header */
.page-hdr{
  background:linear-gradient(160deg,#0A5C5C,#064040 30%,#053030 60%,#1A2A25);
  padding:7rem 1.5rem 3rem;
  color:#FFFCF5;
  text-align:center;
}
.page-hdr h1{
  font-size:2.5rem;
  font-weight:500;
  margin:0;
}
.page-hdr p{
  color:rgba(252,249,245,0.58);
  max-width:640px;
  margin:.55rem auto 0;
  font-size:1.05rem;
}
.page-hdr .article-meta{
  color:rgba(252,249,245,0.5);
  font-size:.82rem;
  margin-top:.85rem;
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:.75rem 1.1rem;
}
.page-hdr .article-meta span{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
}

body.blog-home{
  background:
    radial-gradient(circle at top left, rgba(212,168,75,0.09), transparent 26%),
    radial-gradient(circle at top right, rgba(10,92,92,0.06), transparent 24%),
    linear-gradient(180deg,#FFFFFF 0%,#FFFFFF 56%,#FAF7F1 100%);
}
body.blog-home .page-hdr{
  background:linear-gradient(180deg,#FFFFFF 0%,#FFFFFF 74%,#FAF7F1 100%);
  color:var(--charcoal);
  padding:8.25rem 1.5rem 2rem;
  border-bottom:1px solid var(--sand-200);
  text-align:left;
}
body.blog-home .blog-hero-shell{
  max-width:1280px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);
  gap:1.5rem;
  align-items:end;
}
body.blog-home .blog-hero-copy{
  max-width:720px;
}
body.blog-home .hero-kicker{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--stone);
  margin-bottom:.9rem;
}
body.blog-home .hero-kicker::before{
  content:"";
  width:2.5rem;
  height:1px;
  background:var(--gold);
}
body.blog-home .page-hdr h1{
  font-size:clamp(3rem,6vw,5.2rem);
  line-height:.95;
  max-width:11ch;
  margin:0;
}
body.blog-home .page-hdr p{
  max-width:640px;
  margin:1rem 0 0;
  color:var(--stone);
  font-size:1.05rem;
}
body.blog-home .hero-tokens{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top:1.1rem;
}
body.blog-home .hero-tokens span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:.42rem .75rem;
  border-radius:999px;
  border:1px solid var(--sand-200);
  background:rgba(255,255,255,.9);
  color:var(--stone);
  font-size:.76rem;
  letter-spacing:.02em;
}
body.blog-home .blog-hero-rail{
  background:var(--white);
  border:1px solid var(--sand-200);
  border-radius:28px;
  padding:1.25rem;
  box-shadow:var(--shadow-sm);
}
body.blog-home .blog-hero-feature{
  display:block;
  color:inherit;
}
body.blog-home .hero-feature-label{
  display:inline-flex;
  align-items:center;
  padding:.28rem .58rem;
  border-radius:999px;
  background:rgba(212,168,75,0.12);
  color:var(--terracotta);
  font-size:.68rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
}
body.blog-home .blog-hero-feature strong{
  display:block;
  margin:.7rem 0 .55rem;
  font-family:"Playfair Display",Georgia,serif;
  font-size:1.5rem;
  line-height:1.12;
  letter-spacing:-.02em;
}
body.blog-home .blog-hero-feature p{
  margin:0;
  max-width:none;
  color:var(--stone);
  font-size:.95rem;
}
body.blog-home .blog-hero-note{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top:1rem;
}
body.blog-home .blog-hero-note span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:.35rem .62rem;
  border-radius:999px;
  border:1px solid var(--sand-200);
  background:var(--sand-50);
  color:var(--stone);
  font-size:.72rem;
}

/* Article pages */
body:has(.article-wrap){
  background:var(--white);
}
body:has(.article-wrap) .page-hdr{
  background:
    radial-gradient(circle at 20% 0%, rgba(42,157,157,0.10), transparent 36%),
    radial-gradient(circle at 80% 10%, rgba(212,168,75,0.10), transparent 30%),
    linear-gradient(180deg,#FFFFFF 0%,#FFFFFF 72%,#F9F7F2 100%);
  color:var(--charcoal);
  padding:8rem 1.5rem 2.8rem;
  border-bottom:1px solid var(--sand-200);
  text-align:left;
}
body:has(.article-wrap) .page-hdr h1{
  max-width:900px;
  margin:0 auto;
  font-size:clamp(2.2rem,4vw,4rem);
  font-weight:600;
  line-height:1.06;
}
body:has(.article-wrap) .page-hdr p{
  max-width:780px;
  margin:.9rem auto 0;
  color:var(--stone);
  font-size:1.08rem;
}
body:has(.article-wrap) .page-hdr .article-meta{
  max-width:900px;
  margin:1rem auto 0;
  justify-content:flex-start;
  color:var(--stone);
}
body:has(.article-wrap) .page-hdr .article-meta span{
  background:var(--white);
  border:1px solid var(--sand-200);
  border-radius:999px;
  padding:.45rem .8rem;
  box-shadow:0 1px 0 rgba(255,255,255,.7);
}
body:has(.article-wrap) .article-wrap{
  max-width:1200px;
  margin:0 auto;
  padding:0 1.5rem 3.5rem;
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:2rem;
  align-items:start;
  transform:translateY(-1.25rem);
}
body:has(.article-wrap) article.article-content{
  background:var(--white);
  border:1px solid var(--sand-200);
  border-radius:28px;
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
body:has(.article-wrap) article.article-content > .article-header{
  padding:1.8rem 2rem 0;
}
body:has(.article-wrap) article.article-content > .article-content{
  padding:0 2rem 2.25rem;
}
body:has(.article-wrap) .article-content{
  font-size:1.04rem;
  line-height:1.82;
  color:var(--charcoal-soft);
}
body:has(.article-wrap) .article-content h2,
body:has(.article-wrap) .article-content h3,
body:has(.article-wrap) .article-content h4{
  scroll-margin-top:110px;
}
body:has(.article-wrap) .article-content h2{
  font-size:clamp(1.55rem,2vw,2rem);
  margin:2.4rem 0 1rem;
}
body:has(.article-wrap) .article-content h3{
  font-size:1.2rem;
  margin:1.75rem 0 .65rem;
}
body:has(.article-wrap) .article-content p{
  margin-bottom:1rem;
}
body:has(.article-wrap) .article-content ul,
body:has(.article-wrap) .article-content ol{
  margin:0 0 1rem 1.3rem;
}
body:has(.article-wrap) .article-content li{
  margin-bottom:.45rem;
}
body:has(.article-wrap) .article-content strong{
  color:var(--charcoal);
  font-weight:600;
}
body:has(.article-wrap) .article-content a{
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:2px;
}
body:has(.article-wrap) .article-content a:hover{
  text-decoration-color:var(--gold);
}
body:has(.article-wrap) .article-content img{
  max-width:100%;
  border-radius:20px;
  margin:1.5rem 0;
  box-shadow:var(--shadow-md);
}
body:has(.article-wrap) .article-content blockquote{
  border-left:3px solid var(--gold);
  padding:1rem 1.2rem;
  margin:1.5rem 0;
  background:var(--sand-100);
  border-radius:0 16px 16px 0;
  color:var(--charcoal-soft);
  font-style:italic;
}
body:has(.article-wrap) .article-content table{
  width:100%;
  border-collapse:collapse;
  margin:1.5rem 0;
  overflow:hidden;
  border-radius:16px;
  border:1px solid var(--sand-200);
}
body:has(.article-wrap) .article-content th{
  background:var(--sand-100);
  padding:.8rem .9rem;
  text-align:left;
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--charcoal-soft);
}
body:has(.article-wrap) .article-content td{
  padding:.8rem .9rem;
  border-top:1px solid var(--sand-200);
  font-size:.92rem;
}
body:has(.article-wrap) .article-header .article-meta{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin:0;
}
body:has(.article-wrap) .article-header .article-meta span{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.45rem .7rem;
  border-radius:999px;
  background:var(--sand-50);
  border:1px solid var(--sand-200);
  color:var(--stone);
  font-size:.8rem;
}

body:has(.article-wrap) .article-sidebar{
  position:sticky;
  top:92px;
}
body:has(.article-wrap) .sidebar-widget{
  background:var(--white);
  border:1px solid var(--sand-200);
  border-radius:22px;
  padding:1.2rem 1.15rem;
  box-shadow:var(--shadow-sm);
  margin-bottom:1rem;
}
body:has(.article-wrap) .sidebar-widget h4{
  font-size:1rem;
  margin-bottom:.85rem;
}
body:has(.article-wrap) .sidebar-widget p{
  color:var(--stone);
  font-size:.92rem;
}
body:has(.article-wrap) .toc-list,
body:has(.article-wrap) .related-articles{
  list-style:none;
  margin:0;
}
body:has(.article-wrap) .toc-list li{
  border-top:1px solid var(--sand-200);
}
body:has(.article-wrap) .toc-list li:first-child{
  border-top:none;
}
body:has(.article-wrap) .toc-list a,
body:has(.article-wrap) .related-articles a{
  display:block;
  padding:.65rem 0;
  color:var(--charcoal);
  text-decoration:none;
}
body:has(.article-wrap) .toc-list a:hover,
body:has(.article-wrap) .related-articles a:hover{
  color:var(--teal-700);
}
body:has(.article-wrap) .related-articles li{
  border-top:1px solid var(--sand-200);
  padding:.1rem 0;
}
body:has(.article-wrap) .related-articles li:first-child{
  border-top:none;
}
body:has(.article-wrap) .read-time{
  display:block;
  margin-top:-.25rem;
  color:var(--stone);
  font-size:.76rem;
}
body:has(.article-wrap) .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:44px;
  padding:.75rem 1rem;
  border-radius:14px;
  background:var(--teal-700);
  color:var(--white);
  font-weight:600;
  text-decoration:none;
  transition:transform var(--transition),background var(--transition),box-shadow var(--transition);
  box-shadow:0 10px 24px rgba(10,92,92,0.16);
}
body:has(.article-wrap) .btn:hover{
  background:var(--teal-600);
  transform:translateY(-1px);
  color:var(--white);
}
body:has(.article-wrap) .callout{
  margin:1.8rem 0;
  padding:1.15rem 1.2rem;
  background:linear-gradient(180deg,#FFF9F1, #FFFDF9);
  border:1px solid #F0E1C5;
  border-radius:18px;
  box-shadow:0 8px 20px rgba(212,168,75,0.08);
}
body:has(.article-wrap) .callout h4{
  font-size:.86rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--teal-700);
  margin-bottom:.45rem;
}

/* Article FAQ */
body:has(.article-wrap) .faq-section{
  margin:2.75rem 0 0;
}
body:has(.article-wrap) .faq-section h2{
  margin-bottom:1rem;
}
body:has(.article-wrap) .faq-item{
  border:1px solid var(--sand-200);
  border-radius:18px;
  margin-bottom:.7rem;
  overflow:hidden;
  background:var(--white);
  transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);
}
body:has(.article-wrap) .faq-item:hover{
  box-shadow:var(--shadow-sm);
  border-color:#D6E6E6;
}
body:has(.article-wrap) .faq-item.open{
  border-color:var(--gold);
  box-shadow:0 10px 24px rgba(212,168,75,0.08);
}
body:has(.article-wrap) .faq-item .faq-q{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:1rem 1.1rem;
  font-weight:600;
  font-size:.95rem;
  color:var(--charcoal);
}
body:has(.article-wrap) .faq-item .faq-q svg{
  flex-shrink:0;
  transition:transform .2s;
}
body:has(.article-wrap) .faq-item.open .faq-q svg{
  transform:rotate(180deg);
}
body:has(.article-wrap) .faq-item .faq-a{
  padding:0 1.1rem 1rem;
  font-size:.92rem;
  color:var(--charcoal-soft);
  line-height:1.75;
  display:none;
}
body:has(.article-wrap) .faq-item.open .faq-a{
  display:block;
}

/* Newsletter */
.newsletter{
  background:var(--sand-100);
  padding:3rem 1.5rem;
  text-align:center;
}
.newsletter h2{
  font-size:1.5rem;
  margin-bottom:.5rem;
}
.newsletter p{
  color:var(--stone);
  margin-bottom:1.25rem;
}
.newsletter form{
  display:flex;
  max-width:480px;
  margin:0 auto;
  gap:.5rem;
}
.newsletter input{
  flex:1;
  padding:.7rem 1rem;
  border:1px solid var(--sand-200);
  border-radius:var(--radius-sm);
  font-family:inherit;
  font-size:.9rem;
  background:var(--white);
}
.newsletter input:focus{
  outline:2px solid var(--teal-500);
  outline-offset:-1px;
}
.newsletter button{
  padding:.7rem 1.5rem;
  background:var(--terracotta);
  color:var(--white);
  border:none;
  border-radius:var(--radius-sm);
  font-family:inherit;
  font-size:.85rem;
  font-weight:500;
  cursor:pointer;
  transition:background var(--transition);
  white-space:nowrap;
}
.newsletter button:hover{
  background:var(--terracotta-light);
}

body:has(.article-wrap) .newsletter-section{
  max-width:1200px;
  margin:0 auto 2.5rem;
  padding:0 1.5rem 0;
}
body:has(.article-wrap) .newsletter-content{
  background:
    radial-gradient(circle at right top, rgba(42,157,157,0.08), transparent 32%),
    var(--sand-50);
  border:1px solid var(--sand-200);
  border-radius:28px;
  padding:2rem;
  box-shadow:var(--shadow-sm);
  text-align:left;
}
body:has(.article-wrap) .newsletter-content h2{
  font-size:1.6rem;
  margin-bottom:.45rem;
}
body:has(.article-wrap) .newsletter-content p{
  color:var(--stone);
  max-width:56ch;
}
body:has(.article-wrap) .newsletter-form{
  margin-top:1rem;
  display:flex;
  gap:.65rem;
}
body:has(.article-wrap) .newsletter-form input{
  flex:1;
  min-height:48px;
  border-radius:14px;
  border:1px solid var(--sand-200);
  background:var(--white);
}
body:has(.article-wrap) .newsletter-form button{
  min-height:48px;
  border-radius:14px;
  background:var(--teal-700);
}
body:has(.article-wrap) .newsletter-form button:hover{
  background:var(--teal-600);
}

/* Categories */
.cat-filter{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  justify-content:center;
  padding:1.5rem 1.5rem 0;
  max-width:1280px;
  margin:0 auto;
}
.cat-btn{
  padding:.4rem .9rem;
  border:1px solid var(--sand-200);
  border-radius:100px;
  background:var(--white);
  font-family:inherit;
  font-size:.78rem;
  cursor:pointer;
  color:var(--charcoal-soft);
  transition:all var(--transition);
}
.cat-btn:hover{
  border-color:var(--teal-500);
  color:var(--teal-700);
}
.cat-btn.active{
  background:var(--teal-700);
  color:var(--cream);
  border-color:var(--teal-700);
}
body.blog-home .cat-filter{
  justify-content:flex-start;
  flex-wrap:nowrap;
  overflow-x:auto;
  padding-top:1.2rem;
  scrollbar-width:none;
}
body.blog-home .cat-filter::-webkit-scrollbar{
  display:none;
}
body.blog-home .cat-btn{
  white-space:nowrap;
  background:rgba(255,255,255,.9);
  box-shadow:0 1px 0 rgba(255,255,255,.65);
}
body.blog-home .cat-btn.active{
  background:var(--charcoal);
  border-color:var(--charcoal);
  color:var(--white);
}

body.blog-home .blog-section-head{
  max-width:1280px;
  margin:0 auto;
  padding:1.25rem 1.5rem .25rem;
}
body.blog-home .blog-section-head p{
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--stone);
  margin-bottom:.35rem;
}
body.blog-home .blog-section-head h2{
  font-size:clamp(1.4rem,2vw,2rem);
  margin:0;
}

/* Blog cards */
.blog-grid{
  max-width:1280px;
  margin:0 auto;
  padding:1.5rem 1.5rem 2.5rem;
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:1.25rem;
  align-items:stretch;
}
.blog-card{
  background:var(--white);
  border-radius:22px;
  overflow:hidden;
  box-shadow:none;
  border:1px solid var(--sand-200);
  transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition);
  grid-column:span 4;
  display:flex;
  flex-direction:column;
}
.blog-card:hover{
  box-shadow:0 14px 34px rgba(10,92,92,0.08);
  transform:translateY(-2px);
  border-color:rgba(10,92,92,0.16);
}
.blog-card-img{
  width:100%;
  height:200px;
  object-fit:cover;
  display:block;
}
.blog-card-body{
  padding:1.15rem 1.15rem 1.2rem;
  display:flex;
  flex-direction:column;
  flex:1;
}
.blog-card-cat{
  display:inline-flex;
  align-items:center;
  width:fit-content;
  min-height:30px;
  padding:.25rem .55rem;
  font-size:.68rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--stone);
  border:1px solid var(--sand-200);
  border-radius:999px;
  background:var(--sand-50);
  margin-bottom:.55rem;
}
.blog-card-title{
  font-size:1.15rem;
  font-weight:500;
  margin:0 0 .5rem;
  line-height:1.3;
}
.blog-card-title a{color:var(--charcoal)}
.blog-card-title a:hover{color:var(--teal-700)}
.blog-card-excerpt{
  font-size:.9rem;
  color:var(--charcoal-soft);
  line-height:1.65;
  margin-bottom:.75rem;
}
.blog-card-meta{
  font-size:.78rem;
  color:var(--stone);
  display:flex;
  flex-wrap:wrap;
  gap:.75rem 1rem;
}
.blog-card-meta svg{
  vertical-align:middle;
  margin-right:3px;
}
.read-more{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  font-size:.82rem;
  font-weight:600;
  color:var(--teal-700);
  margin-top:.6rem;
}
.read-more:hover{color:var(--teal-500)}
body.blog-home .blog-card-featured{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);
  min-height:420px;
}
body.blog-home .blog-card-featured .blog-card-img{
  height:100%;
  min-height:420px;
  border-right:1px solid var(--sand-200);
}
body.blog-home .blog-card-featured .blog-card-body{
  padding:1.65rem 1.5rem;
  justify-content:center;
}
body.blog-home .blog-card-featured .blog-card-title{
  font-size:clamp(1.55rem,2.4vw,2.35rem);
  margin-bottom:.7rem;
}
body.blog-home .blog-card-featured .blog-card-excerpt{
  font-size:1rem;
  max-width:44ch;
}
body.blog-home .blog-card:nth-of-type(2),
body.blog-home .blog-card:nth-of-type(3){
  grid-column:span 6;
}

/* Footer */
.site-footer{
  background:var(--teal-900);
  color:rgba(252,249,245,0.5);
  padding:2.5rem 0;
  text-align:center;
  font-size:.82rem;
  margin-top:3rem;
}
.site-footer a{
  color:var(--gold);
}
.site-footer a:hover{
  color:var(--gold-light);
}

/* Mobile */
@media(max-width:1024px){
  body:has(.article-wrap) .article-wrap{
    grid-template-columns:1fr;
  }
  body:has(.article-wrap) .article-sidebar{
    position:static;
  }
  body.blog-home .blog-hero-shell{
    grid-template-columns:1fr;
  }
  body.blog-home .blog-card-featured{
    grid-template-columns:1fr;
  }
  body.blog-home .blog-card-featured .blog-card-img{
    min-height:300px;
    border-right:none;
    border-bottom:1px solid var(--sand-200);
  }
  body.blog-home .blog-card:nth-of-type(2),
  body.blog-home .blog-card:nth-of-type(3){
    grid-column:span 4;
  }
}
@media(max-width:768px){
  .site-header{
    padding:0 1rem;
    padding-top:env(safe-area-inset-top,0px);
  }
  .main-nav,
  .header-actions .header-btn-ghost,
  .header-actions .lang-currency{
    display:none;
  }
  .main-nav.open{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--charcoal);
    padding:.5rem 1rem;
    gap:.25rem;
  }
  .main-nav.open a{
    padding:.65rem .75rem;
    min-height:44px;
    display:flex;
    align-items:center;
    color:rgba(252,249,245,0.85);
  }
  .main-nav.open a:hover{
    color:var(--gold);
    background:rgba(255,255,255,0.05);
  }
  .page-hdr{
    padding:6rem 1rem 2rem;
  }
  .page-hdr h1{
    font-size:1.8rem;
  }
  body.blog-home .page-hdr{
    padding:6.8rem 1rem 1.25rem;
  }
  body.blog-home .page-hdr h1{
    max-width:none;
    font-size:clamp(2.4rem,14vw,3.4rem);
  }
  body.blog-home .page-hdr p{
    font-size:.98rem;
  }
  body.blog-home .blog-section-head{
    padding:1rem 1rem 0;
  }
  body.blog-home .blog-grid{
    padding:1rem 1rem 2rem;
    grid-template-columns:1fr;
  }
  body.blog-home .blog-card,
  body.blog-home .blog-card:nth-of-type(2),
  body.blog-home .blog-card:nth-of-type(3){
    grid-column:auto;
  }
  body.blog-home .blog-card-featured .blog-card-img{
    min-height:240px;
  }
  body:has(.article-wrap) .page-hdr{
    padding:6.6rem 1rem 2.2rem;
  }
  body:has(.article-wrap) .page-hdr h1{
    font-size:2rem;
  }
  body:has(.article-wrap) .article-wrap{
    padding:0 1rem 2.5rem;
    transform:none;
  }
  body:has(.article-wrap) article.article-content > .article-header,
  body:has(.article-wrap) article.article-content > .article-content{
    padding-left:1.1rem;
    padding-right:1.1rem;
  }
  body:has(.article-wrap) .newsletter-section{
    padding:0 1rem;
  }
  body:has(.article-wrap) .newsletter-content{
    padding:1.25rem;
    border-radius:22px;
  }
  body:has(.article-wrap) .newsletter-form{
    flex-direction:column;
  }
  .blog-grid{
    padding:1.5rem 1rem;
    grid-template-columns:1fr;
  }
  .newsletter form{
    flex-direction:column;
  }
  .newsletter input{
    width:100%;
  }
  .mobile-menu-btn{
    display:flex;
    align-items:center;
    justify-content:center;
    min-width:44px;
    min-height:44px;
    background:none;
    border:none;
    color:#FFFCF5;
    cursor:pointer;
  }
}
@media(min-width:769px){
  .mobile-menu-btn{display:none}
}
