:root{
  --night:#0C0E13;
  --night-2:#0F1218;
  --slab:#161A22;
  --slab-2:#1E232E;
  --rule:#2B3340;
  --rule-2:#3A4452;
  --fg:#F3F6F9;
  --fg-2:#D4DBE4;
  --dim:#9AA7B6;
  --dim-2:#71808F;
  --amber:#FF6A1A;
  --amber-2:#E2540A;
  --amber-veil:rgba(255,106,26,.12);
  --jade:#2FE6A6;
  --jade-2:#16B97F;
  --jade-veil:rgba(47,230,166,.10);
  --rose:#FF4B5C;
  --rose-veil:rgba(255,75,92,.12);
  --gold:#FFD23F;
  --sky:#5AA9FF;

  --face-cn:"PingFang SC","HarmonyOS Sans SC","Microsoft YaHei","Noto Sans SC",sans-serif;
  --face-disp:"Segoe UI Semibold","Segoe UI","PingFang SC","Microsoft YaHei",system-ui,sans-serif;
  --face-mono:ui-monospace,"Cascadia Code","Consolas","SFMono-Regular","Roboto Mono",monospace;

  --shell:1180px;
  --round:0px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--face-cn); color:var(--fg); background:var(--night);
  line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden;
  background-image:
    radial-gradient(120% 80% at 88% -8%, rgba(255,106,26,.13), transparent 55%),
    radial-gradient(90% 60% at -5% -2%, rgba(47,230,166,.07), transparent 50%);
  background-attachment:fixed;
}
a{color:var(--jade);text-decoration:none}
a:hover{color:var(--jade-2)}
img{max-width:100%;height:auto;display:block}
hr{border:none;border-top:1px solid var(--rule);margin:28px 0}
::selection{background:var(--amber);color:#10120f}

.wrap{max-width:var(--shell);margin:0 auto;padding:0 40px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:8px;top:8px;z-index:99;background:var(--amber);color:#10120f;padding:8px 14px}

.topbar{position:sticky;top:0;z-index:40;background:rgba(12,14,19,.86);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule)}
.topbar .bar{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:var(--shell);margin:0 auto;padding:0 40px}
.brand{display:flex;align-items:baseline;gap:11px}
.brand .mark{font-family:var(--face-disp);font-weight:800;font-size:20px;letter-spacing:0;background:var(--amber);color:#10120f;padding:4px 9px}
.brand .name{font-weight:800;font-size:18px;letter-spacing:.5px;color:var(--fg)}
.brand .lat{font-family:var(--face-mono);font-size:11px;color:var(--dim);letter-spacing:2px}
.nav{display:flex;gap:24px;align-items:center;font-size:14.5px;font-weight:600}
.nav a{color:var(--dim);padding:6px 0;border-bottom:2px solid transparent}
.nav a:hover,.nav a.on{color:var(--fg);border-color:var(--amber)}
.nav .navcta{border:1px solid var(--amber);color:var(--amber);padding:7px 14px;border-bottom:1px solid var(--amber)}
.nav .navcta:hover{background:var(--amber);color:#10120f}
.navtoggle{display:none;background:none;border:1px solid var(--rule);color:var(--fg);width:44px;height:44px;cursor:pointer;font-size:18px}
.mobnav{display:none;border-top:1px solid var(--rule);background:var(--night-2)}
.mobnav a{display:block;padding:13px 40px;color:var(--fg-2);border-bottom:1px solid var(--rule);font-weight:600}
.mobnav a:hover{background:var(--slab);color:var(--fg)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--face-cn);font-weight:700;font-size:15px;padding:12px 20px;cursor:pointer;border:1px solid transparent;text-align:center}
.btn .arr{font-family:var(--face-mono);font-weight:800}
.btn-cta{background:var(--amber);color:#10120f;border-color:var(--amber);font-weight:800}
.btn-cta:hover{background:var(--amber-2);color:#10120f}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--jade)}
.btn-ghost:hover{background:var(--jade);color:#10120f}
.btn-line{background:transparent;color:var(--fg-2);border-color:var(--rule-2)}
.btn-line:hover{border-color:var(--fg);color:var(--fg)}
.btn-block{width:100%}

.section{padding:54px 0}
.section.tight{padding:36px 0}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--face-mono);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--jade);border:1px solid rgba(47,230,166,.4);background:var(--jade-veil);padding:6px 12px}
.eyebrow .dot{width:7px;height:7px;background:var(--jade);border-radius:50%;box-shadow:0 0 9px var(--jade)}
.sec-head{margin-bottom:26px}
.sec-head h2{font-family:var(--face-disp);font-size:30px;font-weight:800;letter-spacing:0;margin:14px 0 8px}
.sec-head p{color:var(--dim);max-width:60ch}
.mk{color:#10120f;background:var(--gold);padding:0 7px;-webkit-box-decoration-break:clone;box-decoration-break:clone}

.hero{padding:50px 0 38px}
.hero .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:start}
.hero .grid>section,.hero .grid>aside{min-width:0}
.hero h1{font-family:var(--face-disp);font-size:54px;line-height:1.12;font-weight:800;letter-spacing:0;margin:20px 0 16px}
.hero .lede{font-size:17px;color:var(--dim);max-width:31em;margin-bottom:26px}

.convert{position:relative;background:var(--slab);border:1px solid var(--rule);border-top:4px solid var(--amber);padding:22px 22px 17px}
.convert .tab{position:absolute;top:-1px;right:0;font-family:var(--face-mono);font-size:11px;font-weight:700;letter-spacing:1px;background:var(--amber);color:#10120f;padding:4px 11px}
.convert .benefit{font-size:15.5px;font-weight:600;margin:8px 0 15px;line-height:1.55;color:var(--fg-2)}
.convert .benefit b{color:var(--amber)}
.coderow{display:flex;gap:10px;align-items:stretch;margin-bottom:13px}
.codebox{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px dashed var(--rule-2);background:var(--slab-2);padding:10px 15px}
.codebox .lab{font-size:12px;color:var(--dim)}
.codebox .val{font-family:var(--face-mono);font-size:22px;font-weight:700;letter-spacing:2px;color:var(--jade)}
.copy{border:1px solid var(--rule-2);background:transparent;color:var(--fg);font-family:var(--face-mono);font-size:13px;font-weight:600;padding:0 16px;cursor:pointer;white-space:nowrap;min-height:44px}
.copy:hover{background:#fff;color:#10120f}
.convert .foot{font-size:11.5px;color:var(--dim);margin-top:12px;line-height:1.55}

.quest{background:var(--slab);border:1px solid var(--rule)}
.quest .head{display:flex;align-items:center;justify-content:space-between;padding:14px 17px;border-bottom:1px solid var(--rule);background:var(--slab-2)}
.quest .head .t{font-weight:800;font-size:16px}
.quest .head .badge{font-family:var(--face-mono);font-size:11px;color:var(--jade);border:1px solid rgba(47,230,166,.4);padding:3px 8px}
.quest .body{padding:6px 17px}
.qrow{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-bottom:1px dashed var(--rule)}
.qrow:last-child{border-bottom:none}
.qrow .bx{width:21px;height:21px;border:2px solid var(--rule-2);flex:none;margin-top:1px;display:flex;align-items:center;justify-content:center;font-family:var(--face-mono);font-size:13px;font-weight:800;color:var(--night)}
.qrow.ok .bx{background:var(--jade);border-color:var(--jade)}
.qrow .tx{font-size:14px}
.qrow .tx small{display:block;color:var(--dim);font-size:12.5px;margin-top:1px}
.quest .act{padding:15px 17px}
.sticker{background:var(--rose);color:#1a0406;padding:12px 15px;font-size:13px;line-height:1.5;font-weight:600;margin-top:14px}
.sticker b{display:block;font-size:13px;letter-spacing:.5px;margin-bottom:3px}

.linkcols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.linkgroup h3{font-size:15px;font-weight:800;color:var(--fg);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--rule);display:flex;align-items:center;gap:8px}
.linkgroup h3 .tagn{font-family:var(--face-mono);font-size:11px;color:var(--amber);font-weight:700}
.linklist{list-style:none}
.linklist li{padding:6px 0;border-bottom:1px dashed var(--rule)}
.linklist li:last-child{border-bottom:none}
.linklist a{color:var(--fg-2);font-size:14.5px;display:flex;gap:8px;align-items:baseline}
.linklist a:hover{color:var(--jade)}
.linklist a .idx{font-family:var(--face-mono);font-size:11px;color:var(--dim-2);flex:none}

.feat{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat .card{background:var(--slab);border:1px solid var(--rule);display:flex;flex-direction:column}
.feat .card .ph{aspect-ratio:1200/630;background:var(--slab-2);border-bottom:1px solid var(--rule);overflow:hidden}
.feat .card .ph img{width:100%;height:100%;object-fit:cover}
.feat .card .bd{padding:16px 17px 18px;display:flex;flex-direction:column;flex:1}
.feat .card .kicker{font-family:var(--face-mono);font-size:11px;letter-spacing:1px;color:var(--amber);font-weight:700;text-transform:uppercase}
.feat .card h3{font-size:18px;font-weight:800;margin:8px 0 8px;line-height:1.35}
.feat .card h3 a{color:var(--fg)}
.feat .card h3 a:hover{color:var(--jade)}
.feat .card p{color:var(--dim);font-size:14px;margin-bottom:14px;flex:1}
.feat .card .more{font-weight:700;color:var(--jade);font-size:14px}

.toolboard{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.toolcard{background:var(--slab);border:1px solid var(--rule);padding:16px;display:flex;flex-direction:column;gap:8px}
.toolcard:hover{border-color:var(--jade)}
.toolcard .tn{font-family:var(--face-mono);font-size:11px;color:var(--dim-2)}
.toolcard h3{font-size:15.5px;font-weight:800}
.toolcard h3 a{color:var(--fg)}
.toolcard h3 a:hover{color:var(--jade)}
.toolcard p{font-size:13px;color:var(--dim);flex:1}
.toolcard .go{font-size:13px;color:var(--jade);font-weight:700}

.safebar{background:var(--rose-veil);border:1px solid rgba(255,75,92,.35);border-left:4px solid var(--rose);padding:16px 20px;display:flex;gap:14px;align-items:flex-start}
.safebar .ic{font-family:var(--face-mono);font-weight:800;color:var(--rose);font-size:20px;line-height:1.2;flex:none}
.safebar .tx{font-size:14px;color:var(--fg-2)}
.safebar .tx b{color:var(--rose)}

.article{padding:34px 0 50px}
.article .layout{display:grid;grid-template-columns:1fr 250px;gap:46px;align-items:start}
.article .layout>.main{min-width:0}
.crumbs{font-size:13px;color:var(--dim);margin-bottom:18px}
.crumbs a{color:var(--dim)}
.crumbs a:hover{color:var(--jade)}
.article h1{font-family:var(--face-disp);font-size:38px;line-height:1.2;font-weight:800;letter-spacing:0;margin:6px 0 14px}
.byline{display:flex;flex-wrap:wrap;gap:14px;align-items:center;color:var(--dim);font-size:13px;border-bottom:1px solid var(--rule);padding-bottom:18px;margin-bottom:26px}
.byline .who{color:var(--fg-2);font-weight:600}
.article-cover{margin:0 0 26px;border:1px solid var(--rule)}
.article-cover img{width:100%}
.article-cover figcaption{font-size:12px;color:var(--dim-2);padding:8px 12px;background:var(--slab)}

.prose{font-size:16.5px;color:var(--fg-2);line-height:1.8}
.prose>p{margin:0 0 18px}
.prose h2{font-family:var(--face-disp);font-size:25px;font-weight:800;color:var(--fg);margin:38px 0 14px;padding-top:10px;letter-spacing:0}
.prose h3{font-size:19px;font-weight:800;color:var(--fg);margin:28px 0 10px}
.prose ul,.prose ol{margin:0 0 18px;padding-left:22px}
.prose li{margin:7px 0}
.prose strong{color:var(--fg);font-weight:700}
.prose a{color:var(--jade);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(47,230,166,.4)}
.prose a:hover{text-decoration-color:var(--jade)}
.prose blockquote{border-left:3px solid var(--amber);background:var(--slab);padding:14px 18px;margin:0 0 20px;color:var(--fg-2)}
.prose code{font-family:var(--face-mono);font-size:.9em;background:var(--slab-2);border:1px solid var(--rule);padding:1px 6px;color:var(--jade)}
.prose pre{background:var(--slab-2);border:1px solid var(--rule);padding:14px 16px;overflow-x:auto;margin:0 0 20px}
.prose pre code{background:none;border:none;padding:0;color:var(--fg-2)}

.tablewrap{overflow-x:auto;margin:0 0 22px;border:1px solid var(--rule)}
.prose table{border-collapse:collapse;width:100%;font-size:14.5px;min-width:480px}
.prose th,.prose td{border:1px solid var(--rule);padding:10px 13px;text-align:left;vertical-align:top}
.prose th{background:var(--slab-2);color:var(--fg);font-weight:700}
.prose td{color:var(--fg-2)}
.prose tr:nth-child(even) td{background:rgba(255,255,255,.015)}

.callout{border:1px solid var(--rule);border-left:4px solid var(--dim-2);background:var(--slab);padding:15px 18px;margin:0 0 22px}
.callout .ct{font-weight:800;font-size:14.5px;margin-bottom:5px;display:flex;align-items:center;gap:8px}
.callout p:last-child{margin-bottom:0}
.callout.warn{border-left-color:var(--rose);background:var(--rose-veil)}
.callout.warn .ct{color:var(--rose)}
.callout.tip{border-left-color:var(--jade);background:var(--jade-veil)}
.callout.tip .ct{color:var(--jade)}
.callout.note{border-left-color:var(--amber);background:var(--amber-veil)}
.callout.note .ct{color:var(--amber)}

.inline-cta{border:1px solid var(--rule);border-top:3px solid var(--amber);background:var(--slab);padding:18px 20px;margin:6px 0 24px}
.inline-cta .h{font-weight:800;margin-bottom:6px}
.inline-cta p{color:var(--dim);font-size:14px;margin-bottom:12px}
.inline-cta .row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.inline-cta .codechip{font-family:var(--face-mono);font-weight:700;letter-spacing:1px;color:var(--jade);border:1px dashed var(--rule-2);padding:9px 13px}

.toc{position:sticky;top:84px;border:1px solid var(--rule);background:var(--slab);padding:16px 18px;font-size:13.5px}
.toc .tt{font-family:var(--face-mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-bottom:10px}
.toc ul{list-style:none}
.toc li{margin:3px 0}
.toc a{color:var(--fg-2);display:block;padding:4px 0;border-bottom:1px dashed transparent}
.toc a:hover{color:var(--jade)}
.toc .lv3{padding-left:14px;font-size:13px;color:var(--dim)}

.authorbox{display:flex;gap:16px;border:1px solid var(--rule);background:var(--slab);padding:18px;margin:34px 0 0;align-items:flex-start}
.authorbox .av{width:54px;height:54px;flex:none;background:var(--slab-2);border:1px solid var(--rule-2);display:flex;align-items:center;justify-content:center;font-family:var(--face-disp);font-weight:800;font-size:20px;color:var(--amber)}
.authorbox .ab .n{font-weight:800}
.authorbox .ab .r{font-size:13px;color:var(--dim);margin:2px 0 6px}
.authorbox .ab p{font-size:13.5px;color:var(--dim)}

.related{margin-top:36px}
.related h2{font-size:20px;font-weight:800;margin-bottom:14px}
.related ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.related a{display:block;border:1px solid var(--rule);background:var(--slab);padding:12px 14px;color:var(--fg-2);font-size:14px;font-weight:600}
.related a:hover{border-color:var(--jade);color:var(--jade)}

.tool-wrap{padding:30px 0 50px}
.tool-head{border-bottom:1px solid var(--rule);padding-bottom:20px;margin-bottom:26px}
.tool-head h1{font-family:var(--face-disp);font-size:32px;font-weight:800;letter-spacing:0;margin:8px 0 10px}
.tool-head p{color:var(--dim);max-width:65ch}
.tool-panel{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.tool-card{background:var(--slab);border:1px solid var(--rule);padding:22px}
.tool-card h2{font-size:17px;font-weight:800;margin-bottom:16px;display:flex;align-items:center;gap:9px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--fg-2);margin-bottom:6px}
.field .hint{font-size:12px;color:var(--dim-2);margin-top:4px}
input[type=text],input[type=number],select,textarea{width:100%;min-height:44px;background:var(--slab-2);border:1px solid var(--rule-2);color:var(--fg);font-family:var(--face-mono);font-size:15px;padding:11px 13px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--jade)}
.inputrow{display:flex;gap:10px}
.inputrow>*{flex:1}
.result{background:var(--slab-2);border:1px solid var(--rule);padding:18px}
.result .big{font-family:var(--face-mono);font-size:30px;font-weight:700;color:var(--jade);word-break:break-all}
.result .lab{font-size:12px;color:var(--dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-family:var(--face-mono)}
.result .sub{font-size:13px;color:var(--dim);margin-top:8px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px dashed var(--rule)}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--dim);font-size:13.5px}
.kv .v{font-family:var(--face-mono);color:var(--fg);font-weight:600}
.check-list{list-style:none}
.check-item{display:flex;gap:12px;align-items:flex-start;padding:13px 0;border-bottom:1px solid var(--rule)}
.check-item:last-child{border-bottom:none}
.check-item input[type=checkbox]{width:20px;height:20px;flex:none;margin-top:2px;accent-color:var(--jade)}
.check-item .cl{font-size:14.5px;color:var(--fg-2)}
.check-item .cl small{display:block;color:var(--dim);font-size:12.5px;margin-top:2px}
.score{font-family:var(--face-mono);font-size:40px;font-weight:700;color:var(--amber)}
.badge-status{display:inline-block;font-family:var(--face-mono);font-size:12px;font-weight:700;padding:4px 10px;border:1px solid currentColor}
.s-good{color:var(--jade)}.s-warn{color:var(--gold)}.s-bad{color:var(--rose)}

.go-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:30px;text-align:center}
.go-box{max-width:440px;border:1px solid var(--rule);border-top:4px solid var(--amber);background:var(--slab);padding:34px 30px}
.go-box .mark{font-family:var(--face-disp);font-weight:800;font-size:22px;background:var(--amber);color:#10120f;padding:5px 11px;display:inline-block;margin-bottom:18px}
.go-box h1{font-size:22px;font-weight:800;margin-bottom:10px}
.go-box p{color:var(--dim);font-size:14px;margin-bottom:18px}
.go-box .codechip{font-family:var(--face-mono);font-size:20px;font-weight:700;color:var(--jade);letter-spacing:2px;border:1px dashed var(--rule-2);padding:10px 16px;display:inline-block;margin-bottom:18px}

.footer{border-top:1px solid var(--rule);background:var(--night-2);padding:48px 0 30px;margin-top:30px}
.footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px}
.footer .about .brand{margin-bottom:12px}
.footer .about p{color:var(--dim);font-size:13.5px;max-width:34ch}
.footer h4{font-size:13px;font-weight:800;color:var(--fg);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px;font-family:var(--face-mono)}
.footer ul{list-style:none}
.footer li{margin:7px 0}
.footer a{color:var(--dim);font-size:13.5px}
.footer a:hover{color:var(--jade)}
.footer .legal{border-top:1px solid var(--rule);padding-top:22px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:var(--dim-2);font-size:12.5px}
.footer .legal .disc{max-width:70ch;line-height:1.6}

@media (max-width:980px){
  .article .layout{grid-template-columns:1fr;gap:24px}
  .toc{position:static}
  .article .toc{order:-1}
  .linkcols{grid-template-columns:repeat(2,1fr);gap:24px}
  .feat{grid-template-columns:1fr 1fr}
  .toolboard{grid-template-columns:1fr 1fr}
  .tool-panel{grid-template-columns:1fr}
  .footer .cols{grid-template-columns:1fr 1fr}
}
@media (max-width:880px){
  .wrap,.topbar .bar{padding-left:18px;padding-right:18px}
  .nav{display:none}
  .navtoggle{display:inline-flex;align-items:center;justify-content:center}
  .hero .grid{grid-template-columns:1fr;gap:30px}
  .hero h1{font-size:33px;margin:15px 0 11px}
  .hero .lede{font-size:15px;margin-bottom:18px}
  .codebox .val{font-size:18px;letter-spacing:1px}
  .copy{padding:0 12px}
  .sec-head h2{font-size:24px}
  .article h1{font-size:28px}
  .prose{font-size:16px}
  .prose h2{font-size:22px}
}
@media (max-width:560px){
  .linkcols{grid-template-columns:1fr}
  .feat{grid-template-columns:1fr}
  .toolboard{grid-template-columns:1fr}
  .related ul{grid-template-columns:1fr}
  .footer .cols{grid-template-columns:1fr}
  .section{padding:38px 0}
}

@media (hover:none){
  .nav a,.footer a,.linklist a{min-height:auto}
  .btn{min-height:44px}
}

:target{scroll-margin-top:84px}
.prose h2[id]{scroll-margin-top:84px}

html{ -webkit-text-size-adjust:100%; }
body{ text-rendering:optimizeLegibility; }

a,.btn,.copy,.feat .card,.toolcard,.related a,.linkgroup,.quest .act .btn,.navtoggle{
  transition:transform .18s ease, border-color .18s ease, background-color .18s ease, box-shadow .18s ease, color .18s ease;
}

.convert{box-shadow:0 24px 60px -28px rgba(0,0,0,.85), 0 0 0 1px rgba(255,106,26,.06) inset}
.convert .cta,.btn-cta{box-shadow:0 10px 26px -10px rgba(255,106,26,.6)}
.btn-cta:hover{transform:translateY(-1px);box-shadow:0 14px 30px -10px rgba(255,106,26,.7)}
.codebox{transition:border-color .18s ease, background-color .18s ease}
.codebox:hover{border-color:var(--jade)}
.quest{box-shadow:0 24px 60px -34px rgba(0,0,0,.8)}

.brand .mark{transition:transform .18s ease}
.brand:hover .mark{transform:translateY(-1px) rotate(-2deg)}

.sec-head{position:relative}
.sec-head h2{position:relative;padding-left:16px}
.sec-head h2::before{content:"";position:absolute;left:0;top:.18em;width:5px;height:.82em;background:var(--amber)}
#guides .sec-head h2::before{background:var(--rose)}
#tools .sec-head h2::before{background:var(--jade)}
#airdrops .sec-head h2::before{background:var(--sky)}

.feat .card{position:relative}
.feat .card .ph{position:relative}
.feat .card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(12,14,19,.55), transparent 55%);pointer-events:none}
.feat .card:hover{transform:translateY(-4px);border-color:var(--rule-2)}
.feat .card:hover .ph img{transform:scale(1.03)}
.feat .card .ph img{transition:transform .4s ease}
.feat .card .kicker{display:inline-block}

.toolcard{position:relative;overflow:hidden}
.toolcard::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--jade);transition:width .22s ease}
.toolcard:hover{transform:translateY(-3px)}
.toolcard:hover::before{width:100%}
.toolcard .go a{color:var(--jade)}

.related a:hover{transform:translateX(2px)}

.nav a{position:relative}
.nav a::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--amber);transition:width .2s ease}
.nav a:hover::after,.nav a.on::after{width:100%}
.nav a:hover,.nav a.on{border-color:transparent}

.prose>p:first-of-type{font-size:17.5px;color:var(--fg)}

.safebar{box-shadow:0 18px 50px -34px rgba(255,75,92,.5)}
.callout{border-radius:2px}

a:focus-visible,.btn:focus-visible,.copy:focus-visible,input:focus-visible,select:focus-visible,button:focus-visible{
  outline:2px solid var(--jade);outline-offset:2px
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition:none !important;animation:none !important}
  html{scroll-behavior:auto}
}

.hero-stage{position:relative;overflow:hidden}
.hero-stage::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:url(/assets/img/art/hero-bg.webp?v=20260627) right top / cover no-repeat;
  opacity:.9;
}
.hero-stage::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(90deg, var(--night) 4%, rgba(12,14,19,.72) 42%, rgba(12,14,19,.18) 100%),
    linear-gradient(to bottom, rgba(12,14,19,.4) 0%, transparent 22%, transparent 70%, var(--night) 100%);
}
.hero-stage>.hero{position:relative;z-index:1}
@media (max-width:880px){
  .hero-stage::before{opacity:.55}
  .hero-stage::after{background:linear-gradient(to bottom, rgba(12,14,19,.55), var(--night) 60%)}
}
