﻿@charset "UTF-8";

/* --------------------------------------------------------------------
  カテゴリ一覧　共通
--------------------------------------------------------------------- */
h1.category_name_,
h1.genre_name_ {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px 10px;
  margin: 0 0 24px;
  padding: 18px 30px;
  font-weight: bold;
  font-size: 28px;
  line-height: 1.28;
  background: var(--bgColor);
}

h1.category_name_::before,
h1.genre_name_::before {
  content: "";
  position: absolute;
  top: 16px;
  left: 0;
  width: 6px;
  height: 40px;
  background: var(--themeColor);
}

h1.category_name_ span,
h1.genre_name_ span {
  display: inline-block;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.5;
}

h1.category_name_ span:has(+span),
h1.genre_name_ span:has(+span) {
  margin-right: 15px;
}

h1.category_name_img_ {
  margin-bottom: 10px;
}

div.comment_middle_ {
  margin: 0 0 16px;
  font-weight: 400;
  line-height: 1.625;
}

/* --------------------------------------------------------------------
  カテゴリ一覧　ピックアップ
--------------------------------------------------------------------- */
div.CategoryStyleP_ {
  margin: 80px 0 40px;
  padding: 24px;
  background: var(--bgColor);
}

.CategoryStyleP_Title_ {
  margin: 0 0 20px;
  font-weight: bold;
  font-size: 20px;
}

div.CategoryStyleP_Line_ {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

div.CategoryStyleP_Item_ {
  /* 20260428 FO #109 /5->/4*/
  width: calc((100% - (8px*4))/4);
  margin-bottom: 5px;
}

div.CategoryStyleP_Item_ .category_link_,
div.CategoryStyleP_Item_ .category_nolink_ {
  display: block;
  height: 100%;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--borderColor);
  border-radius: 4px;
}

div.CategoryStyleP_Item_:not(:has(.img_)) .category_link_,
div.CategoryStyleP_Item_:not(:has(.img_)) .category_nolink_ {
  display: flex;
  align-items: center;
  height: 56px;
  padding: 0 12px;
}

div.CategoryStyleP_Item_ .img_ {
  margin: 0 0 12px;
}

div.CategoryStyleP_Item_ .name_::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 8px;
  margin-right: 7px;
  background: var(--themeColor);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

div.CategoryStyleP_Item_ .comment_ {
  margin: 7px 0 0;
  font-size: 16px;
  word-break: break-all;
}

/* 20260428 FO #109*/
div.CategoryStyleP_Item_ .category_link_ {
  display: flex;
  align-items: center;
}

div.CategoryStyleP_Item_ .img_ {
  margin: 0 12px 0 0;
}

/* --------------------------------------------------------------------
  カテゴリ一覧　孫カテゴリ
--------------------------------------------------------------------- */
div.CategoryStyleG_ {
  width: 100%;
}

.top_layout_1_ div.CategoryStyleG_ {
  width: auto;
  margin: 0 160px;
}

div.CategoryStyleG_Line_ {
  display: flex;
  flex-wrap: wrap;
  gap: 32px 40px;
  width: 100%;
  margin-top: 20px;
}

div.CategoryStyleG_Item_ {
  width: calc(33% - 23px);
}

div.CategoryStyleG_Item_ h3.name_ {
  margin: 0 0 16px;
  padding: 1px 0;
  font-size: 18px;
  font-weight: bold;
  border-bottom: 1px solid #707070;
}

div.CategoryStyleG_Item_ .img_ {
  margin: 0 0 16px;
}

div.CategoryStyleG_Item_ .comment_ {
  font-size: 16px;
  font-weight: 500;
  word-break: break-all;
}

div.CategoryStyleG_ ul li {
  margin: 0;
  list-style: none;
}

/* --------------------------------------------------------------------
  カテゴリ一覧　一覧
--------------------------------------------------------------------- */
div.CategoryStyleL_ {
  width: 100%;
  border: none;
  padding: 10px 0;
  font-size: 16px;
}

.top_layout_1_ div.CategoryStyleL_ {
  margin: 0 160px;
}

div.CategoryStyleL_ span.name_ {
  margin: 4px;
  font-weight: bold;
  white-space: nowrap;
}

/* --------------------------------------------------------------------
  カテゴリ一覧　サムネイル
--------------------------------------------------------------------- */
div.CategoryStyleT_ {
  width: 100%;
}

.top_layout_1_ div.CategoryStyleT_ {
  width: auto;
  margin: 0 160px;
}

div.CategoryStyleT_Line_ {
  display: flex;
  gap: 41px;
  width: 100%;
  margin: 0 0 40px;
}

div.CategoryStyleT_Line_:last-of-type {
  margin-bottom: 0;
}

div.CategoryStyleT_Item_ {
  width: calc((100% - 123px) / 4);
}

div.CategoryStyleT_Item_ h3.img_ {
  margin: 0 0 12px;
  padding: 0;
  border: none;
}

div.CategoryStyleT_Item_ h3.name_ {
  font-size: 14px;
  font-weight: bold;
  border-bottom: 2px solid #3763ba;
  padding-bottom: 10px;
  margin-bottom: 10px;
}

div.CategoryStyleT_Item_ .comment_ {
  font-size: 16px;
  font-weight: 500;
  word-break: break-all;
}

/* --------------------------------------------------------------------
  カテゴリ一覧　詳細
--------------------------------------------------------------------- */
div.CategoryStyleD_ {
  width: 100%;
  overflow: hidden;
}

.top_layout_1_ div.CategoryStyleD_ {
  width: auto;
  margin: 0 160px;
}

div.CategoryStyleD_Item_ {
  width: 100%;
  overflow: hidden;
}

div.CategoryStyleD_Item_ h3 {
  margin: 0 0 12px;
  padding: 7px 20px;
  border: 1px solid #dedede;
  border-radius: 4px;
  font-size: 16px;
  font-weight: 500;
  background-color: #fff;
}

div.CategoryStyleD_Item_ a {
  color: #3763ba;
}

/* --------------------------------------------------------------------
  ジャンル一覧
--------------------------------------------------------------------- */
div.GenreStyle_ {
  display: none;
  margin: 80px 0 40px;
  padding: 24px;
  background: var(--bgColor);
}

.GenreStyle_Title_ {
  margin: 0 0 20px;
  font-weight: bold;
  font-size: 20px;
}

div.GenreStyle_Line_ {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

div.GenreStyle_Item_ {
  width: calc((100% - (8px*4))/5);
}

div.GenreStyle_Item_ a {
  display: block;
  height: 100%;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--borderColor);
  border-radius: 4px;
}

div.GenreStyle_Item_ h3.name_ a {
  display: flex;
  align-items: center;
  height: 56px;
  padding: 0 12px;
}

div.GenreStyle_Item_ h3.name_ a::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 8px;
  margin-right: 7px;
  background: var(--themeColor);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

div.GenreStyle_Item_ div.comment_ {
  margin: 7px 0 0;
  font-size: 16px;
  word-break: break-all;
}