 /* ==========================================================================
   SurgeonsLab Blogs — shared stylesheet
   Namespace: every selector is prefixed sl-blog- so this can never collide
   with, or be affected by, the legacy site CSS (style.css).
   Powers both /blogs (overview/index) and /blogs/{slug} (single post).
   Brand tokens reused from the main site: Univia Pro / Roboto, #16BBBB cyan,
   #030100 ink, #404040 body grey — kept consistent on purpose.
   ========================================================================== */

:root{
  --sl-blog-ink:        #030100;
  --sl-blog-ink-soft:    #16202b;
  --sl-blog-cyan:        #16BBBB;
  --sl-blog-cyan-deep:    #0d8a8a;
  --sl-blog-cyan-tint:    #EFFAFB;
  --sl-blog-red:         #ED2726;
  --sl-blog-paper:       #FFFFFF;
  --sl-blog-paper-soft:   #F7F5F0;
  --sl-blog-line:        #E6E6E6;
  --sl-blog-text:        #404040;
  --sl-blog-text-soft:    #757575;
  --sl-blog-font-display: "Univia Pro", "Roboto", "Helvetica Neue", Arial, sans-serif;
  --sl-blog-font-body:    "Univia Pro", "Roboto", "Helvetica Neue", Arial, sans-serif;
  --sl-blog-radius:       12px;
  --sl-blog-radius-lg:    20px;
  --sl-blog-container:    1180px;
}

.sl-blog *{ box-sizing: border-box; }
.sl-blog{
  font-family: var(--sl-blog-font-body);
  color: var(--sl-blog-text);
  background: var(--sl-blog-paper);
  line-height: 1.65;
}
.sl-blog a{ text-decoration: none; transition: 0.25s ease; }
.sl-blog img{ max-width: 100%; display: block; }

.sl-blog-container{
  max-width: var(--sl-blog-container);
  margin: 0 auto;
  padding: 0 24px;
}
.sl-blog-container--narrow{ max-width: 860px; }

/* ---------------------------------------------------------------------- *
 * Shared: eyebrow / tag chip / section spacing
 * ---------------------------------------------------------------------- */
.sl-blog-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--sl-blog-font-display);
  font-size: 12.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  color: var(--sl-blog-cyan-deep);
}
.sl-blog-eyebrow::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background: var(--sl-blog-cyan);
}
.sl-blog-section{ padding: 72px 0; }
.sl-blog-section--tight{ padding: 40px 0; }
.sl-blog-section--soft{ background: var(--sl-blog-paper-soft); }

.sl-blog-chip{
  display:inline-flex; align-items:center;
  padding: 6px 14px; border-radius: 100px;
  background: var(--sl-blog-cyan-tint); color: var(--sl-blog-cyan-deep);
  font-family: var(--sl-blog-font-display); font-size: 12.5px; font-weight: 600;
}

/* ==========================================================================
   OVERVIEW / INDEX PAGE  (/blogs)
   ========================================================================== */

.sl-blog-hero{
  background: var(--sl-blog-ink);
  color: #fff;
  padding: 96px 0 64px;
  text-align: center;
}
.sl-blog-hero h1{
  font-family: var(--sl-blog-font-display);
  font-weight: 700;
  font-size: clamp(34px, 5vw, 52px);
  line-height: 1.12;
  margin: 0 0 16px;
}
.sl-blog-hero h1 span{ color: var(--sl-blog-cyan); }
.sl-blog-hero p{
  max-width: 560px; margin: 0 auto;
  color: #C8CDD2; font-size: 17px;
}

/* filter bar */
.sl-blog-filters{
  display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
  margin-top: 32px;
}
.sl-blog-filter{
  font-family: var(--sl-blog-font-display);
  font-size: 13.5px; font-weight: 600;
  padding: 9px 18px; border-radius: 100px;
  background: rgba(255,255,255,0.06); color: #C8CDD2;
  border: 1px solid rgba(255,255,255,0.12);
  cursor:pointer;
}
.sl-blog-filter.is-active,
.sl-blog-filter:hover{
  background: var(--sl-blog-cyan); color: var(--sl-blog-ink); border-color: var(--sl-blog-cyan);
}

/* grid of post cards */
.sl-blog-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
@media (max-width: 980px){ .sl-blog-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .sl-blog-grid{ grid-template-columns: 1fr; } }

.sl-blog-card{
  display:flex; flex-direction:column;
  border: 1px solid var(--sl-blog-line);
  border-radius: var(--sl-blog-radius);
  overflow: hidden;
  background: var(--sl-blog-paper);
  transition: 0.25s ease;
}
.sl-blog-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 16px 32px rgba(3,1,0,0.08);
  border-color: transparent;
}
.sl-blog-card-img{
  aspect-ratio: 16/10; overflow:hidden; background: var(--sl-blog-ink);
}
.sl-blog-card-img img{ width:100%; height:100%; object-fit:cover; }
.sl-blog-card-body{
  padding: 22px 22px 24px;
  display:flex; flex-direction:column; gap:12px; flex:1;
}
.sl-blog-card-tag{
  font-family: var(--sl-blog-font-display);
  font-size: 11.5px; font-weight: 700; letter-spacing:.05em; text-transform:uppercase;
  color: var(--sl-blog-cyan-deep);
}
.sl-blog-card h3{
  font-family: var(--sl-blog-font-display);
  font-size: 19px; font-weight: 700; line-height:1.35; color: var(--sl-blog-ink);
  margin:0;
}
.sl-blog-card p{
  font-size: 14.5px; color: var(--sl-blog-text-soft); margin:0;
  flex:1;
}
.sl-blog-card-meta{
  display:flex; align-items:center; justify-content:space-between;
  font-size: 12.5px; color: var(--sl-blog-text-soft);
  padding-top: 12px; border-top: 1px solid var(--sl-blog-line);
}
.sl-blog-card-readmore{
  font-family: var(--sl-blog-font-display); font-weight: 700; font-size: 13px;
  color: var(--sl-blog-ink);
}
.sl-blog-card:hover .sl-blog-card-readmore{ color: var(--sl-blog-cyan-deep); }

/* featured post (first/large card) */
.sl-blog-featured{
  display:grid; grid-template-columns: 1.1fr 1fr; gap: 0;
  border: 1px solid var(--sl-blog-line); border-radius: var(--sl-blog-radius-lg);
  overflow:hidden; margin-bottom: 48px;
}
@media (max-width: 780px){ .sl-blog-featured{ grid-template-columns:1fr; } }
.sl-blog-featured-img{ background: var(--sl-blog-ink); min-height: 320px; }
.sl-blog-featured-img img{ width:100%; height:100%; object-fit:cover; }
.sl-blog-featured-body{
  padding: 40px; display:flex; flex-direction:column; gap:16px; justify-content:center;
}
.sl-blog-featured-body h2{
  font-family: var(--sl-blog-font-display); font-size: 28px; font-weight:700; line-height:1.25;
  color: var(--sl-blog-ink); margin:0;
}
.sl-blog-featured-body p{ font-size: 15.5px; color: var(--sl-blog-text-soft); margin:0; }

/* pagination */
.sl-blog-pagination{
  display:flex; justify-content:center; gap:8px; margin-top: 56px;
}
.sl-blog-page-btn{
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  border-radius: 8px; border: 1px solid var(--sl-blog-line);
  font-family: var(--sl-blog-font-display); font-weight:600; font-size:14px;
  color: var(--sl-blog-ink);
}
.sl-blog-page-btn.is-active{ background: var(--sl-blog-ink); color:#fff; border-color: var(--sl-blog-ink); }

/* ==========================================================================
   SINGLE POST PAGE  (/blogs/{slug})
   ========================================================================== */

.sl-blog-post-hero{
  background: var(--sl-blog-ink);
  color: #fff;
  padding: 80px 0 56px;
}
.sl-blog-post-hero-inner{ max-width: 760px; margin: 0 auto; text-align:center; }
.sl-blog-post-hero .sl-blog-eyebrow{ color: var(--sl-blog-cyan); justify-content:center; margin-bottom:18px; }
.sl-blog-post-hero h1{
  font-family: var(--sl-blog-font-display);
  font-weight: 700; font-size: clamp(30px, 4.4vw, 46px); line-height: 1.18;
  margin: 0 0 18px;
}
.sl-blog-post-hero p{ color:#C8CDD2; font-size:17px; max-width: 60ch; margin: 0 auto 28px; }

.sl-blog-post-meta{
  display:flex; align-items:center; justify-content:center; gap:20px;
  font-family: var(--sl-blog-font-display); font-size: 13.5px; color:#9AA4AC;
  border-top: 1px solid rgba(255,255,255,0.12); padding-top: 18px;
}
.sl-blog-post-meta b{ color:#fff; }
.sl-blog-post-meta span{ display:inline-flex; align-items:center; gap:7px; }

/* body layout: article + sidebar */
.sl-blog-post-layout{
  display:grid; grid-template-columns: 1fr 320px; gap: 56px;
}
@media (max-width: 960px){ .sl-blog-post-layout{ grid-template-columns: 1fr; } }

.sl-blog-post-body p{
  font-size: 16.5px;
  color: var(--sl-blog-text);
  margin: 0 0 22px;
  text-align: justify;
}

.sl-blog-post-body p:first-of-type{
  font-family: var(--sl-blog-font-display);
  font-size: 16.5px;
  font-weight: 600;
  color: var(--sl-blog-ink);
  border-left: 3px solid var(--sl-blog-cyan);
  padding-left: 18px;
  text-align: justify;
}

.sl-blog-post-body h2,
.sl-blog-post-body h3{ text-align: left; }
.sl-blog-faq-a{ text-align: justify; }
.sl-blog-post-body h2{
  font-family: var(--sl-blog-font-display); font-size: 27px; font-weight:700;
  color: var(--sl-blog-ink); margin: 40px 0 18px;
}
.sl-blog-post-body h3{
  font-family: var(--sl-blog-font-display); font-size: 20px; font-weight:700;
  color: var(--sl-blog-ink); margin: 0px 0 14px;
}
.sl-blog-post-body ul{
  text-align: justify;
  font-family: var(--sl-blog-font-display);
   margin: 0 0 22px;
    padding-left: 0;
     list-style:none;
     }

.sl-blog-post-body ul li{
  position:relative;
  padding: 10px 0 10px 26px; font-size: 15.5px;
  border-top: 1px solid var(--sl-blog-line);
}
.sl-blog-post-body ul li:first-child{ border-top: none; }
.sl-blog-post-body ul li::before{
  content:""; position:absolute; left:0; top:18px; width:8px; height:8px;
  border-radius:2px; background: var(--sl-blog-cyan);
}
.sl-blog-post-body strong{ color: var(--sl-blog-ink); }

.sl-blog-note{
  font-size: 13.5px; font-style: italic; color: var(--sl-blog-text-soft);
  border-left: 2px solid var(--sl-blog-line); padding-left: 14px; margin: 18px 0 26px;
}

.sl-blog-figure{ margin: 32px 0; }
.sl-blog-figure-frame{
  border-radius: var(--sl-blog-radius); overflow:hidden;
  background: var(--sl-blog-ink); aspect-ratio: 16/9;
}
.sl-blog-figure-frame img{ width:100%; height:100%; object-fit:cover; }
.sl-blog-figure-cap{
  font-size: 12px; color: var(--sl-blog-text-soft); margin-top: 8px;
  line-height: 1.5;
}
.sl-blog-figure-cap b{ color: var(--sl-blog-ink); }

.sl-blog-quote{
  text-align:center; padding: 36px; margin: 36px 0;
  background: var(--sl-blog-cyan-tint); border-radius: var(--sl-blog-radius);
}
.sl-blog-quote p{
  font-family: var(--sl-blog-font-display); font-style: italic; font-size: 19px;
  color: var(--sl-blog-ink); margin: 0 0 10px;
}
.sl-blog-quote-name{
  font-family: var(--sl-blog-font-display);
  font-size: 14px;
  color: var(--sl-blog-cyan-deep);
  font-weight:600;
}

/* numbered pathology-style blocks (only when content is a real sequence) */
.sl-blog-step{
  display:grid; grid-template-columns: 56px 1fr; gap: 20px;
  padding: 30px 0; border-top: 1px solid var(--sl-blog-line);
}
.sl-blog-step:first-of-type{ border-top:none; padding-top:8px; }
.sl-blog-step-num{
  font-family: var(--sl-blog-font-display); font-size: 30px; font-weight:700;
  color: var(--sl-blog-cyan-deep); line-height:1;
}
.sl-blog-step p{ text-align: justify; }
.sl-blog-step h3{ text-align: left; }

/* two-column feature split (e.g. hospitals vs device companies) */
.sl-blog-split{ display:grid; grid-template-columns: 1fr 1fr; gap: 24px; margin: 28px 0; }
@media (max-width: 680px){ .sl-blog-split{ grid-template-columns: 1fr; } }
.sl-blog-split-card{
  border: 1px solid var(--sl-blog-line); border-radius: var(--sl-blog-radius);
  padding: 24px;
}
.sl-blog-split-card h4{
  font-family: var(--sl-blog-font-display); font-size: 13px; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase; color: var(--sl-blog-cyan-deep);
  margin: 0 0 14px;
}
.sl-blog-split-card ul li{ text-align: justify; }

/* CTA block */
.sl-blog-cta{
  background: #effafb;
  color:#fff;
  border-radius: var(--sl-blog-radius-lg);
  padding: 44px;
  margin: 44px 0;
}
.sl-blog-cta h3{
  font-family: var(--sl-blog-font-display);
  font-size: 24px;
  margin: 0 0 12px;
  color:#19bcbd;
}
.sl-blog-cta p{ color:#C8CDD2; font-size:15px; max-width:52ch; margin:0 0 24px; }
.sl-blog-btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family: var(--sl-blog-font-display); font-weight:700; font-size:14.5px;
  padding: 13px 26px; border-radius: 6px;
}
.sl-blog-btn--primary{
  background: var(--sl-blog-cyan);
  color: white;
}

.sl-blog-btn--primary:hover{
  background: var(--sl-blog-red);
  color:#fff;
}

.sl-blog-btn--ghost{
  border: 1px solid #19bcbd;
  color:#19bcbd;
  margin-left:12px;
}

.sl-blog-btn--ghost:hover{
  background: var(--sl-blog-red);
  color:#fff;
}

/* sidebar */
.sl-blog-sidebar{ display:flex; flex-direction:column; gap: 36px; }
.sl-blog-sidebar-box{
  border: 1px solid var(--sl-blog-line); border-radius: var(--sl-blog-radius);
  padding: 22px;
}
.sl-blog-sidebar-box h4{
  font-family: var(--sl-blog-font-display); font-size: 15px; font-weight:700;
  color: var(--sl-blog-ink); margin: 0 0 16px;
}
.sl-blog-toc{
  font-family: var(--sl-blog-font-display);
  display:flex;
  flex-direction:column;
  gap:0;
}

.sl-blog-toc a{
  font-size: 14px;
  color: var(--sl-blog-text);
  padding: 10px 0;
  border-top: 1px solid var(--sl-blog-line);
}

.sl-blog-toc a:first-child{ border-top:none; }
.sl-blog-toc a:hover{ color: var(--sl-blog-cyan-deep); }

.sl-blog-sidebar-cta{
  background: var(--sl-blog-cyan-tint); border-radius: var(--sl-blog-radius); padding: 24px;
}
.sl-blog-sidebar-cta h4{ color: var(--sl-blog-ink); }
.sl-blog-sidebar-cta p{ font-size: 13.5px; color: var(--sl-blog-text-soft); margin: 0 0 16px; }

.sl-blog-share{ display:flex; align-items:center; gap:14px; }

.sl-blog-share span{font-family: var(--sl-blog-font-display); font-size: 13px; color: var(--sl-blog-text-soft); }

.sl-blog-share a{
  width:34px; height:34px; border-radius:50%; border:1px solid var(--sl-blog-line);
  display:flex; align-items:center; justify-content:center;
}
.sl-blog-share a:hover{ background: var(--sl-blog-cyan); border-color: var(--sl-blog-cyan); }

/* related posts strip at bottom of single post */
.sl-blog-related{ margin-top: 24px; }
.sl-blog-related h2{
  font-family: var(--sl-blog-font-display); font-size: 26px; font-weight:700;
  color: var(--sl-blog-ink); text-align:center; margin: 0 0 36px;
}

/* faq */
.sl-blog-faq-item{ border-top: 1px solid var(--sl-blog-line); padding: 22px 0; }
.sl-blog-faq-item:first-child{ border-top: none; }
.sl-blog-faq-q{
  font-family: var(--sl-blog-font-display); font-size: 16.5px; font-weight:700;
  color: var(--sl-blog-ink); margin: 0 0 8px;
}
.sl-blog-faq-a{ font-size: 15px; color: var(--sl-blog-text); margin:0; }

/* responsive nudge for post hero/meta */
@media (max-width: 560px){
  .sl-blog-post-meta{ flex-wrap:wrap; gap:12px; }
  .sl-blog-cta{ padding: 30px 24px; }
}