/*!
Theme Name: Devlog Twenty Twenty-Six
Theme URI: https://example.com/devlog-2k26
Author: Pete
Author URI: https://example.com
Description: A standards-compliant, security-conscious WordPress theme for writing about tech, AI, and programming. Ships with device-aware light/dark modes, a monospace terminal-inspired display face (JetBrains Mono) paired with Inter for body copy, first-class syntax highlighting, and help-documentation-style treatment for inline code, function names and keyboard shortcuts. Fully Customizer-aware.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: devlog-2k26
Tags: blog, one-column, two-columns, right-sidebar, custom-colors, custom-logo, custom-menu, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready, block-styles, wide-blocks, accessibility-ready
*/

/* =============================================================================
   1. DESIGN TOKENS (light is the default, dark overrides via [data-theme])
   ----------------------------------------------------------------------------
   All colors, spacing, typography, and radii are declared here so the
   Customizer can override individual tokens without touching component CSS.
   ============================================================================= */

:root {
	/* Typography */
	--dl-font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--dl-font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;

	--dl-text-base: 1.0625rem;      /* 17px */
	--dl-text-sm:   0.875rem;       /* 14px */
	--dl-text-xs:   0.75rem;        /* 12px */
	--dl-text-lg:   1.1875rem;      /* 19px */
	--dl-text-xl:   1.4375rem;      /* 23px */
	--dl-text-2xl:  1.75rem;        /* 28px */
	--dl-text-3xl:  2.1875rem;      /* 35px */
	--dl-text-4xl:  2.75rem;        /* 44px */

	--dl-leading-tight: 1.25;
	--dl-leading-snug:  1.4;
	--dl-leading-body:  1.7;

	--dl-tracking-tight: -0.01em;
	--dl-tracking-mono:  -0.005em;

	/* Spacing scale */
	--dl-sp-1: 0.25rem;
	--dl-sp-2: 0.5rem;
	--dl-sp-3: 0.75rem;
	--dl-sp-4: 1rem;
	--dl-sp-5: 1.5rem;
	--dl-sp-6: 2rem;
	--dl-sp-7: 3rem;
	--dl-sp-8: 4rem;
	--dl-sp-9: 6rem;

	/* Layout */
	--dl-content-width: 42rem;      /* ~672px reading width */
	--dl-wide-width:    56rem;      /* for images/figures/wide blocks */
	--dl-page-width:    72rem;      /* max page frame */
	--dl-radius-sm: 4px;
	--dl-radius-md: 6px;
	--dl-radius-lg: 10px;

	/* Motion */
	--dl-dur-fast: 120ms;
	--dl-dur-med:  200ms;
	--dl-ease: cubic-bezier(0.4, 0, 0.2, 1);

	/* LIGHT THEME COLORS */
	--dl-bg:            #fafaf7;
	--dl-bg-elev:       #ffffff;
	--dl-bg-sunken:     #f3f3ef;
	--dl-ink:           #1a1a1a;
	--dl-ink-soft:      #2e2e2e;
	--dl-muted:         #6e7781;
	--dl-muted-soft:    #9aa1a8;
	--dl-rule:          #e4e4de;
	--dl-rule-strong:   #cfcfc8;
	--dl-accent:        #0969da;
	--dl-accent-hover:  #0550ae;
	--dl-accent-soft:   rgba(9, 105, 218, 0.08);
	--dl-highlight:     #8250df;     /* used for inline identifiers */
	--dl-highlight-soft: rgba(130, 80, 223, 0.10);

	/* Inline <code> "identifier" pill */
	--dl-code-bg:       #f3f3ef;
	--dl-code-ink:      #8250df;
	--dl-code-border:   rgba(130, 80, 223, 0.18);

	/* <kbd> keycap */
	--dl-kbd-bg:        #ffffff;
	--dl-kbd-bg-bottom: #f0f0ea;
	--dl-kbd-ink:       #2e2e2e;
	--dl-kbd-border:    #cfcfc8;
	--dl-kbd-shadow:    0 1px 0 0 #cfcfc8, 0 2px 0 0 #ffffff inset, 0 -1px 0 0 #e4e4de inset;

	/* Code blocks / syntax (Prism-compatible token palette) */
	--dl-cb-bg:         #f6f5f0;
	--dl-cb-ink:        #1a1a1a;
	--dl-cb-gutter:     #9aa1a8;
	--dl-cb-selection:  rgba(9, 105, 218, 0.18);
	--dl-cb-border:     #e4e4de;
	--dl-tok-comment:   #7a828a;
	--dl-tok-string:    #116329;
	--dl-tok-number:    #953800;
	--dl-tok-keyword:   #cf222e;
	--dl-tok-function:  #8250df;
	--dl-tok-class:     #953800;
	--dl-tok-operator:  #0550ae;
	--dl-tok-punct:     #24292f;
	--dl-tok-tag:       #116329;
	--dl-tok-attr:      #0550ae;
	--dl-tok-builtin:   #cf222e;
	--dl-tok-regex:     #116329;

	/* Focus ring */
	--dl-focus: 0 0 0 3px rgba(9, 105, 218, 0.35);

	/* Shadows */
	--dl-shadow-sm: 0 1px 2px rgba(15, 20, 25, 0.06);
	--dl-shadow-md: 0 4px 14px rgba(15, 20, 25, 0.08);
}

/* DARK THEME (applied via [data-theme="dark"], set by JS; also respects prefers-color-scheme when no choice is stored) */
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) {
		color-scheme: dark;
		--dl-bg:            #0f1419;
		--dl-bg-elev:       #141a21;
		--dl-bg-sunken:     #0b1016;
		--dl-ink:           #e6e6e6;
		--dl-ink-soft:      #c9d1d9;
		--dl-muted:         #8b949e;
		--dl-muted-soft:    #5c6773;
		--dl-rule:          #222b36;
		--dl-rule-strong:   #30363d;
		--dl-accent:        #7dcfff;
		--dl-accent-hover:  #a5e3ff;
		--dl-accent-soft:   rgba(125, 207, 255, 0.12);
		--dl-highlight:     #bb9af7;
		--dl-highlight-soft: rgba(187, 154, 247, 0.14);

		--dl-code-bg:       #161b22;
		--dl-code-ink:      #bb9af7;
		--dl-code-border:   rgba(187, 154, 247, 0.22);

		--dl-kbd-bg:        #1b222b;
		--dl-kbd-bg-bottom: #0f141a;
		--dl-kbd-ink:       #e6e6e6;
		--dl-kbd-border:    #30363d;
		--dl-kbd-shadow:    0 1px 0 0 #000, 0 2px 0 0 rgba(255,255,255,0.04) inset, 0 -1px 0 0 #0b0e12 inset;

		--dl-cb-bg:         #11161d;
		--dl-cb-ink:        #e6e6e6;
		--dl-cb-gutter:     #5c6773;
		--dl-cb-selection:  rgba(125, 207, 255, 0.22);
		--dl-cb-border:     #222b36;
		--dl-tok-comment:   #5c6773;
		--dl-tok-string:    #9ece6a;
		--dl-tok-number:    #ff9e64;
		--dl-tok-keyword:   #f7768e;
		--dl-tok-function:  #7dcfff;
		--dl-tok-class:     #e0af68;
		--dl-tok-operator:  #89ddff;
		--dl-tok-punct:     #c9d1d9;
		--dl-tok-tag:       #f7768e;
		--dl-tok-attr:      #bb9af7;
		--dl-tok-builtin:   #f7768e;
		--dl-tok-regex:     #b4f9f8;

		--dl-focus: 0 0 0 3px rgba(125, 207, 255, 0.45);

		--dl-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.35);
		--dl-shadow-md: 0 4px 14px rgba(0, 0, 0, 0.45);
	}
}

/* Explicit dark mode override (user clicked the toggle) */
:root[data-theme="dark"] {
	color-scheme: dark;
	--dl-bg:            #0f1419;
	--dl-bg-elev:       #141a21;
	--dl-bg-sunken:     #0b1016;
	--dl-ink:           #e6e6e6;
	--dl-ink-soft:      #c9d1d9;
	--dl-muted:         #8b949e;
	--dl-muted-soft:    #5c6773;
	--dl-rule:          #222b36;
	--dl-rule-strong:   #30363d;
	--dl-accent:        #7dcfff;
	--dl-accent-hover:  #a5e3ff;
	--dl-accent-soft:   rgba(125, 207, 255, 0.12);
	--dl-highlight:     #bb9af7;
	--dl-highlight-soft: rgba(187, 154, 247, 0.14);
	--dl-code-bg:       #161b22;
	--dl-code-ink:      #bb9af7;
	--dl-code-border:   rgba(187, 154, 247, 0.22);
	--dl-kbd-bg:        #1b222b;
	--dl-kbd-bg-bottom: #0f141a;
	--dl-kbd-ink:       #e6e6e6;
	--dl-kbd-border:    #30363d;
	--dl-kbd-shadow:    0 1px 0 0 #000, 0 2px 0 0 rgba(255,255,255,0.04) inset, 0 -1px 0 0 #0b0e12 inset;
	--dl-cb-bg:         #11161d;
	--dl-cb-ink:        #e6e6e6;
	--dl-cb-gutter:     #5c6773;
	--dl-cb-selection:  rgba(125, 207, 255, 0.22);
	--dl-cb-border:     #222b36;
	--dl-tok-comment:   #5c6773;
	--dl-tok-string:    #9ece6a;
	--dl-tok-number:    #ff9e64;
	--dl-tok-keyword:   #f7768e;
	--dl-tok-function:  #7dcfff;
	--dl-tok-class:     #e0af68;
	--dl-tok-operator:  #89ddff;
	--dl-tok-punct:     #c9d1d9;
	--dl-tok-tag:       #f7768e;
	--dl-tok-attr:      #bb9af7;
	--dl-tok-builtin:   #f7768e;
	--dl-tok-regex:     #b4f9f8;
	--dl-focus: 0 0 0 3px rgba(125, 207, 255, 0.45);
	--dl-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.35);
	--dl-shadow-md: 0 4px 14px rgba(0, 0, 0, 0.45);
}

/* =============================================================================
   2. RESET / BASE
   ============================================================================= */

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
	tab-size: 4;
	scroll-padding-top: var(--dl-sp-7);
}

body {
	margin: 0;
	background: var(--dl-bg);
	color: var(--dl-ink);
	font-family: var(--dl-font-body);
	font-size: var(--dl-text-base);
	line-height: var(--dl-leading-body);
	font-feature-settings: "kern", "liga", "calt", "ss01";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	transition: background-color var(--dl-dur-med) var(--dl-ease), color var(--dl-dur-med) var(--dl-ease);
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}
}

img,
picture,
video,
canvas,
svg {
	display: block;
	max-width: 100%;
	height: auto;
}

hr {
	border: 0;
	border-top: 1px solid var(--dl-rule);
	margin: var(--dl-sp-7) 0;
}

::selection {
	background: var(--dl-accent-soft);
	color: var(--dl-ink);
}

/* =============================================================================
   3. ACCESSIBILITY UTILITIES
   ============================================================================= */

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--dl-bg-elev);
	border-radius: var(--dl-radius-sm);
	box-shadow: var(--dl-focus);
	clip: auto !important;
	clip-path: none;
	color: var(--dl-ink);
	display: block;
	font-size: var(--dl-text-sm);
	font-weight: 600;
	height: auto;
	left: var(--dl-sp-4);
	line-height: normal;
	padding: var(--dl-sp-3) var(--dl-sp-4);
	text-decoration: none;
	top: var(--dl-sp-4);
	width: auto;
	z-index: 100000;
}

.skip-link {
	font-family: var(--dl-font-mono);
}

:focus-visible {
	outline: none;
	box-shadow: var(--dl-focus);
	border-radius: var(--dl-radius-sm);
}

/* =============================================================================
   4. TYPOGRAPHY (article body)
   ============================================================================= */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--dl-font-mono);
	font-weight: 600;
	letter-spacing: var(--dl-tracking-mono);
	line-height: var(--dl-leading-tight);
	color: var(--dl-ink);
	margin: var(--dl-sp-6) 0 var(--dl-sp-4);
	overflow-wrap: break-word;
}

h1 { font-size: var(--dl-text-4xl); letter-spacing: -0.02em; }
h2 { font-size: var(--dl-text-3xl); }
h3 { font-size: var(--dl-text-2xl); }
h4 { font-size: var(--dl-text-xl); }
h5 { font-size: var(--dl-text-lg); }
h6 { font-size: var(--dl-text-base); text-transform: uppercase; letter-spacing: 0.08em; color: var(--dl-muted); }

p {
	margin: 0 0 var(--dl-sp-4);
	overflow-wrap: break-word;
	hyphens: auto;
}

a {
	color: var(--dl-accent);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	text-decoration-color: color-mix(in srgb, var(--dl-accent) 45%, transparent);
	transition: color var(--dl-dur-fast) var(--dl-ease), text-decoration-color var(--dl-dur-fast) var(--dl-ease);
}

a:hover,
a:focus-visible {
	color: var(--dl-accent-hover);
	text-decoration-color: var(--dl-accent-hover);
}

strong, b { font-weight: 700; }
em, i { font-style: italic; }

small { font-size: var(--dl-text-sm); color: var(--dl-muted); }

abbr[title] {
	text-decoration: underline dotted;
	cursor: help;
}

mark {
	background: var(--dl-highlight-soft);
	color: var(--dl-ink);
	padding: 0 0.2em;
	border-radius: 2px;
}

blockquote {
	margin: var(--dl-sp-6) 0;
	padding: var(--dl-sp-3) var(--dl-sp-5);
	border-left: 3px solid var(--dl-accent);
	background: var(--dl-bg-sunken);
	color: var(--dl-ink-soft);
	border-radius: 0 var(--dl-radius-md) var(--dl-radius-md) 0;
}

blockquote cite {
	display: block;
	margin-top: var(--dl-sp-2);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	color: var(--dl-muted);
	font-style: normal;
}

ul, ol {
	padding-left: var(--dl-sp-5);
	margin: 0 0 var(--dl-sp-4);
}

li + li,
li > ul,
li > ol {
	margin-top: var(--dl-sp-2);
}

dl dt { font-weight: 700; margin-top: var(--dl-sp-3); }
dl dd { margin: 0 0 var(--dl-sp-3); padding-left: var(--dl-sp-4); color: var(--dl-ink-soft); }

table {
	width: 100%;
	border-collapse: collapse;
	margin: var(--dl-sp-5) 0;
	font-size: var(--dl-text-sm);
}

th, td {
	text-align: left;
	padding: var(--dl-sp-3);
	border-bottom: 1px solid var(--dl-rule);
}

th {
	font-family: var(--dl-font-mono);
	font-weight: 600;
	color: var(--dl-ink);
	background: var(--dl-bg-sunken);
}

figure {
	margin: var(--dl-sp-6) 0;
}

figcaption {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
	margin-top: var(--dl-sp-2);
	letter-spacing: 0.02em;
}

/* =============================================================================
   5. INLINE CODE, <kbd>, <samp>, <var> — help-documentation style
   ============================================================================= */

/* Inline <code> styled as an "identifier pill" — great for function names,
   variables, file paths, flags. Distinct from code blocks. */
:not(pre) > code,
.wp-block-code code,
code.inline-code {
	font-family: var(--dl-font-mono);
	font-size: 0.9em;
	background: var(--dl-code-bg);
	color: var(--dl-code-ink);
	padding: 0.15em 0.4em;
	border: 1px solid var(--dl-code-border);
	border-radius: var(--dl-radius-sm);
	white-space: break-spaces;
	letter-spacing: var(--dl-tracking-mono);
}

/* Inside a code block, the <code> child should inherit, not re-pillify. */
pre > code {
	background: transparent;
	color: inherit;
	padding: 0;
	border: 0;
	border-radius: 0;
	font-size: 1em;
}

/* Keyboard shortcuts — raised keycap look */
kbd {
	font-family: var(--dl-font-mono);
	font-size: 0.82em;
	font-weight: 600;
	display: inline-block;
	padding: 0.15em 0.55em 0.1em;
	line-height: 1.4;
	background: linear-gradient(180deg, var(--dl-kbd-bg) 0%, var(--dl-kbd-bg-bottom) 100%);
	color: var(--dl-kbd-ink);
	border: 1px solid var(--dl-kbd-border);
	border-radius: var(--dl-radius-sm);
	box-shadow: var(--dl-kbd-shadow);
	white-space: nowrap;
	vertical-align: 1px;
}

/* A chain of keys like <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>P</kbd>:
   render the "+" in a muted mono glyph so it reads as a combo. */
kbd + kbd {
	margin-left: 0.15em;
}

samp {
	font-family: var(--dl-font-mono);
	font-size: 0.9em;
	color: var(--dl-ink-soft);
	background: var(--dl-bg-sunken);
	padding: 0.1em 0.3em;
	border-radius: var(--dl-radius-sm);
}

var {
	font-family: var(--dl-font-mono);
	font-style: normal;
	color: var(--dl-highlight);
	background: var(--dl-highlight-soft);
	padding: 0 0.25em;
	border-radius: 2px;
}

/* =============================================================================
   6. CODE BLOCKS (<pre>) + syntax-highlighting tokens
   ============================================================================= */

pre,
.wp-block-code,
.wp-block-preformatted {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	line-height: 1.6;
	background: var(--dl-cb-bg);
	color: var(--dl-cb-ink);
	padding: var(--dl-sp-4) var(--dl-sp-5);
	margin: var(--dl-sp-5) 0;
	border: 1px solid var(--dl-cb-border);
	border-radius: var(--dl-radius-md);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	tab-size: 2;
	box-shadow: var(--dl-shadow-sm);
	position: relative;
}

pre::selection,
pre *::selection {
	background: var(--dl-cb-selection);
}

/* A tiny language label in the top-right of the code block */
body:not(.dl-no-lang-badge) pre[data-language]::before {
	content: attr(data-language);
	position: absolute;
	top: var(--dl-sp-2);
	right: var(--dl-sp-3);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	user-select: none;
}

/* Line numbers (optional, enabled via body.dl-line-numbers from Customizer) */
body.dl-line-numbers pre[class*="language-"] {
	padding-left: calc(var(--dl-sp-5) + 2.5em);
	counter-reset: dl-line;
}

body.dl-line-numbers pre[class*="language-"] > code {
	display: block;
}

body.dl-line-numbers pre[class*="language-"] .dl-line::before {
	counter-increment: dl-line;
	content: counter(dl-line);
	position: absolute;
	left: var(--dl-sp-3);
	width: 2em;
	text-align: right;
	color: var(--dl-cb-gutter);
	user-select: none;
}

body.dl-line-numbers pre[class*="language-"] .dl-line {
	display: block;
	position: relative;
}

/* Prism-compatible token classes */
.token.comment,
.token.prolog,
.token.doctype,
.token.cdata      { color: var(--dl-tok-comment); font-style: italic; }
.token.punctuation{ color: var(--dl-tok-punct); }
.token.namespace  { opacity: 0.7; }
.token.property,
.token.tag,
.token.constant,
.token.symbol,
.token.deleted    { color: var(--dl-tok-tag); }
.token.boolean,
.token.number     { color: var(--dl-tok-number); }
.token.selector,
.token.attr-name,
.token.string,
.token.char,
.token.builtin,
.token.inserted   { color: var(--dl-tok-string); }
.token.operator,
.token.entity,
.token.url,
.language-css .token.string,
.style .token.string { color: var(--dl-tok-operator); }
.token.atrule,
.token.attr-value,
.token.keyword    { color: var(--dl-tok-keyword); font-weight: 600; }
.token.function,
.token.class-name { color: var(--dl-tok-function); }
.token.regex,
.token.important,
.token.variable   { color: var(--dl-tok-regex); }
.token.important,
.token.bold       { font-weight: 700; }
.token.italic     { font-style: italic; }

/* =============================================================================
   7. LAYOUT
   ============================================================================= */

.dl-container {
	max-width: var(--dl-page-width);
	margin: 0 auto;
	padding: 0 var(--dl-sp-5);
}

.dl-container--narrow {
	max-width: var(--dl-content-width);
}

.dl-container--wide {
	max-width: var(--dl-wide-width);
}

#page { min-height: 100vh; display: flex; flex-direction: column; }
#content { flex: 1 0 auto; padding: var(--dl-sp-6) 0 var(--dl-sp-8); }

/* Two-column with sidebar */
.dl-layout-with-sidebar {
	display: grid;
	gap: var(--dl-sp-7);
	grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 960px) {
	.dl-layout-with-sidebar {
		grid-template-columns: minmax(0, 1fr) 17rem;
	}
}

/* Alignment helpers for Gutenberg */
.alignleft  { float: left;  margin: var(--dl-sp-3) var(--dl-sp-5) var(--dl-sp-3) 0; }
.alignright { float: right; margin: var(--dl-sp-3) 0 var(--dl-sp-3) var(--dl-sp-5); }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.alignwide   { max-width: var(--dl-wide-width); margin-left: auto; margin-right: auto; }
.alignfull   { max-width: none; width: 100%; }

.wp-caption { max-width: 100%; }
.wp-caption-text,
.gallery-caption {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
}

/* =============================================================================
   8. HEADER
   ============================================================================= */

.dl-site-header {
	border-bottom: 1px solid var(--dl-rule);
	background: var(--dl-bg);
	position: sticky;
	top: 0;
	z-index: 50;
	backdrop-filter: saturate(1.6) blur(8px);
	-webkit-backdrop-filter: saturate(1.6) blur(8px);
	background-color: color-mix(in srgb, var(--dl-bg) 85%, transparent);
}

.dl-site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--dl-sp-4);
	padding: var(--dl-sp-3) 0;
}

.dl-site-branding {
	display: flex;
	align-items: center;
	gap: var(--dl-sp-3);
	min-width: 0;
}

.dl-site-title {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-lg);
	font-weight: 700;
	margin: 0;
	letter-spacing: var(--dl-tracking-mono);
	line-height: 1;
	white-space: nowrap;
}

.dl-site-title a {
	color: var(--dl-ink);
	text-decoration: none;
}

.dl-site-title a::before {
	content: "$ ";
	color: var(--dl-accent);
}

.dl-site-description {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.dl-custom-logo-link img {
	max-height: 40px;
	width: auto;
}

/* =============================================================================
   9. PRIMARY NAVIGATION
   ============================================================================= */

.dl-main-nav {
	display: flex;
	align-items: center;
	gap: var(--dl-sp-2);
}

.dl-menu-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--dl-rule);
	color: var(--dl-ink);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	padding: var(--dl-sp-2) var(--dl-sp-3);
	border-radius: var(--dl-radius-sm);
	cursor: pointer;
}

.dl-menu-toggle:hover { border-color: var(--dl-rule-strong); }

.dl-menu {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	align-items: center;
	gap: var(--dl-sp-2);
}

.dl-menu a {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	color: var(--dl-ink-soft);
	text-decoration: none;
	padding: var(--dl-sp-2) var(--dl-sp-3);
	border-radius: var(--dl-radius-sm);
	transition: background-color var(--dl-dur-fast) var(--dl-ease), color var(--dl-dur-fast) var(--dl-ease);
}

.dl-menu a:hover,
.dl-menu .current-menu-item > a,
.dl-menu .current_page_item > a {
	color: var(--dl-accent);
	background: var(--dl-accent-soft);
}

.dl-menu .sub-menu {
	display: none;
}

@media (max-width: 768px) {
	.dl-menu-toggle { display: inline-flex; align-items: center; gap: var(--dl-sp-2); }
	.dl-menu {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--dl-bg-elev);
		border-bottom: 1px solid var(--dl-rule);
		flex-direction: column;
		align-items: stretch;
		padding: var(--dl-sp-3);
		gap: 0;
	}
	.dl-main-nav.is-open .dl-menu { display: flex; }
	.dl-menu a { padding: var(--dl-sp-3) var(--dl-sp-4); }
}

/* Theme toggle button */
.dl-theme-toggle {
	background: transparent;
	border: 1px solid var(--dl-rule);
	color: var(--dl-ink);
	cursor: pointer;
	padding: var(--dl-sp-2) var(--dl-sp-3);
	border-radius: var(--dl-radius-sm);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	display: inline-flex;
	align-items: center;
	gap: var(--dl-sp-2);
	transition: border-color var(--dl-dur-fast) var(--dl-ease), background-color var(--dl-dur-fast) var(--dl-ease);
}

.dl-theme-toggle:hover { border-color: var(--dl-rule-strong); background: var(--dl-bg-sunken); }

.dl-theme-toggle__icon { width: 16px; height: 16px; flex: 0 0 auto; }

.dl-theme-toggle__icon--sun { display: none; }
.dl-theme-toggle__icon--moon { display: inline-block; }

:root[data-theme="dark"] .dl-theme-toggle__icon--sun { display: inline-block; }
:root[data-theme="dark"] .dl-theme-toggle__icon--moon { display: none; }

@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .dl-theme-toggle__icon--sun  { display: inline-block; }
	:root:not([data-theme="light"]) .dl-theme-toggle__icon--moon { display: none; }
}

.dl-theme-toggle__label { font-variant: tabular-nums; }

/* =============================================================================
   10. ENTRIES (post card + single)
   ============================================================================= */

.dl-entry {
	margin-bottom: var(--dl-sp-8);
}

.dl-entry + .dl-entry {
	padding-top: var(--dl-sp-7);
	border-top: 1px solid var(--dl-rule);
}

.dl-entry__header {
	margin-bottom: var(--dl-sp-4);
}

.dl-entry__title {
	font-family: var(--dl-font-mono);
	margin: 0 0 var(--dl-sp-3);
}

.dl-entry__title a {
	color: var(--dl-ink);
	text-decoration: none;
}

.dl-entry__title a:hover { color: var(--dl-accent); }

.dl-entry__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--dl-sp-2) var(--dl-sp-4);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
	letter-spacing: 0.02em;
}

.dl-entry__meta a { color: var(--dl-muted); text-decoration: none; }
.dl-entry__meta a:hover { color: var(--dl-accent); }

.dl-meta-sep { opacity: 0.5; }

.dl-entry__thumbnail {
	margin: 0 0 var(--dl-sp-5);
	border-radius: var(--dl-radius-md);
	overflow: hidden;
	background: var(--dl-bg-sunken);
}

.dl-entry__thumbnail img { width: 100%; height: auto; }

.dl-entry__excerpt { color: var(--dl-ink-soft); }

.dl-entry__readmore {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	margin-top: var(--dl-sp-3);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	text-decoration: none;
	color: var(--dl-accent);
}

.dl-entry__readmore::after {
	content: "→";
	transition: transform var(--dl-dur-fast) var(--dl-ease);
}

.dl-entry__readmore:hover::after { transform: translateX(3px); }

.dl-entry__footer {
	margin-top: var(--dl-sp-5);
	padding-top: var(--dl-sp-4);
	border-top: 1px solid var(--dl-rule);
	display: flex;
	flex-wrap: wrap;
	gap: var(--dl-sp-3);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
}

.dl-taglist {
	display: inline-flex;
	flex-wrap: wrap;
	gap: var(--dl-sp-2);
}

.dl-tag,
.dl-category {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	padding: 0.15em 0.55em;
	border: 1px solid var(--dl-rule);
	border-radius: var(--dl-radius-sm);
	color: var(--dl-ink-soft);
	text-decoration: none;
	background: var(--dl-bg-elev);
	transition: border-color var(--dl-dur-fast) var(--dl-ease), color var(--dl-dur-fast) var(--dl-ease);
}

.dl-tag::before  { content: "#"; color: var(--dl-muted); }
.dl-category::before { content: "/"; color: var(--dl-muted); }

.dl-tag:hover,
.dl-category:hover {
	border-color: var(--dl-accent);
	color: var(--dl-accent);
}

/* Single post typography scale gets slightly larger */
.dl-entry--single .dl-entry__title { font-size: var(--dl-text-4xl); }
.dl-entry--single .dl-entry__content { font-size: 1.075rem; }

.dl-entry__content > * + * { margin-top: var(--dl-sp-4); }
.dl-entry__content > h2,
.dl-entry__content > h3,
.dl-entry__content > h4 { margin-top: var(--dl-sp-6); }

/* =============================================================================
   11. PAGINATION
   ============================================================================= */

.dl-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: var(--dl-sp-2);
	margin: var(--dl-sp-8) 0;
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
}

.dl-pagination .page-numbers {
	padding: var(--dl-sp-2) var(--dl-sp-4);
	border: 1px solid var(--dl-rule);
	border-radius: var(--dl-radius-sm);
	color: var(--dl-ink-soft);
	text-decoration: none;
	background: var(--dl-bg-elev);
	min-width: 2.5rem;
	text-align: center;
}

.dl-pagination .page-numbers:hover,
.dl-pagination .page-numbers.current {
	border-color: var(--dl-accent);
	color: var(--dl-accent);
}

.dl-pagination .page-numbers.current {
	background: var(--dl-accent-soft);
	font-weight: 600;
}

/* post-nav after single */
.dl-post-nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--dl-sp-4);
	margin: var(--dl-sp-8) 0;
}

.dl-post-nav__link {
	padding: var(--dl-sp-4);
	border: 1px solid var(--dl-rule);
	border-radius: var(--dl-radius-md);
	text-decoration: none;
	color: var(--dl-ink);
	background: var(--dl-bg-elev);
	display: flex;
	flex-direction: column;
	gap: var(--dl-sp-1);
}

.dl-post-nav__link:hover { border-color: var(--dl-accent); }

.dl-post-nav__label {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.dl-post-nav__title { font-family: var(--dl-font-mono); font-size: var(--dl-text-sm); }

.dl-post-nav__link--next { text-align: right; }

@media (max-width: 640px) {
	.dl-post-nav { grid-template-columns: 1fr; }
}

/* =============================================================================
   12. COMMENTS
   ============================================================================= */

.dl-comments {
	margin-top: var(--dl-sp-8);
	padding-top: var(--dl-sp-7);
	border-top: 1px solid var(--dl-rule);
}

.dl-comments__title {
	font-family: var(--dl-font-mono);
	margin-bottom: var(--dl-sp-5);
}

.comment-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--dl-sp-6);
}

.comment-list .comment,
.comment-list .pingback {
	padding: var(--dl-sp-4) 0;
	border-bottom: 1px solid var(--dl-rule);
}

.comment-list .children {
	list-style: none;
	padding-left: var(--dl-sp-5);
	border-left: 2px solid var(--dl-rule);
	margin-top: var(--dl-sp-4);
}

.comment-author {
	display: flex;
	gap: var(--dl-sp-3);
	align-items: center;
	margin-bottom: var(--dl-sp-2);
}

.comment-author .avatar {
	border-radius: 50%;
	width: 32px;
	height: 32px;
}

.comment-author .fn {
	font-family: var(--dl-font-mono);
	font-style: normal;
	font-weight: 600;
	color: var(--dl-ink);
}

.comment-metadata {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
	margin-bottom: var(--dl-sp-2);
}

.comment-metadata a { color: var(--dl-muted); }

.reply a {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-accent);
	text-decoration: none;
	padding: 0.1em 0.4em;
	border: 1px solid var(--dl-rule);
	border-radius: var(--dl-radius-sm);
}

.reply a:hover { border-color: var(--dl-accent); background: var(--dl-accent-soft); }

.comment-form p { margin-bottom: var(--dl-sp-4); }
.comment-form label {
	display: block;
	margin-bottom: var(--dl-sp-1);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	color: var(--dl-ink-soft);
}

/* =============================================================================
   13. FORMS
   ============================================================================= */

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="date"],
textarea,
select {
	width: 100%;
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	color: var(--dl-ink);
	background: var(--dl-bg-elev);
	border: 1px solid var(--dl-rule);
	border-radius: var(--dl-radius-sm);
	padding: var(--dl-sp-3);
	transition: border-color var(--dl-dur-fast) var(--dl-ease);
}

input:focus,
textarea:focus,
select:focus {
	outline: none;
	border-color: var(--dl-accent);
	box-shadow: var(--dl-focus);
}

textarea { min-height: 8rem; resize: vertical; }

button,
input[type="submit"],
input[type="button"],
input[type="reset"],
.wp-block-button__link {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	font-weight: 600;
	color: var(--dl-bg);
	background: var(--dl-accent);
	border: 1px solid var(--dl-accent);
	border-radius: var(--dl-radius-sm);
	padding: var(--dl-sp-3) var(--dl-sp-5);
	cursor: pointer;
	transition: background-color var(--dl-dur-fast) var(--dl-ease);
}

button:hover,
input[type="submit"]:hover,
.wp-block-button__link:hover {
	background: var(--dl-accent-hover);
	border-color: var(--dl-accent-hover);
}

:root[data-theme="dark"] button,
:root[data-theme="dark"] input[type="submit"],
:root[data-theme="dark"] .wp-block-button__link {
	color: #0f1419;
}

/* =============================================================================
   14. SIDEBAR / WIDGETS
   ============================================================================= */

.dl-sidebar { min-width: 0; }

.widget {
	margin-bottom: var(--dl-sp-6);
	padding-bottom: var(--dl-sp-5);
	border-bottom: 1px solid var(--dl-rule);
}

.widget:last-child { border-bottom: 0; }

.widget-title {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-sm);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--dl-muted);
	margin: 0 0 var(--dl-sp-3);
}

.widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.widget li {
	padding: var(--dl-sp-2) 0;
	border-bottom: 1px dotted var(--dl-rule);
	font-size: var(--dl-text-sm);
}

.widget li:last-child { border-bottom: 0; }

.widget a { color: var(--dl-ink-soft); text-decoration: none; }
.widget a:hover { color: var(--dl-accent); }

/* =============================================================================
   15. FOOTER
   ============================================================================= */

.dl-site-footer {
	border-top: 1px solid var(--dl-rule);
	background: var(--dl-bg-sunken);
	padding: var(--dl-sp-6) 0;
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	color: var(--dl-muted);
	flex-shrink: 0;
}

.dl-site-footer__inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--dl-sp-3);
}

.dl-site-footer a { color: var(--dl-ink-soft); }
.dl-site-footer a:hover { color: var(--dl-accent); }

/* =============================================================================
   16. SEARCH FORM
   ============================================================================= */

.dl-search-form {
	display: flex;
	gap: var(--dl-sp-2);
	align-items: stretch;
}

.dl-search-form .search-field { flex: 1; }

.dl-search-form .search-submit {
	flex: 0 0 auto;
	padding: var(--dl-sp-3) var(--dl-sp-4);
}

/* =============================================================================
   17. BLOCKS / GUTENBERG SUPPORT
   ============================================================================= */

.wp-block-image img { border-radius: var(--dl-radius-md); }

.wp-block-pullquote {
	margin: var(--dl-sp-6) 0;
	padding: var(--dl-sp-5);
	border-top: 2px solid var(--dl-accent);
	border-bottom: 2px solid var(--dl-accent);
	text-align: center;
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-lg);
}

.wp-block-separator {
	border: 0;
	border-top: 1px solid var(--dl-rule);
	margin: var(--dl-sp-7) 0;
}

.wp-block-separator.is-style-wide { border-top-width: 1px; }
.wp-block-separator.is-style-dots {
	border: 0;
	text-align: center;
	line-height: 1;
}
.wp-block-separator.is-style-dots::before {
	content: "* * *";
	color: var(--dl-muted);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-lg);
	letter-spacing: 0.5em;
}

.wp-block-table { font-size: var(--dl-text-sm); }

.sticky-post-badge {
	display: inline-block;
	background: var(--dl-highlight-soft);
	color: var(--dl-highlight);
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-xs);
	padding: 0.1em 0.5em;
	border-radius: var(--dl-radius-sm);
	margin-left: var(--dl-sp-2);
	letter-spacing: 0.04em;
}

/* =============================================================================
   18. ARCHIVE / PAGE HEADERS
   ============================================================================= */

.dl-page-header {
	margin-bottom: var(--dl-sp-7);
	padding-bottom: var(--dl-sp-4);
	border-bottom: 1px solid var(--dl-rule);
}

.dl-page-header__title {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-2xl);
	margin: 0 0 var(--dl-sp-2);
}

.dl-page-header__title::before {
	content: attr(data-prefix) " ";
	color: var(--dl-muted);
}

.dl-page-header__description { color: var(--dl-muted); margin: 0; }

/* =============================================================================
   19. 404
   ============================================================================= */

.dl-error404 {
	text-align: center;
	padding: var(--dl-sp-9) var(--dl-sp-4);
}

.dl-error404__code {
	font-family: var(--dl-font-mono);
	font-size: clamp(4rem, 12vw, 9rem);
	color: var(--dl-accent);
	margin: 0;
	line-height: 1;
	letter-spacing: -0.04em;
}

.dl-error404__message {
	font-family: var(--dl-font-mono);
	font-size: var(--dl-text-lg);
	color: var(--dl-muted);
	margin: var(--dl-sp-4) 0 var(--dl-sp-5);
}

/* =============================================================================
   20. UTILITY
   ============================================================================= */

.dl-no-js .dl-theme-toggle { display: none; }

.clearfix::after {
	content: "";
	display: block;
	clear: both;
}

/* Print */
@media print {
	.dl-site-header,
	.dl-site-footer,
	.dl-theme-toggle,
	.dl-pagination,
	.dl-post-nav,
	.dl-comments { display: none !important; }
	body { background: #fff; color: #000; }
	pre, code, kbd { background: #f5f5f5 !important; color: #000 !important; border-color: #ccc !important; }
	a { color: #000; text-decoration: underline; }
}
