:root{
  --text:#1E2530;--soft:#586271;--faint:#8C95A3;--line:#E7E9ED;
  --bg:#FFFFFF;--panel:#F4F7FE;--blue:#2563EB;--blue-deep:#1D4ED8;
  --serif:'IBM Plex Serif',serif;--sans:'IBM Plex Sans',sans-serif;
}
/* self-hosted IBM Plex (latin subset) — no third-party font requests */
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/ibm-plex-sans-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/ibm-plex-sans-500.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/ibm-plex-sans-600.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/ibm-plex-serif-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/ibm-plex-serif-500.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/ibm-plex-serif-600.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Serif';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/ibm-plex-serif-700.woff2') format('woff2')}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:72px;scrollbar-width:thin;scrollbar-color:#cbd2dd transparent}
body{font-family:var(--sans);color:var(--text);background:var(--bg);font-size:16.5px;line-height:1.65}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:2px}
.btn{display:inline-block;text-align:center;font-weight:600;font-size:.92rem;background:var(--blue);color:#fff;border-radius:6px;padding:11px 18px;box-shadow:0 1px 2px rgba(37,99,235,.15);transition:background .15s,transform .15s,box-shadow .15s}
.btn:hover{background:var(--blue-deep);transform:translateY(-1px);box-shadow:0 4px 13px rgba(37,99,235,.26)}
.btn.ghost{background:transparent;color:var(--blue);border:1.5px solid var(--blue)}
.btn.ghost:hover{background:var(--blue);color:#fff}

/* ---------- NAV ---------- */
.nav{background:var(--bg);border-bottom:1px solid var(--line)}
/* slim fixed CTA bar that slides in after the hero scrolls away */
.cta-bar{position:fixed;top:0;left:0;right:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--line);box-shadow:0 2px 12px rgba(30,37,48,.08);transform:translateY(-105%);transition:transform .28s ease}
body.show-cta-bar .cta-bar{transform:translateY(0)}
.cta-bar-inner{max-width:1100px;margin:0 auto;padding:9px 24px;display:flex;align-items:center;justify-content:center;gap:18px}
/* the cloned hero CTA block (button + optional sub-line) laid out inline */
.cta-bar .facts-foot{padding:0;border:none;display:flex;align-items:center;gap:16px}
.cta-bar .facts-foot .btn{display:inline-block;font-size:.9rem;padding:9px 22px;white-space:nowrap}
.cta-bar .facts-foot p{margin:0;text-align:left;font-size:.78rem}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 24px;height:62px;display:flex;align-items:center;gap:32px}
.logo img{height:30px;width:auto;display:block}
.logo b{font-family:var(--serif);font-weight:600;font-size:1.25rem}
.nav-links{display:flex;gap:26px;margin-left:auto;align-items:center}
.nav-links a{font-size:.9rem;font-weight:500;color:var(--soft);padding:20px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.nav-links a:hover{color:var(--text);border-bottom-color:var(--text)}
.nav-links a[aria-current]{color:var(--text);border-bottom-color:var(--blue)}
.nav-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:6px;padding:8px 12px;font:inherit;font-size:.85rem;font-weight:600;color:var(--text);cursor:pointer}

/* ---------- HERO ---------- */
.hero-band{background:linear-gradient(180deg,#E8F0FF 0%,#F2F6FF 100%);border-bottom:1px solid #D7E3FB}   /* full-width tinted band behind the centered hero */
.hero{max-width:1100px;margin:0 auto;padding:56px 24px 52px;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(330px,.85fr);gap:64px;align-items:start}
.hero.single{grid-template-columns:1fr;max-width:740px}
.crumb{font-size:.82rem;color:var(--faint);margin-bottom:20px}
.crumb a:hover{color:var(--soft);text-decoration:underline;text-underline-offset:3px}
h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.05rem,4.1vw,2.85rem);line-height:1.16;letter-spacing:-0.012em;margin-bottom:18px}
.dek{font-size:1.12rem;color:var(--soft);max-width:52ch;margin-bottom:28px}
.byline{display:flex;align-items:center;gap:12px;font-size:.86rem;color:var(--soft);padding-top:22px;border-top:1px solid var(--line);max-width:52ch}
.byline img{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--panel)}
.byline .who b{color:var(--text);font-weight:600}
.byline .who b[role="button"]{cursor:help;border-bottom:1px dotted var(--faint)}
.meta-links{margin-top:13px;display:flex;gap:18px;font-size:.8rem;flex-wrap:wrap}
.meta-links a{color:var(--faint);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:3px;cursor:pointer}
.meta-links a:hover{color:var(--blue)}

/* ---------- FACTS PANEL ---------- */
.facts{border:1px solid var(--line);border-radius:8px;background:var(--bg);overflow:hidden;box-shadow:0 6px 20px rgba(23,60,110,.06)}
.facts-head{display:flex;justify-content:space-between;align-items:baseline;padding:14px 20px;border-bottom:1px solid var(--line);background:var(--panel)}
.facts-head .t{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.facts-head .when{font-size:.76rem;color:var(--faint)}
.facts-row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:9px 18px;border-bottom:1px solid var(--line);font-size:.87rem;line-height:1.3}
.facts-row:last-of-type{border-bottom:none}
.facts-row .k{color:var(--soft);letter-spacing:-0.005em}
.facts-row .v{font-weight:600;text-align:right;font-feature-settings:"tnum";letter-spacing:-0.015em}
.facts-row .v small{display:block;font-weight:400;color:var(--faint);font-size:.76rem}
.facts-foot{padding:15px 20px;border-top:1px solid var(--line)}
.facts-foot .btn{display:block}
.facts-foot p{margin-top:10px;text-align:center;font-size:.76rem}
.facts-foot p a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}

/* ---------- ROUTER (persona cards) ---------- */
.router{margin-top:1.6em;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.router a{border:1px solid var(--line);border-radius:8px;padding:16px;display:block;transition:border-color .15s,box-shadow .15s}
.router a:hover{border-color:var(--blue);box-shadow:0 1px 6px rgba(31,78,140,.12)}
.router b{display:block;font-size:.95rem;margin-bottom:4px}
.router span{font-size:.82rem;color:var(--soft);display:block;margin-bottom:10px}
.router .act{font-size:.84rem;font-weight:600;color:var(--blue)}

/* ---------- ARTICLE ---------- */
.article{max-width:1100px;margin:0 auto;padding:44px 24px 80px;display:grid;grid-template-columns:minmax(0,680px) minmax(260px,1fr);gap:64px}
.article.single{grid-template-columns:minmax(0,740px);justify-content:center}
.prose>*+*{margin-top:1.15em}
.prose h2{font-family:var(--serif);font-weight:600;font-size:1.65rem;letter-spacing:-0.008em;line-height:1.25;margin-top:2.2em;padding-top:1.2em;border-top:1px solid var(--line)}
.prose h3{font-family:var(--serif);font-weight:600;font-size:1.28rem;margin-top:2em}
.prose h2 .stepnum,.prose h3 .stepnum,.prose h4 .stepnum{color:var(--faint);font-family:var(--sans);font-weight:500;font-size:.78rem;letter-spacing:.07em;text-transform:uppercase;display:block;margin-bottom:4px}
.prose p,.prose li{color:#333B47}
.prose a{color:var(--blue);text-decoration:underline;text-decoration-color:#A8C4F8;text-underline-offset:3px}
.prose a:hover{text-decoration-color:var(--blue)}
/* .btn links inside content keep button styling (override .prose a color/underline) */
.prose a.btn{text-decoration:none}
.prose a.btn:not(.ghost){color:#fff}
/* a paragraph that is just a (non-YouTube) link -> centered button */
.prose p.link-btn{text-align:center;margin:1.8em 0}
.prose p.link-btn a{display:inline-block;color:#fff;text-decoration:none;background:var(--blue);font-weight:600;font-size:.92rem;border-radius:6px;padding:11px 20px;transition:background .15s}
.prose p.link-btn a:hover{background:var(--blue-deep);text-decoration:none}
.prose ul,.prose ol{padding-left:1.2em}
.prose li+li{margin-top:.5em}
.prose img{max-width:100%;height:auto;border-radius:8px;display:block;margin:1.4em 0}
.prose figure figcaption{font-size:.82rem;color:var(--faint);margin-top:6px;text-align:center}
.prose blockquote{border-left:3px solid var(--line);padding-left:16px;color:var(--soft);font-style:italic}
.prose code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.88em;background:var(--panel);padding:2px 5px;border-radius:4px}
.prose pre{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:16px;overflow-x:auto}
.prose pre code{background:none;padding:0}
.prose table{width:100%;border-collapse:collapse;font-size:.92rem}
.prose th{text-align:left;font-weight:600;border-bottom:1px solid var(--text);padding:0 14px 9px}
.prose td{padding:12px 14px;border-bottom:1px solid var(--line)}
.note{font-size:.86rem;color:var(--soft);border-left:2px solid var(--line);padding-left:14px}

/* in-content table of contents (before first h2) */
.prose .toc-content{border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:14px 20px;margin:1.6em 0}
.prose .toc-content h4{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--soft);margin:0 0 8px}
.prose .toc-content a{display:block;padding:7px 0;color:var(--soft);text-decoration:none;border-bottom:1px solid var(--line);font-size:.92rem}
.prose .toc-content a:last-child{border-bottom:none}
.prose .toc-content a:hover{color:var(--blue)}
.prose .toc-content.toc-mobile{display:none}                 /* short posts: mobile only */
@media(max-width:920px){.prose .toc-content.toc-mobile{display:block}}

.steps-index{border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-top:1.4em}
.steps-index a{display:flex;gap:14px;align-items:baseline;padding:12px 18px;border-bottom:1px solid var(--line);font-size:.95rem;font-weight:500;transition:background .12s;color:var(--text);text-decoration:none}
.steps-index a:last-child{border-bottom:none}
.steps-index a:hover{background:var(--panel)}
.steps-index .n{font-feature-settings:"tnum";color:var(--faint);font-size:.85rem;width:1.4em}

/* ---------- COMPARISON TABLE ---------- */
.cmp{width:100%;border-collapse:collapse;font-size:.92rem;margin-top:1.4em}
.cmp caption{caption-side:top;text-align:left;font-size:.78rem;color:var(--faint);padding-bottom:8px}
.cmp th{text-align:left;font-weight:600;font-size:.76rem;letter-spacing:.05em;text-transform:uppercase;color:var(--soft);border-bottom:1px solid var(--text);padding:0 14px 9px}
.cmp td{padding:16px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.cmp td:first-child,.cmp th:first-child{padding-left:0}
.cmp tr:hover td{background:var(--panel)}
.cmp .name{font-weight:600}
.cmp .name small{display:block;font-weight:400;color:var(--faint);font-size:.78rem}
.cmp .badge{display:inline-block;font-size:.66rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);border:1px solid var(--blue);border-radius:4px;padding:2px 7px;margin-bottom:5px}
.cmp .price{font-feature-settings:"tnum";white-space:nowrap;font-weight:600}
.cmp .price small{display:block;font-weight:400;color:var(--faint);font-size:.76rem}
.cmp .btn{white-space:nowrap;padding:10px 16px;font-size:.86rem}
.cmp .sub{display:block;font-size:.72rem;color:var(--faint);margin-top:5px;text-align:center}

.callout{border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:0 8px 8px 0;background:var(--panel);padding:18px 20px;font-size:.93rem;margin-top:1.6em}
.callout .tag{font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:6px}
.callout a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:3px}

/* ---------- CLOSER ---------- */
.closer{border:1px solid var(--line);border-radius:8px;padding:26px;margin-top:2.4em;text-align:center;background:var(--panel)}
.closer h2{font-family:var(--serif);font-weight:600;font-size:1.35rem;margin:0 0 8px;border:none;padding:0}
.closer p{color:var(--soft);font-size:.95rem;max-width:46ch;margin:0 auto 18px}
.closer .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- SIDEBAR ---------- */
.side{font-size:.9rem}
.side .stick{position:sticky;top:86px;display:flex;flex-direction:column;gap:16px}
.side .box{border:1px solid var(--line);border-radius:8px;padding:18px 20px}
.side h4{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--soft);margin-bottom:12px}
.side .toc a{display:block;padding:7px 0;color:var(--soft);border-bottom:1px solid var(--line)}
.side .toc a:last-child{border-bottom:none}
.side .toc a:hover{color:var(--blue)}
.side .offer{background:var(--bg)}
.side .offer .tag{font-size:.68rem;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:8px}
.side .offer b{display:block;font-size:1rem;margin-bottom:4px}
.side .offer p{font-size:.84rem;color:var(--soft);margin-bottom:14px}
.side .offer .btn{display:block;font-size:.88rem}

/* ---------- FAQ ---------- */
details{border-bottom:1px solid var(--line);padding:4px 0}
details summary{font-weight:600;cursor:pointer;padding:12px 0;list-style:none;display:flex;justify-content:space-between;gap:16px}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";color:var(--faint);font-weight:400}
details[open] summary::after{content:"–"}
details p{padding:0 0 14px;color:#333B47}

.footer{border-top:1px solid var(--line);background:var(--panel)}
.footer-inner{max-width:1100px;margin:0 auto;padding:36px 24px;font-size:.83rem;color:var(--faint);display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer a{color:var(--soft)}
.footer a:hover{color:var(--blue)}

@media(max-width:920px){
  .hero{grid-template-columns:1fr;gap:38px;padding-top:34px}
  .article{grid-template-columns:1fr}
  .side{display:none}
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:62px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--line);padding:12px 24px;gap:0}
  .nav-links.open a{padding:12px 0;border-bottom:1px solid var(--line)}
  .nav-toggle{display:block}
  .router{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important}}

/* ---------- ADS ---------- */
.ad{margin:1.9em 0;text-align:center;min-height:1px}
.ad-label{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:7px}
.ad ins{margin:0 auto}

/* ---------- LOGO IMAGE ---------- */
.logo .logo-img{height:32px;width:auto;display:block}

/* ---------- NAV SEARCH ---------- */
.nav-search{display:inline-flex;align-items:center;color:var(--soft);padding:20px 4px;cursor:pointer;transition:color .15s}
.nav-search svg{display:block}
.nav-search:hover{color:var(--blue)}
.search-box{display:none;border-bottom:1px solid var(--line);background:var(--bg)}
.search-box.open{display:block}
.search-box input{display:block;max-width:1100px;margin:0 auto;width:100%;padding:15px 24px;border:none;font:inherit;font-size:1rem;background:transparent;outline:none}

/* ---------- FOOTER (multi-column) ---------- */
.footer-cols{max-width:1100px;margin:0 auto;padding:48px 24px 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.fcol-title{font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--text);margin-bottom:15px}
.fcol .fmenu{list-style:none;padding:0;margin:0}
.fcol .fmenu li{margin:0 0 9px}
.fcol .fmenu a{font-size:.88rem;color:var(--soft)}
.fcol .fmenu a:hover{color:var(--blue)}
.fcol p{font-size:.86rem;color:var(--soft);line-height:1.62}
.footer-bottom{border-top:1px solid var(--line)}
.footer-bottom-inner{max-width:1100px;margin:0 auto;padding:18px 24px;font-size:.82rem;color:var(--faint);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer-bottom-inner a{color:var(--soft)}
.footer-bottom-inner a:hover{color:var(--blue)}
@media(max-width:920px){.footer-cols{grid-template-columns:repeat(2,1fr);gap:30px}}
@media(max-width:560px){.footer-cols{grid-template-columns:1fr}}

/* ---------- SMALL IMAGES (float right) ---------- */
.prose img.img-small{width:215px;height:auto;float:right;margin:6px 0 18px 24px;border-radius:8px}
.prose h2,.prose h3{clear:both}   /* keep headings below a floated image */
@media(max-width:560px){
  .prose img.img-small{float:none;display:block;width:60%;margin:1.3em auto}
}

/* ================= HERO META (author card + actions) ================= */
.hero-main{min-width:0}
.post-meta{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:22px;border-top:1px solid var(--line);margin-top:6px}
.author-card{display:flex;align-items:center;gap:13px}
.author-pic{width:46px;height:46px;border-radius:50%;object-fit:cover;background:var(--panel);flex:none}
.author-text{display:flex;flex-direction:column;gap:3px;font-size:.85rem}
.author-name{font-weight:600;color:var(--text);cursor:pointer;width:fit-content;border-bottom:1px dotted var(--faint)}
.author-name.static{cursor:default;border:none}
.author-name:hover{color:var(--blue)}
.author-role{color:var(--soft);display:flex;align-items:center;flex-wrap:wrap}
.author-updated{color:var(--faint);font-size:.8rem}

.meta-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.meta-btn{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:7px 15px;font:inherit;font-size:.82rem;font-weight:500;color:var(--text);cursor:pointer;transition:border-color .15s,background .15s}
.meta-btn:hover{border-color:var(--blue);color:var(--blue)}
.share{display:flex;align-items:center;gap:8px}
.share-x,.share-more{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:999px;background:var(--bg);color:var(--text);cursor:pointer;font:inherit;font-size:.82rem;font-weight:500;transition:border-color .15s,color .15s}
.share-x{width:34px;height:34px;font-size:.95rem}
.share-more{padding:7px 15px}
.share-x:hover,.share-more:hover{border-color:var(--blue);color:var(--blue)}

/* hero right-hand boxes */
.hero-aside{min-width:0;align-self:center}   /* whatever box it holds (facts/table/image/offer) is vertically centered in the hero */
.hero-box-img{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.hero-box-img img{max-width:100%;width:auto;height:auto;border-radius:10px;display:block}
.hero-box-cap{display:block;font-size:.8rem;color:var(--faint);margin-top:8px}
/* hero "facts" card built from a 2-column key/value table */
.hero-box-table{border:1px solid var(--line);border-top:3px solid var(--blue);border-radius:10px;background:var(--bg);box-shadow:0 8px 24px rgba(23,60,110,.08);overflow:hidden}
.hero-box-table table{width:100%;border-collapse:collapse;font-size:.9rem;margin:0}
.hero-box-table thead th{background:var(--panel);font-weight:600;padding:13px 18px;border-bottom:1px solid var(--line);vertical-align:top}
.hero-box-table thead th:first-child{text-align:left;color:var(--text)}
.hero-box-table thead th+th{text-align:right;color:var(--blue)}
.hero-box-table td{padding:12px 18px;border-bottom:1px solid var(--line);vertical-align:top}
.hero-box-table td:first-child{color:var(--soft)}
.hero-box-table td+td{text-align:right;font-weight:600;color:var(--text);font-feature-settings:"tnum"}
.hero-box-table tbody tr:last-child td{border-bottom:none}
.hero-box-table tbody tr:hover{background:var(--panel)}
.hero-offer .offer-tag{font-size:.68rem;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:8px}
.hero-offer .offer-head{display:block;font-size:1.05rem;margin-bottom:6px}
.hero-offer .offer-text{font-size:.9rem;color:var(--soft);margin-bottom:14px;text-align:left}
.hero-offer .btn{display:block}
.hero-offer .offer-alt{display:block;text-align:center;margin-top:10px;font-size:.82rem;color:var(--soft);text-decoration:underline;text-underline-offset:3px}
.hero-offer .offer-alt:hover{color:var(--blue)}

/* portals (light tooltips + share menu) */
.ttip-portal,.share-portal{display:none;position:fixed;top:0;left:0;z-index:9999;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px rgba(30,37,48,.18),0 2px 6px rgba(30,37,48,.08)}
.ttip-portal{width:320px;max-width:min(90vw,340px);padding:18px 20px;font-size:.9rem;line-height:1.6;color:#333B47}
.ttip-portal.is-open,.share-portal.is-open{display:block}
.ttip-portal .ttip-card{display:flex;align-items:center;gap:12px;padding-bottom:13px;margin-bottom:13px;border-bottom:1px solid var(--line)}
.ttip-portal .ttip-card img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.ttip-portal .ttip-card b{display:block;color:var(--text)}
.ttip-portal .ttip-card span{font-size:.82rem;color:var(--soft)}
.ttip-portal p{margin:0}
.share-portal{min-width:170px;padding:8px}
.share-portal a{display:block;padding:9px 12px;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text)}
.share-portal a:hover{background:var(--panel);color:var(--blue)}

@media(max-width:920px){
  .post-meta{flex-direction:column;align-items:flex-start;gap:16px}
}

/* ================= SIMPLE PAGES + ARCHIVES ================= */
.simple-page{padding-top:48px}
.page-title{font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,3.5vw,2.5rem);line-height:1.18;letter-spacing:-0.01em;margin-bottom:28px}
.arch-list{display:flex;flex-direction:column}
.arch-item{padding:20px 0;border-bottom:1px solid var(--line)}
.arch-item:first-child{padding-top:0}
.arch-link{font-family:var(--serif);font-weight:600;font-size:1.25rem;color:var(--text);line-height:1.3}
.arch-link:hover{color:var(--blue)}
.arch-desc{color:var(--soft);font-size:.92rem;margin:6px 0 8px;max-width:60ch}
.arch-date{font-size:.8rem;color:var(--faint)}

/* ---------- LITE YOUTUBE ---------- */
.yt-lite{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:10px;overflow:hidden;cursor:pointer;margin:1.7em 0}
.yt-lite .yt-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;margin:0;border-radius:0}
.yt-lite .yt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:68px;height:48px;border:none;border-radius:14px;background:rgba(0,0,0,.6);cursor:pointer;transition:background .2s}
.yt-lite:hover .yt-play{background:#c00}
.yt-lite .yt-play::before{content:"";position:absolute;top:50%;left:53%;transform:translate(-50%,-50%);border-style:solid;border-width:10px 0 10px 17px;border-color:transparent transparent transparent #fff}
.yt-lite iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- FAQ ---------- */
.prose details.faq{border-bottom:1px solid var(--line);padding:4px 0;margin:0}
.prose details.faq>summary{font-weight:600;cursor:pointer;padding:13px 0;list-style:none;display:flex;justify-content:space-between;gap:16px;color:var(--text)}
.prose details.faq>summary::-webkit-details-marker{display:none}
.prose details.faq>summary::after{content:"+";color:var(--faint);font-weight:400;font-size:1.15rem;line-height:1}
.prose details.faq[open]>summary::after{content:"\2013"}
.prose details.faq>summary:hover{color:var(--blue)}
.prose details.faq .faq-a{padding:0 0 14px}
.prose details.faq .faq-a>:first-child{margin-top:0}
.prose details.faq .faq-a>:last-child{margin-bottom:0}

/* ---------- SIDEBAR AD (under TOC) ---------- */
.side .side-ad{text-align:center}
.side .side-ad .ad-label{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);display:block;margin-bottom:8px}

/* ---------- PRODUCT COMPARISON TABLE (shortcodes) ---------- */
.ptable{border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:1.9em 0;box-shadow:0 6px 20px rgba(23,60,110,.06)}
.ptable-head,.ptable-row{display:grid;grid-template-columns:1.15fr 1fr 1.5fr .9fr;gap:20px;align-items:center;padding:18px 22px}
.ptable-head{background:var(--panel);border-bottom:1px solid var(--text);font-size:.74rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--soft)}
.ptable-row+.ptable-row{border-top:1px solid var(--line)}
.ptable-row:hover{background:var(--panel)}
.pt-service{display:flex;flex-direction:column;gap:10px;min-width:0}
.pt-service a{display:inline-block;text-decoration:none}
.pt-service img{max-width:160px;max-height:48px;width:auto;height:auto;object-fit:contain;display:block}
.pt-badge{align-self:flex-start;font-size:.62rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);background:#EAF1FE;border:1px solid var(--blue);border-radius:999px;padding:3px 9px}
/* fractional star rating: set --rating:0–5 (supports halves). Gold fill clipped over a gray track. */
.pt-stars{display:inline-block;position:relative;font-size:1.12rem;line-height:1;font-family:Arial,"Segoe UI Symbol",sans-serif;letter-spacing:2px}
.pt-stars::before{content:"★★★★★";color:#dfe3ea}
.pt-stars::after{content:"★★★★★";color:#F5B301;position:absolute;left:0;top:0;width:calc(var(--rating,5) / 5 * 100%);overflow:hidden;white-space:nowrap}
.pt-price{font-weight:600;margin-top:6px;font-feature-settings:"tnum"}
.pt-price small{font-weight:400;color:var(--faint)}
.pt-features{margin:0;padding:0;list-style:none;font-size:.88rem;color:var(--soft)}
.pt-features li{position:relative;padding-left:16px;margin:0 0 6px;line-height:1.4}
.pt-features li:last-child{margin-bottom:0}
.pt-features li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--blue)}
.pt-cta .btn{display:inline-block;white-space:nowrap}
@media(max-width:680px){
  .ptable-head{display:none}
  .ptable-row{grid-template-columns:1fr;gap:14px;text-align:center;padding:24px 20px}
  .pt-service{align-items:center;gap:12px}
  .pt-badge{align-self:center}
  .pt-features{display:inline-block;text-align:left}
  .pt-cta .btn{width:100%;max-width:280px}
}

/* ---------- POLISH ---------- */
::selection{background:#cfe0ff;color:var(--text)}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-thumb{background:#cbd2dd;border:3px solid var(--bg);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:#aab3c0}
/* back-to-top floating button (fades in after scrolling, in build_footer) */
.to-top{position:fixed;right:22px;bottom:22px;z-index:40;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:var(--bg);color:var(--soft);box-shadow:0 4px 16px rgba(30,37,48,.16);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .22s,transform .22s,color .15s,border-color .15s}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{color:var(--blue);border-color:var(--blue)}
@media(max-width:560px){.to-top{right:14px;bottom:14px}}
