/*
Theme Name: dhavid.com
Theme URI: https://dhavid.com
Author: Dhavid Claudius Gunawan
Author URI: https://dhavid.com
Description: A clean, minimal black-and-white blog theme with bold lines and a terminal/techy aesthetic. Grotesk headlines, mono details, one accent colour. Built for tutorials, deals, and random things.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dhavid
Tags: blog, one-column, two-columns, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   Tokens
   ============================================================ */
:root{
	--paper:#FAFAF9;
	--ink:#0A0A0A;
	--ac:#00C16A;
	--muted:#6B6B66;
	--muted-2:#9A9A95;
	--line:rgba(10,10,10,.13);
	--grotesk:"Archivo",Helvetica,Arial,sans-serif;
	--mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
	--wrap:1200px;
}

/* ============================================================
   Base
   ============================================================ */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
	margin:0;
	background-color:var(--paper);
	background-image:
		linear-gradient(rgba(10,10,10,.035) 1px,transparent 1px),
		linear-gradient(90deg,rgba(10,10,10,.035) 1px,transparent 1px);
	background-size:28px 28px;
	color:var(--ink);
	font-family:var(--grotesk);
	font-size:17px;
	line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
@keyframes dh-blink{0%,49%{opacity:1}50%,100%{opacity:0}}
@keyframes dh-ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   Status bar
   ============================================================ */
.topbar{background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:12px;letter-spacing:.02em}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:8px 24px}
.topbar__path{display:flex;align-items:center;gap:9px}
.topbar__led{width:9px;height:9px;background:var(--ac);border-radius:50%}
.topbar__dim{opacity:.5}
.topbar__right{display:flex;gap:18px;align-items:center}
.topbar__right .dim{opacity:.55}

/* ============================================================
   Masthead
   ============================================================ */
.masthead{background:var(--paper);border-bottom:3px solid var(--ink)}
.masthead__inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;padding:22px 24px}
.brand{display:flex;align-items:center}
.brand__name{font-weight:900;font-size:30px;letter-spacing:-.025em}
.brand img{max-height:40px;width:auto}
.brand__cursor{width:13px;height:25px;background:var(--ac);display:inline-block;margin-left:7px;animation:dh-blink 1.1s step-end infinite}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:4px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.09em;font-weight:500}
.main-nav a{display:block;padding:9px 13px;border:2px solid transparent}
.main-nav a:hover,.main-nav .current-menu-item > a{border:2px solid var(--ink)}

/* ============================================================
   Command bar / search
   ============================================================ */
.cmdbar{background:var(--ink);border-bottom:3px solid var(--ink)}
.cmdbar__inner{display:flex;align-items:center;gap:10px;padding:12px 24px;color:var(--paper);font-family:var(--mono);font-size:13px}
.cmdbar__sigil{color:var(--ac);font-weight:700}
.cmdbar__dim{opacity:.6}
.search-form{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.search-form input[type=search]{flex:1;min-width:120px;background:transparent;border:none;outline:none;color:var(--paper);font:inherit}
.search-form input[type=search]::placeholder{color:rgba(250,250,249,.45)}
.search-form button{background:none;border:none;color:var(--ac);font-family:var(--mono);font-weight:700;cursor:pointer;text-transform:uppercase;font-size:11px;letter-spacing:.06em}
.cmdbar__count{margin-left:auto;opacity:.55;white-space:nowrap}

/* ============================================================
   Ticker
   ============================================================ */
.ticker{background:var(--paper);border-bottom:3px solid var(--ink);display:flex;align-items:stretch;overflow:hidden;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em}
.ticker__label{background:var(--ink);color:var(--paper);padding:11px 16px;white-space:nowrap;font-weight:700;flex:none;display:flex;align-items:center;gap:7px}
.ticker__label span{color:var(--ac)}
.ticker__track-wrap{overflow:hidden;flex:1;display:flex;align-items:center}
.ticker__track{display:inline-flex;white-space:nowrap;animation:dh-ticker 28s linear infinite;will-change:transform}
.ticker__item{padding:0 22px}
.ticker__item::before{content:"\25CF";color:var(--ac);margin-right:9px}

/* ============================================================
   Shared bits
   ============================================================ */
.cat-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.11em;font-weight:700;border:1.5px solid var(--ink);padding:4px 9px}
.cat-tag:hover{background:var(--ink);color:var(--paper)}
.cat-tag__dot{width:8px;height:8px;background:var(--ac);display:inline-block}
.thumb{position:relative;border:2px solid var(--ink);overflow:hidden}
.thumb__img{width:100%;height:100%;object-fit:cover}
.thumb--placeholder{min-height:128px;background-color:#ECECE9;background-image:repeating-linear-gradient(135deg,rgba(10,10,10,.8) 0 1.5px,transparent 1.5px 10px)}
.thumb__cap{position:absolute;left:0;bottom:0;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:10px;padding:3px 7px;letter-spacing:.02em}
.btn-cli{display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:13px 22px;cursor:pointer;border:none}
.btn-cli:hover{background:var(--ac);color:var(--ink)}

/* ============================================================
   Featured
   ============================================================ */
.featured{display:grid;grid-template-columns:1.05fr .95fr;border-bottom:3px solid var(--ink)}
.featured__media{position:relative;border-right:3px solid var(--ink);min-height:360px;overflow:hidden}
.featured__media .thumb{border:none;height:100%}
.featured__media .thumb--placeholder{min-height:360px}
.featured__flag{position:absolute;top:0;left:0;background:var(--ac);color:var(--ink);font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:7px 12px;z-index:2}
.featured__body{padding:38px 40px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.featured__title{margin:0;font-weight:900;font-size:40px;line-height:1.02;letter-spacing:-.025em}
.featured__title a:hover{color:var(--ink)}
.featured__meta{font-family:var(--mono);font-size:12.5px;color:var(--muted)}
.featured__excerpt{margin:0;font-size:15.5px;line-height:1.65;color:#3A3A37;max-width:54ch}
.featured .cat-tag{align-self:flex-start;border-width:2px;padding:6px 11px}
.featured .btn-cli{align-self:flex-start}

/* ============================================================
   Content grid (list + sidebar)
   ============================================================ */
.content-grid{display:grid;grid-template-columns:1fr 312px;border-bottom:3px solid var(--ink)}
.post-list{border-right:3px solid var(--ink);min-width:0}
.list-tools{display:flex;flex-wrap:wrap;gap:8px;padding:18px 28px;border-bottom:1px solid var(--line);align-items:center}
.list-tools__label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-right:4px}
.chip{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;padding:6px 10px;border:1.5px solid var(--ink);cursor:pointer;font-weight:600;background:transparent;color:var(--ink)}
.chip:hover,.chip.is-active{background:var(--ink);color:var(--paper)}
.chip span{opacity:.5}

.post-card{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:26px 28px;border-bottom:1px solid var(--line);align-items:start;background:transparent;transition:box-shadow .16s ease,background .16s ease}
.post-card:hover{box-shadow:inset 5px 0 0 var(--ac);background:#fff}
.post-card--no-thumb{grid-template-columns:1fr}
.post-card__media{align-self:stretch}
.post-card__media .thumb{height:100%}
.post-card__head{display:flex;align-items:center;gap:12px;margin-bottom:9px;flex-wrap:wrap}
.post-card__date{font-family:var(--mono);font-size:11.5px;color:var(--muted-2)}
.entry-title{margin:0 0 8px;font-weight:800;font-size:23px;line-height:1.12;letter-spacing:-.015em}
.entry-title a{border-bottom:2px solid transparent}
.entry-title a:hover{border-bottom:2px solid var(--ac)}
.post-card__excerpt{margin:0 0 10px;font-size:14px;line-height:1.6;color:#5A5A55;max-width:62ch}
.post-card__foot{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11.5px;color:var(--muted)}
.post-card__foot .sep{color:var(--ac)}
.post-card__more{font-weight:700}
.post-card__more:hover{color:var(--ac)}
.post-card__idx{margin-left:auto;font-family:var(--mono);font-size:11.5px;font-weight:700;color:#D3D3CC}

/* Pagination */
.pagination{padding:22px 28px;font-family:var(--mono);font-size:13px}
.pagination .nav-links{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pagination .page-numbers{padding:7px 11px;border:1.5px solid rgba(10,10,10,.2)}
.pagination .page-numbers:hover{border-color:var(--ink)}
.pagination .page-numbers.current{background:var(--ink);color:var(--paper);border-color:var(--ink);font-weight:700}
.pagination .page-numbers.dots{border:none}

/* ============================================================
   Sidebar / widgets
   ============================================================ */
.sidebar{padding:26px 24px;display:flex;flex-direction:column;gap:34px;background:var(--paper)}
.widget-title{margin:0 0 14px;font-family:var(--mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em}
.widget-title__mark{color:var(--ac)}
.widget ul{list-style:none;margin:0;padding:0}
.widget li{border-top:1px solid var(--line);padding:10px 0;font-size:14px;font-weight:600;letter-spacing:-.01em}
.widget li:hover{color:var(--ac)}
.widget a{display:block}

/* Subscribe block (can be placed as a Text/HTML widget too) */
.subscribe{background:var(--ink);color:var(--paper);padding:20px}
.subscribe__kicker{font-family:var(--mono);font-size:11px;opacity:.55;text-transform:uppercase;letter-spacing:.1em}
.subscribe__line{font-family:var(--mono);font-size:13px;margin-top:12px;line-height:1.5}
.subscribe__line span{color:var(--ac);font-weight:700}
.subscribe__form{display:flex;margin-top:15px;border:2px solid var(--paper)}
.subscribe__form input{flex:1;min-width:0;background:transparent;border:none;color:var(--paper);padding:11px;font-family:var(--mono);font-size:12.5px;outline:none}
.subscribe__form input::placeholder{color:rgba(250,250,249,.4)}
.subscribe__form button{background:var(--ac);border:none;color:var(--ink);font-weight:900;padding:0 16px;cursor:pointer;font-size:15px}

/* ============================================================
   Single post
   ============================================================ */
.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:9998;background:transparent}
.progress__bar{height:100%;width:0;background:var(--ac);transition:width .08s linear}
.crumb{background:var(--ink);border-bottom:3px solid var(--ink)}
.crumb__inner{display:flex;align-items:center;gap:9px;padding:11px 24px;color:var(--paper);font-family:var(--mono);font-size:12.5px}
.crumb__inner .sigil{color:var(--ac);font-weight:700}
.crumb__inner .dim{opacity:.5}
.crumb__inner a:hover{color:var(--ac)}
.crumb__right{margin-left:auto;opacity:.5}

.article-head{max-width:860px;margin:0 auto;padding:52px 0 36px}
.article-head__top{display:flex;align-items:center;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.article-head__top .date{font-family:var(--mono);font-size:12px;color:var(--muted-2)}
.article-title{margin:0;font-weight:900;font-size:50px;line-height:1.04;letter-spacing:-.03em}
.article-dek{margin:22px 0 0;font-size:19px;line-height:1.6;color:#5A5A55;max-width:62ch}
.byline{display:flex;align-items:center;gap:16px;margin-top:30px;padding-top:24px;border-top:1px solid var(--line)}
.byline__avatar{width:46px;height:46px;flex:none;border:2px solid var(--ink);background:var(--ink);color:var(--ac);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;font-size:15px}
.byline__avatar img{width:100%;height:100%;object-fit:cover}
.byline__name{font-weight:700;font-size:15px}
.byline__role{font-family:var(--mono);font-size:12px;color:#8A8A85}
.byline__stats{margin-left:auto;display:flex;gap:18px;font-family:var(--mono);font-size:12px;color:#8A8A85}
.byline__stats span span{color:var(--ac);font-weight:700}

.article-hero{max-width:1040px;margin:0 auto;border:3px solid var(--ink);position:relative;overflow:hidden;min-height:440px}
.article-hero .thumb{border:none}
.article-hero .thumb--placeholder{min-height:440px}
.article-hero__fig{position:absolute;right:0;top:0;background:var(--ac);color:var(--ink);font-family:var(--mono);font-size:11px;font-weight:700;padding:5px 10px;letter-spacing:.06em}

.article-body{display:grid;grid-template-columns:180px minmax(0,1fr) 244px;gap:52px;padding:48px 0 20px;align-items:start}
.share-rail{position:sticky;top:30px;display:flex;flex-direction:column;gap:10px;font-family:var(--mono)}
.share-rail__label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-2);margin-bottom:4px}
.share-rail a{width:42px;height:42px;border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.share-rail a:hover{background:var(--ink);color:var(--ac)}

.entry-content{min-width:0;max-width:720px;font-size:17px;line-height:1.78;color:#23231F;counter-reset:dh-h2}
.entry-content > p:first-of-type::first-letter{float:left;font-family:var(--mono);font-weight:700;font-size:58px;line-height:.82;padding:6px 14px 0 0;color:var(--ink)}
.entry-content p{margin:0 0 22px}
.entry-content h2{display:flex;align-items:baseline;gap:14px;margin:46px 0 16px;font-weight:800;font-size:29px;line-height:1.15;letter-spacing:-.02em;scroll-margin-top:90px}
.entry-content h2::before{counter-increment:dh-h2;content:counter(dh-h2,decimal-leading-zero);font-family:var(--mono);font-size:15px;color:var(--ac);font-weight:700}
.entry-content h3{margin:34px 0 12px;font-weight:800;font-size:22px;letter-spacing:-.015em}
.entry-content a{border-bottom:2px solid var(--ac)}
.entry-content a:hover{background:var(--ac);color:var(--ink)}
.entry-content ul,.entry-content ol{margin:0 0 24px;padding:0 0 0 4px;list-style:none}
.entry-content li{position:relative;padding:6px 0 6px 26px}
.entry-content ul li::before{content:"";position:absolute;left:0;top:12px;width:8px;height:8px;background:var(--ac)}
.entry-content ol{counter-reset:dh-li}
.entry-content ol li::before{counter-increment:dh-li;content:counter(dh-li);position:absolute;left:0;top:4px;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--ac)}
.entry-content code{font-family:var(--mono);font-size:.86em;background:#EDEDE9;border:1px solid rgba(10,10,10,.12);padding:1px 6px}
.entry-content pre{margin:0;padding:16px 18px;font-family:var(--mono);font-size:13.5px;line-height:1.75;overflow:auto;background:var(--ink);color:var(--paper)}
.entry-content pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit}
.entry-content blockquote{border-left:4px solid var(--ac);background:#F1F1ED;padding:16px 20px;margin:0 0 26px;font-size:16px;line-height:1.6;font-style:italic;color:#3A3A37}
.entry-content blockquote p{margin:0}
.entry-content img{border:2px solid var(--ink);margin:0 0 14px}
.entry-content .wp-caption-text,.entry-content figcaption{font-family:var(--mono);font-size:12.5px;color:#8A8A85;text-align:center;margin:0 0 22px}

/* JS-wrapped code block with copy button */
.code-wrap{border:2px solid var(--ink);margin:0 0 22px;background:var(--ink)}
.code-wrap__bar{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;border-bottom:1px solid rgba(250,250,249,.14);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:rgba(250,250,249,.55)}
.code-wrap__copy{background:none;border:none;color:var(--ac);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;cursor:pointer;padding:0}
.code-wrap pre{margin:0}

.entry-tags{display:flex;flex-wrap:wrap;gap:8px;margin:36px 0 0;padding-top:26px;border-top:1px solid var(--line)}
.entry-tags a{font-family:var(--mono);font-size:12px;border:1.5px solid var(--ink);padding:6px 11px;border-bottom:1.5px solid var(--ink)}
.entry-tags a:hover{background:var(--ink);color:var(--ac)}

/* TOC */
.post-aside{position:sticky;top:30px;display:flex;flex-direction:column;gap:30px}
.toc__title{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.toc__title span{color:var(--ac)}
.toc__list{display:flex;flex-direction:column;border-left:2px solid var(--line);font-family:var(--mono)}
.toc__list a{padding:9px 16px;margin-left:-2px;font-size:12.5px;line-height:1.35;border-left:2px solid transparent;color:#8A8A85;font-weight:500}
.toc__list a.is-active{border-left-color:var(--ac);color:var(--ink);font-weight:700}

/* Support widget */
.support{border:2px solid var(--ink);background:var(--paper)}
.support__head{background:var(--ink);color:var(--paper);padding:10px 14px;font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:8px}
.support__dot{width:8px;height:8px;background:var(--ac);display:inline-block}
.support__body{padding:15px 14px}
.support__blurb{margin:0 0 4px;font-size:13px;line-height:1.5;color:#3A3A37}
.support__opt{display:flex;align-items:center;gap:10px;padding:11px 0;border-top:1px solid var(--line)}
.support__opt:hover{color:var(--ac)}
.support__sq{width:9px;height:9px;flex:none;background:var(--ac);display:inline-block}
.support__label{flex:1;font-weight:700;font-size:13.5px;letter-spacing:-.01em}
.support__note{font-family:var(--mono);font-size:10.5px;color:var(--muted-2)}
.support__arrow{font-family:var(--mono);font-size:12px}
.support__goal{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-family:var(--mono)}
.support__goalrow{display:flex;justify-content:space-between;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#8A8A85;margin-bottom:7px}
.support__bar{height:11px;border:2px solid var(--ink);background:var(--paper);padding:1px}
.support__fill{display:block;height:100%;background:var(--ac)}
.support__caption{font-size:11px;color:#8A8A85;margin-top:7px}

/* Author card */
.author-card{max-width:860px;margin:30px auto 0;background:var(--ink);color:var(--paper);border:3px solid var(--ink);display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;padding:26px 28px}
.author-card__avatar{width:64px;height:64px;flex:none;border:2px solid var(--ac);color:var(--ac);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;font-size:20px}
.author-card__avatar img{width:100%;height:100%;object-fit:cover}
.author-card__kicker{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.55}
.author-card__name{font-weight:800;font-size:20px;margin:3px 0 6px}
.author-card__bio{margin:0;font-size:14px;line-height:1.6;opacity:.8;max-width:52ch}
.author-card__follow{flex:none;background:var(--ac);color:var(--ink);font-family:var(--mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:12px 18px}
.author-card__follow:hover{background:var(--paper)}

/* Post nav */
.post-nav{max-width:1040px;margin:30px auto 0;display:grid;grid-template-columns:1fr 1fr;border:3px solid var(--ink)}
.post-nav a{padding:24px 26px}
.post-nav .prev{border-right:3px solid var(--ink)}
.post-nav .next{text-align:right}
.post-nav a:hover{background:var(--ink);color:var(--paper)}
.post-nav__label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-2);margin-bottom:10px}
.post-nav__title{font-weight:700;font-size:17px;line-height:1.25;letter-spacing:-.01em}

/* Related */
.related{max-width:1040px;margin:56px auto 0}
.related__grid{display:grid;grid-template-columns:repeat(3,1fr);border:3px solid var(--ink)}
.related__cell{display:block;background:var(--paper);transition:background .14s ease}
.related__cell + .related__cell{border-left:2px solid var(--ink)}
.related__cell:hover{background:#fff}
.related__media{position:relative;border-bottom:2px solid var(--ink);min-height:130px;overflow:hidden}
.related__media .thumb{border:none}
.related__media .thumb--placeholder{min-height:130px}
.related__body{padding:16px 18px}
.related__cat{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--ac);font-weight:700;margin-bottom:8px}
.related__title{font-weight:700;font-size:16px;line-height:1.25;letter-spacing:-.01em}

/* ============================================================
   Comments
   ============================================================ */
.comments{max-width:860px;margin:56px auto 0;padding-bottom:60px}
.comments__head{display:flex;align-items:baseline;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:3px solid var(--ink)}
.comments__count{font-weight:900;font-size:26px;letter-spacing:-.02em}
.comments__note{font-family:var(--mono);font-size:12px;color:var(--muted-2)}
.comment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:24px}
.comment-list ol{list-style:none;margin:18px 0 0;padding:0 0 0 30px;display:flex;flex-direction:column;gap:24px}
.comment-body{display:grid;grid-template-columns:auto 1fr;gap:16px}
.comment-avatar{width:44px;height:44px;flex:none;border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;font-size:13px;background:var(--paper);overflow:hidden}
.comment-avatar img{width:100%;height:100%;object-fit:cover}
.comment-head{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}
.comment-author{font-weight:700;font-size:14px}
.comment-meta{font-family:var(--mono);font-size:11.5px;color:var(--muted-2)}
.comment-text{font-size:14.5px;line-height:1.6;color:#3A3A37}
.comment-text p{margin:0 0 8px}
.comment-reply-link{font-family:var(--mono);font-size:11.5px;font-weight:700;color:var(--muted)}
.comment-reply-link:hover{color:var(--ac)}

.comment-respond{background:var(--ink);color:var(--paper);padding:22px 24px;margin-bottom:34px}
.comment-respond .comment-reply-title{margin:0 0 14px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.55;font-weight:500}
.comment-respond .comment-reply-title small a{color:var(--ac)}
.comment-form{display:flex;flex-direction:column;gap:12px}
.comment-form-author,.comment-form-email{display:inline-block}
.comment-form .comment-form-author,.comment-form .comment-form-email{width:calc(50% - 6px)}
.comment-form-author{margin-right:12px}
.comment-form label{display:block;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;opacity:.6;margin-bottom:4px}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;background:transparent;border:2px solid rgba(250,250,249,.45);color:var(--paper);padding:11px 13px;font-family:var(--mono);font-size:13px;outline:none}
.comment-form textarea{resize:vertical}
.comment-form :focus{border-color:var(--ac)}
.comment-form .form-submit{margin:0;text-align:right}
.comment-form .submit{background:var(--ac);color:var(--ink);border:none;font-family:var(--mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:12px 22px;cursor:pointer}
.comment-form .submit:hover{background:var(--paper)}
.comment-form .comment-form-cookies-consent{display:flex;align-items:center;gap:8px}
.comment-form .comment-form-cookies-consent label{margin:0}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--ink);color:var(--paper)}
.site-footer__top{display:flex;justify-content:space-between;align-items:flex-start;gap:28px;flex-wrap:wrap;padding:34px 24px}
.site-footer__brand{display:flex;align-items:center}
.site-footer__name{font-weight:900;font-size:24px;letter-spacing:-.025em}
.site-footer__cursor{width:11px;height:20px;background:var(--ac);display:inline-block;margin-left:6px;animation:dh-blink 1.1s step-end infinite}
.site-footer__tag{font-family:var(--mono);font-size:12px;opacity:.6;margin-top:10px;letter-spacing:.02em}
.site-footer__nav ul{list-style:none;margin:0;padding:0;display:flex;gap:22px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.07em}
.site-footer__nav a:hover{color:var(--ac)}
.site-footer__legal{border-top:1px solid rgba(250,250,249,.14)}
.site-footer__legal-inner{padding:14px 24px;font-family:var(--mono);font-size:11px;opacity:.5;letter-spacing:.03em}

/* ============================================================
   Custom cursor
   ============================================================ */
.dh-cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;opacity:0;transition:opacity .2s ease;will-change:transform}
.dh-cursor__dot{width:20px;height:20px;border:2px solid var(--ac);border-radius:2px;transform:translate(-50%,-50%);transition:transform .13s ease,background .13s ease,border-radius .13s ease,opacity .13s ease}
body.has-custom-cursor.dh-cursor-active,
body.has-custom-cursor.dh-cursor-active *{cursor:none !important}

/* ============================================================
   404 / search-none
   ============================================================ */
.page-stub{max-width:860px;margin:0 auto;padding:80px 24px;min-height:40vh}
.page-stub h1{font-weight:900;font-size:64px;letter-spacing:-.03em;margin:0 0 16px}
.page-stub p{font-family:var(--mono);font-size:14px;color:var(--muted);line-height:1.7}
.page-stub .sigil{color:var(--ac)}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1000px){
	.article-body{grid-template-columns:minmax(0,1fr);gap:32px}
	.share-rail{flex-direction:row;position:static}
	.post-aside{position:static}
	.featured{grid-template-columns:1fr}
	.featured__media{border-right:none;border-bottom:3px solid var(--ink)}
	.content-grid{grid-template-columns:1fr}
	.post-list{border-right:none;border-bottom:3px solid var(--ink)}
}
@media(max-width:680px){
	.article-title{font-size:34px}
	.featured__title{font-size:30px}
	.post-card{grid-template-columns:1fr}
	.post-card__media{max-width:none}
	.byline{flex-wrap:wrap}
	.byline__stats{margin-left:0;width:100%}
	.author-card{grid-template-columns:1fr;text-align:left}
	.post-nav{grid-template-columns:1fr}
	.post-nav .prev{border-right:none;border-bottom:3px solid var(--ink)}
	.post-nav .next{text-align:left}
	.related__grid{grid-template-columns:1fr}
	.related__cell + .related__cell{border-left:none;border-top:2px solid var(--ink)}
	.comment-form .comment-form-author,.comment-form .comment-form-email{width:100%;margin-right:0}
}
@media(max-width:480px){
	.entry-content > p:first-of-type::first-letter{font-size:44px}
	.page-stub h1{font-size:44px}
}
