*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,system-ui,sans-serif;line-height:1.7;color:#333;background:#fff}
.footer-a116d1{max-width:780px;margin:0 auto;padding:0 20px}
header{background:#1a1a2e;color:#fff;padding:32px 0;margin-bottom:40px}
header h1{font-size:28px;margin-bottom:4px}
header p{opacity:.7;font-size:15px}
header .shell-c1ab1c{color:#fff;text-decoration:none;font-size:18px;font-weight:600}
.content-de02a0{border-bottom:1px solid #eee;padding:24px 0}
.content-de02a0 h2{font-size:20px;margin-bottom:8px}
.content-de02a0 h2 a{color:#1a1a2e;text-decoration:none}
.content-de02a0 h2 a:hover{color:#e94560}
.content-de02a0 .date{font-size:13px;color:#999;margin-bottom:8px}
.container-32c0ad{color:#e94560;text-decoration:none;font-size:14px;font-weight:600}
.inner-c34af8{padding-bottom:60px}
.inner-c34af8 h1{font-size:32px;margin-bottom:8px}
.inner-c34af8 time{font-size:13px;color:#999;display:block;margin-bottom:24px}
.inner-c34af8 h2{font-size:22px;margin:32px 0 12px}
.inner-c34af8 h3{font-size:18px;margin:24px 0 8px}
.inner-c34af8 p{margin-bottom:16px}
.inner-c34af8 ul,.inner-c34af8 ol{margin:0 0 16px 24px}
.inner-c34af8 a{color:#e94560}
.inner-c34af8 img{max-width:100%;height:auto;border-radius:8px;margin:16px 0}
footer{border-top:1px solid #eee;padding:24px 0;margin-top:40px;text-align:center;font-size:13px;color:#999}
footer a{color:#999}
.footer-f1c66d{background:#f5f5f5;border-left:3px solid #999;padding:10px 14px;margin-bottom:20px;font-size:13px;color:#777;font-style:italic}
.header-500f7e{background:#fef9e7;border:1px solid #f0c36d;padding:10px 14px;margin-top:20px;font-size:12px;color:#8a6d3b}
.region-3323d3{font-size:13px;color:#999;margin:-16px 0 24px;font-style:italic}
.module-42b44f{text-align:center;margin:0 0 20px}
.footer-29d1f9{max-width:100%;height:auto;border-radius:6px}
.widget-1b95c5{text-align:center;margin:24px 0}
.container-32844a{max-width:100%;height:auto;border-radius:6px}
.header-dc9e07{margin-top:40px;padding-top:24px;border-top:1px solid #eee}
.header-dc9e07 h3{font-size:18px;margin-bottom:12px}
.header-dc9e07 ul{list-style:none;padding:0}
.header-dc9e07 li{padding:4px 0}
.header-dc9e07 a{color:#e94560;text-decoration:none}
/* === Theme === */
:root{--primary:#C9722B;--accent:#2C4055;--bg:#ECE3CA;--fg:#1A1F2A;--border:#C9BFA6;--r:3px;--fb:'IBM Plex Sans';--fh:'Roboto Slab'}
/* === Custom === */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:ital,wght@0,400;0,500;0,700;1,400&family=Roboto+Slab:wght@500;700&display=swap');

:root body {
  font-family: var(--fb), system-ui, -apple-system, sans-serif;
  color: var(--fg);
  background: var(--bg);
  line-height: 1.74;
  font-size: 16px;
}
::selection { background: var(--primary); color: var(--bg); }
:root hr { border: 0; border-top: 1px solid var(--border); margin: 28px 0; }

:root header {
  background: var(--primary);
  color: var(--bg);
  padding: 36px 0 24px;
  margin-bottom: 40px;
  border-bottom: 6px solid var(--accent);
}
:root header h1 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 30px;
  font-weight: 700;
  color: var(--bg);
  letter-spacing: -.01em;
  margin-bottom: 4px;
  line-height: 1.18;
}
:root header h1 + p {
  font-family: var(--fb), system-ui, sans-serif;
  font-size: 13.5px;
  color: rgba(236, 227, 202, .88);
  font-style: normal;
}
:root header a {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 20px;
  color: var(--bg);
  text-decoration: none;
  font-weight: 700;
  letter-spacing: -.01em;
}

:root main { padding-bottom: 60px; }

:root main > h1 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--fg);
  line-height: 1.18;
  margin: 10px 0 6px;
  letter-spacing: -.005em;
}
:root main > time {
  display: block;
  font-family: 'IBM Plex Mono', 'SFMono-Regular', 'Menlo', monospace;
  font-size: 11px;
  color: var(--accent);
  margin-bottom: 28px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

:root main > article:not(:has(> .date)) > p { margin-bottom: 16px; font-size: 16.5px; }
:root main > article:not(:has(> .date)) > h2 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--bg);
  background: var(--primary);
  padding: 8px 14px;
  margin: 36px -14px 14px;
  text-transform: uppercase;
  letter-spacing: .03em;
}
:root main > article:not(:has(> .date)) > h3 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 17px;
  font-weight: 500;
  color: var(--accent);
  margin: 24px 0 8px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--border);
}
:root main > article:not(:has(> .date)) ul,
:root main > article:not(:has(> .date)) ol { margin: 0 0 18px 22px; }
:root main > article:not(:has(> .date)) li { margin-bottom: 6px; }
:root main > article:not(:has(> .date)) blockquote {
  border-left: 4px solid var(--primary);
  padding: 8px 0 8px 18px;
  margin: 24px 0;
  font-style: italic;
  color: var(--accent);
  background: rgba(44, 64, 85, .05);
}

:root main > article:not(:has(> .date)) > p a,
:root main > article:not(:has(> .date)) > p a:visited {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: var(--primary);
  text-underline-offset: 3px;
  text-decoration-thickness: 1.5px;
}
:root main > article:not(:has(> .date)) > p a:hover {
  color: var(--primary);
  text-decoration-color: var(--accent);
}

:root main > article:not(:has(> .date)) > p a[href^="/try/"],
:root main > article:not(:has(> .date)) > p a[href^="/ref/"] {
  font-family: 'IBM Plex Mono', 'SFMono-Regular', monospace;
  font-size: 13px;
  color: var(--bg);
  background: var(--accent);
  border: 1px solid var(--accent);
  padding: 2px 8px;
  border-radius: var(--r);
  text-decoration: none;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-weight: 500;
}
:root main > article:not(:has(> .date)) > p a[href^="/try/"]:hover,
:root main > article:not(:has(> .date)) > p a[href^="/ref/"]:hover {
  background: var(--primary);
  border-color: var(--primary);
}

:root main > article:not(:has(> .date)) > div:has(> img) {
  margin: 0 0 28px;
}
:root main > article:not(:has(> .date)) > div:has(> img) > img {
  width: 100%;
  height: auto;
  display: block;
  border: 1px solid var(--border);
  border-radius: var(--r);
}

:root main > article:not(:has(> .date)) > div:has(> em) {
  border-top: 2px solid var(--primary);
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
  margin-top: 36px;
  font-size: 13px;
  color: var(--fg);
  font-family: var(--fb), system-ui, sans-serif;
  background: rgba(201, 114, 43, .04);
  padding-left: 14px;
}
:root main > article:not(:has(> .date)) > div:has(> em) em {
  font-family: var(--fh), Cambria, serif;
  font-style: normal;
  color: var(--primary);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: .14em;
  display: inline-block;
  margin-right: 8px;
  font-weight: 700;
}

:root main > article:has(> .date) {
  padding: 22px 0;
  border-bottom: 1px solid var(--border);
}
:root main > article:has(> .date):last-of-type { border-bottom: 0; }
:root main > article:has(> .date) > h2 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 4px;
  line-height: 1.3;
  letter-spacing: -.005em;
}
:root main > article:has(> .date) > h2 a {
  color: var(--fg);
  text-decoration: none;
}
:root main > article:has(> .date) > h2 a:hover { color: var(--primary); }
:root main > article:has(> .date) > .date {
  font-family: 'IBM Plex Mono', 'SFMono-Regular', monospace;
  font-size: 11px;
  color: var(--accent);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: block;
}
:root main > article:has(> .date) > p:not(.date) {
  font-size: 14.5px;
  color: var(--fg);
  opacity: .85;
  margin-bottom: 10px;
}
:root main > article:has(> .date) > a:last-child {
  font-family: 'IBM Plex Mono', 'SFMono-Regular', monospace;
  font-size: 11px;
  color: var(--primary);
  text-decoration: none;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 500;
  border: 1px solid var(--primary);
  padding: 4px 10px;
  display: inline-block;
}
:root main > article:has(> .date) > a:last-child:hover {
  background: var(--primary);
  color: var(--bg);
}

:root main > section {
  margin-top: 40px;
  padding-top: 20px;
  border-top: 2px solid var(--primary);
}
:root main > section > h3 {
  font-family: var(--fh), Cambria, 'Times New Roman', serif;
  font-size: 14px;
  color: var(--primary);
  margin-bottom: 14px;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 700;
}
:root main > section > ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
:root main > section > ul > li {
  padding: 8px 0;
  border-bottom: 1px dotted var(--border);
}
:root main > section > ul > li:last-child { border-bottom: 0; }
:root main > section > ul > li > a {
  color: var(--fg);
  text-decoration: none;
  font-family: var(--fb), system-ui, sans-serif;
  font-size: 14.5px;
}
:root main > section > ul > li > a:hover { color: var(--primary); }

:root footer {
  background: transparent;
  border-top: 1px solid var(--border);
  padding: 22px 0 32px;
  margin-top: 40px;
  text-align: center;
  font-family: 'IBM Plex Mono', 'SFMono-Regular', monospace;
  font-size: 11px;
  color: var(--fg);
  opacity: .58;
  letter-spacing: .08em;
}
:root footer a {
  color: var(--fg);
  text-decoration: none;
  border-bottom: 1px dotted var(--border);
}
:root footer a:hover {
  color: var(--primary);
  border-bottom-color: var(--primary);
}
