/* === Mastel theme — consulting style === */
* { margin: 0; padding: 0; box-sizing: border-box; }

html {
  --viewport-height: 100vh;
  --background-height: 100vh;
}

body {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: #000;
  background-color: #FCF9F8;
}

/* Background decorative pattern — exact match with consulting page */
body::before {
  content: '';
  display: block;
  height: var(--background-height);
  left: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  transform: scale(1);
  width: 100vw;
  z-index: 0;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%22600%22%20height%3D%22347%22%20viewBox%3D%220%200%20600%20347%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%20%3Cstyle%20type%3D%22text%2Fcss%22%3E%20polygon%20%7B%20fill%3A%20%23F7F0E6%3B%20transform%3A%20scale%28146%25%29%3B%20%7D%20%3C%2Fstyle%3E%20%3Cpolygon%20points%3D%220.0%2C0.0%2020.0%2C0.0%2030.0%2C17.3205%2020.0%2C34.641%200.0%2C34.641%20-10.0%2C17.3205%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2230.0%2C-17.3205%2050.0%2C-17.3205%2060.0%2C0.0%2050.0%2C17.3205%2030.0%2C17.3205%2020.0%2C0.0%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2260.0%2C-17.3205%2080.0%2C-17.3205%2090.0%2C0.0%2080.0%2C17.3205%2060.0%2C17.3205%2050.0%2C0.0%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2290.0%2C-17.3205%20110.0%2C-17.3205%20120.0%2C0.0%20110.0%2C17.3205%2090.0%2C17.3205%2080.0%2C0.0%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22120.0%2C-17.3205%20140.0%2C-17.3205%20150.0%2C0.0%20140.0%2C17.3205%20120.0%2C17.3205%20110.0%2C0.0%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22150.0%2C-17.3205%20170.0%2C-17.3205%20180.0%2C0.0%20170.0%2C17.3205%20150.0%2C17.3205%20140.0%2C0.0%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%220.0%2C34.641%2020.0%2C34.641%2030.0%2C52.0%2020.0%2C69.282%200.0%2C69.282%20-10.0%2C52.0%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2230.0%2C17.3205%2050.0%2C17.3205%2060.0%2C34.641%2050.0%2C52.0%2030.0%2C52.0%2020.0%2C34.641%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2260.0%2C17.3205%2080.0%2C17.3205%2090.0%2C34.641%2080.0%2C52.0%2060.0%2C52.0%2050.0%2C34.641%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2290.0%2C17.3205%20110.0%2C17.3205%20120.0%2C34.641%20110.0%2C52.0%2090.0%2C52.0%2080.0%2C34.641%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22120.0%2C17.3205%20140.0%2C17.3205%20150.0%2C34.641%20140.0%2C52.0%20120.0%2C52.0%20110.0%2C34.641%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22150.0%2C17.3205%20170.0%2C17.3205%20180.0%2C34.641%20170.0%2C52.0%20150.0%2C52.0%20140.0%2C34.641%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%220.0%2C69.282%2020.0%2C69.282%2030.0%2C86.603%2020.0%2C103.923%200.0%2C103.923%20-10.0%2C86.603%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2230.0%2C52.0%2050.0%2C52.0%2060.0%2C69.282%2050.0%2C86.603%2030.0%2C86.603%2020.0%2C69.282%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2260.0%2C52.0%2080.0%2C52.0%2090.0%2C69.282%2080.0%2C86.603%2060.0%2C86.603%2050.0%2C69.282%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2290.0%2C52.0%20110.0%2C52.0%20120.0%2C69.282%20110.0%2C86.603%2090.0%2C86.603%2080.0%2C69.282%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22120.0%2C52.0%20140.0%2C52.0%20150.0%2C69.282%20140.0%2C86.603%20120.0%2C86.603%20110.0%2C69.282%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22150.0%2C52.0%20170.0%2C52.0%20180.0%2C69.282%20170.0%2C86.603%20150.0%2C86.603%20140.0%2C69.282%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%220.0%2C103.923%2020.0%2C103.923%2030.0%2C121.244%2020.0%2C138.564%200.0%2C138.564%20-10.0%2C121.244%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2230.0%2C86.603%2050.0%2C86.603%2060.0%2C103.923%2050.0%2C121.244%2030.0%2C121.244%2020.0%2C103.923%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2260.0%2C86.603%2080.0%2C86.603%2090.0%2C103.923%2080.0%2C121.244%2060.0%2C121.244%2050.0%2C103.923%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%2290.0%2C86.603%20110.0%2C86.603%20120.0%2C103.923%20110.0%2C121.244%2090.0%2C121.244%2080.0%2C103.923%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22120.0%2C86.603%20140.0%2C86.603%20150.0%2C103.923%20140.0%2C121.244%20120.0%2C121.244%20110.0%2C103.923%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3Cpolygon%20points%3D%22150.0%2C86.603%20170.0%2C86.603%20180.0%2C103.923%20170.0%2C121.244%20150.0%2C121.244%20140.0%2C103.923%22%20fill-opacity%3D%220%22%3E%20%3Canimate%20attributeName%3D%22fill-opacity%22%20dur%3D%2210700ms%22%20repeatCount%3D%22indefinite%22%20values%3D%220%3B0%3B0%3B0.4%3B0.8%3B0%3B0%3B0%3B0.5%3B0.9%3B1%3B0.9%3B0.5%3B0%22%20%2F%3E%20%3C%2Fpolygon%3E%20%3C%2Fsvg%3E');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

#wrapper {
  width: 100%;
  position: relative;
}

#main {
  position: relative;
  z-index: 2;
}

#main > .inner {
  width: 100%;
  max-width: 100%;
}

.page-width {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 24px;
}

.page-content {
  padding: 40px 0 80px;
}

/* Header */
.site-header {
  background: transparent;
  padding: 15px 0;
}

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

.site-logo {
  font-family: "WindSong", Georgia, "Times New Roman", serif;
  font-size: 32px;
  font-weight: 500;
  color: #00664f;
  text-decoration: none;
}

.header-nav ul {
  list-style: none;
  display: flex;
  gap: 24px;
}

.header-nav a {
  color: #000;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.5px;
}

.header-nav a:hover {
  color: #00664f;
}

/* Section header */
.section-header {
  margin-bottom: 30px;
}

.section-header__title {
  font-size: 28px;
  font-weight: 700;
  color: #000;
  line-height: 1.2;
  font-family: "Work Sans", sans-serif;
}

.section-header__description {
  color: #666;
  margin-top: 6px;
  font-size: 15px;
}

/* Breadcrumb */
.breadcrumb {
  margin-bottom: 20px;
}

.breadcrumb a {
  color: #00664f;
  text-decoration: none;
  font-size: 14px;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

/* Blog sections */
.blog-section {
  margin-bottom: 48px;
}

.blog-section:last-child {
  margin-bottom: 0;
}

.section-title {
  font-size: 13px;
  font-weight: 600;
  color: #888;
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: 2px;
  position: relative;
}

/* Section tabs */
.section-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 32px;
  border-bottom: 1px solid #e8e8e8;
  padding-bottom: 0;
}

.tab {
  background: none;
  border: none;
  padding: 10px 20px 10px;
  font-size: 14px;
  font-weight: 500;
  color: #888;
  cursor: pointer;
  position: relative;
  letter-spacing: 0.5px;
  transition: color 0.2s;
}

.tab:hover {
  color: #444;
}

.tab::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: transparent;
  transition: background 0.2s;
}

.tab--active {
  color: #000;
}

.tab--active::after {
  background: #00664f;
}

.tab-count {
  display: inline-block;
  background: #f0f0f0;
  color: #888;
  font-size: 11px;
  font-weight: 600;
  padding: 1px 7px;
  border-radius: 10px;
  margin-left: 6px;
  vertical-align: middle;
}

.tab--active .tab-count {
  background: #00664f;
  color: #fff;
}

/* Tab content panels */
.section-content {
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.section-content--active {
  display: block;
  opacity: 1;
}

/* Card grid */
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 10px;
  overflow: hidden;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1);
}

.card__image-wrap {
  position: relative;
  overflow: hidden;
  background: #f4f4f4;
}

.card__image-wrap::before {
  content: "";
  display: block;
  padding-bottom: 100%;
}

.card__image {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-color: #e8e8e8;
  transition: transform 0.5s ease-in-out;
}

.card:hover .card__image {
  transform: rotate(-2deg) scale(1.08);
}

.card__content {
  padding: 18px 0 4px;
}

.card__title {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.35;
  color: #000;
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card__date {
  font-size: 12px;
  color: #999;
}

/* Pagination */
.pagination {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid #e8e8e8;
}

.page-btn {
  background: none;
  border: 1px solid #e0e0e0;
  min-width: 36px;
  height: 36px;
  padding: 0 8px;
  font-size: 14px;
  color: #555;
  cursor: pointer;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
}

.page-btn:hover {
  border-color: #00664f;
  color: #00664f;
}

.page-btn--active {
  background: #00664f;
  border-color: #00664f;
  color: #fff;
  font-weight: 600;
}

.page-btn--active:hover {
  background: #00513f;
  border-color: #00513f;
  color: #fff;
}

.blog-count {
  color: #999;
  font-size: 13px;
  margin-top: 36px;
  text-align: center;
}

/* Article page */
.article__content {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 20px;
}

.article__date {
  font-size: 13px;
  color: #999;
  margin-bottom: 6px;
}

.article__date a {
  color: #00664f;
  text-decoration: none;
}

.article__date a:hover {
  text-decoration: underline;
}

.article__body {
  font-size: 17px;
  line-height: 1.8;
  color: #2a2a2a;
}

.article__body img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 32px auto;
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}

.article__body h1,
.article__body h2,
.article__body h3,
.article__body h4 {
  color: #000;
  margin: 36px 0 12px;
  line-height: 1.3;
  font-family: "Work Sans", sans-serif;
  font-weight: 600;
}

.article__body h1 { font-size: 26px; letter-spacing: -0.3px; }
.article__body h2 { font-size: 22px; letter-spacing: -0.2px; }
.article__body h3 { font-size: 18px; }
.article__body h4 { font-size: 16px; }

.article__body p {
  margin-bottom: 20px;
}

.article__body p:first-of-type {
  font-size: 18px;
  line-height: 1.85;
  color: #444;
}

.article__body ul,
.article__body ol {
  margin-bottom: 20px;
  padding-left: 28px;
}

.article__body li {
  margin-bottom: 8px;
  line-height: 1.7;
}

.article__body blockquote {
  border-left: none;
  padding: 24px 28px;
  margin: 32px 0;
  color: #444;
  background: #F7F4F0;
  border-radius: 12px;
  font-style: italic;
  font-size: 18px;
  line-height: 1.7;
  position: relative;
}

.article__body blockquote::before {
  content: '"';
  font-family: "WindSong", serif;
  font-size: 64px;
  line-height: 1;
  color: #00664f;
  position: absolute;
  top: 8px;
  left: 16px;
  opacity: 0.3;
}

.article__body blockquote p {
  margin-bottom: 0;
}

.article__body a {
  color: #00664f;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.article__body a:hover {
  color: #004d3b;
}

.article__body table {
  width: 100%;
  border-collapse: collapse;
  margin: 28px 0;
  font-size: 15px;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.article__body th {
  background: #00664f;
  color: #fff;
  font-weight: 600;
  text-align: left;
}

.article__body td,
.article__body th {
  padding: 12px 16px;
  border: 1px solid #e0ddd9;
}

.article__body tr:nth-child(even) {
  background: #F7F4F0;
}

.article__body iframe {
  max-width: 100%;
  margin: 28px 0;
  border-radius: 12px;
}

/* Highlight container — key info boxes */
.article__body .container-hl {
  background: linear-gradient(135deg, #F7F4F0 0%, #F0EAE4 100%);
  border-radius: 16px;
  padding: 32px 36px;
  margin: 36px 0;
  border: 1px solid #e8e0d8;
  position: relative;
}

.article__body .container-hl::before {
  content: '✦';
  font-size: 24px;
  color: #00664f;
  position: absolute;
  top: 16px;
  right: 20px;
  opacity: 0.4;
}

.article__body .main-hl {
  font-size: 16px;
  line-height: 1.7;
}

.article__body .main-hl p {
  margin-bottom: 16px;
}

.article__body .main-hl p:first-of-type {
  font-size: 16px;
  color: #2a2a2a;
}

.article__body .main-hl strong {
  color: #00664f;
}

.article__body .list-hl {
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
}

.article__body .list-hl li {
  padding: 10px 16px 10px 36px;
  margin-bottom: 8px;
  background: rgba(255,255,255,0.7);
  border-radius: 10px;
  position: relative;
  line-height: 1.6;
  font-size: 15px;
}

.article__body .list-hl li::before {
  content: '▸';
  color: #00664f;
  font-weight: 700;
  position: absolute;
  left: 14px;
}

.article__body .list-hl li strong {
  color: #00664f;
}

/* Citation text */
.article__body .citation-text {
  font-size: 13px;
  line-height: 1.6;
  color: #888;
  padding: 8px 16px 8px 20px;
  margin: 4px 0;
  border-left: 2px solid #ccc;
}

.article__body .citation-text a {
  font-size: 13px;
  word-break: break-all;
}

/* Podcast notes structure */
.article__body .syno-o-doc-pm-page-content {
  background: #FAF8F6;
  border-radius: 12px;
  padding: 24px;
  margin: 28px 0;
  border: 1px solid #eee8e2;
}

.article__body .syno-o-doc-pm-page-content-container {
  font-size: 15px;
  line-height: 1.7;
}

.article__body .syno-o-doc-pm-paragraph {
  margin-bottom: 12px;
}

/* Podcast transcription styling */
.article__body .syno-o-doc-pm-mark-link a {
  color: #00664f;
}

/* Podcast notes headings inside syno */
.article__body .syno-o-doc-pm-page-content h4 {
  font-size: 15px;
  color: #00664f;
  margin-top: 20px;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Column layout from original blog */
.article__body .layoutArea {
  margin: 28px 0;
}

.article__body .column {
  margin-bottom: 16px;
}

/* Highlight boxes for episode titles etc */
.article__body .articleTitle {
  font-family: "Work Sans", sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: #00664f;
  margin: 24px 0 12px;
}

.article__body .author {
  font-size: 14px;
  color: #888;
  font-style: italic;
}

/* Separator for podcast show notes */
.article__body .article__body p:has(strong:only-child) {
  margin: 28px 0 12px;
  padding-top: 20px;
  border-top: 1px solid #eee8e2;
}

/* Footer */
.site-footer {
  border-top: 1px solid #e8e8e8;
  padding: 24px 0;
  text-align: center;
  color: #999;
  font-size: 13px;
}

/* Responsive */
@media (max-width: 768px) {
  .page-width { padding: 0 24px; }
  .page-content { padding: 24px 0 60px; }
  .section-header__title { font-size: 22px; }
  .section-header { margin-bottom: 20px; }
  .section-tabs { margin-bottom: 20px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .tab { padding: 10px 14px 10px; font-size: 13px; white-space: nowrap; min-height: 44px; }
  .card-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .card__title { font-size: 14px; }
  .card__content { padding: 10px 0 2px; }
  .header-layout { gap: 6px; }
  .site-logo { font-size: 22px; }
  .header-nav ul { gap: 12px; }
  .header-nav a { font-size: 12px; }
  .pagination { margin-top: 24px; padding-top: 16px; gap: 6px; }
  .page-btn { min-width: 36px; height: 36px; font-size: 13px; }
  .article__content { padding: 0 16px; }
  .article__body { font-size: 16px; line-height: 1.7; }
  .article__body h1 { font-size: 22px; }
  .article__body h2 { font-size: 20px; }
  .article__body h3 { font-size: 17px; }
  .article__body blockquote { font-size: 16px; padding: 20px 20px; }
  .article__body p:first-of-type { font-size: 17px; }
  .article__body p:first-of-type::first-letter { font-size: 44px; }
  .article__body .container-hl { padding: 24px 20px; }
}

@media (max-width: 480px) {
  .page-width { padding: 0 24px; }
  .card-grid { grid-template-columns: 1fr; gap: 16px; }
  .card__image-wrap::before { padding-bottom: 56.25%; }
  .pagination { gap: 4px; }
  .page-btn { min-width: 36px; height: 36px; font-size: 12px; padding: 0 4px; }
  .tab { padding: 8px 10px 8px; font-size: 12px; min-height: 40px; }
  .tab-count { font-size: 10px; padding: 0 5px; }
  .section-header__title { font-size: 20px; }
  .card__title { font-size: 15px; }
  .site-logo { font-size: 20px; }
  .header-nav a { font-size: 11px; letter-spacing: 0.5px; }
  .header-nav ul { gap: 10px; }
  .article__content { padding: 0 12px; }
}

@media (max-width: 360px) {
  .page-width { padding: 0 16px; }
  .page-content { padding: 16px 0 40px; }
  .card-grid { gap: 12px; }
  .card__title { font-size: 14px; }
  .header-nav a { font-size: 10px; }
  .header-nav ul { gap: 6px; }
  .article__content { padding: 0 8px; }
}
