/* ═══════════════════════════════════════════════════════════
   SUSHANTA PAUL — Literary Editorial Theme
   Fonts: Fraunces (display) + Instrument Sans (body) + Noto Sans Bengali
   Palette: Off-white ink paper, deep charcoal, warm terracotta accent
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;1,9..144,300;1,9..144,400&family=Instrument+Sans:wght@400;500;600&family=Noto+Sans+Bengali:wght@300;400;500;600&display=swap');

/* ── Design Tokens ──────────────────────────────────────── */
:root {
  --ink:         #1c1917;
  --ink-2:       #44403c;
  --ink-3:       #78716c;
  --paper:       #faf9f7;
  --paper-2:     #f5f3ef;
  --paper-3:     #ede9e3;
  --border:      #e7e2da;
  --accent:      #b45309;
  --accent-light:#fef3c7;
  --accent-hover:#92400e;
  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'Instrument Sans', system-ui, sans-serif;
  --font-bengali: 'Noto Sans Bengali', sans-serif;
  --content-w:   700px;
  --wide-w:      1100px;
  --radius:      4px;
  --radius-lg:   10px;
  --ease: cubic-bezier(.4,0,.2,1);
}

@media (prefers-color-scheme: dark) { :root:not(.light) { --ink:#e8e3db; --ink-2:#c4bdb4; --ink-3:#8a8078; --paper:#141210; --paper-2:#1c1917; --paper-3:#252118; --border:#2e2924; --accent:#e8a045; --accent-light:#1c1409; --accent-hover:#f59e0b; } }
:root.dark  { --ink:#e8e3db; --ink-2:#c4bdb4; --ink-3:#8a8078; --paper:#141210; --paper-2:#1c1917; --paper-3:#252118; --border:#2e2924; --accent:#e8a045; --accent-light:#1c1409; --accent-hover:#f59e0b; }
:root.light { --ink:#1c1917; --ink-2:#44403c; --ink-3:#78716c; --paper:#faf9f7; --paper-2:#f5f3ef; --paper-3:#ede9e3; --border:#e7e2da; --accent:#b45309; --accent-light:#fef3c7; --accent-hover:#92400e; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 17px; }
body { background: var(--paper); color: var(--ink); font-family: var(--font-body); line-height: 1.75; -webkit-font-smoothing: antialiased; transition: background .3s var(--ease), color .3s var(--ease); }
:lang(bn), .lang-bn { font-family: var(--font-bengali); }
img { max-width: 100%; height: auto; display: block; }
svg { overflow: visible; }
a { color: var(--accent); text-decoration: none; transition: color .15s; }
a:hover { color: var(--accent-hover); }
.container { width: 100%; max-width: var(--wide-w); margin: 0 auto; padding: 0 24px; }
.content-width { max-width: var(--content-w); margin: 0 auto; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

.site-header { position: sticky; top: 0; z-index: 100; background: var(--paper); border-bottom: 1px solid var(--border); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); transition: background .3s var(--ease), border-color .3s var(--ease); }
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; gap: 24px; }
.site-title { font-family: var(--font-display); font-size: 1.35rem; font-weight: 400; letter-spacing: -.02em; color: var(--ink); white-space: nowrap; flex-shrink: 0; }
.site-title span { color: var(--accent); }
.site-title:hover { color: var(--ink); }
.header-controls { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.toggle-pill { display: inline-flex; align-items: center; background: var(--paper-3); border: 1px solid var(--border); border-radius: 99px; padding: 3px; gap: 1px; cursor: pointer; }
.toggle-pill button { background: none; border: none; padding: 4px 12px; border-radius: 99px; font-family: var(--font-body); font-size: .75rem; font-weight: 600; letter-spacing: .04em; color: var(--ink-3); cursor: pointer; transition: all .2s var(--ease); }
.toggle-pill button.active { background: var(--paper); color: var(--ink); box-shadow: 0 1px 4px rgba(0,0,0,.1); }
.theme-toggle { width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--border); background: var(--paper-3); color: var(--ink-2); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .15s; flex-shrink: 0; }
.theme-toggle:hover { border-color: var(--ink-3); color: var(--ink); }
.theme-toggle svg { width: 16px; height: 16px; }
.header-search-btn { width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--border); background: var(--paper-3); color: var(--ink-2); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .15s; }
.header-search-btn:hover { border-color: var(--ink-3); color: var(--ink); }
.header-search-btn svg { width: 15px; height: 15px; }
.mobile-menu-btn { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 36px; height: 36px; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; position: relative; z-index: 160; }
.mobile-menu-btn span { display: block; width: 22px; height: 1.5px; background: var(--ink-2); border-radius: 2px; transition: all .25s var(--ease); transform-origin: center; }
.mobile-menu-btn.open span:nth-child(1) { transform: translateY(3.25px) rotate(45deg); }
.mobile-menu-btn.open span:nth-child(2) { opacity: 0; }
.mobile-menu-btn.open span:nth-child(3) { transform: translateY(-3.25px) rotate(-45deg); }

.search-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(20,18,16,.85); backdrop-filter: blur(8px); display: flex; align-items: flex-start; justify-content: center; padding-top: 120px; opacity: 0; pointer-events: none; transition: opacity .2s var(--ease); }
.search-overlay.open { opacity: 1; pointer-events: all; }
.search-box { width: 100%; max-width: 580px; margin: 0 24px; background: var(--paper-2); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; transform: translateY(-12px); transition: transform .25s var(--ease); }
.search-overlay.open .search-box { transform: translateY(0); }
.search-box form { display: flex; align-items: center; padding: 4px 16px; gap: 10px; }
.search-box input { flex: 1; border: none; background: none; font-family: var(--font-body); font-size: 1.1rem; color: var(--ink); padding: 14px 0; outline: none; }
.search-box input::placeholder { color: var(--ink-3); }
.search-box button { background: none; border: none; color: var(--ink-3); cursor: pointer; padding: 4px; }

/* ── Slide-out Menu ─────────────────────────────────────── */
.site-menu { position: fixed; top: 0; right: 0; bottom: 0; width: 320px; max-width: 85vw; z-index: 150; background: var(--paper); border-left: 1px solid var(--border); transform: translateX(100%); transition: transform .3s var(--ease); overflow-y: auto; -webkit-overflow-scrolling: touch; }
.site-menu.open { transform: translateX(0); }
.site-menu__inner { padding: 88px 28px 40px; }
.site-menu__list { list-style: none; display: flex; flex-direction: column; gap: 0; }
.site-menu__list li { border-bottom: 1px solid var(--border); }
.site-menu__list li:first-child { border-top: 1px solid var(--border); }
.site-menu__list a { display: block; padding: 16px 4px; font-size: 1rem; font-weight: 500; color: var(--ink); transition: color .15s, padding-left .2s var(--ease); }
.site-menu__list a:hover { color: var(--accent); padding-left: 8px; }
.site-menu-backdrop { position: fixed; inset: 0; z-index: 140; background: rgba(0,0,0,.4); backdrop-filter: blur(4px); opacity: 0; pointer-events: none; transition: opacity .3s var(--ease); }
.site-menu-backdrop.open { opacity: 1; pointer-events: all; }

.hero-section { padding: 72px 0 56px; border-bottom: 1px solid var(--border); }
.hero-inner { display: grid; grid-template-columns: 1fr 340px; gap: 56px; align-items: center; max-width: var(--wide-w); margin: 0 auto; padding: 0 24px; }
.hero-kicker { font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.hero-kicker::after { content:''; flex: 1; height: 1px; background: var(--accent); opacity: .3; max-width: 60px; }
.hero-title { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3.2rem); font-weight: 300; line-height: 1.2; letter-spacing: -.03em; color: var(--ink); margin-bottom: 20px; }
.hero-title a { color: inherit; }
.hero-title a:hover { color: var(--accent); }
.hero-excerpt { color: var(--ink-2); font-size: 1.05rem; line-height: 1.7; margin-bottom: 28px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.hero-meta { display: flex; align-items: center; gap: 16px; font-size: .8rem; color: var(--ink-3); }
.hero-meta time { font-variant-numeric: tabular-nums; }
.hero-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--ink-3); }
.read-more { display: inline-flex; align-items: center; gap: 8px; font-size: .82rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--accent); margin-top: 24px; transition: gap .2s var(--ease); }
.read-more:hover { gap: 14px; color: var(--accent-hover); }
.read-more svg { width: 14px; height: 14px; }
.hero-image-wrap { aspect-ratio: 4/3; overflow: hidden; border-radius: var(--radius-lg); background: var(--paper-3); position: relative; }
.hero-image-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.hero-image-wrap:hover img { transform: scale(1.03); }
.hero-image-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 5rem; color: var(--border); user-select: none; }

.posts-section { padding: 64px 0; }
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 36px; }
.section-label { font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); }
.view-all { font-size: .78rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--accent); }
.view-all:hover { color: var(--accent-hover); }
.posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px 28px; }
.post-card { display: flex; flex-direction: column; gap: 0; }
.post-card-image { aspect-ratio: 16/10; overflow: hidden; border-radius: var(--radius); background: var(--paper-3); margin-bottom: 18px; position: relative; }
.post-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.post-card:hover .post-card-image img { transform: scale(1.04); }
.post-card-image-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3rem; color: var(--border); }
.post-card-cat { font-size: .68rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.post-card-title { font-family: var(--font-display); font-size: 1.15rem; font-weight: 400; line-height: 1.35; letter-spacing: -.01em; color: var(--ink); margin-bottom: 10px; transition: color .15s; }
.post-card:hover .post-card-title { color: var(--accent); }
.post-card-excerpt { font-size: .88rem; color: var(--ink-2); line-height: 1.65; flex: 1; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.post-card-meta { font-size: .75rem; color: var(--ink-3); margin-top: 14px; display: flex; gap: 10px; align-items: center; }
.post-card-meta .dot { width: 2px; height: 2px; border-radius: 50%; background: var(--ink-3); }
.posts-list { border-top: 1px solid var(--border); margin-top: 48px; }
.post-list-item { display: grid; grid-template-columns: 1fr auto; align-items: start; gap: 24px; padding: 22px 0; border-bottom: 1px solid var(--border); transition: background .15s; }
.post-list-cat { font-size:.66rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:5px; }
.post-list-title { font-family:var(--font-display); font-size:1.05rem; font-weight:400; line-height:1.35; letter-spacing:-.01em; color:var(--ink); transition:color .15s; }
.post-list-item:hover .post-list-title { color: var(--accent); }
.post-list-meta { font-size:.72rem; color:var(--ink-3); margin-top:6px; }
.post-list-date { font-size:.72rem; color:var(--ink-3); white-space:nowrap; }

.single-layout { display: grid; grid-template-columns: 1fr 280px; gap: 64px; max-width: var(--wide-w); margin: 0 auto; padding: 56px 24px 80px; align-items: start; position: relative; }
.article-header { margin-bottom: 40px; }
.article-cat { font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.article-title { font-family: var(--font-display); font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 300; line-height: 1.2; letter-spacing: -.03em; color: var(--ink); margin-bottom: 20px; }
.article-meta { display: flex; align-items: center; gap: 12px; font-size: .8rem; color: var(--ink-3); padding-bottom: 24px; border-bottom: 1px solid var(--border); }
.article-meta .dot { width: 3px; height: 3px; border-radius:50%; background:var(--ink-3); }
.article-meta .read-time { display:flex; align-items:center; gap:5px; }
.article-featured-image { border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 40px; aspect-ratio: 16/8; background: var(--paper-3); }
.article-featured-image img { width:100%; height:100%; object-fit:cover; }
.article-content { font-size: 1.08rem; line-height: 1.85; color: var(--ink-2); }
.article-content p { margin-bottom: 1.6em; }
.article-content h2, .article-content h3, .article-content h4 { font-family: var(--font-display); font-weight: 400; color: var(--ink); letter-spacing: -.02em; margin: 2em 0 .75em; line-height: 1.3; }
.article-content h2 { font-size: 1.65rem; }
.article-content h3 { font-size: 1.35rem; }
.article-content h4 { font-size: 1.1rem; }
.article-content a { color: var(--accent); border-bottom: 1px solid transparent; transition: border-color .15s; }
.article-content a:hover { border-color: var(--accent); }
.article-content blockquote { margin: 2em 0; padding: 20px 28px; border-left: 3px solid var(--accent); background: var(--accent-light); border-radius: 0 var(--radius) var(--radius) 0; font-family: var(--font-display); font-style: italic; font-size: 1.15rem; color: var(--ink); line-height: 1.65; }
.article-content blockquote cite { display:block; font-size:.8rem; font-style:normal; color:var(--ink-3); margin-top:10px; font-family:var(--font-body); }
.article-content ul, .article-content ol { margin: 1.2em 0 1.6em 1.5em; }
.article-content li { margin-bottom: .5em; }
.article-content img { border-radius: var(--radius); margin: 2em 0; }
.article-content hr { border:none; border-top:1px solid var(--border); margin: 2.5em 0; }
.article-content figure { margin: 2em 0; }
.article-content figcaption { font-size:.8rem; color:var(--ink-3); text-align:center; margin-top:8px; }
.article-content code { font-family: monospace; font-size:.9em; background:var(--paper-3); padding:2px 6px; border-radius:3px; }
.article-content pre { background:var(--paper-3); padding:20px; border-radius:var(--radius); overflow-x:auto; margin:1.5em 0; }
.article-content > p:first-child::first-letter { font-family: var(--font-display); font-size: 4em; font-weight: 300; line-height: .8; float: left; margin: .05em .12em 0 0; color: var(--accent); }
.article-content > p:first-child::after { content: ''; display: table; clear: both; }
.article-tags { margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--border); display:flex; gap:8px; flex-wrap:wrap; }
.tag-pill { font-size:.72rem; font-weight:600; letter-spacing:.04em; padding: 5px 14px; border-radius:99px; background:var(--paper-3); color:var(--ink-2); border:1px solid var(--border); transition:all .15s; }
.tag-pill:hover { background:var(--accent); color:#fff; border-color:var(--accent); }
.article-share { margin-top: 48px; padding: 28px 32px; border-radius: var(--radius-lg); background: var(--paper-2); border: 1px solid var(--border); display: flex; flex-direction: column; align-items: center; gap: 14px; }
.article-share__label { font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-3); }
.article-share__buttons { display: flex; gap: 10px; }
.share-btn { width: 42px; height: 42px; border-radius: 50%; border: 1px solid var(--border); background: var(--paper); color: var(--ink-2); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .2s var(--ease); text-decoration: none; flex-shrink: 0; padding: 0; line-height: 1; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.share-btn:hover { border-color: var(--accent); background: var(--accent); color: #fff; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.share-btn svg { width: 16px; height: 16px; display: block; pointer-events: none; flex-shrink: 0; }

.post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--border); }
.post-nav-item { display:flex; flex-direction:column; gap:6px; }
.post-nav-item.next { text-align:right; align-items:flex-end; }
.post-nav-label { font-size:.68rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.post-nav-title { font-family:var(--font-display); font-size:.95rem; font-weight:400; color:var(--ink); line-height:1.4; transition:color .15s; }
.post-nav-item:hover .post-nav-title { color:var(--accent); }

.sidebar { position: sticky; top: 88px; display:flex; flex-direction:column; gap:32px; }
.author-box { background: var(--paper-2); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px; text-align: center; }
.author-avatar { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; margin: 0 auto 14px; border: 3px solid var(--paper-3); box-shadow: 0 0 0 2px var(--accent); }
.author-avatar-placeholder { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--accent-hover)); margin: 0 auto 14px; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:1.8rem; color:#fff; box-shadow: 0 0 0 3px var(--paper-2), 0 0 0 5px var(--accent); }
.author-name { font-family: var(--font-display); font-size: 1.05rem; font-weight:400; letter-spacing:-.01em; color: var(--ink); margin-bottom:6px; }
.author-title { font-size: .72rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.author-bio { font-size:.84rem; color:var(--ink-2); line-height:1.65; }
.author-links { display:flex; justify-content:center; gap:10px; margin-top:16px; }
.author-link { width:32px; height:32px; border-radius:50%; border:1px solid var(--border); background:var(--paper-3); display:flex; align-items:center; justify-content:center; color:var(--ink-3); transition:all .15s; }
.author-link:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.author-link svg { width:14px; height:14px; }
.sidebar-widget-title { font-size:.68rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:16px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.sidebar-post-list { display:flex; flex-direction:column; gap:14px; }
.sidebar-post-item { display:flex; gap:12px; align-items:flex-start; }
.sidebar-post-thumb { width:58px; height:48px; border-radius:var(--radius); object-fit:cover; flex-shrink:0; background:var(--paper-3); overflow:hidden; }
.sidebar-post-thumb img { width:100%; height:100%; object-fit:cover; }
.sidebar-post-title { font-size:.83rem; line-height:1.4; color:var(--ink); transition:color .15s; font-weight:500; }
.sidebar-post-item:hover .sidebar-post-title { color:var(--accent); }
.sidebar-post-date { font-size:.68rem; color:var(--ink-3); margin-top:4px; }
.sidebar-cats { display:flex; flex-wrap:wrap; gap:7px; }
.sidebar-cat-pill { font-size:.72rem; font-weight:500; padding:5px 12px; border-radius:99px; border:1px solid var(--border); color:var(--ink-2); background:var(--paper-2); transition:all .15s; }
.sidebar-cat-pill:hover { background:var(--accent); border-color:var(--accent); color:#fff; }

.archive-header { padding: 56px 0 40px; border-bottom: 1px solid var(--border); margin-bottom: 56px; }
.archive-super { font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
.archive-title { font-family:var(--font-display); font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:300; letter-spacing:-.03em; color:var(--ink); margin-bottom:12px; }
.archive-desc { font-size:1rem; color:var(--ink-2); max-width:560px; }
.archive-count { font-size:.78rem; color:var(--ink-3); margin-top:8px; }
.archive-layout { display: grid; grid-template-columns: 1fr 280px; gap: 64px; max-width: var(--wide-w); margin: 0 auto; padding: 0 24px 80px; align-items: start; }
.pagination { display:flex; justify-content:center; gap:6px; margin-top:56px; padding-top:40px; border-top:1px solid var(--border); }
.pagination a, .pagination span { width:38px; height:38px; border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:.82rem; font-weight:600; border:1px solid var(--border); color:var(--ink-2); background:var(--paper-2); transition:all .15s; }
.pagination a:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.pagination .current { background:var(--ink); border-color:var(--ink); color:var(--paper); }

.about-hero { padding: 80px 0 64px; border-bottom: 1px solid var(--border); }
.about-hero-inner { display: grid; grid-template-columns: 1fr 320px; gap: 64px; align-items: center; }
.about-eyebrow { font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; }
.about-name { font-family:var(--font-display); font-size:clamp(2.2rem,4vw,4rem); font-weight:300; letter-spacing:-.04em; color:var(--ink); line-height:1.1; margin-bottom:6px; }
.about-subtitle { font-family:var(--font-display); font-style:italic; font-size:1.2rem; color:var(--ink-2); margin-bottom:24px; }
.about-bio-short { font-size:1.05rem; line-height:1.8; color:var(--ink-2); margin-bottom:28px; }
.about-social { display:flex; gap:10px; flex-wrap:wrap; }
.about-social-link { display:inline-flex; align-items:center; gap:7px; font-size:.78rem; font-weight:600; padding:9px 16px; border-radius:99px; border:1px solid var(--border); color:var(--ink-2); background:var(--paper-2); transition:all .15s; }
.about-social-link:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.about-social-link svg { width:14px; height:14px; }
.about-portrait-wrap { aspect-ratio:3/4; max-height:420px; border-radius: 120px 120px 12px 12px; overflow:hidden; background:var(--paper-3); position:relative; }
.about-portrait-wrap img { width:100%; height:100%; object-fit:cover; }
.about-portrait-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:8rem; color:var(--border); }
.about-sections { padding: 72px 0; }
.about-section { margin-bottom: 64px; }
.about-section-label { font-size:.68rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:24px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.about-section-content { font-size:1rem; line-height:1.85; color:var(--ink-2); }
.about-section-content p { margin-bottom:1.4em; }
.works-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.work-card { border:1px solid var(--border); border-radius:var(--radius-lg); padding:22px; background:var(--paper-2); transition:border-color .15s, transform .2s var(--ease); }
.work-card:hover { border-color:var(--accent); transform:translateY(-2px); }
.work-card-year { font-size:.68rem; font-weight:600; letter-spacing:.08em; color:var(--accent); margin-bottom:8px; }
.work-card-title { font-family:var(--font-display); font-size:1rem; font-weight:400; color:var(--ink); line-height:1.4; margin-bottom:6px; }
.work-card-desc { font-size:.82rem; color:var(--ink-2); line-height:1.6; }

.site-footer { border-top: 1px solid var(--border); background: var(--paper-2); padding: 48px 0 32px; }
.footer-inner { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.footer-brand-name { font-family:var(--font-display); font-size:1.2rem; font-weight:400; color:var(--ink); margin-bottom:8px; }
.footer-brand-name span { color:var(--accent); }
.footer-tagline { font-size:.84rem; color:var(--ink-3); line-height:1.6; max-width:260px; margin-bottom:18px; }
.footer-social { display:flex; gap:8px; }
.footer-social-link { width:32px; height:32px; border-radius:50%; border:1px solid var(--border); background:var(--paper-3); display:flex; align-items:center; justify-content:center; color:var(--ink-3); transition:all .15s; }
.footer-social-link:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.footer-social-link svg { width:13px; height:13px; }
.footer-col-title { font-size:.68rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:14px; }
.footer-links { display:flex; flex-direction:column; gap:8px; }
.footer-links a { font-size:.85rem; color:var(--ink-2); transition:color .15s; }
.footer-links a:hover { color:var(--accent); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding-top:24px; border-top:1px solid var(--border); font-size:.75rem; color:var(--ink-3); }

.page-layout { max-width: var(--content-w); margin: 0 auto; padding: 64px 0 80px; }

.comments-section { margin-top:56px; padding-top:40px; border-top:1px solid var(--border); }
.comments-title { font-family:var(--font-display); font-size:1.4rem; font-weight:400; letter-spacing:-.02em; color:var(--ink); margin-bottom:28px; }
.comment-form input, .comment-form textarea { width:100%; padding:11px 14px; border:1px solid var(--border); border-radius:var(--radius); background:var(--paper-2); color:var(--ink); font-family:var(--font-body); font-size:.9rem; transition:border-color .15s; outline:none; }
.comment-form input:focus, .comment-form textarea:focus { border-color:var(--accent); }
.comment-form textarea { min-height:140px; resize:vertical; }
.comment-submit { display:inline-flex; align-items:center; gap:8px; padding:11px 24px; border-radius:99px; background:var(--accent); color:#fff; border:none; font-family:var(--font-body); font-size:.85rem; font-weight:600; cursor:pointer; transition:background .15s; }
.comment-submit:hover { background:var(--accent-hover); }

.reading-progress { position:fixed; top:0; left:0; z-index:200; height:2px; width:0%; background:linear-gradient(90deg, var(--accent), var(--accent-hover)); transition:width .1s linear; }
.scroll-top { position:fixed; bottom:28px; right:28px; z-index:90; width:40px; height:40px; border-radius:50%; background:var(--paper-2); border:1px solid var(--border); color:var(--ink-2); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .2s var(--ease); opacity:0; transform:translateY(8px); pointer-events:none; }
.scroll-top.visible { opacity:1; transform:translateY(0); pointer-events:all; }
.scroll-top:hover { background:var(--accent); border-color:var(--accent); color:#fff; }
.scroll-top svg { width:16px; height:16px; }

@media (max-width: 1024px) {
  .hero-inner { grid-template-columns: 1fr; gap:36px; }
  .hero-image-wrap { aspect-ratio:16/8; max-height:360px; }
  .posts-grid { grid-template-columns: repeat(2,1fr); }
  .single-layout, .archive-layout { grid-template-columns:1fr; gap:48px; }
  .sidebar { position:static; }
  .footer-inner { grid-template-columns:1fr 1fr; }
  .about-hero-inner { grid-template-columns:1fr; }
  .about-portrait-wrap { max-height:300px; border-radius:var(--radius-lg); }
}
@media (max-width: 768px) {
  html { font-size: 16px; }
  /* Fix post body visibility on mobile */
  .single-layout { padding: 28px 0 80px; }
  .article-content { font-size: 1rem; overflow: visible; word-break: break-word; overflow-wrap: break-word; }
  .article-content p, .article-content li { overflow-wrap: break-word; word-break: break-word; }
  .article-content img { width: 100%; height: auto; }
  .article-content pre { white-space: pre-wrap; word-break: break-all; }
  .article-title { font-size: 1.65rem; }
  .article-meta { flex-wrap: wrap; gap: 8px; }
  .header-inner { height:56px; }
  .hero-section { padding:40px 0 36px; }
  .hero-title { font-size:1.9rem; }
  .hero-kicker::after { display:none; }
  .article-share { padding: 22px 20px; }
  .share-btn { width: 38px; height: 38px; }
  .posts-grid { grid-template-columns:1fr; gap:28px; }
  .works-grid { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; }
  .post-nav { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:8px; text-align:center; }
  .toggle-pill button { padding:4px 9px; font-size:.7rem; }
}
@media (max-width: 480px) {
  .container { padding:0 16px; }
  .about-name { font-size:2.2rem; }
  /* Disable drop-cap on very small screens — it breaks single-word lines */
  .article-content > p:first-child::first-letter { float:none; font-size:1em; margin:0; color:inherit; }
  .article-featured-image { margin-bottom: 24px; }
}

@keyframes fadeUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
.fade-up { animation: fadeUp .5s var(--ease) both; }
.fade-up-1 { animation-delay:.1s; }
.fade-up-2 { animation-delay:.2s; }
.fade-up-3 { animation-delay:.3s; }
.no-js .search-overlay { display:none; }
