/* ============================================================
   gorogo-design.css  v3
   文字サイズ全面拡大・見やすさ重視
   ============================================================ */

/* ---- デザイントークン ---- */
:root {
  --gorogo-bg:       #EDECEA;
  --gorogo-bg2:      #F4F2F0;
  --gorogo-bg3:      #FAFAF8;
  --gorogo-ink:      #141412;
  --gorogo-ink-mid:  #5C5A56;
  --gorogo-ink-soft: #9A9893;
  --gorogo-rule:     #DDDBD8;
  --gorogo-accent:   #B8622A;
  --gorogo-pop:      #2D78C8;
  --gorogo-pop-lt:   #EBF2FB;
  --gorogo-ftr:      #3A3936;
}

/* ============================================================
   ヘッダー固定（sticky）
   ============================================================ */
#site-header,
.site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
  background: var(--gorogo-bg3) !important;
  border-bottom: 1px solid var(--gorogo-rule) !important;
  box-shadow: none !important;
}
.admin-bar #site-header,
.admin-bar .site-header {
  top: 32px !important;
}
@media screen and (max-width: 782px) {
  .admin-bar #site-header,
  .admin-bar .site-header {
    top: 46px !important;
  }
}
/* 社名：太い明朝体 */
.site-title a,
.site-title a:hover,
.site-header-logo a,
.site-header-logo a span {
  font-family: 'Noto Serif JP', 'YuMincho', '游明朝', Georgia, serif !important;
  font-weight: 700 !important;
  font-style: normal !important;
  font-size: 17px !important;
  letter-spacing: .1em !important;
  color: var(--gorogo-ink) !important;
  text-decoration: none !important;
}
.global-nav a,
.vk-mobile-nav a {
  font-size: 13px !important;
  color: var(--gorogo-ink-mid) !important;
  letter-spacing: .08em !important;
}
.global-nav a:hover { color: var(--gorogo-ink) !important; }
.global-nav .menu-item:last-child a {
  color: var(--gorogo-pop) !important;
  border-bottom: 1.5px solid var(--gorogo-pop);
  padding-bottom: 14px !important;
}

/* ============================================================
   お知らせバー
   ============================================================ */
.gorogo-news-bar {
  background: var(--gorogo-bg2);
  border-bottom: 1px solid var(--gorogo-rule);
  width: 100%;
}
.gorogo-news-bar__inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  gap: 16px;
  height: 40px;
}
.gorogo-news-bar__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .2em;
  color: var(--gorogo-pop);
  flex-shrink: 0;
  font-family: 'Noto Sans JP', sans-serif;
}
.gorogo-news-bar__divider {
  width: 1px;
  height: 14px;
  background: var(--gorogo-rule);
  flex-shrink: 0;
}
.gorogo-news-bar__date {
  font-size: 12px;
  color: var(--gorogo-ink-soft);
  flex-shrink: 0;
  letter-spacing: .04em;
}
.gorogo-news-bar__text {
  font-size: 13px;
  color: var(--gorogo-ink-mid);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}
.gorogo-news-bar__text strong { color: var(--gorogo-ink); font-weight: 600; }
.gorogo-news-bar__text a { color: var(--gorogo-ink-mid) !important; text-decoration: none; }
.gorogo-news-bar__text a:hover { color: var(--gorogo-pop) !important; }
.gorogo-news-bar__more {
  font-size: 11px;
  color: var(--gorogo-ink-soft);
  text-decoration: none;
  letter-spacing: .06em;
  flex-shrink: 0;
  transition: color .15s;
}
.gorogo-news-bar__more:hover { color: var(--gorogo-pop); }

/* ============================================================
   ヒーロー
   ============================================================ */
.gorogo-hero {
  background: var(--gorogo-bg2);
  border-bottom: 1px solid var(--gorogo-rule);
  padding: 80px 32px 72px;
  position: relative;
  overflow: hidden;
}
.gorogo-hero::after {
  content: 'G';
  position: absolute;
  right: -30px;
  top: 50%;
  transform: translateY(-50%);
  font-family: 'Noto Serif JP', Georgia, serif;
  font-size: 340px;
  font-weight: 400;
  font-style: italic;
  color: rgba(20, 20, 18, .04);
  line-height: 1;
  pointer-events: none;
}
.gorogo-hero__inner {
  max-width: 1080px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.gorogo-hero__eyebrow {
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--gorogo-ink-soft);
  font-family: 'Noto Sans JP', sans-serif;
  margin-bottom: 20px;
  display: block;
}
.gorogo-hero__title {
  font-family: 'Noto Serif JP', 'YuMincho', Georgia, serif !important;
  font-size: clamp(28px, 4vw, 46px) !important;
  font-weight: 400 !important;
  font-style: italic !important;
  color: var(--gorogo-ink) !important;
  line-height: 1.45 !important;
  letter-spacing: .08em !important;
  margin-bottom: 20px !important;
  border: none !important;
  padding: 0 !important;
}
.gorogo-hero__sub {
  font-size: 15px;
  color: var(--gorogo-ink-mid);
  line-height: 2;
  letter-spacing: .04em;
  max-width: 480px;
}
.gorogo-hero__rule {
  width: 32px;
  height: 2px;
  background: var(--gorogo-pop);
  margin: 24px 0 0;
}

/* ============================================================
   全体背景
   ============================================================ */
body { background-color: var(--gorogo-bg) !important; }

/* ============================================================
   セクション見出し
   ============================================================ */
.gorogo-sec-eyebrow {
  font-size: 11px;
  letter-spacing: .22em;
  color: var(--gorogo-pop);
  font-weight: 700;
  display: block;
  margin-bottom: 10px;
  font-family: 'Noto Sans JP', sans-serif;
}
.gorogo-sec-title {
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  color: var(--gorogo-ink) !important;
  letter-spacing: .03em;
  border: none !important;
  padding: 0 !important;
  border-left: 3px solid var(--gorogo-pop) !important;
  padding-left: 14px !important;
  line-height: 1.3;
  margin-bottom: 32px;
}
.gorogo-sec-rule {
  border: none;
  border-top: 1px solid var(--gorogo-rule);
  margin: 64px 0;
}

/* ============================================================
   書籍グリッド
   ============================================================ */
.gorogo-book-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--gorogo-rule);
}
.gorogo-book-card {
  background: var(--gorogo-bg3);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: background .2s;
  text-decoration: none !important;
  color: inherit !important;
}
.gorogo-book-card:hover { background: #fff; }

/* 書影エリア：高さを拡大 */
.gorogo-cover-wrap {
  width: 100%;
  height: 260px;
  background: var(--gorogo-bg2);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  position: relative;
  overflow: hidden;
}
.gorogo-cover-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  transition: transform .35s;
}
.gorogo-book-card:hover .gorogo-cover-wrap img { transform: scale(1.04); }

/* NEWリボン */
.gorogo-ribbon {
  position: absolute;
  top: 0; left: 0;
  background: var(--gorogo-pop);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .16em;
  padding: 5px 14px;
  font-family: 'Noto Sans JP', sans-serif;
}

/* カード本文 */
.gorogo-card-body {
  padding: 18px 20px 14px;
  display: flex;
  flex-direction: column;
  gap: 9px;
  flex: 1;
  border-top: 1px solid var(--gorogo-rule);
}
.gorogo-card-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.gorogo-tag {
  font-size: 11px;
  letter-spacing: .06em;
  color: var(--gorogo-ink-soft);
  border: 1px solid var(--gorogo-rule);
  padding: 3px 9px;
  font-family: 'Noto Sans JP', sans-serif;
}
.gorogo-tag--new {
  color: var(--gorogo-pop);
  border-color: var(--gorogo-pop);
  font-weight: 700;
}

/* カードタイトル：書名は大きく読みやすく */
.gorogo-card-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px !important;
  font-weight: 700;
  color: var(--gorogo-ink);
  line-height: 1.6;
}
.gorogo-card-title a {
  color: inherit !important;
  text-decoration: none !important;
}
.gorogo-card-title a:hover { color: var(--gorogo-pop) !important; }

/* 抜粋文 */
.gorogo-card-excerpt {
  font-size: 13px;
  color: var(--gorogo-ink-mid);
  line-height: 1.8;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* メタ情報（価格・発売日） */
.gorogo-card-meta {
  font-size: 13px;
  color: var(--gorogo-ink-soft);
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid var(--gorogo-rule);
  display: flex;
  flex-direction: column;
  gap: 3px;
  line-height: 1.6;
}

/* カードフッター */
.gorogo-card-foot {
  padding: 12px 20px 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  border-top: 1px solid var(--gorogo-rule);
}

/* ---- ボタン ---- */
.gorogo-btn {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  padding: 8px 18px;
  text-decoration: none !important;
  border: 1.5px solid var(--gorogo-ink);
  color: var(--gorogo-ink) !important;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
  font-family: 'Noto Sans JP', sans-serif;
  transition: background .15s, color .15s;
}
.gorogo-btn:hover { background: var(--gorogo-ink); color: var(--gorogo-bg) !important; }
.gorogo-btn--primary {
  border-color: var(--gorogo-pop) !important;
  color: #fff !important;
  background: var(--gorogo-pop) !important;
  font-size: 12px;
  padding: 8px 18px;
}
.gorogo-btn--primary:hover { background: #1a5fa8 !important; border-color: #1a5fa8 !important; }
.gorogo-btn--ghost {
  border-color: var(--gorogo-rule) !important;
  color: var(--gorogo-ink-mid) !important;
}
.gorogo-btn--ghost:hover { background: var(--gorogo-rule) !important; color: var(--gorogo-ink) !important; }
.gorogo-btn--pdf {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 8px 18px;
  border: 1.5px solid var(--gorogo-rule);
  color: var(--gorogo-ink-soft) !important;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
  font-family: 'Noto Sans JP', sans-serif;
  text-decoration: none !important;
  transition: border-color .15s, color .15s;
}
.gorogo-btn--pdf::before { content: '▶'; font-size: 9px; }
.gorogo-btn--pdf:hover { border-color: var(--gorogo-pop) !important; color: var(--gorogo-pop) !important; }

/* ============================================================
   SNS・WEBカード
   ============================================================ */
.gorogo-web-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--gorogo-rule);
}
.gorogo-web-card {
  background: var(--gorogo-bg3);
  padding: 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 9px;
  cursor: pointer;
  transition: background .2s, box-shadow .2s, transform .2s;
  position: relative;
}
.gorogo-web-card:hover {
  background: #fff;
  box-shadow: 0 4px 20px rgba(20, 20, 18, .08);
  transform: translateY(-3px);
  z-index: 1;
}
.gorogo-web-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gorogo-pop);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .2s ease;
}
.gorogo-web-card:hover::before { transform: scaleX(1); }
.gorogo-web-label {
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--gorogo-pop);
  font-weight: 700;
  font-family: 'Noto Sans JP', sans-serif;
}
.gorogo-web-name {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--gorogo-ink);
}
.gorogo-web-desc {
  font-size: 13px;
  color: var(--gorogo-ink-mid);
  line-height: 1.8;
  flex: 1;
}
.gorogo-web-link {
  font-size: 12px;
  color: var(--gorogo-ink-soft);
  letter-spacing: .08em;
  padding-top: 12px;
  border-top: 1px solid var(--gorogo-rule);
  transition: color .2s;
  text-decoration: none;
  display: block;
}
.gorogo-web-card:hover .gorogo-web-link { color: var(--gorogo-pop); }

/* ============================================================
   フッター
   ============================================================ */
#footer,
.site-footer {
  background: var(--gorogo-ftr) !important;
}
.gorogo-ftr-logo {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  font-weight: 700;
  font-style: normal;
  color: rgba(250, 249, 247, .88);
  letter-spacing: .06em;
  margin-bottom: 12px;
}
.gorogo-ftr-addr {
  font-size: 13px;
  color: rgba(250, 249, 247, .32);
  line-height: 1.9;
  letter-spacing: .04em;
}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 768px) {
  .gorogo-book-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    background: transparent;
  }
  .gorogo-web-grid { grid-template-columns: repeat(2, 1fr); }
  .gorogo-hero { padding: 48px 20px 40px; }
  .gorogo-hero::after { font-size: 180px; }
  .gorogo-news-bar__inner { padding: 0 16px; }
}
@media (max-width: 480px) {
  .gorogo-book-grid { grid-template-columns: 1fr; }
  .gorogo-web-grid  { grid-template-columns: 1fr; }
  .gorogo-cover-wrap { height: 220px; }
}