@charset "UTF-8";
/* ==========================================================================
   AFP — Final Overrides
   jinrのコアCSSと衝突するので、特異性とimportantで殴り直す層。
   読み込み順は最後（loaderで一番下に置く）。
   ========================================================================== */

/* --- Buttons: jinrの "a"汎用スタイル（背景画像下線）と色の継承を完全に上書き --- */
.afp-skin a.afp-btn,
.afp-skin .afp-btn,
.afp-skin .afp-btn:link,
.afp-skin .afp-btn:visited {
  background-image: none !important;
  background-size: 0 0 !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: var(--afp-s-2);
  padding: 14px 28px;
  border-radius: var(--afp-radius-pill);
  font-family: var(--afp-sans-jp);
  font-weight: 700;
  font-size: var(--afp-fs-md);
  line-height: 1 !important;
  letter-spacing: .04em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--afp-dur-fast) var(--afp-ease),
              box-shadow var(--afp-dur-fast) var(--afp-ease),
              background var(--afp-dur-fast) var(--afp-ease),
              color var(--afp-dur-fast) var(--afp-ease);
}
.afp-skin a.afp-btn--primary,
.afp-skin .afp-btn--primary {
  background: var(--afp-bordeaux) !important;
  background-color: var(--afp-bordeaux) !important;
  color: #ffffff !important;
  border-color: var(--afp-bordeaux) !important;
  box-shadow: 0 6px 18px rgba(122,31,45,.25);
}
.afp-skin a.afp-btn--primary:hover,
.afp-skin .afp-btn--primary:hover {
  background: var(--afp-bordeaux-dk) !important;
  background-color: var(--afp-bordeaux-dk) !important;
  color: #ffffff !important;
  transform: translateY(-1px);
}
.afp-skin a.afp-btn--ghost,
.afp-skin .afp-btn--ghost {
  background: transparent !important;
  color: var(--afp-bordeaux) !important;
  border-color: var(--afp-bordeaux) !important;
}
.afp-skin a.afp-btn--ghost:hover,
.afp-skin .afp-btn--ghost:hover {
  background: var(--afp-bordeaux) !important;
  color: #ffffff !important;
}
.afp-skin a.afp-btn--lg,
.afp-skin .afp-btn--lg { padding: 18px 36px; font-size: var(--afp-fs-lg); }

/* --- Breadcrumb: ヘッダー直下にスリム配置 ------------------------------------ */
.afp-skin .afp-breadcrumb-wrap {
  background: var(--afp-bg);
  border-bottom: 1px solid var(--afp-line-soft);
}
.afp-skin .afp-breadcrumb {
  padding: 6px 0 !important;
  font-size: 11px !important;
  color: var(--afp-ink-mute);
  line-height: 1.4;
}
.afp-skin .afp-breadcrumb ol {
  display: flex; flex-wrap: wrap;
  gap: 0 6px !important;
  margin: 0; padding: 0;
  list-style: none;
}
.afp-skin .afp-breadcrumb li { display: inline-flex; align-items: center; }
.afp-skin .afp-breadcrumb li + li::before {
  width: 5px !important; height: 5px !important;
  margin: 0 6px 0 0 !important;
}
@media (max-width: 720px) {
  .afp-skin .afp-breadcrumb { padding: 5px 0 !important; font-size: 10px !important; }
}

/* --- Header: 半透明ボルドー（背面ぼかし） ---------------------------------- */
body.afp-skin #commonHeader,
body.afp-skin #commonHeader.d--transparent,
body.afp-skin #commonHeader.d--header-style-default,
body.afp-skin .d--transparent#commonHeader {
  background: rgba(122, 31, 45, 0.88) !important;        /* var(--afp-bordeaux) 88% */
  background-color: rgba(122, 31, 45, 0.88) !important;
  border-bottom: 1px solid rgba(255,255,255,.10);
  position: sticky; top: 0; z-index: 50;
  padding: 0 !important;
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  box-shadow: 0 6px 24px rgba(122, 31, 45, .18);
}
.afp-skin #commonHeaderInner {
  max-width: var(--afp-container-wide);
  margin: 0 auto;
  padding: 10px var(--afp-s-5) !important;
  display: flex; align-items: center; gap: var(--afp-s-5);
  min-height: 96px;
}
@media (max-width: 720px) {
  .afp-skin #commonHeaderInner { min-height: 60px; padding: 6px var(--afp-s-4) !important; }
}
.afp-skin #headerLogo { margin-right: auto; line-height: 0; }
.afp-skin #headerLogoLink,
.afp-skin #headerLogoLink:link,
.afp-skin #headerLogoLink:visited {
  font-family: var(--afp-serif-jp) !important;
  font-weight: 700;
  font-size: 16px !important;
  letter-spacing: .02em;
  color: #faf7f2 !important;
  background-image: none !important;
  text-decoration: none !important;
  display: inline-flex; align-items: center; gap: 8px;
}
.afp-skin #headerLogoLink:hover { color: #fff !important; }
/* 装飾の◯は廃止 */
.afp-skin #headerLogoLink::before { display: none !important; content: none !important; }
/* アップ済みlogo.pngを綺麗に表示 */
/* ロゴ最適化：4:1（1000×250）想定。読める存在感を確保 */
.afp-skin #headerLogoImage {
  height: 80px !important;        /* PC: 80px → 320px幅（viewportの約22%） */
  max-height: 80px !important;
  width: auto !important;
  max-width: none !important;
  object-fit: contain;
  display: block;
}
@media (max-width: 720px) {
  .afp-skin #headerLogoImage {
    height: 44px !important;      /* SP: 44px → 176px幅 */
    max-height: 44px !important;
  }
}
.afp-skin #globalMenu ul,
.afp-skin #globalMenu .menu {
  display: flex; gap: var(--afp-s-5); list-style: none; margin: 0; padding: 0;
}
.afp-skin #globalMenu a,
.afp-skin #globalMenu a:link,
.afp-skin #globalMenu a:visited {
  font-family: var(--afp-sans-jp) !important;
  font-weight: 600 !important;
  font-size: var(--afp-fs-sm) !important;
  color: rgba(255,255,255,.82) !important;
  background-image: none !important;
  letter-spacing: .04em;
  position: relative;
  padding: 6px 2px;
}
.afp-skin #globalMenu a:hover { color: #fff !important; }
.afp-skin #globalMenu a::after {
  content: ""; position: absolute; left: 50%; bottom: 0;
  width: 0; height: 2px; background: var(--afp-gold);
  transition: width var(--afp-dur-base) var(--afp-ease), left var(--afp-dur-base) var(--afp-ease);
}
.afp-skin #globalMenu a:hover::after { width: 24px; left: calc(50% - 12px); }
.afp-skin #headerSearch .a--search-icon {
  background: rgba(255,255,255,.08);
  border-radius: 50%;
  width: 36px; height: 36px;
  display: grid; place-items: center;
  cursor: pointer;
  transition: background .2s var(--afp-ease);
}
.afp-skin #headerSearch .a--search-icon:hover { background: rgba(255,255,255,.18); }
.afp-skin #headerSearch i { color: rgba(255,255,255,.85); }

/* スティッキーヘッダーぶん、Heroに上余白を確保 */
.afp-skin .afp-hero,
.afp-skin .afp-section,
.afp-skin .afp-areahead { scroll-margin-top: 80px; }

/* --- jinrのデフォルト本文padding等をAFP側で吸収 --------------------------- */
.afp-skin #mainContent,
.afp-skin #mainContentInner { max-width: none !important; padding: 0 !important; margin: 0 !important; }

/* --- jinrの "a" 全体への背景画像下線を、AFPコンテナ内では無効化 ---------- */
.afp-skin .afp-content a,
.afp-skin .afp-areahead a,
.afp-skin .afp-section a {
  background-image: linear-gradient(currentColor, currentColor);
  background-size: 0 1px;
  background-repeat: no-repeat;
  background-position: 0 100%;
}
.afp-skin .afp-content a:hover { background-size: 100% 1px; }
.afp-skin .afp-area-card,
.afp-skin a.afp-area-card { background-image: none !important; background-size: 0 0 !important; }
