:root { --ink:#111; --paper:#fff; --bg:#0e1b27; --muted:#5f7287; --accent:#00a2b8; }
.maguro-home .container { width:min(1100px,92%); margin-inline:auto; }
.sec-title { margin:0 0 .5rem; font-size:clamp(1.2rem, 1.2rem + 1vw, 1.8rem); font-weight:700; }
.btn { display:inline-block; padding:.75rem 1rem; border-radius:999px; border:1px solid currentColor; text-decoration:none; font-weight:700; }
.btn--primary { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn--ghost { background:transparent; color:#fff; border-color:#fff; }

.hero { color:#fff; background:linear-gradient(135deg,#001b2e 0%,#003046 100%); }
.hero__inner { display:grid; grid-template-columns:1.2fr .8fr; gap:28px; align-items:center; padding:56px 0; }
.hero__title { margin:0 0 .25em; font-size:clamp(1.8rem, 1.6rem + 2vw, 2.6rem); line-height:1.2; }
.hero__lead { color:#e7f5f8; margin:.25rem 0 1.2rem; font-size:1rem; }
.hero__actions .btn { margin-right:.5rem; }
.hero__thumb__ph { width:100%; aspect-ratio:4/3; border-radius:18px; background:linear-gradient(135deg,#0b3148,#135a7a); box-shadow:0 20px 50px rgba(0,0,0,.25); }
@media (max-width:900px){ .hero__inner{ grid-template-columns:1fr; } }

.features { padding:36px 0 8px; background:#f6f8fb; }
.cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; margin-top:12px; }
.card { display:block; background:#fff; border-radius:16px; padding:16px; text-decoration:none; color:var(--ink); box-shadow:0 8px 24px rgba(0,0,0,.06); transition:transform .2s ease, box-shadow .2s ease; }
.card:hover { transform:translateY(-2px); box-shadow:0 12px 28px rgba(0,0,0,.10); }
.card__title { margin:0 0 .25rem; font-weight:700; }
.card__desc { margin:0; color:#516170; font-size:.95rem; }

.latest { padding:32px 0; }
.posts { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:18px; margin-top:12px; }
.post-card { background:#fff; border-radius:14px; overflow:hidden; box-shadow:0 6px 18px rgba(0,0,0,.06); }
.post-card__link { color:inherit; text-decoration:none; display:block; }
.post-card__thumb img, .thumb-ph { width:100%; height:auto; display:block; aspect-ratio:16/9; object-fit:cover; background:#dde7ee; }
.post-card__body { padding:12px 14px; }
.post-card__title { margin:0 0 .25rem; font-weight:700; font-size:1rem; line-height:1.35; }
.post-card__date { display:block; color:#6c7a86; font-size:.85rem; margin-bottom:.25rem; }
.post-card__excerpt { color:#4b5a69; font-size:.95rem; }
.post-card__meta { padding:0 14px 12px; font-size:.85rem; color:#6b7b8b; }

.taxonomy-grid { padding:16px 0 28px; background:#f6f8fb; }
.chips { display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; }
.chip { display:inline-block; padding:.55rem .9rem; background:#fff; border:1px solid #e2e8f0; border-radius:999px; text-decoration:none; color:#22303c; font-weight:600; }

.cta { padding:36px 0 64px; }
.cta__box { background:linear-gradient(135deg,#001b2e,#003046); color:#fff; border-radius:18px; padding:28px; text-align:center; box-shadow:0 16px 40px rgba(0,0,0,.18); }
.cta__title { margin:.2rem 0 .5rem; font-size:clamp(1.2rem, 1rem + 1vw, 1.8rem); }
.cta__text { color:#e7f5f8; margin:0 0 1rem; }
.more-center { text-align:center; margin-top:18px; }

/* ===== Category Blocks (ご飯情報 / 旅行 / 趣味) ===== */
.maguro-cat-blocks { padding: 8px 0 32px; background:#f6f8fb; }
.cat-blocks__wrap { display:grid; gap:20px; }
@media (min-width: 900px){ 
  .cat-blocks__wrap{ grid-template-columns:repeat(3,1fr); } 
}

.cat-block { background:#fff; border-radius:16px; padding:16px; box-shadow:0 8px 24px rgba(0,0,0,.06); }
.cat-block__head { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.cat-block__title { margin:0; font-size:1.05rem; font-weight:800; }
.cat-block__more { font-weight:700; text-decoration:none; color:#00a2b8; }
.cat-block__desc { margin:.3rem 0 .8rem; color:#516170; font-size:.93rem; }

.cat-block__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.cat-post { background:#fff; border-radius:12px; overflow:hidden; border:1px solid #eef2f7; }
.cat-post__link { display:block; color:inherit; text-decoration:none; }
.cat-post__thumb img, .cat-post .thumb-ph { 
  width:100%; 
  aspect-ratio:16/9; 
  object-fit:cover; 
  background:#dde7ee; 
  display:block; 
}
.cat-post__body { padding:10px 12px; }
.cat-post__title { margin:0 0 .25rem; font-size:.98rem; font-weight:700; line-height:1.35; }
.cat-post__date { display:block; color:#6b7b8b; font-size:.83rem; }