:root { --maxw: 1024px; }
* { box-sizing: border-box; }
body { font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial; margin: 0; background: #fafafa; color: #111; }
a { color: inherit; }
.container { max-width: var(--maxw); margin: 0 auto; padding: 16px; }
.header { display:flex; align-items:center; justify-content:space-between; gap: 12px; }
.brand { display:flex; flex-direction:column; gap: 4px; }
.brand h1 { margin: 0; font-size: 22px; }
.brand p { margin: 0; opacity: 0.8; }
.nav a { margin-left: 12px; text-decoration: none; opacity: 0.9; }
.nav a:hover { text-decoration: underline; }

.toolbar { display:flex; gap: 10px; align-items:center; margin: 12px 0 18px; }
.search { flex: 1; }
.search input { width: 100%; padding: 12px 14px; border-radius: 12px; border: 1px solid #ddd; font-size: 14px; }
.select select { padding: 12px 14px; border-radius: 12px; border: 1px solid #ddd; font-size: 14px; background: white; }

.grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 12px; }
.card { background: white; border: 1px solid #e6e6e6; border-radius: 16px; padding: 14px; text-decoration: none; display:block; }
.card:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(0,0,0,0.06); }
.card h3 { margin: 0 0 6px; font-size: 16px; }
.badges { display:flex; flex-wrap:wrap; gap: 6px; margin-top: 10px; }
.badge { font-size: 12px; padding: 3px 8px; border: 1px solid #eee; border-radius: 999px; background: #f7f7f7; }
.meta { font-size: 13px; opacity: 0.85; line-height: 1.35; margin: 0; }

.footer { margin-top: 24px; padding: 16px; opacity: 0.8; font-size: 13px; }
.notice { background: #fff; border: 1px solid #e6e6e6; border-radius: 16px; padding: 12px 14px; margin: 12px 0; font-size: 13px; }
