@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=Fraunces:opsz,wght@9..144,500;9..144,700&display=swap');

:root{
  --bg:#faf9f7;
  --card:#ffffff;
  --text:#1a1a1a;
  --muted:#5c5c5c;
  --link:#2563eb;
  --accent:#059669;
  --accent-soft:#ecfdf5;
  --border:rgba(0,0,0,.08);
  --max: 1080px;
  --shadow: 0 1px 3px rgba(0,0,0,.04), 0 6px 16px rgba(0,0,0,.06);
  --radius: 12px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}

body{
  font-family: 'Outfit', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.7;
  font-size: 16px;
}

h1, h2, h3 {
  font-family: 'Fraunces', serif;
  font-weight: 700;
  letter-spacing: -0.02em;
}

a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

.container{max-width:var(--max);margin:0 auto;padding:24px}

/* Header */
.header{
  position:sticky;top:0;
  background: rgba(250,249,247,.92);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--border);
  z-index:100;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;color:var(--text)}
.brand:hover{text-decoration:none}
.badge{
  font-size:11px;
  font-weight:500;
  padding:3px 10px;
  background:var(--accent-soft);
  color:var(--accent);
  border-radius:20px;
  text-transform:uppercase;
  letter-spacing:.5px;
}
.menu{display:flex;gap:8px;flex-wrap:wrap}
.menu a{
  padding:8px 14px;
  border-radius:8px;
  color:var(--text);
  font-weight:500;
  font-size:14px;
  transition: background .15s;
}
.menu a:hover{background:rgba(0,0,0,.04);text-decoration:none}

/* Hero */
.hero{padding:48px 0 32px;max-width:720px}
.hero h1{font-size:clamp(32px, 5vw, 46px);line-height:1.1;margin:0 0 16px}
.hero p{margin:0;color:var(--muted);font-size:18px;max-width:64ch}

.kicker{
  display:inline-block;
  color:var(--accent);
  font-size:13px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:8px;
}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px;margin:32px 0 40px}

/* Cards */
.card{
  grid-column:span 12;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:24px;
  box-shadow: var(--shadow);
  transition: transform .2s, box-shadow .2s;
}
.card:hover{
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,.08), 0 12px 24px rgba(0,0,0,.08);
}
.card h2{margin:0 0 8px;font-size:20px}
.card p{margin:0;color:var(--muted);font-size:15px}

@media (min-width: 860px){
  .card.span6{grid-column:span 6}
  .card.span4{grid-column:span 4}
}

/* Thumbnail system */
.card-thumb{
  height:140px;
  border-radius:8px;
  margin-bottom:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  background-size:cover;
  background-position:center;
}
.card-thumb.cat-checklist{background-image:url('/img/checklist.svg')}
.card-thumb.cat-windows{background-image:url('/img/windows.svg')}
.card-thumb.cat-plumbing{background-image:url('/img/plumbing.svg')}
.card-thumb.cat-cleaning{background-image:url('/img/cleaning.svg')}
.card-thumb.cat-moveout{background-image:url('/img/moveout.svg')}
.card-thumb.cat-doors{background-image:url('/img/doors.svg')}
.card-thumb.cat-humidity{background-image:url('/img/humidity.svg')}
.card-thumb.cat-kitchen{background-image:url('/img/kitchen.svg')}
.card-thumb.cat-vent{background-image:url('/img/vent.svg')}
.card-thumb.cat-shower{background-image:url('/img/shower.svg')}
.card-thumb.cat-drain{background-image:url('/img/drain.svg')}

/* Section titles */
.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:20px}
.section-title h2{margin:0;font-size:24px}
.section-title a{font-size:14px;font-weight:500}

/* Post list */
.post-list{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:700px){
  .post-list{grid-template-columns:repeat(2,1fr)}
}

.post{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
  transition: transform .2s, box-shadow .2s;
}
.post:hover{
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,.08), 0 12px 24px rgba(0,0,0,.08);
}
.post-thumb{
  height:120px;
  display:flex;
  align-items:center;
  justify-content:center;
  background-size:cover;
  background-position:center;
}
.post-thumb.cat-checklist{background-image:url('/img/checklist.svg')}
.post-thumb.cat-windows{background-image:url('/img/windows.svg')}
.post-thumb.cat-plumbing{background-image:url('/img/plumbing.svg')}
.post-thumb.cat-cleaning{background-image:url('/img/cleaning.svg')}
.post-thumb.cat-moveout{background-image:url('/img/moveout.svg')}
.post-thumb.cat-doors{background-image:url('/img/doors.svg')}
.post-thumb.cat-humidity{background-image:url('/img/humidity.svg')}
.post-thumb.cat-kitchen{background-image:url('/img/kitchen.svg')}
.post-thumb.cat-vent{background-image:url('/img/vent.svg')}
.post-thumb.cat-shower{background-image:url('/img/shower.svg')}
.post-thumb.cat-drain{background-image:url('/img/drain.svg')}
.post-body{padding:16px 20px 20px}
.post .meta{font-size:12px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.post h3{margin:6px 0 8px;font-size:17px;line-height:1.35}
.post h3 a{color:var(--text)}
.post h3 a:hover{color:var(--link)}
.post p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}

/* Content pages */
.content{max-width:72ch}
.content h1{line-height:1.15;font-size:clamp(28px, 4vw, 38px);margin-top:0}
.content h2{margin-top:32px;font-size:22px}
.content ul,.content ol{padding-left:24px}
.content li{margin:8px 0}
.content table{width:100%;border-collapse:collapse;margin:20px 0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow: var(--shadow)}
.content th,.content td{border:1px solid var(--border);padding:12px 14px;text-align:left;vertical-align:top}
.content th{background:#f8f8f8;font-weight:600;font-size:14px}
.content td{font-size:15px}

/* Article images */
.content img{
  max-width:100%;
  height:auto;
  border-radius:var(--radius);
  margin:20px 0;
  box-shadow: var(--shadow);
}
.content figure{
  margin:24px 0;
  padding:0;
}
.content figcaption{
  font-size:13px;
  color:var(--muted);
  text-align:center;
  margin-top:8px;
  font-style:italic;
}

/* Author box */
.author-box{
  display:flex;
  align-items:center;
  gap:14px;
  padding:16px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin:24px 0;
}
.author-avatar{
  width:48px;
  height:48px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--accent-soft), #d1fae5);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  font-weight:600;
  color:var(--accent);
  flex-shrink:0;
}
.author-info{flex:1}
.author-name{font-weight:600;font-size:15px;margin:0}
.author-bio{font-size:13px;color:var(--muted);margin:2px 0 0}

/* Utilities */
.hr{height:1px;background:var(--border);margin:28px 0}
.footer{border-top:1px solid var(--border);padding:24px 0;color:var(--muted);font-size:13px;background:#fff}
.footer a{color:var(--muted);font-weight:500}
.footer a:hover{color:var(--text)}

.callout{
  font-size:14px;
  border-left:3px solid var(--accent);
  padding:14px 18px;
  border-radius:0 var(--radius) var(--radius) 0;
  background:var(--accent-soft);
  margin:20px 0;
}
.callout strong{color:var(--accent)}

.byline{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  font-size:13px;
  color:var(--muted);
  margin:12px 0 20px;
}
.byline strong{color:var(--text)}
.tag{
  display:inline-block;
  font-size:11px;
  font-weight:600;
  padding:3px 10px;
  background:var(--accent-soft);
  color:var(--accent);
  border-radius:20px;
  text-transform:uppercase;
  letter-spacing:.5px;
}

.btn{
  display:inline-block;
  padding:12px 20px;
  background:var(--accent);
  color:#fff;
  border-radius:8px;
  font-weight:600;
  font-size:14px;
  transition: background .15s, transform .15s;
}
.btn:hover{
  background:#047857;
  text-decoration:none;
  transform: translateY(-1px);
}
.btn-outline{
  background:transparent;
  border:1px solid var(--border);
  color:var(--text);
}
.btn-outline:hover{
  background:rgba(0,0,0,.03);
  transform: translateY(-1px);
}

.breadcrumbs{
  font-size:13px;
  color:var(--muted);
  margin:8px 0 14px;
}
.breadcrumbs a{
  color:var(--muted);
  font-weight:500;
}
.breadcrumbs a:hover{
  color:var(--text);
  text-decoration:none;
}
.breadcrumbs .sep{
  margin:0 6px;
  opacity:.6;
}

.small{font-size:13px;color:var(--muted)}
