/*
Theme Name: Hearth & Wander
Theme URI: https://hearthandwander.com
Author: Hearth & Wander
Author URI: https://hearthandwander.com
Description: A warm, family-first lifestyle blog theme — cozy serif typography, soft earthy colors, and a Pinterest-friendly layout for travel, vacations, kids, home, and style content. Includes a homepage with hero, category grid, and post cards.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.6
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: hearth-and-wander
*/

:root{
  --clay:#A8512F; --clay-soft:#C17A54; --brown:#8A4B30; --sage:#6E7A52;
  --gold:#C9A24B; --cream:#FAF5EE; --tan:#F2E9DD; --card:#FFFFFF;
  --ink:#3E3A35; --muted:#8A7F70; --line:#E7DBCB;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Nunito Sans','Segoe UI',system-ui,sans-serif;
  --wrap:1140px; --radius:16px; --shadow:0 10px 30px rgba(120,80,50,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased}
.container{max-width:var(--wrap);margin:0 auto;padding:0 24px}
a{color:var(--clay);text-decoration:none}
a:hover{color:var(--brown)}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.2;font-weight:600}
.center{text-align:center}
.muted{color:var(--muted)}

/* Header */
.site-header{background:rgba(250,245,238,.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:16px;padding-bottom:16px;flex-wrap:wrap}
.brand-link{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--serif);font-weight:700;font-size:26px;color:var(--clay);letter-spacing:.3px}
.brand-tag{font-size:12px;color:var(--sage);font-style:italic;margin-top:4px;letter-spacing:.4px}
.main-nav .nav-list{list-style:none;display:flex;gap:22px;margin:0;padding:0;flex-wrap:wrap}
.main-nav a{color:var(--ink);font-weight:600;font-size:15px;letter-spacing:.2px}
.main-nav a:hover{color:var(--clay)}

/* Buttons */
.btn{display:inline-block;background:var(--clay);color:#fff;padding:13px 26px;border-radius:999px;font-weight:700;font-size:15px;letter-spacing:.3px;border:2px solid var(--clay);transition:.2s}
.btn:hover{background:var(--brown);border-color:var(--brown);color:#fff;transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--clay)}
.btn.ghost:hover{background:var(--clay);color:#fff}

/* Hero */
.hero{background:linear-gradient(160deg,var(--tan) 0%,var(--cream) 70%);border-bottom:1px solid var(--line)}
.hero-inner{text-align:center;padding:84px 24px 92px}
.hero-kicker{text-transform:uppercase;letter-spacing:4px;color:var(--sage);font-size:13px;font-weight:700;margin:0 0 10px}
.hero-title{font-size:64px;color:var(--clay);margin:0 0 14px;font-weight:700}
.hero-sub{font-family:var(--serif);font-style:italic;font-size:23px;color:var(--brown);margin:0 0 14px}
.hero-desc{max-width:620px;margin:0 auto 28px;color:var(--ink);font-size:18px}

/* Sections */
.block{padding:64px 24px}
.section-title{text-align:center;font-size:34px;color:var(--brown);margin:0 0 36px;position:relative}
.section-title:after{content:"";display:block;width:54px;height:3px;background:var(--gold);border-radius:3px;margin:14px auto 0}

/* Category grid */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;background:var(--card);border:1px solid var(--line);border-left:6px solid var(--c);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow);transition:.2s}
.cat-card:hover{transform:translateY(-3px)}
.cat-dot{width:14px;height:14px;border-radius:50%;background:var(--c)}
.cat-name{font-family:var(--serif);font-weight:700;font-size:21px;color:var(--ink)}
.cat-count{font-size:13px;color:var(--muted)}

/* Post grid + cards */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.2s}
.card:hover{transform:translateY(-4px)}
.card-media{display:block}
.card-thumb{width:100%;aspect-ratio:16/10;object-fit:cover}
.card-thumb.ph{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--ph),rgba(0,0,0,.18));}
.card-thumb.ph span{font-family:var(--serif);color:#fff;font-weight:700;font-size:20px;letter-spacing:.5px;text-shadow:0 1px 6px rgba(0,0,0,.25)}
.card-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.pill{align-self:flex-start;background:var(--c);color:#fff;font-size:12px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:4px 12px;border-radius:999px}
.pill:hover{color:#fff;opacity:.9}
.card-title{font-size:21px;margin:2px 0 0;line-height:1.25}
.card-title a{color:var(--ink)}
.card-title a:hover{color:var(--clay)}
.card-excerpt{color:var(--muted);font-size:15.5px;margin:0;flex:1}
.card-more{font-weight:700;font-size:14.5px;color:var(--clay)}

/* Archive head */
.archive-head{background:var(--tan);border-bottom:1px solid var(--line);padding:54px 0;text-align:center;margin-bottom:48px}
.archive-title{font-size:40px;color:var(--brown);margin:0}
.archive-desc{color:var(--muted);max-width:620px;margin:12px auto 0}

/* Single */
.single-wrap{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:48px;padding-top:54px;padding-bottom:64px;align-items:start}
.single{background:transparent}
.single-head{margin-bottom:22px}
.single-title{font-size:40px;color:var(--clay);margin:14px 0 8px;line-height:1.15}
.single-meta{color:var(--muted);font-size:14px;margin:0}
.single-hero{margin:0 0 26px;border-radius:var(--radius);overflow:hidden}
.single-content{font-size:18.5px;color:var(--ink)}
.single-content p{margin:0 0 20px}
.single-content h2{font-size:28px;color:var(--brown);margin:38px 0 14px}
.single-content h3{font-size:22px;color:var(--sage);margin:28px 0 10px}
.single-content ul,.single-content ol{margin:0 0 22px;padding-left:24px}
.single-content li{margin:0 0 9px}
.single-content a{text-decoration:underline;text-underline-offset:3px}
.single-content blockquote{margin:24px 0;padding:6px 22px;border-left:4px solid var(--gold);background:var(--tan);border-radius:8px;font-style:italic;color:var(--brown)}
.single-content img{border-radius:var(--radius);margin:18px 0}
.page-single{max-width:760px;margin:0 auto;padding:40px 0 64px}

/* Sidebar */
.sidebar{display:flex;flex-direction:column;gap:22px;position:sticky;top:96px}
.card-widget,.widget{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px;box-shadow:var(--shadow)}
.widget-title{font-size:18px;color:var(--brown);margin:0 0 12px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.link-list{list-style:none;margin:0;padding:0}
.link-list li{padding:7px 0;border-bottom:1px dotted var(--line)}
.link-list li:last-child{border-bottom:none}
.link-list a{color:var(--ink);font-weight:600;font-size:15px}
.link-list a:hover{color:var(--clay)}

/* Search */
.search-form{display:flex;gap:8px}
.search-field{flex:1;padding:11px 14px;border:1px solid var(--line);border-radius:999px;font-family:var(--sans);font-size:15px;background:var(--cream)}

/* Pagination */
.pagination{margin:46px 0 10px;text-align:center}
.pagination .page-numbers{display:inline-block;padding:9px 15px;margin:0 4px;border-radius:10px;background:var(--card);border:1px solid var(--line);color:var(--ink);font-weight:700}
.pagination .current{background:var(--clay);color:#fff;border-color:var(--clay)}

/* Footer */
.site-footer{background:#2f2a25;color:#e9e0d4;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px;padding:56px 24px 40px}
.footer-brand{font-family:var(--serif);font-size:26px;color:#fff;font-weight:700;display:block;margin-bottom:10px}
.footer-about p{color:#c9bdac;font-size:15.5px;max-width:340px}
.footer-col h4{font-family:var(--serif);color:#fff;font-size:18px;margin:0 0 14px}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{padding:6px 0}
.footer-col a,.footer-about a{color:#d8cdbd}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid #443d35;padding:18px 0;font-size:13.5px;color:#a89c8c;text-align:center}

@media (max-width:900px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .post-grid{grid-template-columns:repeat(2,1fr)}
  .single-wrap{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-title{font-size:48px}
}
@media (max-width:560px){
  body{font-size:17px}
  .cat-grid,.post-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-title{font-size:38px}
  .header-inner{justify-content:center;text-align:center}
  .brand-link{align-items:center}
  .single-title{font-size:30px}
}

/* ===== Images & polish (v1.1) ===== */
.hero--photo{border-bottom:none}
.hero--photo .hero-inner{padding:104px 24px 112px}
.hero--photo .hero-kicker{color:#F2E9DD}
.hero--photo .hero-title{color:#fff}
.hero--photo .hero-sub{color:#FBEFE4}
.hero--photo .hero-desc{color:#F4EAdd}
.hero--photo .btn{background:#fff;color:#A8512F;border-color:#fff}
.hero--photo .btn:hover{background:#F2E9DD;border-color:#F2E9DD;color:#8A4B30}

img.card-thumb{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.card-media{overflow:hidden}
.card-thumb{transition:transform .45s ease}
.card:hover .card-thumb{transform:scale(1.05)}

.cat-card.has-img{padding:0;flex-direction:column;align-items:stretch;overflow:hidden}
.cat-card.has-img .cat-img{display:block;height:160px;background-size:cover;background-position:center;transition:transform .5s ease}
.cat-card.has-img:hover .cat-img{transform:scale(1.05)}
.cat-card.has-img .cat-meta{display:flex;flex-direction:column;gap:2px;padding:14px 18px;border-left:6px solid var(--c);background:var(--card)}

.single-hero{margin:0 0 28px;border-radius:var(--radius);overflow:hidden;max-height:460px}
.single-hero img{width:100%;height:460px;object-fit:cover;display:block}

.archive-head--photo{border-bottom:none}
.archive-head--photo .archive-title{color:#fff}
.archive-head--photo .archive-desc{color:#F2E9DD}
@media (max-width:560px){ .single-hero img{height:280px} .hero--photo .hero-inner{padding:72px 24px} }
