/*
Theme Name: Quill
Theme URI: https://example.com/quill
Author: Your Name
Author URI: https://example.com
Description: A clean, minimal blog theme with an editorial, monochrome aesthetic. Generous whitespace, refined typography, and almost no color — just ink on paper. Built for writing-first blogs.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
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: quill
Tags: blog, minimal, editorial, two-columns, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ---------- Design tokens ---------- */
:root{
  --paper:#fbfaf8;
  --ink:#1a1a18;
  --ink-soft:#4a4a46;
  --muted:#8a8a82;
  --line:#e6e3dc;
  --line-soft:#efece6;
  --accent:#3a3a36;       /* understated link/hover ink */
  --accent-rule:#1a1a18;
  --max:42rem;            /* reading column */
  --wide:64rem;           /* header/footer width */
}

/* ---------- Reset-ish ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:'Hanken Grotesque',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line);transition:border-color .2s ease,color .2s ease}
a:hover{color:var(--accent);border-color:var(--accent)}

h1,h2,h3,h4{
  font-family:'Newsreader',Georgia,'Times New Roman',serif;
  font-weight:500;
  line-height:1.18;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0 0 .5em;
}
h1{font-size:2.25rem}
h2{font-size:1.6rem}
h3{font-size:1.25rem}
p{margin:0 0 1.3em}

/* ---------- Layout ---------- */
.container{max-width:var(--max);margin:0 auto;padding:0 1.5rem}
.container-wide{max-width:var(--wide);margin:0 auto;padding:0 1.5rem}

/* ---------- Header ---------- */
.site-header{
  border-bottom:1px solid var(--line);
  padding:2.4rem 0 2rem;
  margin-bottom:3rem;
}
.site-header .container-wide{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;
}
.site-branding{display:flex;align-items:center;gap:.9rem}
.site-logo img{
  width:auto;height:70px;max-width:none;display:block;
}
.site-text{display:flex;flex-direction:column}
.site-title{
  font-family:'Newsreader',Georgia,serif;
  font-size:1.7rem;font-weight:500;letter-spacing:-.015em;
  margin:0;
}
.site-title a{border:none;color:var(--ink)}
.site-title a:hover{color:var(--ink)}
.site-description{
  margin:.25rem 0 0;color:var(--muted);font-size:.92rem;
  font-weight:400;
}

/* nav */
.main-nav ul{
  list-style:none;display:flex;gap:1.5rem;margin:0;padding:0;flex-wrap:wrap;
}
.main-nav a{
  border:none;font-size:.82rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--ink-soft);
}
.main-nav a:hover{color:var(--ink)}
.main-nav .current-menu-item a{color:var(--ink);border-bottom:1px solid var(--ink)}

/* ---------- Post list (index) ---------- */
.post-list .post-summary{
  padding-bottom:2.6rem;margin-bottom:2.6rem;
  border-bottom:1px solid var(--line-soft);
}
.post-list .post-summary:last-child{border-bottom:none}
.post-meta{
  font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);margin-bottom:.6rem;
}
.post-meta a{border:none;color:var(--muted)}
.post-meta a:hover{color:var(--ink)}
.entry-title{margin-bottom:.5rem}
.entry-title a{border:none}
.post-summary .entry-title{font-size:1.65rem}
.entry-excerpt{color:var(--ink-soft)}
.read-more{
  display:inline-block;margin-top:.4rem;font-size:.85rem;
  letter-spacing:.04em;border-bottom:1px solid var(--ink);
}

.featured-thumb{margin-bottom:1.2rem}
.featured-thumb img{border-radius:2px}

/* ---------- Single post / page ---------- */
.entry-content{font-size:1.06rem}
.entry-content p,
.entry-content ul,
.entry-content ol{margin-bottom:1.4em}
.entry-content h2{margin-top:2em}
.entry-content h3{margin-top:1.6em}
.entry-content blockquote{
  margin:1.8em 0;padding:.2em 0 .2em 1.4rem;
  border-left:2px solid var(--accent-rule);
  font-family:'Newsreader',Georgia,serif;font-style:italic;
  font-size:1.2rem;color:var(--ink-soft);
}
.entry-content img{margin:1.6em auto;border-radius:2px}
.entry-content code{
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:.88em;background:var(--line-soft);
  padding:.12em .4em;border-radius:3px;
}
.entry-content pre{
  background:var(--ink);color:var(--paper);padding:1.2rem;
  border-radius:4px;overflow:auto;font-size:.85rem;line-height:1.6;
}
.entry-content pre code{background:none;padding:0;color:inherit}
.entry-content hr{
  border:none;border-top:1px solid var(--line);
  margin:2.5em 0;
}

.single-header{margin-bottom:2rem}
.single-header .entry-title{font-size:2.4rem;margin-bottom:.7rem}

.entry-footer{
  margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--line);
  font-size:.85rem;color:var(--muted);
}
.entry-footer a{color:var(--ink-soft);border:none}
.entry-footer a:hover{color:var(--ink)}

/* ---------- Comments ---------- */
.comments-area{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line)}
.comments-title{font-size:1.3rem;margin-bottom:1.5rem}
.comment-list{list-style:none;margin:0;padding:0}
.comment-list li{margin-bottom:1.6rem}
.comment-body{
  padding:1.2rem 0;border-bottom:1px solid var(--line-soft);
}
.comment-author{font-weight:600;font-size:.95rem}
.comment-metadata{font-size:.78rem;color:var(--muted);margin-bottom:.5rem}
.comment-metadata a{border:none;color:var(--muted)}
.comment-list .children{list-style:none;margin:1rem 0 0 1.5rem;padding-left:1.2rem;border-left:1px solid var(--line)}

.comment-respond{margin-top:2rem}
.comment-form label{display:block;font-size:.82rem;letter-spacing:.04em;margin-bottom:.3rem;color:var(--ink-soft)}
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea{
  width:100%;padding:.7rem .8rem;margin-bottom:1rem;
  border:1px solid var(--line);border-radius:3px;
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--ink);
}
.comment-form input:focus,.comment-form textarea:focus{
  outline:none;border-color:var(--ink);
}

/* ---------- Buttons ---------- */
.btn,
input[type=submit],
button{
  display:inline-block;background:var(--ink);color:var(--paper);
  border:none;border-radius:3px;padding:.7rem 1.4rem;
  font-family:inherit;font-size:.85rem;letter-spacing:.06em;
  cursor:pointer;transition:opacity .2s ease;
}
.btn:hover,input[type=submit]:hover,button:hover{opacity:.85;border:none;color:var(--paper)}

/* ---------- Sidebar ---------- */
.with-sidebar .container-wide{
  display:grid;grid-template-columns:minmax(0,42rem) 15rem;
  gap:3.5rem;justify-content:center;
}
.sidebar .widget{margin-bottom:2.2rem}
.sidebar .widget-title{
  font-family:'Hanken Grotesque',sans-serif;font-size:.78rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;color:var(--muted);
  margin-bottom:.9rem;
}
.sidebar ul{list-style:none;margin:0;padding:0}
.sidebar li{margin-bottom:.5rem;font-size:.92rem}
.sidebar a{border:none;color:var(--ink-soft)}
.sidebar a:hover{color:var(--ink)}

/* ---------- Pagination ---------- */
.pagination{
  display:flex;justify-content:space-between;gap:1rem;
  margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);
  font-size:.85rem;letter-spacing:.04em;
}
.pagination a{border:none}
.pagination .nav-previous a::before{content:"\2190  "}
.pagination .nav-next a::after{content:"  \2192"}

/* ---------- Footer ---------- */
.site-footer{
  margin-top:5rem;padding:2.5rem 0 3rem;
  border-top:1px solid var(--line);
  color:var(--muted);font-size:.85rem;
}
.site-footer .container-wide{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;flex-wrap:wrap;gap:1.1rem;text-align:center;
}
.footer-logo{display:inline-block;border:none;line-height:0}
.footer-logo:hover{opacity:.85}
.footer-logo-img{height:47px;width:auto;max-width:none;display:block}
.site-footer a{border:none;color:var(--ink-soft)}
.site-footer a:hover{color:var(--ink)}

/* ---------- Accessibility ---------- */
.screen-reader-text{
  position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);
  white-space:nowrap;
}
.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);
  padding:.6rem 1rem;z-index:100;
}
.skip-link:focus{left:1rem;top:1rem}

/* ---------- Responsive ---------- */
@media(max-width:820px){
  .with-sidebar .container-wide{grid-template-columns:1fr;gap:2.5rem}
  .sidebar{border-top:1px solid var(--line);padding-top:2rem}
}
@media(max-width:600px){
  body{font-size:17px}
  h1{font-size:1.9rem}
  .single-header .entry-title{font-size:1.9rem}
  .site-header .container-wide{flex-direction:column;gap:1rem}
  .site-header{padding:1.8rem 0 1.4rem;margin-bottom:2rem}
}
