/* ============================================================
   工具箱 — 前台樣式
   美學:暖米色方格紙 · 墨黑 · 朱紅 accent · 編輯/工作坊風
   ============================================================ */
:root{
  --paper:#f2ede1;
  --paper-2:#fbf8f0;
  --ink:#1b1714;
  --ink-soft:#5a5249;
  --accent:#e6411d;
  --accent-ink:#fff;
  --line:rgba(27,23,20,.10);
  --line-strong:rgba(27,23,20,.22);
  --shadow:6px 6px 0 var(--ink);
  --display:'Fraunces',Georgia,serif;
  --body:'Noto Sans TC',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  line-height:1.65;letter-spacing:.01em;min-height:100vh;
  display:flex;flex-direction:column;
}
/* graph-paper backdrop */
.grid-bg{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:28px 28px;
  mask-image:radial-gradient(ellipse 120% 90% at 50% 0%,#000 55%,transparent 100%);
}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono);font-size:.8rem;letter-spacing:0}
.dim{color:var(--ink-soft)}
/* 內聯 Lucide 圖示:跟隨字級與字色 */
.ic{width:1em;height:1em;display:inline-block;vertical-align:-.14em;flex-shrink:0}
.tool-glyph{display:inline-block;line-height:1} /* 非 Lucide 名稱的原字元 fallback */
/* 工具圖示上 accent 色,線條同色仍好掃描 */
.tool-icon .ic,.tool-page-icon .ic,.nav-drop-ic .ic,.seo-related-icon .ic{color:var(--accent)}

/* ---------- header ---------- */
.site-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1rem,5vw,3rem);
  border-bottom:2px solid var(--ink);
  position:sticky;top:0;background:rgba(242,237,225,.85);backdrop-filter:blur(8px);z-index:10;
}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--display);font-weight:900;font-size:1.35rem}
.brand-mark{
  display:inline-grid;place-items:center;width:1.7em;height:1.7em;
  background:var(--accent);color:var(--accent-ink);font-size:.8em;border-radius:3px;
  transform:rotate(-4deg);box-shadow:2px 2px 0 var(--ink);
}
.head-nav{display:flex;gap:1.4rem;align-items:center;font-weight:500}
/* 導覽列從頁首正中間開始,往右排列 */
.head-nav{position:absolute;left:50%;top:50%;transform:translateY(-50%)}

/* 漢堡按鈕(僅手機顯示) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;border:2px solid var(--ink);border-radius:6px;
  background:var(--paper);cursor:pointer;padding:0}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--ink);margin:0 auto;transition:transform .25s,opacity .2s}
.site-head.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-head.nav-open .nav-toggle span:nth-child(2){opacity:0}
.site-head.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.head-nav a{position:relative;padding:.2rem 0}
.head-nav a:not(.ghost):after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--accent);transition:right .25s}
.head-nav a:not(.ghost):hover:after{right:0}
.head-nav .ghost{border:2px solid var(--ink);padding:.3rem .8rem;border-radius:4px;font-size:.9rem}
.head-nav .ghost:hover{background:var(--ink);color:var(--paper)}

/* 導覽列分類下拉 */
.head-nav .nav-item.has-drop{position:relative}
.head-nav .nav-top{display:inline-flex;align-items:center;gap:.25rem}
.nav-caret{width:.85em;height:.85em;transition:transform .2s}
.has-drop:hover .nav-caret{transform:rotate(180deg)}
.nav-drop{
  position:absolute;top:100%;left:50%;transform:translateX(-50%);margin-top:.5rem;
  display:none;flex-direction:column;min-width:210px;max-height:70vh;overflow:auto;
  background:var(--paper);border:2px solid var(--ink);border-radius:10px;
  box-shadow:5px 5px 0 var(--line-strong);padding:.4rem;z-index:40
}
/* hover 橋接放在 has-drop(無 overflow,不被 dropdown 裁切),補滿 top 與 dropdown 間隙 */
.has-drop:hover:after{content:"";position:absolute;left:0;right:0;top:100%;height:.6rem}
.has-drop:hover .nav-drop{display:flex}
.nav-drop a{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;border-radius:6px;font-size:.9rem;white-space:nowrap;font-weight:500}
.nav-drop a:after{display:none!important}
.nav-drop a:hover{background:var(--paper-2)}
.nav-drop-ic{width:1.3em;text-align:center;flex-shrink:0}
@media(max-width:680px){
  .nav-toggle{display:flex}
  /* nav 收進漢堡面板:預設隱藏,開啟時從 header 下方展開 */
  .head-nav{position:absolute;left:0;right:0;top:100%;transform:none;
    flex-direction:column;align-items:stretch;gap:.2rem;
    background:rgba(242,237,225,.97);backdrop-filter:blur(8px);
    border-bottom:2px solid var(--ink);
    padding:.7rem clamp(1rem,5vw,3rem) 1rem;display:none;max-height:80vh;overflow:auto}
  .site-head.nav-open .head-nav{display:flex}
  .head-nav .nav-item{display:block}
  .head-nav .nav-item.has-drop{position:static}
  .nav-top{padding:.45rem 0}
  .nav-caret{display:none}
  /* 手機展開:分類工具直接平鋪,不用 hover */
  .nav-drop{position:static;transform:none;display:flex;box-shadow:none;border:0;
    min-width:0;margin:0 0 .4rem;padding:0 0 0 1rem;max-height:none;background:none}
  .nav-drop a{padding:.4rem 0;font-size:.88rem}
}

/* ---------- layout ---------- */
.wrap{width:min(1100px,92vw);margin:0 auto;padding:clamp(1.4rem,4vw,2.8rem) 0 4rem;flex:1}
.site-foot{border-top:2px solid var(--ink);padding:1.4rem;text-align:center;color:var(--ink-soft)}

/* ---------- hero ---------- */
.hero{margin-bottom:clamp(2.5rem,7vw,4.5rem);max-width:62ch}
/* 進場:純 CSS,頁面解析即跑,不等 GSAP CDN(接力淡入上移) */
.hero>.hero-title,.hero>.hero-sub,.hero>.toolsearch{animation:rise .42s both}
.hero>.hero-sub{animation-delay:.07s}
.hero>.toolsearch{animation-delay:.14s}
.kicker{color:var(--accent);font-weight:700;margin:0 0 1rem}
.hero-title{
  font-family:var(--display);font-weight:900;font-size:clamp(2.2rem,6vw,4rem);
  line-height:1.08;margin:0;letter-spacing:-.02em;
  text-wrap:balance;word-break:keep-all;line-break:strict;
}
.hero-sub{font-size:1.1rem;color:var(--ink-soft);margin:1.1rem 0 1.8rem}
.toolsearch{position:relative;max-width:30rem}
.toolsearch .ts-ic{
  position:absolute;left:1rem;top:50%;transform:translateY(-50%);
  width:1.2em;height:1.2em;color:var(--ink-soft);pointer-events:none;
}
.toolsearch input{
  width:100%;font-family:var(--body);font-size:1.05rem;
  padding:.85rem 1.1rem .85rem 2.8rem;border:2px solid var(--ink);border-radius:6px;background:var(--paper-2);
  box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s;
}
.toolsearch input:focus{outline:none;transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--accent)}

/* ---------- category blocks ---------- */
.cat-block{margin-bottom:3rem}
/* 無 JS / reduced-motion:沿用原本載入淡入,確保內容可見 */
.no-anim .cat-block{animation:rise .5s both;animation-delay:var(--d)}
.cat-title{
  display:flex;align-items:baseline;gap:.7rem;font-family:var(--display);font-weight:600;
  font-size:1.55rem;margin:0 0 1.2rem;padding-bottom:.5rem;border-bottom:1px dashed var(--line-strong);
}
.cat-no{color:var(--accent);font-weight:700}

/* ---------- tool grid / cards ---------- */
.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem}
.tool-card{
  position:relative;display:flex;flex-direction:column;gap:.35rem;
  padding:1.25rem 1.2rem 1.1rem;background:var(--paper-2);
  border:2px solid var(--ink);border-radius:8px;
  transition:transform .14s ease,box-shadow .14s ease;
  overflow:hidden;
}
.tool-card:before{
  content:"";position:absolute;top:0;left:0;width:100%;height:4px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s;
}
.tool-card:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow)}
.tool-card:hover:before{transform:scaleX(1)}
.tool-icon{font-size:1.6rem;line-height:1}
.tool-name{font-family:var(--display);font-weight:600;font-size:1.18rem}
.tool-desc{color:var(--ink-soft);font-size:.9rem;flex:1}
.tool-go{display:inline-flex;align-items:center;gap:.3rem;color:var(--accent);font-weight:700;opacity:0;transform:translateX(-4px);transition:.2s}
.tool-card:hover .tool-go{opacity:1;transform:translateX(0)}
.tool-card.hide{display:none}

/* ---------- tool page ---------- */
.crumbs{margin-bottom:1.5rem;color:var(--ink-soft)}
.crumbs a{color:var(--accent)}
.tool-head{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.8rem;padding-bottom:1.4rem;border-bottom:2px solid var(--ink)}
.tool-page-icon{font-size:2.6rem;line-height:1}
.tool-head h1{font-family:var(--display);font-weight:900;font-size:clamp(1.8rem,5vw,2.8rem);margin:0;line-height:1.05}
.tool-page-desc{color:var(--ink-soft);margin:.4rem 0 0}
.tool-body{animation:rise .4s both .05s}

/* ---------- shared form/field bits used by tools ---------- */
.field-area{
  width:100%;min-height:200px;resize:vertical;font-family:var(--body);font-size:1rem;line-height:1.6;
  padding:1rem 1.1rem;border:2px solid var(--ink);border-radius:8px;background:var(--paper-2);
}
.field-area:focus{outline:none;box-shadow:4px 4px 0 var(--accent)}
.field-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;font-weight:500}
.btn{
  display:inline-flex;align-items:center;gap:.4rem;font-family:var(--body);font-weight:600;cursor:pointer;
  padding:.6rem 1.1rem;border:2px solid var(--ink);border-radius:6px;background:var(--paper-2);color:var(--ink);
  transition:transform .1s,box-shadow .1s;
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:3px 3px 0 var(--ink)}
.btn.sm{padding:.32rem .7rem;font-size:.82rem;border-width:1.5px}
.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--ink)}

/* word-counter */
.wc-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.8rem;margin-top:1.3rem}
.wc-stat{padding:1rem;border:2px solid var(--ink);border-radius:8px;background:var(--paper-2);text-align:center}
.wc-num{display:block;font-family:var(--display);font-weight:900;font-size:1.9rem;line-height:1;color:var(--accent)}
.wc-label{display:block;margin-top:.4rem;font-size:.8rem;color:var(--ink-soft)}

/* base64 */
.b64{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:stretch}
.b64-mid{display:grid;place-items:center;font-size:1.6rem;color:var(--accent)}
.b64-err{color:var(--accent);font-weight:600;margin-top:.8rem}
@media(max-width:680px){.b64{grid-template-columns:1fr}.b64-mid{transform:rotate(90deg)}}

/* ---------- shared tool-kit widgets ---------- */
.tk-controls{display:flex;flex-wrap:wrap;gap:.8rem 1.2rem;align-items:center;margin-bottom:1.1rem}
.tk-input{font-family:var(--body);font-size:1rem;padding:.6rem .85rem;border:2px solid var(--ink);border-radius:6px;background:var(--paper-2);min-width:0}
.tk-input:focus{outline:none;box-shadow:3px 3px 0 var(--accent)}
.tk-input.full{width:100%}
.tk-label{font-weight:500;display:inline-flex;align-items:center;gap:.45rem}
.tk-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin:1rem 0}
.tk-out{
  width:100%;font-family:var(--mono);font-size:.92rem;line-height:1.6;white-space:pre-wrap;word-break:break-all;
  padding:1rem 1.1rem;border:2px solid var(--ink);border-radius:8px;background:var(--paper-2);min-height:3rem;
}
.tk-out.area{min-height:200px;resize:vertical}
.tk-grid{display:grid;grid-template-columns:auto 1fr;gap:.6rem 1rem;align-items:center}
.tk-grid .tk-out{min-height:0;padding:.55rem .8rem}
.tk-msg{font-weight:600;margin-top:.7rem}
.tk-msg.err{color:var(--accent)}
.tk-range{accent-color:var(--accent)}
.tk-chk{accent-color:var(--accent);width:1.1em;height:1.1em}
.swatch{width:2.4rem;height:2.4rem;border:2px solid var(--ink);border-radius:6px;flex-shrink:0}
.qr-box{display:inline-grid;place-items:center;padding:1rem;background:#fff;border:2px solid var(--ink);border-radius:8px;margin-top:1rem}

/* markdown preview */
.md-preview{
  width:100%;min-height:200px;padding:1rem 1.1rem;border:2px solid var(--ink);border-radius:8px;
  background:var(--paper-2);overflow:auto;
}
.md-preview > *:first-child{margin-top:0}
.md-preview > *:last-child{margin-bottom:0}
.md-preview h1,.md-preview h2,.md-preview h3{font-family:var(--display);line-height:1.15;margin:1rem 0 .55rem}
.md-preview h1{font-size:1.8rem}.md-preview h2{font-size:1.45rem}.md-preview h3{font-size:1.2rem}
.md-preview p,.md-preview ul,.md-preview ol,.md-preview blockquote,.md-preview pre{margin:.75rem 0}
.md-preview ul,.md-preview ol{padding-left:1.35rem}
.md-preview a{color:var(--accent);text-decoration:underline;text-underline-offset:.16em}
.md-preview code{font-family:var(--mono);font-size:.9em;background:rgba(27,23,20,.08);padding:.08rem .3rem;border-radius:4px}
.md-preview pre{padding:.85rem 1rem;border:1px dashed var(--line-strong);border-radius:6px;overflow:auto;background:rgba(27,23,20,.06)}
.md-preview pre code{display:block;padding:0;background:transparent;border-radius:0;white-space:pre}
.md-preview blockquote{padding:.25rem 0 .25rem .8rem;border-left:3px solid var(--accent);color:var(--ink-soft)}

/* diff */
.diff-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.diff-out{padding:.5rem 0;overflow:auto}
.diff-line{display:block;padding:.12rem 1rem;border-bottom:1px solid var(--line);white-space:pre-wrap;word-break:break-word}
.diff-line.same{color:var(--ink-soft)}
.diff-line.add{background:rgba(46,125,50,.14)}
.diff-line.del{background:rgba(230,65,29,.14)}

/* image compressor */
.img-preview{display:inline-block;max-width:100%;padding:.75rem;background:#fff;border:2px solid var(--ink);border-radius:8px}
.img-preview img{display:block;max-width:100%;height:auto}

/* converter / calculators */
.conv-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:end}
.conv-side{display:grid;gap:.55rem}
.conv-input{font-size:1.35rem}
.tool-table-wrap{max-width:680px;overflow:auto}
.tool-table{width:100%;border-collapse:collapse;background:var(--paper-2);border:2px solid var(--ink);border-radius:8px;overflow:hidden}
.tool-table th,.tool-table td{padding:.65rem .85rem;border-bottom:1px solid var(--line);text-align:left}
.tool-table th{font-weight:700;background:rgba(27,23,20,.06)}
.tool-table tr:last-child td{border-bottom:none}
.nm-grid .tk-out{word-break:break-word}
.status-panel{
  display:inline-flex;align-items:center;justify-content:center;min-width:7rem;min-height:3rem;margin:.3rem 0 1rem;
  padding:.7rem 1rem;border:2px solid var(--ink);border-radius:8px;background:var(--paper-2);
  font-family:var(--display);font-size:1.45rem;font-weight:900;
}
.status-panel.ok{background:rgba(46,125,50,.16)}
.status-panel.bad{background:rgba(230,65,29,.16)}

/* time / date tools */
.time-card,.countdown-panel{
  padding:1.2rem;border:2px solid var(--ink);border-radius:8px;background:var(--paper-2);margin-bottom:1rem;
}
.time-main{font-size:clamp(2.8rem,10vw,5.8rem);font-weight:700;line-height:1;color:var(--accent);font-variant-numeric:tabular-nums}
.time-date{margin-top:.5rem;color:var(--ink-soft);font-weight:600}
.countdown-title{font-family:var(--display);font-size:1.4rem;font-weight:900;margin-bottom:.8rem}
.countdown-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}
.countdown-grid span{display:grid;place-items:center;padding:.85rem;border:1px dashed var(--line-strong);border-radius:8px}
.countdown-grid strong{font-family:var(--display);font-size:clamp(1.8rem,6vw,3.2rem);line-height:1;color:var(--accent);font-variant-numeric:tabular-nums}
.countdown-grid small{margin-top:.35rem;color:var(--ink-soft)}

/* wheel */
.wheel-layout{display:grid;grid-template-columns:minmax(260px,1fr) minmax(280px,420px);gap:1.4rem;align-items:start}
.wheel-stage{position:relative;display:grid;place-items:center;max-width:420px;margin:0 auto}
.wheel-canvas{width:100%;height:auto;border-radius:50%;background:transparent;box-shadow:0 8px 26px rgba(27,23,20,.18)}
.wheel-pointer{
  position:absolute;top:-.45rem;left:50%;z-index:2;width:0;height:0;transform:translateX(-50%);
  border-left:.75rem solid transparent;border-right:.75rem solid transparent;border-top:1.25rem solid var(--ink);
}
.wheel-result{
  margin:1.1rem auto 0;max-width:420px;padding:.8rem 1rem;border:2px solid var(--ink);border-radius:8px;
  background:var(--paper-2);font-family:var(--display);font-weight:900;font-size:1.45rem;text-align:center;
}
.spin-history{max-width:420px;margin:1rem auto 0;padding-left:1.4rem}
.spin-history li{margin:.25rem 0;font-weight:600}

/* symbols */
.symbol-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:.6rem}
.symbol-btn{
  display:grid;gap:.18rem;place-items:center;min-height:4.5rem;padding:.6rem;border:2px solid var(--ink);border-radius:8px;
  background:var(--paper-2);color:var(--ink);cursor:pointer;transition:transform .1s,box-shadow .1s;
}
.symbol-btn:hover{transform:translate(-2px,-2px);box-shadow:3px 3px 0 var(--ink)}
.symbol-btn strong{font-family:var(--display);font-size:1.45rem;line-height:1}
.symbol-btn span{font-size:.75rem;color:var(--ink-soft);text-align:center}

.empty{padding:2rem;text-align:center;color:var(--ink-soft);border:2px dashed var(--line-strong);border-radius:8px}
.empty a{color:var(--accent);font-weight:600}

@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media(max-width:760px){.diff-cols{grid-template-columns:1fr}}
@media(max-width:680px){.conv-grid{grid-template-columns:1fr}.conv-grid .b64-mid{transform:rotate(90deg)}}
@media(max-width:780px){.wheel-layout{grid-template-columns:1fr}.countdown-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
/* ---- 廣告版位(預留) ---- */
.ad-slot{
  display:flex;align-items:center;justify-content:center;
  margin:1.6rem auto;width:100%;overflow:hidden;
  border:2px dashed var(--line-strong);border-radius:8px;
  background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(27,23,20,.03) 10px,rgba(27,23,20,.03) 20px)
}
.ad-slot.ad-leaderboard{min-height:100px;max-width:970px}
.ad-slot.ad-rect{min-height:250px;max-width:336px}
.ad-ph{color:var(--ink-soft);opacity:.5;font-size:.8rem;letter-spacing:.05em}
/* 接上真實廣告後,去掉佔位外框 */
.ad-slot:has(ins),.ad-slot:has(iframe){border:none;background:none}

/* ---- 熱門使用區 ---- */
.popular-block .tool-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.popular-card{border-color:var(--accent)}
.popular-card .tool-go{color:var(--accent);font-weight:700;opacity:1;transform:none}
.pop-rank{
  position:absolute;top:.6rem;right:.7rem;
  font-weight:900;font-size:.9rem;color:var(--accent-ink);
  background:var(--accent);padding:.05rem .45rem;border-radius:999px;
  box-shadow:2px 2px 0 var(--ink)
}

/* ---- SEO 內容區塊(intro / steps / faq / related) ---- */
.seo-block{
  margin-top:1.6rem;padding:1.4rem 1.6rem;
  background:var(--paper-2);border:2px solid var(--ink);
  border-radius:10px;box-shadow:4px 4px 0 var(--line-strong)
}
.seo-block h2{
  font-size:1.25rem;margin:0 0 1rem;padding-left:.7rem;
  border-left:4px solid var(--accent)
}
.seo-block p{color:var(--ink-soft);line-height:1.75;margin:.5rem 0}
.cat-link{color:inherit;text-decoration:none}
.cat-link:hover{color:var(--accent)}
.home-cats{margin:.5rem 0;padding-left:1.3rem;line-height:1.85}
.home-cats li{margin:.4rem 0;color:var(--ink-soft)}
.home-cats strong{color:var(--ink)}
.seo-steps{margin:.5rem 0;padding-left:1.3rem;line-height:1.8}
.seo-steps li{margin:.35rem 0;color:var(--ink-soft)}
.seo-faq details{border:2px solid var(--line-strong);border-radius:6px;background:var(--paper);padding:.4rem .9rem;margin:.6rem 0}
.seo-faq summary{cursor:pointer;font-weight:700;padding:.45rem 0;list-style:none}
.seo-faq summary::-webkit-details-marker{display:none}
.seo-faq summary:before{content:"+ ";color:var(--accent);font-weight:900}
.seo-faq details[open] summary:before{content:"– "}
.seo-faq details[open] summary{border-bottom:1px solid var(--line)}
.seo-faq p{margin:.6rem 0 .3rem;line-height:1.75}
.seo-related{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.9rem;margin:.5rem 0}
.seo-related-card{
  display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;
  column-gap:.7rem;row-gap:.3rem;align-items:center;
  padding:.9rem 1rem;background:var(--paper);
  border:2px solid var(--ink);border-radius:8px;color:var(--ink);
  transition:transform .15s,box-shadow .15s
}
.seo-related-card:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--accent)}
.seo-related-icon{grid-row:1/3;font-weight:900;color:var(--accent);font-size:1.3rem;line-height:1}
.seo-related-name{font-weight:700;align-self:end}
.seo-related-desc{grid-column:2;font-size:.85rem;color:var(--ink-soft);line-height:1.5;align-self:start}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
