/* idmly — shared article/guide stylesheet. Mirrors the pillar page exactly. */
:root{
  --bg:oklch(99% 0.002 95); --surface:oklch(97.2% 0.002 95);
  --ink:oklch(22% 0 0); --ink-2:oklch(38% 0 0); --muted:oklch(52% 0 0);
  --faint:oklch(70% 0 0); --line:oklch(91% 0.002 95); --line-2:oklch(84% 0 0);
  --sans:"Geist",-apple-system,BlinkMacSystemFont,sans-serif;
  --mono:"Geist Mono",ui-monospace,monospace;
  --mx:clamp(22px,6vw,96px); --maxw:1180px; --readw:760px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg); color:var(--ink); font-family:var(--sans);
  line-height:1.5; -webkit-font-smoothing:antialiased; overflow-x:hidden;
  font-feature-settings:"ss01","cv01";}
::selection{background:var(--ink); color:var(--bg)}
a{color:inherit}
.kicker{font-family:var(--mono); font-size:11.5px; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase; color:var(--muted)}

.top{display:flex; justify-content:space-between; align-items:center;
  padding:24px var(--mx); border-bottom:1px solid var(--line)}
.brand img{height:18px; width:auto; display:block}
.brand a{text-decoration:none}
.meta-row{display:flex; align-items:center; gap:16px}
.nav-activate{font-size:13px; color:var(--muted); text-decoration:none}
.nav-activate:hover{color:var(--ink); text-decoration:underline; text-underline-offset:3px}
.top .meta{font-family:var(--mono); font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--faint)}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 var(--mx)}
.crumb{font-family:var(--mono); font-size:11px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--faint); padding:30px var(--mx) 0}
.crumb a{color:var(--muted); text-decoration:none}
.crumb a:hover{color:var(--ink)}

.head{padding:clamp(34px,5vw,56px) var(--mx) clamp(20px,3vw,32px)}
.head .inner{max-width:var(--maxw); margin:0 auto}
h1{font-weight:600; font-size:clamp(34px,5.4vw,64px); line-height:1.04;
  letter-spacing:-.035em; max-width:18ch}
.updated{font-family:var(--mono); font-size:11.5px; letter-spacing:.06em;
  color:var(--faint); margin-top:22px}

.body{padding:clamp(8px,2vw,20px) var(--mx) clamp(60px,8vw,100px)}
.body .col{max-width:var(--readw); margin:0 auto}

/* the answer object — the bit AI lifts */
.answer{border-left:2px solid var(--ink); background:var(--surface);
  padding:22px 24px; border-radius:0 11px 11px 0; margin:6px 0 14px}
.answer p{font-size:18.5px; line-height:1.55; color:var(--ink-2)}
.answer p b{color:var(--ink); font-weight:600}
.answer p+p{margin-top:12px}

h2{font-weight:600; font-size:clamp(24px,3.2vw,34px); line-height:1.14;
  letter-spacing:-.025em; max-width:22ch; margin:clamp(44px,5vw,64px) 0 0}
h3{font-weight:550; font-size:clamp(18px,2.1vw,21px); letter-spacing:-.02em; margin:30px 0 0}
.body p{font-size:17px; line-height:1.62; color:var(--ink-2); margin-top:16px; max-width:66ch}
.body p b{color:var(--ink); font-weight:600}
.body p a{color:var(--ink); text-decoration:underline; text-underline-offset:3px}
.body code{font-family:var(--mono); font-size:.84em; background:var(--surface);
  border:1px solid var(--line); padding:1px 6px; border-radius:5px; color:var(--ink)}
.lead{font-size:19px!important; color:var(--ink-2)}

/* comparison table — the most-cited format */
.cmp-wrap{margin-top:26px; overflow-x:auto; border:1px solid var(--line-2); border-radius:12px}
table.cmp{width:100%; border-collapse:collapse; font-size:14.5px; min-width:640px}
table.cmp caption{text-align:left; font-family:var(--mono); font-size:10.5px;
  letter-spacing:.13em; text-transform:uppercase; color:var(--muted);
  padding:14px 16px 0; caption-side:top}
table.cmp th,table.cmp td{text-align:left; padding:13px 16px; vertical-align:top;
  border-bottom:1px solid var(--line)}
table.cmp thead th{font-family:var(--mono); font-size:10.5px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--muted); font-weight:500; border-bottom:1px solid var(--ink)}
table.cmp tbody th{font-weight:600; color:var(--ink); white-space:nowrap}
table.cmp td{color:var(--ink-2)}
table.cmp tr.win th,table.cmp tr.win td{background:var(--surface)}
table.cmp tr.win th{color:var(--ink)}
table.cmp tr:last-child td,table.cmp tr:last-child th{border-bottom:none}
.yes{color:var(--ink); font-weight:600}
.no{color:var(--muted)}

/* stat strip */
.stat{margin-top:30px; display:flex; gap:clamp(20px,4vw,46px); flex-wrap:wrap;
  padding:24px 26px; background:var(--surface); border:1px solid var(--line-2); border-radius:12px}
.stat .s-item{flex:1 1 150px}
.stat .s-big{font-weight:600; font-size:clamp(28px,3.6vw,38px); letter-spacing:-.03em; line-height:1}
.stat .s-lab{font-size:13.5px; color:var(--muted); margin-top:8px; line-height:1.45}

ul.ticks{margin:18px 0 0; padding:0; list-style:none; border-top:1px solid var(--ink)}
ul.ticks li{display:flex; gap:13px; padding:14px 0; border-bottom:1px solid var(--line);
  font-size:16px; color:var(--ink-2)}
ul.ticks li .mk{color:var(--ink); font-weight:600; flex:none}

ol.steps2{margin:22px 0 0; padding:0; list-style:none; counter-reset:s; border-top:1px solid var(--ink)}
ol.steps2 li{padding:20px 0 20px 46px; border-bottom:1px solid var(--line); position:relative; counter-increment:s}
ol.steps2 li::before{content:counter(s,decimal-leading-zero); position:absolute; left:0; top:22px;
  font-family:var(--mono); font-size:12px; color:var(--muted)}
ol.steps2 li b{display:block; font-weight:600; font-size:18px; color:var(--ink); letter-spacing:-.01em; margin-bottom:5px}
ol.steps2 li span{font-size:15.5px; color:var(--ink-2); line-height:1.55}

.faq{margin-top:22px; border-top:1px solid var(--ink)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer; list-style:none; display:flex; justify-content:space-between;
  align-items:baseline; gap:20px; padding:19px 0; font-weight:550; font-size:17px; letter-spacing:-.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; font-family:var(--mono); color:var(--faint); font-size:16px; flex:none}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 0 22px; color:var(--ink-2); font-size:15.5px; max-width:66ch; line-height:1.62}
.faq .a a{color:var(--ink); text-underline-offset:3px}

/* related guides */
.related{margin-top:clamp(40px,5vw,56px); border-top:1px solid var(--ink); padding-top:8px}
.related h2{margin-top:24px}
.related .links{margin-top:18px; display:grid; gap:0}
.related a{display:flex; justify-content:space-between; align-items:baseline; gap:16px;
  padding:16px 0; border-bottom:1px solid var(--line); text-decoration:none; color:var(--ink-2);
  font-size:16px; transition:color .15s}
.related a:hover{color:var(--ink)}
.related a .go{font-family:var(--mono); color:var(--faint); flex:none}

.cta{margin-top:clamp(40px,5vw,60px); padding:30px 30px 28px; background:var(--ink);
  color:var(--bg); border-radius:14px}
.cta h2{color:var(--bg); margin:0; max-width:24ch; font-size:clamp(22px,2.8vw,30px)}
.cta p{color:oklch(74% 0 0); margin-top:12px; font-size:16px; max-width:54ch}
.cta .row{display:flex; gap:10px; flex-wrap:wrap; margin-top:22px}
.cta a.primary{display:inline-block; padding:13px 24px; font-size:15px; font-weight:500;
  color:var(--ink); background:var(--bg); border-radius:9px; text-decoration:none}
.cta a.ghost{padding:13px 22px; font-size:15px; font-weight:500; color:var(--bg);
  background:transparent; border:1px solid oklch(48% 0 0); border-radius:9px; text-decoration:none}
.cta a.ghost:hover{border-color:var(--bg)}

footer{padding:30px var(--mx); display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:10px; font-family:var(--mono); font-size:11px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--faint); border-top:1px solid var(--line); margin-top:10px}
footer .links{display:flex; gap:18px; flex-wrap:wrap}
footer a{text-decoration:none} footer a:hover{text-decoration:underline; color:var(--muted)}
