/* assets/css/menu.css — カテゴリタブ・レストランカード・メニューアイテム */

/* ===== カテゴリタブ ===== */
.category-tabs {
  background: var(--color-bg-card);
  border-bottom: 2px solid var(--color-border);
  padding-block: 0.6rem;
  position: sticky;
  top: 62px;
  z-index: 100;
}

.tab-list {
  display: flex;
  gap: 0.4rem;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: 0.2rem;
}

.tab-list::-webkit-scrollbar {
  display: none;
}

.tab {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.4rem 1rem;
  border-radius: 20px;
  font-size: 0.875rem;
  font-weight: 500;
  white-space: nowrap;
  color: var(--color-text);
  border: 2px solid var(--color-border);
  background: var(--color-bg-card);
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.tab:hover:not(.tab--active) {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.tab--active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* ===== カテゴリヒーロー ===== */
.category-hero {
  background: linear-gradient(135deg, #fff5f5 0%, #fff 60%);
  border-bottom: 1px solid var(--color-border);
  padding-block: 2.5rem;
  text-align: center;
}

.category-hero__icon {
  font-size: 3rem;
  margin-bottom: 0.75rem;
}

.category-hero__title {
  font-size: 2rem;
  font-weight: 800;
  color: var(--color-text);
  margin-bottom: 0.5rem;
}

.category-hero__desc {
  color: var(--color-muted);
  font-size: 1rem;
  margin-bottom: 0.75rem;
}

/* ===== レストランセクション ===== */
.restaurant-section {
  padding-block: 2rem;
}

/* ===== レストラングリッド ===== */
.restaurant-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}

/* ===== レストランカード ===== */
.restaurant-card {
  background: var(--color-bg-card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), box-shadow var(--transition);
}

.restaurant-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.restaurant-card__img {
  width: 100%;
  height: 190px;
  object-fit: cover;
}

.restaurant-card__img--placeholder {
  width: 100%;
  height: 190px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #fff3f3, #fce4ec);
  font-size: 4rem;
}

.restaurant-card__body {
  padding: 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1;
}

.restaurant-card__name {
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.4;
}

.restaurant-card__name a {
  color: var(--color-text);
}

.restaurant-card__name a:hover {
  color: var(--color-primary);
}

.restaurant-card__desc {
  font-size: 0.85rem;
  color: var(--color-muted);
  line-height: 1.6;
  flex: 1;
}

.restaurant-card__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.85rem;
}

/* ===== レストランヒーロー（詳細ページ） ===== */
.restaurant-hero {
  padding-block: 2rem;
}

.restaurant-detail__header {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 2rem;
  align-items: start;
  margin-bottom: 2.5rem;
}

.restaurant-detail__img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.restaurant-detail__img-placeholder {
  width: 100%;
  height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #fff3f3, #fce4ec);
  border-radius: var(--radius);
  font-size: 5rem;
}

.restaurant-detail__info {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.restaurant-detail__name {
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.3;
}

.restaurant-detail__desc {
  color: var(--color-muted);
  line-height: 1.8;
}

.restaurant-detail__meta {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
}

.restaurant-detail__address,
.restaurant-detail__phone {
  font-size: 0.9rem;
  color: var(--color-muted);
}

.restaurant-detail__phone a {
  color: var(--color-secondary);
}

/* ===== メニューセクション ===== */
.menu-wrapper {
  margin-top: 1rem;
}

.menu-heading {
  font-size: 1.5rem;
  font-weight: 800;
  padding-bottom: 0.75rem;
  border-bottom: 3px solid var(--color-primary);
  margin-bottom: 1.5rem;
}

.menu-section {
  margin-bottom: 2.5rem;
}

.menu-section__title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-text);
  padding: 0.5rem 0.75rem;
  background: #fff3f3;
  border-left: 4px solid var(--color-primary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin-bottom: 1rem;
}

.menu-items-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.menu-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding: 0.9rem 1.1rem;
  background: var(--color-bg-card);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border);
  transition: box-shadow var(--transition);
}

.menu-item:hover {
  box-shadow: var(--shadow);
}

.menu-item__info {
  flex: 1;
  min-width: 0;
}

.menu-item__name {
  font-size: 0.975rem;
  font-weight: 700;
  display: block;
  margin-bottom: 0.25rem;
}

.menu-item__desc {
  font-size: 0.825rem;
  color: var(--color-muted);
  line-height: 1.6;
  margin-bottom: 0.4rem;
}

.menu-item__badges {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.menu-item__price {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--color-primary);
  white-space: nowrap;
  min-width: 5rem;
  text-align: right;
}

/* ===== ソートバー ===== */
.sort-bar {
  background: var(--color-bg-card);
  border-bottom: 1px solid var(--color-border);
  padding: .6rem 0;
}

.sort-bar .container {
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
}

.sort-bar__label {
  font-size: .85rem;
  color: var(--color-muted);
  white-space: nowrap;
}

.sort-bar__select {
  padding: .35rem .75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-card);
  font-size: .875rem;
  color: var(--color-text);
  cursor: pointer;
}

.sort-bar__reset {
  font-size: .8rem;
  color: var(--color-muted);
  text-decoration: underline;
}

/* ===== メニューアイテム（栄養情報・期間限定対応版） ===== */
.menu-item__img {
  width: 100%;
  max-height: 180px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  margin-bottom: .75rem;
}

.menu-item--limited {
  border-left: 3px solid #f4a522;
}

.menu-item__main {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.menu-item__info { flex: 1; }

.menu-item__name-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}

.menu-item__end-date {
  font-size: .78rem;
  color: #f4a522;
  margin-top: .15rem;
}

.menu-item__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .35rem;
  min-width: 120px;
}

.menu-item__nutrition {
  font-size: .8rem;
  text-align: right;
  color: var(--color-muted);
  line-height: 1.5;
}

.nutrition-cal {
  display: block;
  font-weight: 700;
  color: var(--color-text);
  font-size: .875rem;
}

.nutrition-pfc {
  display: flex;
  gap: .35rem;
  font-size: .75rem;
  margin-top: .15rem;
}

.pfc-p { color: var(--pfc-p); font-weight: 600; }
.pfc-f { color: var(--pfc-f); font-weight: 600; }
.pfc-c { color: var(--pfc-c); font-weight: 600; }

/* PFCバー（restaurant.php 用） */
.pfc-bar {
  display: flex;
  height: 6px;
  border-radius: 3px;
  overflow: hidden;
  width: 120px;
}

.pfc-bar__p { flex: var(--pfc-p, 0); background: var(--pfc-p); }
.pfc-bar__f { flex: var(--pfc-f, 0); background: var(--pfc-f); }
.pfc-bar__c { flex: var(--pfc-c, 0); background: var(--pfc-c); }

/* ===== 期間限定バッジ ===== */
.badge--limited {
  background: #fff3cd;
  color: #856404;
  border: 1px solid #ffc107;
  font-size: .7rem;
  padding: .1em .5em;
  border-radius: 9999px;
  white-space: nowrap;
}

/* ===== 記事一覧 ===== */
.articles-section { padding: 2rem 0; }

.article-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 1.5rem;
}

.article-card {
  background: var(--color-bg-card);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
}

.article-card:hover {
  box-shadow: var(--shadow);
  transform: translateY(-3px);
}

.article-card__thumb-link {
  display: block;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--color-bg);
}

.article-card__thumb-link--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
}

.article-card__thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s ease;
}

.article-card__thumb-link:hover .article-card__thumb {
  transform: scale(1.04);
}

.article-card__body {
  padding: 1rem;
}

.badge--restaurant {
  background: #e8f0fe;
  color: #1967d2;
  font-size: .7rem;
  padding: .15em .6em;
  border-radius: 9999px;
  text-decoration: none;
  display: inline-block;
  margin-bottom: .4rem;
}

.article-card__title {
  font-size: .95rem;
  font-weight: 700;
  line-height: 1.5;
  margin: .3rem 0 .5rem;
}

.article-card__title a {
  color: var(--color-text);
  text-decoration: none;
}

.article-card__title a:hover { color: var(--color-primary); }

.article-card__excerpt {
  font-size: .8rem;
  color: var(--color-muted);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: .5rem;
}

.article-card__date {
  font-size: .75rem;
  color: var(--color-muted);
}

/* ===== 記事詳細 ===== */
.article-detail {
  padding: 2rem 0;
}

.article-detail__container {
  max-width: 780px;
}

.article-detail__header {
  margin-bottom: 1.5rem;
}

.article-detail__title {
  font-size: 1.75rem;
  font-weight: 800;
  line-height: 1.4;
  margin: .5rem 0;
}

.article-detail__date {
  font-size: .85rem;
  color: var(--color-muted);
}

.article-detail__thumbnail {
  width: 100%;
  border-radius: var(--radius);
  margin-bottom: 1.5rem;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.article-detail__body {
  line-height: 1.9;
  font-size: .95rem;
}

.article-detail__body p { margin-bottom: 1rem; }

.article-detail__footer {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

/* ===== ページネーション ===== */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
}

.pagination__link {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: 600;
  font-size: .875rem;
}

.pagination__info {
  font-size: .85rem;
  color: var(--color-muted);
}

/* ===== コンタクトフォーム ===== */
.contact-section { padding: 2rem 0; }

.contact-section__container { max-width: 640px; }

.contact-section__lead {
  color: var(--color-muted);
  margin-bottom: 1.5rem;
}

.contact-form .btn--lg {
  padding: .75rem 2rem;
  font-size: 1rem;
}

/* ===== フォーム共通 ===== */
.form-group {
  margin-bottom: 1.25rem;
}

.form-group--error .form-input,
.form-group--error .form-textarea,
.form-group--error .form-select {
  border-color: #e63946;
  background: #fff8f8;
}

.form-label {
  display: block;
  font-size: .875rem;
  font-weight: 600;
  margin-bottom: .4rem;
  color: var(--color-text);
}

.form-required {
  color: var(--color-primary);
  font-size: .75rem;
  margin-left: .25rem;
}

.form-input,
.form-textarea,
.form-select {
  display: block;
  width: 100%;
  padding: .5rem .75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--color-text);
  background: var(--color-bg-card);
  transition: border-color var(--transition);
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  outline: none;
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(69,123,157,.15);
}

.form-textarea { resize: vertical; min-height: 140px; }

.form-error {
  color: #e63946;
  font-size: .8rem;
  margin-top: .3rem;
}

.form-check {
  display: flex;
  align-items: center;
  gap: .5rem;
  cursor: pointer;
  font-size: .9rem;
}

/* ===== アラート（公開ページ用） ===== */
.alert--success { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; border-radius: var(--radius); padding: 1rem 1.25rem; }
.alert--error   { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; border-radius: var(--radius); padding: 1rem 1.25rem; }
