/* Tag archive layout */
.tag-hero { padding: 48px 0 28px; background: #fafafb; border-bottom: 1px solid #eee; }
.tag-hero .tag-ttl { font-size: clamp(22px, 3.5vw, 34px); margin: 0 0 8px; }
.tag-hero .tag-meta { color: #666; margin-bottom: 12px; font-size: 14px; }
.tag-hero .tag-desc { max-width: 820px; line-height: 1.9; }

.tag-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.tag-chips .chip { display: inline-block; border: 1px solid #ddd; padding: 6px 10px; border-radius: 999px; font-size: 13px; background: #fff; }

.wrap { width: min(1100px, 92%); margin: 0 auto; }
.tag-body { display: grid; grid-template-columns: 1fr 320px; gap: 28px; padding: 28px 0; }
@media (max-width: 1024px) { .tag-body { grid-template-columns: 1fr; } }

.card-grid { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 1100px) { .card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .card-grid { grid-template-columns: 1fr; } }

.card { border: 1px solid #eee; background: #fff; border-radius: 10px; overflow: hidden; display: flex; flex-direction: column; }
.card-thumb img { width: 100%; height: auto; display: block; aspect-ratio: 3/2; object-fit: cover; }
.card-body { padding: 14px 14px 16px; display: flex; flex-direction: column; gap: 10px; }
.card-ttl { font-size: 18px; line-height: 1.5; margin: 0; }
.card-ttl a { text-decoration: none; }
.card-excerpt { color: #444; font-size: 14px; line-height: 1.8; margin: 0; }
.card-meta { display: flex; gap: 10px; align-items: center; color: #777; font-size: 12px; }
.card-cat a { color: inherit; text-decoration: underline; }
.card-cta { margin-top: auto; }
.btn { display: inline-block; padding: 10px 14px; border-radius: 6px; text-decoration: none; border: 1px solid #ddd; }
.btn-more { background: #f7f7f8; }
.btn-primary { background: #e53935; color: #fff; border-color: #e53935; }
.btn-secondary { background: #f0f1f3; }
.btn-line { background: #00c300; color: #fff; border-color: #00c300; }
.btn:hover { opacity: .9; }

.tag-aside .aside-box { border: 1px solid #eee; border-radius: 8px; padding: 14px; background: #fff; margin-bottom: 16px; }
.aside-ttl { font-size: 16px; margin: 0 0 10px; }
.mini-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.mini-list a { text-decoration: none; }
.svc-links { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.svc-links a { text-decoration: none; }

.pagination { margin-top: 24px; }
.pagination .page-numbers { display: inline-block; margin-right: 6px; padding: 8px 10px; border: 1px solid #eee; border-radius: 6px; }
.pagination .current { background: #111; color: #fff; border-color: #111; }
