/* ===== EDITORIAL INFOGRAPHICS ===== */
/* Shared across all articles */

/* --- Comparison Card (two-column) --- */
.ig-compare{margin:44px 0;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02);}
.ig-compare-header{padding:20px 28px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px;}
.ig-compare-header svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5;flex-shrink:0;}
.ig-compare-header h3{font-family:var(--body,Montserrat,sans-serif);font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin:0;}
.ig-compare-grid{display:grid;grid-template-columns:1fr 1fr;min-height:0;}
.ig-compare-col{padding:28px;display:flex;flex-direction:column;gap:14px;}
.ig-compare-col:first-child{border-right:1px solid rgba(255,255,255,.06);}
.ig-compare-col .col-label{font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;display:flex;align-items:center;gap:8px;margin-bottom:4px;}
.ig-compare-col .col-label svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;}
.ig-compare-col .col-item{font-size:14px;line-height:1.55;padding-left:18px;position:relative;}
.ig-compare-col .col-item::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;}
@media(max-width:600px){.ig-compare-grid{grid-template-columns:1fr;}.ig-compare-col:first-child{border-right:none;border-bottom:1px solid rgba(255,255,255,.06);}}

/* --- Stat Cards Row --- */
.ig-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin:44px 0;}
.ig-stat{padding:24px 20px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);text-align:center;transition:transform .2s,border-color .2s;}
.ig-stat:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.18);}
.ig-stat .stat-num{font-family:'Bebas Neue',var(--display,sans-serif);font-size:clamp(32px,5vw,48px);line-height:1;margin-bottom:6px;}
.ig-stat .stat-label{font-size:12px;font-weight:700;color:#9fb4c4;letter-spacing:.04em;}

/* --- Cycle/Flow Diagram --- */
.ig-cycle{margin:44px 0;padding:32px;border-radius:16px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.08);}
.ig-cycle-header{font-family:var(--body,Montserrat,sans-serif);font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:24px;text-align:center;display:flex;align-items:center;justify-content:center;gap:10px;}
.ig-cycle-header svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5;}
.ig-cycle-ring{display:flex;flex-wrap:wrap;justify-content:center;gap:0;position:relative;}
.ig-cycle-step{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;flex:0 0 auto;position:relative;}
.ig-cycle-step .step-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;border:2px solid;transition:transform .2s;}
.ig-cycle-step:hover .step-icon{transform:scale(1.1);}
.ig-cycle-step .step-text{font-size:12px;font-weight:700;text-align:center;max-width:90px;line-height:1.35;}
.ig-cycle-arrow{display:flex;align-items:center;padding:0 4px;color:rgba(255,255,255,.2);font-size:20px;align-self:center;}
@media(max-width:500px){.ig-cycle-ring{gap:6px;}.ig-cycle-step{padding:10px 6px;}.ig-cycle-step .step-icon{width:42px;height:42px;font-size:16px;}}

/* --- Vertical Timeline / Process --- */
.ig-timeline{margin:44px 0;padding:0 0 0 32px;border-left:2px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:0;}
.ig-tl-step{position:relative;padding:24px 0 24px 28px;}
.ig-tl-step::before{content:"";position:absolute;left:-9px;top:30px;width:16px;height:16px;border-radius:50%;border:2px solid;background:var(--navy-dark,#011526);}
.ig-tl-step .tl-num{font-family:'Bebas Neue',var(--display,sans-serif);font-size:36px;line-height:1;margin-bottom:4px;}
.ig-tl-step .tl-title{font-size:16px;font-weight:800;color:#fff;margin-bottom:6px;}
.ig-tl-step .tl-desc{font-size:14px;color:#b8cdd9;line-height:1.6;}
@media(max-width:500px){.ig-timeline{padding-left:20px;}.ig-tl-step{padding-left:20px;}.ig-tl-step .tl-num{font-size:28px;}}

/* --- Pull-Quote Hero Card --- */
.ig-pullquote{margin:54px -20px;padding:48px 36px;border-radius:20px;position:relative;overflow:hidden;text-align:center;}
.ig-pullquote::before{content:"";position:absolute;inset:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.ig-pullquote .pq-mark{font-family:'Bebas Neue',var(--display,sans-serif);font-size:100px;line-height:.7;opacity:.12;margin-bottom:8px;}
.ig-pullquote .pq-text{font-size:clamp(22px,3.5vw,32px);font-weight:700;color:#fff;line-height:1.35;position:relative;z-index:1;max-width:600px;margin:0 auto;font-style:italic;}
.ig-pullquote .pq-attr{font-size:13px;font-weight:700;margin-top:20px;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:8px;}
.ig-pullquote .pq-line{width:24px;height:2px;border-radius:1px;}
@media(max-width:600px){.ig-pullquote{margin:44px -8px;padding:36px 20px;}.ig-pullquote .pq-mark{font-size:70px;}}

/* --- Inline Image Figure --- */
.ig-figure{margin:44px 0;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 40px rgba(0,0,0,.3);}
.ig-figure img{width:100%;aspect-ratio:16/9;object-fit:cover;object-position:center 20%;display:block;}
.ig-figure figcaption{padding:14px 20px;font-size:12px;font-weight:600;color:#9fb4c4;background:rgba(0,0,0,.3);border-top:1px solid rgba(255,255,255,.06);line-height:1.5;}

/* Keep faces in frame on narrow viewports */
@media(max-width:768px){
  .ig-figure img{aspect-ratio:4/3;object-position:center top;}
}
@media(max-width:480px){
  .ig-figure img{aspect-ratio:3/4;object-position:center top;}
}
