/*
Theme Name: The Cozy Overthinker
Theme URI: https://example.com/themes/cozy-overthinker
Author: Andi
Author URI: https://example.com
Description: A warm, witty, minimalist theme for essays and cozy living. Built for Gutenberg, with a custom front page and clean typography.
Version: 1.0.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cozy-overthinker
Tags: blog, one-column, two-column, custom-colors, custom-logo, custom-menu, featured-images
*/
:root{--latte:#d9c7b8;--cream:#f7f2ed;--blush:#e8d6d0;--sage:#cfd8cf;--terra:#c87a5b;--ink:#262626;--muted:#5c5c5c;--white:#ffffff;--maxw:1100px;--radius:14px;--shadow:0 8px 24px rgba(0,0,0,.06)}
body{margin:0;background:var(--cream);color:var(--ink);font-family:'Lato',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.7;font-size:18px}
a{color:var(--terra);text-decoration:none}a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
header.site-hero{background:linear-gradient(180deg,var(--blush),var(--cream));padding:48px 0 28px;border-bottom:1px solid rgba(0,0,0,.06)}
.brand{display:flex;align-items:center;gap:14px}
.brand .logo{width:46px;height:46px;border-radius:50%;background:var(--latte);display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow);font-family:'Playfair Display',serif;font-weight:700}
.brand h1{margin:0;font-family:'Playfair Display',serif;font-size:34px;letter-spacing:.4px}
.brand .tagline{margin-top:6px;color:var(--muted)}
.nav{display:flex;gap:18px;align-items:center;justify-content:flex-end;margin-left:auto}
.nav a{padding:8px 12px;border-radius:8px}
.nav a.cta{background:var(--ink);color:var(--white)}.nav a.cta:hover{background:#000;text-decoration:none}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;margin-top:24px}
.hero-card{background:var(--white);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.hero-photo{background:url('../assets/images/hero-placeholder.jpg') center/cover no-repeat;min-height:260px;border-radius:var(--radius);box-shadow:var(--shadow)}
.section{padding:42px 0}
.section h2{font-family:'Playfair Display',serif;font-size:32px;margin:0 0 18px}
.grid{display:grid;gap:20px}
.grid.posts{grid-template-columns:repeat(3,1fr)}
.card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;height:100%}
.card img{width:100%;height:180px;object-fit:cover}
.card .pad{padding:18px}
.card h3{margin:0 0 8px;font-size:20px;line-height:1.3}
.meta{color:var(--muted);font-size:14px}
.categories{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat{background:var(--white);border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:6px}
.cat span{font-size:14px;color:var(--muted)}
.newsletter{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.newsletter form{display:flex;gap:10px}
input[type="email"]{padding:12px 14px;border-radius:10px;border:1px solid #ddd;min-width:280px}
button{padding:12px 16px;border-radius:10px;border:0;background:var(--terra);color:white;cursor:pointer}
button:hover{filter:brightness(.95)}
.about{background:linear-gradient(180deg,var(--cream),var(--sage));border-radius:var(--radius);padding:26px;display:grid;grid-template-columns:.9fr 1.1fr;gap:18px}
.about .photo{background:url('../assets/images/andi-placeholder.jpg') center/cover no-repeat;min-height:220px;border-radius:12px;box-shadow:var(--shadow)}
footer.site-footer{margin-top:38px;padding:26px 0;border-top:1px solid rgba(0,0,0,.08);color:var(--muted)}
.post-hero{padding:40px 0;background:var(--blush);border-bottom:1px solid rgba(0,0,0,.06)}
.single-wrap{max-width:760px;margin:0 auto;padding:0 20px}
.single-wrap h1{font-family:'Playfair Display',serif;margin:0 0 8px}
.byline{color:var(--muted);margin-bottom:24px}
.single-wrap img{max-width:100%;border-radius:12px;box-shadow:var(--shadow)}
.single-wrap p{margin:18px 0}
@media (max-width:920px){.hero-inner{grid-template-columns:1fr}.grid.posts{grid-template-columns:1fr 1fr}.categories{grid-template-columns:1fr 1fr}.about{grid-template-columns:1fr}}
@media (max-width:540px){.grid.posts{grid-template-columns:1fr}}
