/* <system section="theme" selected="6801883189105087702"> */
@charset "utf-8";
/*
  Theme: white media
  Author: 8saki
  Description:
  Licensed under the MIT license.
  Responsive: yes
*/
/*--------------------------------------
css変数 （どのテンプレにも適用させる）
--------------------------------------*/
:root {
  /* color */
  --color-text-primary: #08131a;
  --color-text-secondary: rgba(8, 19, 26, 0.6588235294117647);
  --color-clear: hsla(0, 0%, 100%, 0);
  --color-whiteAlpha-900: #fff;
  --color-whiteAlpha-800: hsla(0, 0%, 100%, 0.9019607843137255);
  --color-whiteAlpha-600: hsla(0, 0%, 100%, 0.6588235294117647);
  --color-whiteAlpha-400: hsla(0, 0%, 100%, 0.4);
  --color-whiteAlpha-200: hsla(0, 0%, 100%, 0.2196078431372549);
  --color-whiteAlpha-50: hsla(0, 0%, 100%, 0.03137254901960784);
  --color-blackAlpha-900: #000;
  --color-blackAlpha-800: rgba(0, 0, 0, 0.9019607843137255);
  --color-blackAlpha-600: rgba(0, 0, 0, 0.6588235294117647);
  --color-blackAlpha-400: rgba(0, 0, 0, 0.4);
  --color-blackAlpha-200: rgba(0, 0, 0, 0.2196078431372549);
  --color-blackAlpha-100: rgba(0, 0, 0, 0.1);
  --color-blackAlpha-100-hex: #E5E5E5;
  --color-blackAlpha-50: rgba(0, 0, 0, 0.03137254901960784);
  --color-blue: rgba(20, 20, 200, 1);
  --color-google-map-gray: #E8EAED;
  --color-codeblock: #1d2020;
  --color-linemarker: #fffcc7;

  /* kaereba bland color */
  --color-id-amazon: #FF9901;
  --color-id-rakuten: #c20004;
  --color-id-yahoo: #7b0099;
  --color-id-kindle: #007dcd;
  --color-id-kakakucom: #314995;
  --color-id-jalan: #FF5800;
  --color-id-jtb: #CA1F31;
  --color-id-knt: #0B499E;
  --color-id-ikyu: #274A73;
  --color-id-rurubu: #010066;
  
  /* opacity */
  --opacity-link-hover: 0.6;

  /* radius */
  --radius-2: 2px;
  --radius-4: 4px;
  --radius-8: 8px;

  /* spacing */
  --spacing-xs: 10px;
  --spacing-ss: 20px;
  --spacing-s: 30px;
  --spacing-m: 40px;
  --spacing-l: 60px;
  --spacing-ll: 100px;

  /* margin */
  --margin-base-row: 30px 0;

  /* font size */
  /*10px*/
  --fontsize-10: 0.625rem;
  /*12px*/
  --fontsize-12: 0.75rem;
  /*13px*/
  --fontsize-13: 0.8125rem;
  /*14px*/
  --fontsize-14: 0.875rem;
  /*15px*/
  --fontsize-15: 0.9375rem;
  /*16px*/
  --fontsize-16: 1rem;
  /*18px*/
  --fontsize-18: 1.125rem;
  /*20px*/
  --fontsize-20: 1.25rem;
  /*22px*/
  --fontsize-22: 1.375rem;
  /*24px*/
  --fontsize-24: 1.5rem;
  /*26px*/
  --fontsize-26: 1.625rem;
  /*28px*/
  --fontsize-28: 1.75rem;
  /*30px*/
  --fontsize-30: 1.875rem;
  /*32px*/
  --fontsize-32: 2rem;
  /*34px*/
  --fontsize-34: 2.125rem;
  /*36px*/
  --fontsize-36: 2.25rem;
  /*38px*/
  --fontsize-38: 2.375rem;
  /*40px*/
  --fontsize-40: 2.5rem;
}
/*--------------------------------------
breakpoints

【pc】960px〜 (min-width: 960px)
【tab】768px〜 (min-width: 768px)
【smp】～767px (max-width: 767px)
--------------------------------------*/
html {
  font-family: "Helvetica Neue", Arial, YakuHanJP, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
 * Remove default margin.
 */
body {
  margin: 0;
}
/* HTML5 display definitions
   ========================================================================== */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}
a {
  background: transparent;
}
a:active,
a:hover {
  outline: 0;
}
abbr[title] {
  border-bottom: 1px dotted;
}
b,
strong {
  font-weight: bold;
}
dfn {
  font-style: italic;
}
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
mark {
  background: #ff0;
  color: #000;
}
small {
  font-size: 80%;
}
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}
/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}
/**
 * Address differences between Firefox and other browsers.
 */
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}
/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}
/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}
/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}
/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}
/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}
/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box;
}
/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}
/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}
/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
/*  import mixin */
.clearfix {
  display: block;
  *zoom: 1;
}
.clearfix:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
.inline-block {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}
.ellipsis {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
/*  import variable */
/* Common */
html,
body {
  font-family: 'Helvetica Neue', 'Helvetica', 'Arial', 'Hiragino Kaku Gothic Pro', 'Meiryo', 'MS PGothic', sans-serif;
  color: var(--color-blackAlpha-800);
  background-color: var(--color-whiteAlpha-900);
}
a {
  color: var(--color-blue);
}
a:visited {
  color: var(--color-blue);
}
a:hover {
  text-decoration: none;
  opacity: var(--opacity-link-hover);
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a,
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover,
h1 a:visited,
h2 a:visited,
h3 a:visited,
h4 a:visited,
h5 a:visited,
h6 a:visited {
  color: var(--color-blackAlpha-800);
  text-decoration: none;
}
p,
ol,
ul,
dl,
figure,
blockquote,
pre,
h1,
h2,
h3,
h4,
h5,
h6,
table {
  margin: var(--margin-base-row);
}
a.keyword {
  text-decoration: none;
  border-bottom: 1px dotted var(--color-blackAlpha-100);
  color: #454545;
}
/* Buttons */
.btn {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #454545;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: bold;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none !important;
}
.btn:hover {
  background-color: #f5f5f5;
  text-decoration: none !important;
}
.btn-small {
  padding: 2px 10px !important;
  font-size: 11px !important;
}
.btn-large {
  padding: 13px 19px;
  font-size: 17px;
  line-height: normal;
  font-weight: bold;
}
/* ヘッダ（グローバルヘッダ）
  グローバルヘッダの中はiframeですが、
  #globalheader-container に背景色や文字色を指定することでiframeの中にも色が反映されます。
*/
#globalheader-container {
  background-color: #333;
  color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
@media (max-width: 767px) {
  #globalheader-container {
    position: static;
  }
}
/* container */
#container {
  width: 100%;
  /* margin-top: 200px; */
  margin-left: auto;
  margin-right: auto;
  /* margin-bottom: 30px; */
  padding-top: 37px;
}
/* @media screen and (max-width: 767px) {
  #container {
    margin-top: 120px;
  }
} */

#container #content {
  display: block;
  *zoom: 1;
}
#container #content:after {
  display: block;
  visibility: hidden;
  font-size: 0;
  height: 0;
  clear: both;
  content: ".";
}
@media (min-width: 768px) and (max-width: 960px) {
  #container {
    /* width: 720px; */
  }
}
@media (max-width: 767px) {
  #container {
    word-wrap: break-word;
    overflow: hidden;
    padding-top: 0;
  }
}
.globalheader-off #container {
  padding-top: 0;
}
/* 2カラムレイアウト 
#main {
    width: 600px;
    float: left;
}
#box2 {
    width: 300px;
    float: right;
}

/* 1カラム */
#main {
  width: 100%;
  float: none;
}
#box2 {
  float: none;
}
#box2-inner {
  padding: 40px 0; 
  column-count: auto;
  column-width: 20rem;
  column-gap: 60px;
  width: min(720px, calc(100% - 60px* 2));
}
@media (min-width: 768px) and (max-width: 960px) {
  #main,
  #box2 {
    width: 100%;
  }
  #box2-inner {
    width: min(720px, calc(100% - 60px* 2));
  }
}
@media (max-width: 767px) {
  #main {
    width: 100%;
    float: none;
  }
  #box2 {
    width: 100%;
    float: none;
  }
}

.ad-online-afc, 
.archive-entries, 
.entry-content, 
.entry-footer, 
.page-archive-category .archive-header-category, 
#box2-inner  {
  margin: 0 auto;
  background: 0 0;
  border: none;
}
.entry-content, 
.hatenablog-entry, 
.entry-footer {
  margin: 40px auto 40px;
  font-size: var(--fontsize-16);
  position: relative;
  width: min(720px, calc(100% - 60px* 2));
}


@media (max-width: 767px) {
  .entry-content, 
  .hatenablog-entry, 
  .entry-footer, 
  #box2-inner, 
  .pager.pager-permalink {
    width: min(720px, calc(100% - 20px* 2));
  }
}

.hatena-module {
  text-align: left;
  break-inside: avoid;
}


/* header */

#title {
  margin: 0;
}

#blog-description {
  font-weight: normal;
  font-size: 80%;
  margin: 5px 0 0 0;
}
/* ヘッダ画像を設定したとき */
.header-image-enable #title {
  padding-top: 70px;
}
.header-image-enable #title,
.header-image-enable #blog-description {
  padding-left: 20px;
}
/* パンくず（カテゴリーページで表示されます） */
#top-box {
  font-size: var(--fontsize-12);
}

a.breadcrumb-link, a.breadcrumb-child-link {
  color: var(--color-blackAlpha-800);
}

#top-box .breadcrumb {
  border: 1px solid var(--color-blackAlpha-100);
  padding: 10px 60px;
}

@media (max-width: 767px) {
  #top-box .breadcrumb {
    border: 1px solid var(--color-blackAlpha-100);
    padding: 10px 20px;
  }
}

/* ヘッダーカスタム（ブログタイトル下）
  ========================================================================== */
/* ヘッダ全体 */
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1140px;
  margin: 16px auto;
}

/* タイトルロゴ */
h1 {
  margin: 0;
}

#title {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20240521/20240521163344.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left center;
  height: 60px;
  opacity: 0.8;
}

#title a {
  opacity: 0;
  color: var(--color-blackAlpha-600);
}

#blog-title {
  /* position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1000; */
  margin: 30px 0 100px 0;
  padding: 0 60px;
  background: var(--color-whiteAlpha-600);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: all .3s ease;
  /* clip-path: polygon(100% 0%, 0% 0% , 0.00% 81.92%, 5.00% 83.64%, 10.00% 84.42%, 15.00% 84.24%, 20.00% 83.11%, 25.00% 81.06%, 30.00% 78.17%, 35.00% 74.54%, 40.00% 70.29%, 45.00% 65.59%, 50.00% 60.59%, 55.00% 55.48%, 60.00% 50.43%, 65.00% 45.62%, 70.00% 41.23%, 75.00% 37.40%, 80.00% 34.28%, 85.00% 31.97%, 90.00% 30.56%, 95.00% 30.10%, 100.00% 30.60%); */
}

@media (max-width: 767px) {
  #blog-title {
    padding: 0 30px;
    margin: 20px 0 60px 0;
  }
  #title {
    height: 45px;
  }
}
/* //グローバルナビゲーション

.globalnav-list {
  list-style: none;
  margin: 0;
  display: flex;
  justify-content: center;
  gap: 64px;
  font-size: 14px;
}
.globalnav-item a {
  text-decoration: none;
  color: #101010;
  display: block;
  text-align: center;
} */

/* デフォルトのヘッダ部分非表示 */
.blog-controlls {
  display: none;
}

/*--------------------------------------
entry
--------------------------------------*/

/* entry */
.entry {
  position: relative;
}

.entry-header {
  width: min(720px, calc(100% - 60px* 2));
  margin: 0 auto;
}
@media (max-width: 767px) {
  .entry-header {
    width: min(720px, calc(100% - 20px* 2));
  }
}

.entry-title {
  margin: 0;
  line-height: 1.5;
  letter-spacing: .04em;
  font-size: var(--fontsize-28);
  
}
@media (max-width: 767px) {
  .entry-title {
    font-size: var(--fontsize-22);
  }
}

/* 日付 */
.entry-date {
  font-size: var(--fontsize-14);
  margin-bottom: 20px;
  color: var(--color-blackAlpha-400);
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
.date > a {
  text-decoration: none;
  color: var(--color-blackAlpha-400);
  display: flex;
  align-items: center;
  gap: 4px;
}

.date > a::before {
  content: "\f017";
  font-family: "FontAwesome";
  font-size: 90%;
}

.date-last-updated  {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 4px;
}

.date-last-updated .blogicon {
  width: 13px;
  height: 13px;
}

/* 日付を年月日表示 */
/* .hyphen {
  display: none;
}
.date-year::after {
  content: "年";
}
.date-month::after {
  content: "月";
}
.date-day::after {
  content: "日";
} */

/* カテゴリ */

.entry-header .entry-categories {
  margin-top: 15px;
  font-size: var(--fontsize-10);
  display: flex;
  gap: 10px;
  flex-direction: row;
  flex-wrap: wrap;
}

.categories a {
  color: var(--color-blackAlpha-600);
}
.entry-category-link {
  padding: 2px 15px;
  border: solid 1px var(--color-blackAlpha-600);
  border-radius: var(--radius-2);
  text-decoration: none;
  font-size: var(--fontsize-10);
  font-weight: 700;
}
.categories.no-categories {
  margin: 0;
}
/* 「編集する」ボタン */
.entry-header-menu {
  position: absolute;
  bottom: 0px;
  left: -60px;
}
.entry-header-menu a {
  display: inline-block;
  *display: inline;
  *zoom: 1;
  padding: 4px 10px 4px;
  margin-bottom: 0;
  line-height: 18px;
  color: #454545;
  background-color: #ffffff;
  text-align: center;
  vertical-align: middle;
  border-top-right-radius: 2px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 2px;
  background-clip: padding-box;
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
  font-weight: bold;
  border: 1px solid rgba(0, 0, 0, 0.2);
  text-decoration: none !important;
}
.entry-header-menu a:hover {
  background-color: #f5f5f5;
  text-decoration: none !important;
}
@media (max-width: 767px) {
  .entry-header-menu {
    top: -30px;
    left: 0px;
  }
}


/* 記事上部HTMLの中身 */

.customized-header {
  margin-top: 40px;
}

.entry-top-img {
  margin-right: calc(50% - 50vw);
	margin-left: calc(50% - 50vw);
  margin-bottom: 60px;
}

.entry-top-img img {
	display: block;
	width: 100%;
	height: auto;
}

@media (min-width: 1200px) /* これだけbreak pointから例外 */ {
  .entry-top-img {
    margin-right: calc(50% - 45vw);
    margin-left: calc(50% - 45vw);
  }
}

.entry-top-img figcaption{
  padding: 0 10px;
}

/* entry-content の中の書式 */
.entry-content {
  font-size: var(--fontsize-16);
  line-height: 2;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-blackAlpha-100);
}

.entry-content::after {
  content: '';
  margin-right: calc(50% - 45vw);
  margin-left: calc(50% - 45vw);
  height: 1px;
  display: inline-block;
  background-color: var(--color-blackAlpha-100);
}

.entry-content img {
  max-width: 100%;
}
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
  margin-top: 2rem;
  margin-bottom: 2rem;
  line-height: 2rem;
  font-weight: bold;
  letter-spacing: .04em;
}
.entry-content h1 {
  margin-top: var(--spacing-l);
  font-size: var(--fontsize-22);
  padding-bottom: 1.0rem;
  border-bottom: 1px solid var(--color-blackAlpha-600);
}
.entry-content h2 {
  margin-top: var(--spacing-l);
  font-size: var(--fontsize-18);
  border-bottom: solid 4px var(--color-blackAlpha-100);
  margin: 60px 0 0;
  position: relative;
}
.entry-content h3 {
  font-size: var(--fontsize-18);
  margin: 40px 0 0;
  padding: 0 0 0 20px;
  position: relative;
}
.entry-content h3::before {
  content: "";
  display: block;
  width: 4px;
  background: var(--color-blackAlpha-200);
  position: absolute;
  top: .25em;
  bottom: .25em;
  left: 0;
}
.entry-content h4 {
  font-size: var(--fontsize-17);
}
.entry-content h5 {
  font-size: var(--fontsize-16);
}
.entry-content h6 {
  font-size: var(--fontsize-15);
}

.entry-content a {
  color: var(--color-blackAlpha-800);
}

/* 表 table */
.entry-content table {
  width: 100%;
  text-align: center;
  border-collapse: collapse;
  border-spacing: 0;
  border: solid 1px var(--color-blackAlpha-100-hex);
  font-size: var(--fontsize-14);
  table-layout: fixed;
  overflow-x: scroll;
}

.entry-content tbody {
  vertical-align: top;
}

.entry-content table img {
  max-width: 100%;
  height: auto;
}
.entry-content table th,
.entry-content table td {
  padding: 10px;
  border: solid 1px var(--color-blackAlpha-100-hex);
}

.entry-content table th {
  background: var(--color-blackAlpha-50);
  color: var(--color-blackAlpha-600);
  letter-spacing: .025em;
}

.entry-content table td {
  text-align: left;
  line-height: 1.6;
}
/* 
@media (max-width: 767px) {
  .entry-content table {
    font-size: var(--fontsize-13);
    line-height: 1.6;
  }
  .entry-content table th,
  .entry-content table td {
  padding: 5px;
  }
  .entry-content table td {
    font-size: var(--fontsize-12);
  }
} */

/* デフォルト引用ブロック */

.entry-content blockquote,
.entry-content blockquote.quote-1 {
  padding: 20px;
  font-size: var(--fontsize-16);
  line-height: 1.8;
  background-color: var(--color-blackAlpha-50);
  color: var(--color-blackAlpha-600);
  border-left: 2px solid var(--color-blackAlpha-50);
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.entry-content blockquote p {
  margin: 0;
}

.entry-content cite {
  display: block;
  color: var(--color-blackAlpha-600);
  font-size: var(--fontsize-14);
  font-style: normal;
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 2px;
  margin-top: 20px;
}

.entry-content blockquote.quote-1 p {
  margin: 0;
}

/* .entry-content blockquote {
  padding: 25px 36px;
  font-size: var(--fontsize-14);
  line-height: 2.25;
  background-color: var(--color-blackAlpha-50);
}
.entry-content blockquote p {
  margin-top: 0;
  margin-bottom: 0;
}

.entry-content blockquote p a {
  color: var(--color-blackAlpha-800);
} */

/* 引用 */

/* blockquote.quote-1 {
  max-width: 600px;
  padding: 16px;
  border-left: 2px solid var(--color-blackAlpha-50);
  color: var(--color-blackAlpha-600);
  background-color: var(--color-blackAlpha-50);
  font-style: normal;
}

blockquote.quote-1:has(cite) {
  padding-bottom: .5em;
}

blockquote.quote-1 p {
  margin-top: 0;
  margin-bottom: 16px;
}

blockquote.quote-1 cite {
  display: block;
  color: var(--color-blackAlpha-600);
  font-size: .8em;
  text-align: right;
  font-style: normal;
} */

/* コードブロック ``` ``` */

.entry-content pre {
  border: 1px solid var(--color-blackAlpha-100);
  white-space: pre;
}

.entry-content pre.code {
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
  border: 0;
  display: block;
  margin: 30px 0;
  padding: 30px;
  overflow-x: auto;
  font-size: var(--fontsize-12);
  line-height: 1.45;
  color: var(--color-whiteAlpha-900);
  word-wrap: normal;
  -webkit-overflow-scrolling: touch;
  background-color: var(--color-codeblock);
}

/* インラインコード ` ` */
.entry-content code {
  font-size: var(--fontsize-13);
  margin: 0 2px;
  padding: 0 5px;
  border: 1px solid var(--color-blackAlpha-100);
  background-color: var(--color-blackAlpha-50);
  border-radius: var(--radius-4);
  font-family: 'Monaco', 'Consolas', 'Courier New', Courier, monospace, sans-serif;
}

/* リスト（ul,ol,li） */

.entry-content ul,
.entry-content ol {
padding-left: 20px;
list-style-type: none;
}

.entry-content ul li,
.entry-content ol li {
  list-style-type: disc;
  margin-top: 5px;
  margin-bottom: 5px;
  overflow: initial;
  font-size: var(--fontsize-16);
  line-height: 2;
}

.entry-content ul li > ul,
.entry-content ol li > ol {
  margin: 0
}

.entry-content ul p {
  margin: 0
}

/* 説明リスト要素（dl:グループ化, dt:見出し, dd:説明） */

.entry-content dl {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 0;
  margin-bottom: 40px;
}

.entry-content dt,
.entry-content dd {
  font-size: var(--fontsize-16);
  line-height: 1.8;
  margin: 0;
}

.entry-content dt { 
  width: 100px;
  font-weight: 700;
  padding-right: 10px;
}

.entry-content dd {
  width: calc(100% - 110px);
}

/* はてなデフォルト商品リンク */

.hatena-asin-detail,
.hatena-rakuten-detail {
  padding: 0;
  margin: var(--margin-base-row);
  border: solid 1px var(--color-blackAlpha-100);
  border-radius: var(--radius-4);
  box-shadow: none;
  align-items: center;
  padding: 20px;
}

.hatena-asin-detail .hatena-asin-detail-image-link, 
.hatena-asin-detail>a {
  flex: 1;
  height: auto;
}

.hatena-asin-detail .hatena-asin-detail-info {
  font-size: var(--fontsize-13);
  flex: 4;
  gap: 15px;
  margin: 0;
  padding-left: 30px;
}


.hatena-asin-detail .hatena-asin-detail-info .hatena-asin-detail-title {
  margin: 0;
  line-height: 1.4;
  font-size: var(--fontsize-16)
}

.hatena-asin-detail .hatena-asin-detail-info .hatena-asin-detail-title a {
  color: var(--color-blackAlpha-800);
  line-height: 1.6;
  -webkit-line-clamp: 2;
}


.hatena-asin-detail .hatena-asin-detail-info ul, 
.hatena-asin-detail .hatena-asin-detail-info .hatena-asin-detail-meta {
  opacity: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 0;
}

.hatena-asin-detail .hatena-asin-detail-info ul li,
.hatena-asin-detail .hatena-asin-detail-info .hatena-asin-detail-meta li {
  list-style: none;
  margin: 0;
  line-height: 1.5;
  font-size: var(--fontsize-14);
  color: var(--color-blackAlpha-600);
}

.hatena-asin-detail li {
  margin-bottom: 10px;
  margin: 0;
}

/* .hatena-asin-detail li>a:not(.hatena-asin-detail-label),  */
.hatena-rakuten-detail li a:not(.hatena-asin-detail-label),
.hatena-asin-detail .hatena-asin-detail-info .asin-detail-buy{
  display: inline-block;
  text-align: center;
  cursor: pointer;
  letter-spacing: .025em;
  overflow: hidden;
  font-weight: 700;
  text-decoration: none;
  box-sizing: border-box;
  width: 100%;
  font-size: var(--fontsize-12);
  padding: 10px;
  color: var(--color-id-rakuten);
  background-color: var(--color-blackAlpha-50);
  border-radius: var(--radius-4);
}

.hatena-asin-detail .hatena-asin-detail-info .asin-detail-buy {
  color: var(--color-id-amazon);
  margin-top: 0;
}

@media screen and (max-width: 767px) {
  .hatena-asin-detail,
  .hatena-rakuten-detail {
    flex-direction: row-reverse;
    padding: 20px 10px;
  }
  .hatena-asin-detail .hatena-asin-detail-info {
    padding-left: 0;
    padding-right: 20px;
    flex: 3;
  }
  .hatena-asin-detail .hatena-asin-detail-info .hatena-asin-detail-title {
    font-size: var(--fontsize-16);
  }
}

/* もくじ */
.entry-content .table-of-contents {
  padding: 30px 60px;
  background: var(--color-blackAlpha-50);
  margin: 40px 0 0;
}
.entry-content .table-of-contents::before {
  content: '目次';
  display: block;
  margin: 0 0 20px;
  font-weight: bold;
  font-size: var(--fontsize-14);
}
.entry-content .table-of-contents ul {
  margin: 0;
  padding-inline-start: 40px;
}
.entry-content .table-of-contents li {
  border-top: solid 1px var(--color-blackAlpha-100);
  padding: 8px 0 0;
  /* margin: 4px 0 0; */
  font-size: var(--fontsize-14);
  list-style-type: none;
}
.entry-content .table-of-contents li a {
  text-decoration: none;
  color: var(--color-blackAlpha-600);
}
@media (max-width: 767px) {
  .entry-content .table-of-contents {
    padding: 20px;
  }
}


/* entry-footer */

/* .entry-footer {
  margin-top: 10px;
} */

.entry-footer .hatena-module {
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px solid var(--color-blackAlpha-100);
}

.entry-footer-section, .hatena-star-container {
  width: 100%;
  background: var(--color-blackAlpha-50);
  font-size: var(--fontsize-14);
  color: var(--color-blackAlpha-400);
  line-height: 1.0;
  box-sizing: border-box;
  border-radius: var(--radius-4);
  padding: 10px 20px;
  margin: 10px 0;

}
.entry-footer-section a {
  color: var(--color-blackAlpha-400);
}
.social-buttons,
.entry-footer-html {
  margin: 10px 0;
}

/* 記事下のタグ */

.entry-footer .entry-tags-wrapper {
  width: 100%;
  background: var(--color-blackAlpha-50);
  font-size: var(--fontsize-14);
  color: var(--color-blackAlpha-400);
  /* line-height: 1.8; */
  box-sizing: border-box;
  border-radius: var(--radius-4);
  padding: 10px 20px;
  margin: 10px 0;
}

.entry-tags::before {
  content: "タグ：";
  margin-right: 5px;
  color: var(--color-blackAlpha-600);
}

.entry-footer .entry-tags-wrapper .entry-tag {
  margin-right: 10px;
}

.entry-footer .entry-tag .entry-tag-link {
  color: var(--color-blackAlpha-800);
  font-size: var(--fontsize-14);
  line-height: 1.1;
  text-decoration: none;
  display: inline-block;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  margin-bottom: 0;
  border-bottom: solid 1px var(--color-blackAlpha-800);
}

/* コメント */

.comment-box ul {
  list-style: none;
  margin: 0 0 15px 0;
  padding: 0;
  font-size: 95%;
  line-height: 1.7;
}
.comment-box li {
  padding: 10px 0 10px 60px;
  border-bottom: 1px solid var(--color-blackAlpha-100);
  position: relative;
}
.comment-box li:first-child {
  border-top: 1px solid var(--color-blackAlpha-100);
}
.comment-box .read-more-comments {
  padding-left: 0;
}
.comment-box .hatena-id-icon {
  position: absolute;
  top: 10px;
  left: 0;
  width: 50px !important;
  height: 50px !important;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
}
.comment-user-name {
  margin: 0 0 10px 0;
  font-weight: bold;
}
.comment-content {
  font-size: 90%;
  margin: 0 0 10px 0;
  word-wrap: break-word;
}
.comment-content p {
  margin: 0 0 10px 0;
}
.comment-metadata {
  font-size: 80%;
  color: #999999;
  margin: 0;
}
.comment-metadata a {
  color: #999999;
}
.leave-comment-title {
  background-color: var(--color-blackAlpha-50);
  border: none;
  border-radius: var(--radius-4);
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  vertical-align: top;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  display: inline-flex;
  margin: 0;
  font-weight: 700;
  line-height: 1;
  padding: 0 16px;
  font-size: var(--fontsize-12);
  color: var(--color-blackAlpha-800);
}



/*--------------------------------------
モジュール共通 (記事下footer、カラムfooter)
--------------------------------------*/


.hatena-module a {
  color: var(--color-blackAlpha-800);
  text-decoration: none;
}

.hatena-module-title {
  font-weight: bold;
  margin-bottom: 15px;
  font-size: var(--fontsize-14);
}

.hatena-module-title a:hover {
  text-decoration: underline;
}

/*--------------------------------------
urllist module 共通
--------------------------------------*/
/* 
    リンク・最新記事・最近のコメント・月別アーカイブ・カテゴリモジュールは .hatena-urllist という共通の class が振られます
*/

/* 個別で設定したいのでこちらは使わず、リセットする */

.hatena-urllist,        
.hatena-urllist ul  {
  list-style: none;
  margin: 0 0 0 0;
  padding: 0 0 0 0;
}
/* .hatena-urllist li {
  line-height: 1.5;
} */
.hatena-urllist li a {
  text-decoration: none;
}

.urllist-date-link {
  font-size: 100%;
}

.urllist-category-link {
  margin: 0 0 0 0;
  padding: 0 0 0 0;
}

/*--------------------------------------
  サイドバー（1カラムなのでカラムfooter)
--------------------------------------*/

#box2 {
  line-height: 1.5;
  margin: 0 auto;
  background-color: var(--color-blackAlpha-100);
}

#box2 .hatena-module {
  padding-bottom: 20px;
  margin-top: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--color-blackAlpha-100);
}

/* Profile module

#box2 .hatena-module-profile .profile-icon {
  border-radius: 100px;
  border: 0.5px solid var(--color-blackAlpha-900);
  float: none;
  vertical-align: middle;
  margin: 0 2.0rem 0.5rem 0;
}

#box2 .hatena-module-profile .id {
  display: block;
  font-weight: bold;
  font-size: 110%;
  margin-bottom: 5px;
}

#box2 .hatena-module-profile .profile-description {
  font-size: 90%;
}

#box2 .hatena-module-profile .profile-description p {
  margin-top: 0;
}

#box2 .hatena-id-link {
  font-weight: bold;
}

#box2 .profile-description {
  margin: 20px 0 30px 0;
}

#box2 .hatena-module-custom-who {
  border-top: 0.5px solid var(--color-blackAlpha-900);
  padding-top: 2.0rem;
} */


/* HTML Profile module */

#box2 .hatena-module-custom-profile {
  margin-top: 0;
}

#box2 .hatena-module-custom-profile .hatena-module-title {
  display: none;
}

#box2 .hatena-module-custom-profile .creatorProfile {
  display: flex;
}
#box2 .creatorProfile__avatar_image {
  width: 56px;
  height: 56px;
  display: block;
  border-radius: 80px;
}

#box2 .creatorProfile__body {
  flex: 1;
  margin-left: 16px;
}

#box2 .creatorProfile__header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
}

#box2 .creatorProfile__name {
  display: flex;
  flex: 1;
  font-size: var(--fontsize-16);
  font-weight: 700;
  -webkit-hyphens: auto;
  hyphens: auto;
  overflow-wrap: anywhere;
}

#box2 .creatorProfile__name a {
  cursor: pointer;
}

#box2 .creatorProfile__subscribe {
  margin-left: 16px;
}

#box2 .creatorProfile__subscribe_button {
  background-color: var(--color-whiteAlpha-900);
  border: none;
  border-radius: var(--radius-4);
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  vertical-align: top;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  display: inline-flex;
  margin: 0;
  font-weight: 700;
  line-height: 1;
}
#box2 .creatorProfile__subscribe_button a {
  font-size: var(--fontsize-12);
  position: relative;
  display: flex;
  padding: 0 16px;
  }

#box2 .creatorProfile__description {
  display: flex;
  align-items: flex-start;
}

#box2 .creatorProfile__introduction {
  flex: 1;
  font-size: var(--fontsize-13);
  color: var(--color-blackAlpha-800);
}

#box2 .creatorProfile__profile {
  margin-bottom: 10px;
  word-break: break-all;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#box2 .creatorProfile__profile p {
  margin: 0;
}

#box2 a.creatorProfile__profile__naillink {
  text-decoration: underline;
}

#box2 .creatorProfile__profile_detail {
  margin-bottom: 8px;
}
#box2 .creatorProfile__aside {
  display: flex;
  justify-content: flex-start;
}

#box2 .creatorProfile__social {
  margin-right: 8px;
}

#box2 ul.creatorSocialLinks {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  list-style-type: none;
  list-style: none;
  margin: 0;
  padding: 0;
}

#box2 li.creatorSocialLinks__item {
  line-height: 1;
  font-size: var(--fontsize-20);
}

#box2 li.creatorSocialLinks__item a {
  color: var(--color-blackAlpha-400);
}

.a-icon::before {
  top: 0;
  left: 0;
  font-family: blogicon;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  line-height: 1;
  text-decoration: none;
  text-transform: none;
  vertical-align: middle;
}

.a-icon--x::before {
  content: "\f035";
}

.a-icon--instagram::before {
  content: "\f71b";
}

/* カラムfooter　人気記事 module */

#box2 .urllist-title-link, 
#box2 .entries-access-ranking-title-link,
#box2 .urllist-title,
#box2 .entries-access-ranking-title {
  font-weight: 600;
}

#box2 li.entries-access-ranking-item:first-child, 
#box2 li.recent-entries-item:first-child {
  padding-top: 0;
}

#box2 .entries-access-ranking {
  font-size: var(--fontsize-14);
  font-weight: 600;
  list-style-type: decimal;
}

#box2 .entries-access-ranking li {
  margin-left: 24px;
  padding: 8px 0 0 4px;
}

#box2 .entries-access-ranking li::marker {
  font-weight: 700;
  color: var(--color-blackAlpha-200);
  font-size: 110%;
}

#box2 .entries-access-ranking li.rank-1::marker {
  color: #D9A400;
}
#box2 .entries-access-ranking li.rank-2::marker {
  color: var(--color-blackAlpha-400);
}
#box2 .entries-access-ranking li.rank-3::marker {
  color: #CE7C56;
}
#box2 .entries-access-ranking li.rank-4::marker,
#box2 .entries-access-ranking li.rank-5::marker {
  font-weight: 400;
}

/* カラムfooter　最新記事 module */

#box2 li.recent-entries-item {
  padding: 8px 0;
  border-bottom: 1px solid var(--color-blackAlpha-100);
}

#box2 li.recent-entries-item:last-child {
  border-bottom: none;
}

#box2 .recent-entries-title {
  font-size: var(--fontsize-14);
  margin: 4px 0;
  font-weight: 600;
  display: block;
  line-height: 1.45;
  letter-spacing: .04em;
  overflow: hidden;
}

#box2 a.recent-entries-category-link {
  margin: 10px 10px 0 0;
  font-size: var(--fontsize-12);
  color: var(--color-blackAlpha-400);
}

#box2 .recent-entries-date-link {
  display: block;
  line-height: 1;
}

#box2 .recent-entries-date-link>a {
  font-size: var(--fontsize-14);
  color: var(--color-blackAlpha-400);
}

#box2 .urllist-with-thumbnails li .urllist-image {
  max-width: 100%;
  height: auto;
  margin: 0 10px 0 0;
  border-radius: var(--radius-4);
}

/* 最新記事もっと見るボタン */

.urllist-see-more {
  margin-top: 15px;
  text-align: center;
  font-size: var(--fontsize-14);
  border: none;
  justify-content: center;
  align-items: center;
  line-height: 1;
}

/* カラムfooter　カテゴリ一覧 module */

#box2 .hatena-module-category .hatena-urllist {
  padding: 0;
  margin: 0;
  list-style: none;
  font-size: var(--fontsize-14);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 2.5%;
}

#box2 .hatena-module-category .hatena-urllist li {
  padding: 0 0 8px 0;
}

#box2 .hatena-module-category .hatena-urllist li a {
  color: var(--color-blackAlpha-800);
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  padding: 2px 8px;
  font-size: var(--fontsize-12);
  background-color: var(--color-whiteAlpha-900);
  border: 1px solid var(--color-blackAlpha-600);
  text-decoration: none;
  border-radius: var(--radius-2);
}

/* カラムfooter archive module */

#box2 .hatena-module-archive .hatena-urllist {
  padding: 0;
  margin: 0;
  list-style: none;
  font-size: var(--fontsize-14);
  break-inside: avoid;
}

#box2 .hatena-urllist .archive-module-year {
  padding-left: 5px;
  margin-bottom: 2px;
  line-height: 32px;
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year .archive-module-button {
  position: relative;
  opacity: 1;
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year .archive-module-button>span {
  color: transparent;
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year .archive-module-button>span:before {
  position: absolute;
  content: "\f107";
  color: var(--color-blackAlpha-400);
  font-family: "FontAwesome";
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year .archive-module-button>span {
  color: transparent;
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year .archive-module-button>span.archive-module-show-button:before {
  font-family: "FontAwesome";
  content: "\f105";
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year .archive-module-year-title {
  padding-left: 5px;
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year ul.archive-module-months {
  line-height: 30px;
}

#box2 .hatena-module.hatena-module-archive ul li.archive-module-year ul.archive-module-months li.archive-module-month {
  border: none;
  padding: 0;
}

.hatena-urllist .archive-module-year .archive-module-month {
  margin: 0 0 0 30px;
  padding: 0;
  border: none;
  list-style-type: none !important;
  background: none;
}

/* カラムfooter　about module */

#box2 .hatena-module-custom-about p {
  margin: 0;
}

#box2 .hatena-module-custom-about .hatena-module-title {
  display: none;
}

#box2 .about-body {
  display: grid;
  gap: 16px;
}

#box2 .about-section-title {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 4px;
}
#box2 .about-section-text {
  font-size: 12px;
  line-height: 20px;
}

#box2 .about-section-text p {
  margin-bottom: 6px;
}

#box2 .about-section-text .privacy-policy {
  text-decoration: underline;
}

/*--------------------------------------
記事下モジュール
--------------------------------------*/

.entry-footer .urllist-with-thumbnails li .urllist-image {
  max-width: 100%;
  height: auto;
  margin: 0;
  float: none;
  border-radius: var(--radius-4);
}

/* 記事下の最新記事 module */

.entry-footer .related-entries.urllist-with-thumbnails, 
.entry-footer .recent-entries.urllist-with-thumbnails {
  list-style: none;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 20px 20px;
}

.entry-footer .related-entries.urllist-with-thumbnails li, 
.entry-footer .recent-entries.urllist-with-thumbnails li {
  width: calc((100% - 40px) / 3);
}

@media (max-width: 767px) {
  .entry-footer .related-entries.urllist-with-thumbnails li, 
  .entry-footer .recent-entries.urllist-with-thumbnails li {
      width: calc((100% - 20px) / 2);
  }
}


.entry-footer .related-entries-item-inner, 
.entry-footer .recent-entries-item-inner {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.entry-footer .related-entries-title, 
.entry-footer .recent-entries-title {
  font-size: var(--fontsize-16);
  font-weight: 600;
  display: block;
  letter-spacing: .04em;
  overflow: hidden;
}

.entry-footer .related-entries-categories, 
.entry-footer .recent-entries-categories {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 2px 8px;
}

.entry-footer a.related-entries-category-link, 
.entry-footer a.recent-entries-category-link {
  font-size: var(--fontsize-14);
  color: var(--color-blackAlpha-600);
}

.entry-footer .related-entries-date-link>a, 
.entry-footer .recent-entries-date-link>a {
  font-size: var(--fontsize-14);
  color: var(--color-blackAlpha-600);
}

.entry-footer li.related-entries-item, 
.entry-footer li.recent-entries-item {
  padding: 0;
}
/* 記事下の人気記事 module */

.entry-footer .entries-access-ranking {
  font-size: var(--fontsize-14);
  font-weight: 600;
  list-style-type: decimal;
}

.entry-footer .entries-access-ranking li {
  margin-left: 20px;
  padding: 8px 0 0 8px;
}
.entry-footer  .entries-access-ranking li::marker {
  font-weight: 700;
  color: var(--color-blue);
  font-size: 110%;
}

a.entries-access-ranking-title-link {
  line-height: 1.4;
  display: block;
  font-size: var(--fontsize-14);
  letter-spacing: .04em;
}

/* 記事下customized-footer */
.entry-footer .customized-footer {
  margin: 40px 0;
}

/* Search module */

.hatena-module-search-box .search-form {
  border: 1px solid var(--color-blackAlpha-600);
  border-top-right-radius: 3px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
  border-top-left-radius: 0;
  border-radius: 3px;
  background-clip: padding-box;
  width: 100%;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  background-color: var(--color-whiteAlpha-800);
}
.hatena-module-search-box .search-module-input {
  padding: 5px;
  color: #454545;
  background: none;
  border: none;
  outline: none;
  height: 20px;
  width: 90%;
  font-size: var(--fontsize-14);
}
.hatena-module-search-box .search-module-button {
  width: 20px;
  height: 20px;
  background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cdefs%3E%3Cstyle%3E.a%7Bfill:none;%7D%3C/style%3E%3C/defs%3E%3Ctitle%3Esearch%3C/title%3E%3Cpath d='M16.7,15l-3.4-3.3h-.1a5.4,5.4,0,0,0,.9-3.1,5.6,5.6,0,1,0-5.6,5.6,5.4,5.4,0,0,0,3.1-.9.1.1,0,0,0,.1.1L15,16.7a1.1,1.1,0,0,0,.8.3,1.6,1.6,0,0,0,.9-.3,1.4,1.4,0,0,0,0-1.7M8.5,12.3A3.8,3.8,0,0,1,4.8,8.5,3.8,3.8,0,0,1,8.5,4.7a3.9,3.9,0,0,1,3.8,3.8,3.8,3.8,0,0,1-3.8,3.8'/%3E%3Crect class='a' width='20' height='20'/%3E%3C/svg%3E") no-repeat center;
  border: none;
  outline: none;
  text-indent: -9999px;
  position: absolute;
  top: 5px;
  right: 5px;
  opacity: 0.5;
}
.hatena-module-search-box .search-module-button:hover {
  opacity: 0.85;
}

/*--------------------------------------
記事下ソーシャルボタン（記事ページ＞記事下HTML）
--------------------------------------*/

/* 記事下ソーシャルボタン 下部の余白 */
.sns-tag-cloud-under {
  margin: 0px 0 30px 0;
}

/* SNSシェアボタン */
.sns-tag-cloud {
  padding-inline-start: 0px;
  font-size: 12px;
  font-weight: bold;
}
.sns-tag-cloud-under {
  padding-inline-start: 0px;
  font-size: 12px;
  font-weight: bold;
  text-align: center;
}
a.sns-tag-cloud-hatenab {
  display: inline-block;
  padding: 10px;
  margin: 3px;
  line-height: 1;
  text-decoration: none;
  color: #00A4DE;
  border: 1.5px solid;
  border-color: #00A4DE;
  border-radius: 3px;
}
a.sns-tag-cloud-hatenab:hover {
  background: #00A4DE;
  color: #fff;
}
a.sns-tag-cloud-facebook {
  display: inline-block;
  padding: 10px;
  margin: 3px;
  line-height: 1;
  text-decoration: none;
  color: #4064AC;
  border: 1.5px solid;
  border-color: #4064AC;
  border-radius: 3px;
}
a.sns-tag-cloud-facebook:hover {
  background: #4064AC;
  color: #fff;
}
a.sns-tag-cloud-twitter {
  display: inline-block;
  padding: 10px;
  margin: 3px;
  line-height: 1;
  text-decoration: none;
  color: #1DA1F2;
  border: 1.5px solid;
  border-color: #1DA1F2;
  border-radius: 3px;
}
a.sns-tag-cloud-twitter:hover {
  background: #1DA1F2;
  color: #fff;
}
a.sns-tag-cloud-line {
  display: inline-block;
  padding: 10px;
  margin: 3px;
  line-height: 1;
  text-decoration: none;
  color: #21BA4E;
  border: 1.5px solid;
  border-color: #21BA4E;
  border-radius: 3px;
}
a.sns-tag-cloud-line:hover {
  background: #21BA4E;
  color: #fff;
}

/* Pager */

.pager {
  width: min(720px, calc(100% - 60px* 2));
  margin: 0 auto 60px;
  flex-direction: row;
  justify-content: flex-end;
  display: flex;
  align-items: flex-start;
  padding: 32px 0 15px;
  *zoom: 1;
  border-top: 1px solid var(--color-blackAlpha-100);
  border-bottom: 1px solid var(--color-blackAlpha-100);
}

@media (max-width: 767px) {
  .pager {
    *zoom: 1;
    width: min(720px, calc(100% - 20px* 2));
    margin: 0 auto 40px;
  }
}

.pager-arrow {
  display: none;
}

.pager-prev,
.pager-next {
  display: flex;
  gap: 5px;
  position: relative;
}
.pager-prev {
  flex: 1;
  justify-content: flex-start;
  border-right: 1px solid var(--color-blackAlpha-100-hex);
  padding-right: 15px;
}

.pager-prev::before {
  color: var(--color-blackAlpha-600);
  content: '';
  width: 18px;
  height: 6px;
  border-bottom: solid 1px;
  border-left: solid 1px;
  transform: skew(145deg);
  margin-top: -16px;
  position: absolute;
  left: 3px;
}

.pager-next {
  flex: 1;
  justify-content: flex-end;
  padding-left: 15px;
}

.pager-next::after {
  color: var(--color-blackAlpha-600);
  content: '';
  width: 18px;
  height: 6px;
  border-bottom: solid 1px;
  border-right: solid 1px;
  transform: skew(35deg);
  margin-top: -16px;
  position: absolute;
  right: 3px;
}

.pager-prev a ,
.pager-next a {
  font-size: var(--fontsize-14);
  font-weight: 700;
  text-decoration: none;
  color: var(--color-blackAlpha-800);
}

/* Footer */
#footer {
  padding: 30px 0;
  text-align: center;
  color: #999999;
  line-height: 1.5;
  font-size: 80%;
}
#footer p {
  margin: 0;
}
#footer a {
  color: #999999;
}
/* About ページ */
.page-about dt {
  font-size: 16px;
  font-weight: bold;
  border-bottom: 1px solid #dfdfdf;
  margin-bottom: 5px;
}
.page-about dd {
  margin-left: 0;
  margin-bottom: 30px;
}

/* archive ページ */

.page-archive .archive-entries .entry-title {
  font-size: var(--fontsize-18);
}
@media screen and (max-width: 767px) {
  .page-archive .archive-entries .entry-title {
    font-size: var(--fontsize-16);
  }
}

.page-archive .archive-entries .categories {
  margin: 0 0 .5em;
}
.page-archive .archive-entries .entry-description {
  /* margin: 0 0 10px 0;
  line-height: 1.8;
  font-size: var(--fontsize-14); */
  display: none;
}

.page-archive .archive-entries {
  font-size: var(--fontsize-16);
  line-height: 1.8;
  margin: 0 auto 60px;
  font-size: var(--fontsize-16);
  position: relative;
  width: min(720px, calc(100% - 60px* 2));
}
@media screen and (max-width: 767px) {
  .page-archive .archive-entries {
    margin: 0 auto 40px;
  }
}

.page-archive .archive-entries section:first-child {
  padding-top: 0;
}

.archive-header-category .archive-heading,
#main-inner .archive-heading {
  margin: 40px auto;
  width: min(720px, calc(100% - 60px* 2));
  font-size: var(--fontsize-20);
}

@media screen and (max-width: 767px) {
  .page-archive .archive-entries {
    width: min(720px, calc(100% - 20px* 2));
  }
  .archive-header-category .archive-heading,
  #main-inner .archive-heading {
  width: min(720px, calc(100% - 20px* 2));
}
}

.archive-header-category .archive-heading::before {
  content: "カテゴリ：";
  color: var(--color-blackAlpha-400);
  font-weight: 400;
}

/* 記事はありませんのときの表示 */
#main-inner > p {
  width: min(720px, calc(100% - 60px* 2));
  margin: 40px auto 60px;
}

.page-archive .archive-entry {
  padding: 20px 0;
  border-bottom: 1px solid var(--color-blackAlpha-100-hex);
  display: flex;
  flex-direction: row;
}

.archive-entry .archive-entry-header {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-right: 30px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .archive-entry .archive-entry-header {
    margin-right: 20px;
  }
}

.archive-entry .entry-title {
  order: 1;
}

.archive-entry .archive-date {
  font-size: var(--fontsize-14);
  color: var(--color-blackAlpha-400);
  order: 2;
}

.archive-entry .archive-date.date a::before {
  content: "";
  margin: 0;
}

.archive-entry .archive-entry-tags-wrapper {
  display: none;
}

.page-archive .categories {
  display: none;
}

.page-archive .categories a {
  padding: 2px 15px;
  border: solid 1px var(--color-blackAlpha-600);
  border-radius: var(--radius-2);
  text-decoration: none;
  font-size: var(--fontsize-10);
  font-weight: 700;
}

/* .entry-thumb-link {
  position: absolute;
  left: -140px;
} */

.page-archive .entry-thumb {
  width: 120px;
  height: 84px;
  float: none;
  border-radius: var(--radius-4);
  margin: 0;
}
/*  import media queries */
/* Media Queries - Retina Display */
@media (-webkit-min-device-pixel-ratio: 2) {
  .hatena-module-search-box .search-module-button {
    background: transparent url(https://cdn.blog.st-hatena.com/images/theme/search@2x.png?version=9f3d2a69deb4e4b689c1a23af3625d) no-repeat right center;
    background-size: 20px 20px;
  }
}

.search-result-form {
  margin: 0px auto;
  border: 1px solid var(--color-blackAlpha-600);
}


/* ========================================================================== */
/* 全テーマ共通
  ========================================================================== */

/* はてな共通
  ========================================================================== */

/* embed:citeリンクを貼った時についてくる不要リンクを消す */
cite.hatena-citation {
  display: none;
}

/* トップページのはてなスターを消す */
.page-index .star-container {
  display: none;
}

/* 記事一覧の共有ボタンを消す */
.social-buttons {
  display: none;
}

/* キャプションあり写真 */

.figure-image {
  margin: var(--margin-base-row);
  text-align: left;
}

.figure-image>figcaption {
  margin: 0;
  opacity: 1;
  color: var(--color-blackAlpha-600);
  text-align: left;
  font-size: var(--fontsize-14);
  line-height: 1.5;
  margin-top: 10px;
  display: block;
}

/* 横並びの写真の調整 */

.figure-image>span img, .figure-image>p img {
  margin-bottom: 0;
}

.images-row>span, .images-row .images-row-item {
  margin: 0;
}

.images-row {
  display: flex;
  align-items: center;
  margin: 0;
  gap: 20px;
  margin-top: 20px;
}

@media screen and (max-width: 767px) {
  .images-row {
    gap: 10px;
    margin-top: 10px;
  }
}

/* 定型文, 装飾
   ========================================================================== */

/* 地図BOX */
.entry-map-box {
  background: var(--color-google-map-gray);
  padding-top: 30px;
  padding-bottom: 30px;
  margin: var(--margin-base-row);
  border-radius: var(--radius-4);
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  padding-right: calc(55vw - 50%);
  padding-left: calc(55vw - 50%);
}
.entry-map-title {
  font-weight: 700;
  margin: 0;
  line-height: 1.5;
}
.entry-map-title::before {
  content: "\f727";
  font-size: var(--fontsize-16);
  font-family: blogicon;
  margin-right: 8px;
}
ul.entry-map-content {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

ul.entry-map-content li iframe {
  border: 0;
  width: 100%;
  max-height: 35vh;
}


ul.entry-map-content li.entry-map-content__address,
ul.entry-map-content li.entry-map-content__gmap,
ul.entry-map-content li.entry-map-content__link {
  list-style-type: none;
  margin: 0;
  line-height: 1.4;
}

ul.entry-map-content li.entry-map-content__link {
  font-size: var(--fontsize-14);
}

ul.entry-map-content li.entry-map-content__link a {
  color: var(--color-blackAlpha-600);
}

ul.entry-map-content li.entry-map-content__link::before {
  content: "\f702";
  font-size: var(--fontsize-16);
  color: var(--color-blackAlpha-400);
  font-family: blogicon;
  margin-right: 5px;
}

ul.entry-map-content li.entry-map-content__gmap> iframe {
  width: 100%;
}

/* 地図BOX ※旧構造対応*/

ul.entry-map-content li {
  list-style-type: none;
  margin: 0;
  line-height: 1.4;
  font-size: var(--fontsize-14);
}

ul.entry-map-content li a {
  color: var(--color-blackAlpha-800);
}

/* 補足BOX */
.entry-detail-box {
  border-radius: var(--radius-8);
  padding: 0.75rem 1.5rem 0.5rem;
  margin: 0 30px;
  border: 1px solid var(--color-blackAlpha-200);
}
@media screen and (max-width: 767px) {
  .entry-detail-box {
    margin: 0 10px;
  }
}
.entry-detail-box p {
  margin-top: 0;
  margin-bottom: 12px;
}
.entry-detail-box p> :last-child {
  margin-bottom: none;
}
p.detail-box-title {
  font-weight: bold;
}
p.detail-box-contents {
  font-size: 95%;
}

/* スクショの囲み */
.screenshot-img-frame img {
  border: 4px solid var(--color-blackAlpha-50);
  box-sizing: border-box;
  outline: #ffffff solid 2px;
  outline-offset: -6px;
}

/* 区切り線 */
.entry-content hr {
  border: none;
  border-bottom: 1px solid var(--color-blackAlpha-100);
  width: 100%;
  margin-top: 36px;
  margin-bottom: 36px;
}
/* 記事内box装飾 */
.box {
  position: relative;
  margin: 2em 0;
  padding: 0.5em 1em;
  border: solid 1px var(--color-blackAlpha-600);
  border-radius: 12px;
}
.box .box-title {
  position: absolute;
  display: inline-block;
  top: -12px;
  left: 16px;
  padding: 0 10px;
  background: var(--color-whiteAlpha-900);
  color: var(--color-blackAlpha-600);
  font-weight: bold;
}
.box-title {
  line-height: 1.25;
  max-width: 95%;
}
.box-top {
  border-bottom: none;
  border-bottom-right-radius: 0px;
  border-bottom-left-radius: 0px;
  margin: 40px 8px 20px;
}
.box-bottom {
  border-top: none;
  border-top-left-radius: 0px;
  border-top-right-radius: 0px;
  margin: 4px 8px 40px;
}
/*マーカー線・黄色*/
.marker-yellow {
  background: var(--color-linemarker);
  font-weight: bold;
}
/* ステップバーデザイン */
.step-wrap3 {
  counter-reset: count;
  margin: 2em 0;
  position: relative;
}
.step-content3 {
  padding: 1.5em 0 .3em 1.5em;
  margin: 0 0 1em 1em;
  position: relative;
  border-top: solid 2px var(--color-blackAlpha-200);
}
.step-content3::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 4px;
  left: -11px;
  border-style: solid;
  border-width: 12px 8px 0 8px;
  border-color: var(--color-blackAlpha-200) transparent transparent transparent;
}
.step-content3::after {
  content: "";
  display: block;
  height: calc(100% - 36px);
  border-left: dashed 2px var(--color-blackAlpha-200);
  position: absolute;
  top: 16px;
  left: -4px;
}
.step-label3 {
  padding: 2px 15px;
  color: #fff;
  font-weight: 600;
  position: absolute;
  top: -14px;
  left: -20px;
  background: var(--color-blackAlpha-600);
  z-index: 1;
  border-radius: 2px;
  font-size: var(--fontsize-14);
  line-height: 1.5;
}
.step-label3::after {
  counter-increment: count;
  content: counter(count);
  position: relative;
  left: .3em;
}
.step-title3 {
  font-weight: 600;
}
.step-body3 {
  margin-top: .5em;
  padding: 0 0 1.5em;
}
.step-wrap3> :last-child {
  box-shadow: 5px 7px 0 -5px var(--color-blackAlpha-200);
}
.step-wrap3> :last-child::before, .step-wrap3> :last-of-type::after {
  display: none;
}
/* 丸円 */
.entry-content .circle-number {
  background-color: var(--color-blackAlpha-800);
  color: var(--color-whiteAlpha-900);
  font-weight: bold;
  margin-right: 6px;
  text-align: center;
  line-height: 22px;
  width: 22px;
  font-size: 14px;
  display: inline-block;
  border-radius: 100%;
  border: 1px solid transparent;
  position: relative;
  top: -1px;
  height: 22px;
}

li:has(> span.circle-number) {
  list-style-type: none;
}

.entry-content .rectangle-number {
  display: inline-flex;
  background-color: var(--color-blackAlpha-200);
  color: var(--color-blackAlpha-800);
  align-items: center;
  width: 1.25em;
  height: 1.25em;
  font-size: 0.875em;
  justify-content: center;
  border-radius: 0.15em;
  font-weight: 600;
  margin: 0 0.3em;
  position: relative;
  top: -0.05em;
}

/* 黒丸番号リスト */

.entry-content ul.circle-number-list {
  counter-reset: item;
  padding-left: 0;
}
.entry-content ul.circle-number-list > li {
  list-style-type: none;
  counter-increment: item;
  position: relative;
  padding-left: 35px;
  margin-bottom: 20px;
}
.entry-content ul.circle-number-list > li:before {
  content: counter(item);
  background-color: var(--color-blackAlpha-800);
  color: var(--color-whiteAlpha-900);
  font-weight: bold;
  text-align: center;
  line-height: 22px;
  min-width: 22px;
  font-size: 14px;
  display: inline-block;
  border-radius: 100%;
  border: 1px solid transparent;
  position: absolute;
  top: 3px;
  left: 0;
  margin-bottom: 15px;
}

/* kaereba, yomereba, tomareba brand color
   ========================================================================== */

/*    ショップボタン共通    */

.shoplinkamazon a::before,
.shoplinkrakuten a::before,
.shoplinkyahoo a::before,
.shoplinkkindle a::before,
.shoplinkkakakucom a::before,
.shoplinkjalan a::before,
.shoplinkjtb a::before,
.shoplinkknt a::before,
.shoplinkikyu a::before,
.shoplinkrurubu a::before {
  content: '';
  display: inline-block;
  width: 15px;
  height: 15px;
  background-size: contain;
  vertical-align: middle;
  margin-right: 5px;
}

.shoplinkamazon a::after,
.shoplinkrakuten a::after,
.shoplinkyahoo a::after,
.shoplinkkindle a::after,
.shoplinkkakakucom a::after,
.shoplinkjalan a::after,
.shoplinkjtb a::after,
.shoplinkknt a::after,
.shoplinkikyu a::after,
.shoplinkrurubu a::after {
  font-family: "FontAwesome";
  content: "\f105";
  margin-left: 8px;
  color: var(--color-blackAlpha-800);
  font-size: 80%;
  opacity: 0.4;
}

/*    Amazon    */
.shoplinkamazon a {
  color: var(--color-id-amazon);
}
.shoplinkamazon a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920101304.png);
}

/*    rakuten    */
.shoplinkrakuten a {
  color: var(--color-id-rakuten);
}
.shoplinkrakuten a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920101301.png);
}

/*    Yahoo    */
.shoplinkyahoo a {
  color: var(--color-id-yahoo);
}
.shoplinkyahoo a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920101256.png);
}

/*    Kindle    */
.shoplinkkindle a {
  color: var(--color-id-kindle);
}
.shoplinkkindle a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920101308.png);
}

/*    価格コム    */
.shoplinkkakakucom a {
  color: var(--color-id-kakakucom);
}
.shoplinkkakakucom a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920101314.png);
}

/*    じゃらん    */
.shoplinkjalan a {
  color: var(--color-id-jalan);
}
.shoplinkjalan a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920095905.png);
}

/*    JTB    */
.shoplinkjtb a {
  color: var(--color-id-jtb);
}
.shoplinkjtb a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920095908.png);
}

/*    knt 近畿日本ツーリスト    */
.shoplinkknt a {
  color: var(--color-id-knt);
}
.shoplinkknt a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920101124.png);
}

/*    一休    */
.shoplinkikyu a {
  color: var(--color-id-ikyu);
}
.shoplinkikyu a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920095901.png);
}

/*    るるぶ    */
.shoplinkrurubu a {
  color: var(--color-id-rurubu);
}
.shoplinkrurubu a::before {
  background-image: url(https://cdn-ak.f.st-hatena.com/images/fotolife/s/saki0118/20230920/20230920101128.png);
}



/* kaereba, yomereba, tomareba
   ========================================================================== */

/* .shoplinkamazon,
.shoplinkrakuten,
.shoplinkkindle,
.shoplinkkakakucom,
.shoplinkyahoo,
.shoplinkjalan, 
.shoplinkjtb, 
.shoplinkknt, 
.shoplinkikyu, 
.shoplinkrurubu {
} */

.shoplinkamazon a, 
.shoplinkrakuten a, 
.shoplinkkindle a, 
.shoplinkkakakucom a, 
.shoplinkyahoo a,
.shoplinkjalan a, 
.shoplinkjtb a, 
.shoplinkknt a, 
.shoplinkikyu a, 
.shoplinkrurubu a {
  transition: all ease-in-out .1s;
  display: block;
  text-decoration: none;
  text-align: left;
  padding: 8px 20px;
  font-weight: bold;
  letter-spacing: .025em;
}

.booklink-box, 
.kaerebalink-box, 
.tomarebalink-box {
  border: 1px solid var(--color-blackAlpha-100);
  margin: var(--margin-base-row);
  display: flex;
  align-items: center;
  box-sizing: border-box;
  justify-content: space-between;
  border-radius: var(--radius-4);
}

.booklink-image, 
.kaerebalink-image, 
.tomarebalink-image {
  zoom: 1.2;
  padding: 20px;
  margin: 0 auto;
  display: flex;
  justify-content: space-evenly;
  flex: 1;
}

.booklink-info, 
.kaerebalink-info, 
.tomarebalink-info {
  padding: 20px;
  font-size: var(--fontsize-12);
  display: flex;
  flex: 4;
  gap: 10px;
  align-items: center;
}

.booklink-name, 
.kaerebalink-name, 
.tomarebalink-name {
  margin-bottom: 0;
  flex: 2;
}

.booklink-name a, 
.kaerebalink-name a, 
.tomarebalink-name a {
  display: block;
  line-height: 1.6;
  letter-spacing: .025em;
  font-weight: bold;
  font-size: var(--fontsize-16);
  color: var(--color-blackAlpha-800);
  text-decoration: none;
}

.booklink-link1,
.kaerebalink-link1,
.tomarebalink-link1 {
  max-width: 328px;
  margin-top: 0;
  flex: 2;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.booklink-link1 div, 
.kaerebalink-link1 div, 
.tomarebalink-link1 div {
  border-bottom: none;
  background-color: var(--color-blackAlpha-50);
}

.booklink-link1 div:first-child, 
.kaerebalink-link1 div:first-child, 
.tomarebalink-link1 div:first-child {
  border-radius: var(--radius-4) var(--radius-4) 0px 0px;
}

.booklink-link1 div:last-child, 
.kaerebalink-link1 div:last-child, 
.tomarebalink-link1 div:last-child {
  border-radius: 0px 0px var(--radius-4) var(--radius-4);
}

.tomarebalink-address {
  display: none;
}

.booklink-footer {
  display: none;
}

.booklink--powered-date, 
.kaerebalink-powered-date, 
.tomarebalink-powered-date {
  display: none;
}

/* SMP表示 */

@media screen and (max-width: 767px) {
  .booklink-box, 
  .kaerebalink-box, 
  .tomarebalink-box {
    gap: 10px;
    flex-direction: row-reverse;
  }

  .booklink-image, 
  .kaerebalink-image, 
  .tomarebalink-image {
    margin: 0 auto;
    float: none !important;
    flex: 2;
    padding: 10px;
  }
  .booklink-info, 
  .kaerebalink-info, 
  .tomarebalink-info {
    padding: 20px 0 20px 10px;
    gap: 10px;
    flex-direction: column;
    align-items: flex-start;
    align-items: stretch;
  }
  .booklink-name a, 
  .kaerebalink-name a, 
  .tomarebalink-name a {
    font-size: var(--fontsize-16);
    letter-spacing: .025em;
  }
  .booklink-link1 div, 
  .kaerebalink-link1 div, 
  .tomarebalink-link1 div {
    font-size: var(--fontsize-14);
  }
  .shoplinkamazon a, 
  .shoplinkrakuten a, 
  .shoplinkkindle a, 
  .shoplinkkakakucom a, 
  .shoplinkyahoo a,
  .shoplinkjalan a, 
  .shoplinkjtb a, 
  .shoplinkknt a, 
  .shoplinkikyu a, 
  .shoplinkrurubu a {
    padding: 5px 10px;
  }
}

/* </system> */