/*
Theme Name: Kotobuki Clinic
Theme URI:  https://example.com/
Author:     Office Bravo!
Author URI: https://example.com/
Description: 「いぬとねこのクリニック ことぶき」1ページテーマ
Version:    1.0
Text Domain: kotobuki-clinic
*/

/* 実際のスタイルは asset/css/style.css を読み込む */


@charset "UTF-8";
/* CSS Document */ :root {
  --bg: #fbfbe8;
  --accent: #ffeaa5;
  --accent-soft: #fff9c9;
  --main: #4d6fb3;
  --text: #444;
  --radius-lg: 2.8rem;
  --inner-width: 960px;
  --shadow-soft: 0 10px 25px rgba(0, 0, 0, 0.08);
  --maxw: var(--inner-width);
  --side: 1.5rem;
  font-size: 62.5%;
}
*, *::before, *::after {
  box-sizing: border-box;
}
html, body {
  margin: 0;
  padding: 0;
}
body {
  font-family: "Zen Maru Gothic", "Hiragino Kaku Gothic ProN", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 1.6rem;
  line-height: 1.8;
  background: var(--bg);
  color: var(--text);
}
/* common */
.inner {
  width: min(var(--inner-width), 100% - 3rem);
  margin-inline: auto;
}
.section {
  padding: 6rem 0;
}
.section-soft {
  background: #fffdf1;
}
.sec-title {
  font-size: 2.4rem;
  text-align: center;
  letter-spacing: 0.08em;
  margin: 0 0 1.5rem;
  color: var(--main);
}
.sec-title.-left {
  text-align: left;
}
.sec-lead {
  text-align: center;
  margin: 0 0 3.5rem;
  font-size: 1.5rem;
}
.card {
  background: var(--accent-soft);
  border-radius: var(--radius-lg);
  padding: 2.4rem 3rem;
  box-shadow: var(--shadow-soft);
}
.card + .card {
  margin-top: 2.4rem;
}
.card-title {
  font-size: 1.8rem;
  margin: 0 0 0.8rem;
}
.card-title.-sub {
  margin-top: 2.4rem;
}
.card-list {
  padding-left: 1.4rem;
  margin: 0 0 1.5rem;
}
.card-list li {
  margin-bottom: 0.4rem;
}
.label {
  display: inline-block;
  font-size: 1.5rem;
  background: #fff7b5;
  padding: 0.4rem 1.2rem;
  border-radius: 999px;
  margin-bottom: 0.8rem;
}
/* header */
.global-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(251, 251, 232, 0.9);
  backdrop-filter: blur(8px);
}
/* ===== 繝倥ャ繝?繝ｼ縺ｮ繝吶?繧ｹ?医い繝九Γ逕ｨ縺ｫ繝医Λ繝ｳ繧ｸ繧ｷ繝ｧ繝ｳ霑ｽ蜉?? ===== */
.global-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(251, 251, 232, 0.9);
  backdrop-filter: blur(8px);
  transition:
    background-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 0; /* 笘? 蛻晄悄縺ｯ蟆代＠繧?▲縺溘ｊ */
  transition: padding 0.25s ease;
}
.site-logo img {
  display: block;
  height: 56px; /* 笘? 蛻晄悄繝ｭ繧ｴ繧ｵ繧､繧ｺ */
  transition: height 0.25s ease;
}
/* ===== 繧ｹ繧ｯ繝ｭ繝ｼ繝ｫ蠕鯉ｼ育ｸｮ繧薙□迥ｶ諷具ｼ? ===== */
.global-header.is-scrolled {
  background: rgba(251, 251, 232, 0.96);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
}
.global-header.is-scrolled .header-inner {
  padding: 0.5rem 0; /* 笘? 鬮倥＆繧偵く繝･繝?→ */
}
.global-header.is-scrolled .site-logo img {
  height: 42px; /* 笘? 繝ｭ繧ｴ繧ょｰ代＠蟆上＆縺? */
}
/* 繧ｹ繧ｯ繝ｭ繝ｼ繝ｫ蠕後?繝翫ン繧ょｰ代＠縺縺代さ繝ｳ繝代け繝医↓ */
.global-header.is-scrolled .site-nav a {
  padding-top: 0.2rem;
  padding-bottom: 0.2rem;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.8rem 0;
}
.site-logo img {
  display: block;
  height: 52px;
}
/* nav */
.site-nav ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; /* 笘? 蟾ｦ蜿ｳ繧ｻ繝ｳ繧ｿ繝ｼ */
  align-items: center;
  list-style: none;
  gap: 0.8rem 1.6rem;
  margin: 0;
  padding: 0;
  font-size: 1.3rem;
}
.site-nav ul li a {
  text-align: center; /* 笘? 繝?く繧ｹ繝医ｂ荳ｭ螟ｮ蟇?○縺ｫ */
  display: block;
}
.site-nav a {
  display: block;
  text-decoration: none;
  color: var(--text);
  padding: 0.4rem 1.4rem; /* 笘? 繝翫ン縺ｮ鬮倥＆?井ｸ贋ｸ九?菴咏區?? */
  border-radius: 999px; /* 縺｡繧?＞ pill 縺｣縺ｽ縺? */
  border: 1px solid transparent;
  line-height: 1.4;
  transition:
    background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
/* 繝帙ヰ繝ｼ譎ゅ?閭梧勹??枚蟄苓牡 */
.site-nav a:hover {
  background: var(--main); /* 繝｡繧､繝ｳ繧ｫ繝ｩ繝ｼ閭梧勹 */
  color: #fff;
  border-color: transparent;
  transform: translateY(-1px); /* 縺ｻ繧薙?蟆代＠豬ｮ縺? */
}
/* ========== Hero & KV?医％縺ｨ縺ｶ縺搾ｼ? ========== */
.hero {
  width: 100%;
  padding: 3rem 0 5rem;
  min-height: 85vh; /* 笘? KV繧ｻ繧ｯ繧ｷ繝ｧ繝ｳ蜈ｨ菴薙?鬮倥＆ */
  display: flex;
  align-items: center;
}
.hero-inner {
  width: min(var(--inner-width), 100% - 3rem);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between; /* 蟾ｦ繝ｭ繧ｴ / 蜿ｳKV 繧貞ｷｦ蜿ｳ縺ｫ驟咲ｽｮ */
  gap: 4rem;
}
/* 蟾ｦ繝ｭ繧ｴ */
.hero-logo {
  flex: 0 0 auto;
}
.hero-logo img {
  display: block;
  max-width: 220px;
  height: auto;
}
.hero-logo-text {
  margin-top: 1.6rem;
  line-height: 1.6;
}
/* 繧ｵ繝悶さ繝斐?縲後＞縺ｬ縺ｨ縺ｭ縺薙?繧ｯ繝ｪ繝九ャ繧ｯ縲? */
.hero-logo-sub {
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  color: #555;
  display: inline-block;
  margin-bottom: 0.3rem;
}
/* 繝｡繧､繝ｳ繝ｭ繧ｴ縲後％縺ｨ縺ｶ縺阪?? */
.hero-logo-main {
  font-size: clamp(2.8rem, 4vw, 4rem);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-indent: 0.18em;
  color: var(--main);
}
/* 蜿ｳKV */
.hero-visual {
  position: relative;
  flex: 1 1 auto;
}
/* KV譛ｬ菴薙?繧ｵ繧､繧ｺ隱ｿ謨ｴ */
.kv-blob-wrapper {
  position: relative;
  width: 100%;
  max-width: 900px; /* 笘? PC縺ｧ縺励▲縺九ｊ螟ｧ縺阪￥隕九○繧? */
  margin-left: auto;
}
.kv-blob-svg {
  display: block;
  width: 100%;
  height: auto;
}
/* Safari fallback 逕ｨ縺ｮ逕ｻ蜒上さ繝ｳ繝?リ縺ｯ繝?ヵ繧ｩ繝ｫ繝磯撼陦ｨ遉ｺ */
.kv-blob-css {
  display: none;
}
/* ==== Safari逕ｨ clip-path 繝槭せ繧ｯ ==== */
.is-safari .kv-blob-svg {
  display: none;
}
.is-safari .kv-blob-css {
  display: block;
  overflow: hidden;
  clip-path: polygon(5% 50%, 7% 35%, 20% 15%, 40% 8%, 60% 8%, 80% 15%, 93% 30%, 95% 45%, 90% 60%, 75% 75%, 50% 82%, 25% 80%, 12% 70%, 6% 60%);
  animation: kvBlobMove 10s ease-in-out infinite alternate;
}
.is-safari .kv-blob-css img {
  width: 100%;
  display: block;
}
@keyframes kvBlobMove {
  0% {
    clip-path: polygon(10% 30%, 30% 10%, 60% 15%, 80% 35%, 90% 60%, 70% 85%, 40% 90%, 15% 70%);
  }
  50% {
    clip-path: polygon(15% 25%, 35% 15%, 65% 10%, 85% 30%, 95% 55%, 75% 80%, 45% 88%, 12% 72%);
  }
  100% {
    clip-path: polygon(8% 28%, 28% 12%, 58% 18%, 78% 37%, 92% 62%, 72% 86%, 38% 92%, 12% 68%);
  }
}
/* ==== SP繝ｬ繧､繧｢繧ｦ繝? ==== */
@media (max-width: 640px) {
  .hero {
    min-height: 70vh; /* SP縺ｧ縺ｯ蟆代＠謗ｧ縺医ａ縺ｫ */
    padding: 2.4rem 0 3.2rem;
  }
  .hero-inner {
    flex-direction: column;
    text-align: center;
    gap: 2.4rem;
  }
  .hero-logo img {
    margin-inline: auto;
  }
  .hero-logo-sub {
    font-size: 1.2rem;
  }
  .hero-logo-main {
    font-size: 2.6rem;
  }
  .kv-blob-wrapper {
    max-width: 340px; /* SP縺ｧ縺ｯ邵ｦ髟ｷ縺ｫ縺ｪ繧翫☆縺弱↑縺?ｨ句ｺｦ縺ｫ */
    margin-inline: auto;
  }
}
/* about */
.about-grid {
  display: flex;
  flex-direction: column;
  gap: 3.2rem;
  margin-top: 3rem;
}
/* 騾壼ｸｸ 竊? 蜀咏悄蟾ｦ / 繝?く繧ｹ繝亥承 */
.about-card {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  align-items: center;
  gap: 2rem;
}
/* reverse 竊? 蜀咏悄蜿ｳ / 繝?く繧ｹ繝亥ｷｦ */
.about-card.-reverse .about-photo {
  order: 2;
}
.about-card.-reverse .about-text {
  order: 1;
}
.about-text p {
  margin: 0;
  font-size: 1.5rem;
}
@media (max-width: 768px) {
  .about-card, .about-card.-reverse {
    grid-template-columns: 1fr;
  }
  /* reverse縺ｮ蜈･繧梧崛縺医ｒ辟｡蜉ｹ蛹悶＠縺ｦ邵ｦ荳ｦ縺ｳ繧堤ｵｱ荳? */
  .about-card.-reverse .about-photo {
    order: 1;
  }
  .about-card.-reverse .about-text {
    order: 2;
  }
}
.blob {
  border-radius: 60% 40% 50% 50%;
  overflow: hidden;
}
.blob img {
  width: 100%;
  height: auto;
  display: block;
}
/* guide */
.guide-grid {
  display: grid;
  grid-template-columns: 1fr; /* 竊? 1繧ｫ繝ｩ繝縺ｫ螟画峩?? */
  gap: 2.4rem;
}
.note {
  font-size: 1.3rem;
}
/* time table */
.time-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 1rem;
  font-size: 1.3rem;
  text-align: center;
}
.time-table th, .time-table td {
  border: 1px solid #e3e3e3;
  padding: 0.5rem 0.3rem;
}
.time-table thead th {
  background: #fff7b5;
}
/* director */
.director-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  gap: 3rem;
  align-items: center;
}
.director-name {
  font-size: 1.8rem;
  margin: 0 0 1.2rem;
}

/* =========================
   Director?售P繝ｬ繧､繧｢繧ｦ繝郁ｪｿ謨ｴ
   ========================= */
@media (max-width: 640px) {
  /* 讓ｪ荳ｦ縺ｳ竊堤ｸｦ荳ｦ縺ｳ縺ｫ螟画峩 */
  .director-grid {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1.8rem;
  }

  /* .director-text 縺ｮ邂ｱ繧呈ｶ医＠縺ｦ荳ｭ霄ｫ繧堤峩蛻励?隕∫ｴ縺ｫ縺吶ｋ */
  .director-grid .director-text {
    display: contents;
  }

  /* 荳ｦ縺ｳ鬆??謖?ｮ夲ｼ井ｸ翫°繧蛾?↓?? */
  .director-grid .sec-title {
    order: 1;
    text-align: center;       /* 繧ｿ繧､繝医Ν荳ｭ螟ｮ蟇?○?医♀螂ｽ縺ｿ縺ｧ?? */
    margin-bottom: 1.2rem;
  }

  .director-grid .director-photo {
    order: 2;
    max-width: 260px;         /* 蜀咏悄縺ｮ譛?螟ｧ蟷?ｼ医♀螂ｽ縺ｿ縺ｧ?? */
    margin: 0 auto 1.2rem;    /* 荳ｭ螟ｮ蟇?○?倶ｸ九↓蟆代＠繝槭?繧ｸ繝ｳ */
  }

  .director-grid .director-name {
    order: 3;
    text-align: center;
    margin-bottom: 1.2rem;
  }

  .director-grid p {
    order: 4;
  }

  /* 荳｡繧ｵ繧､繝峨?菴咏區繧貞ｰ代＠蠎?£繧? */
  .section-director .inner,
  #director .inner {
    width: min(var(--inner-width), 100% - 4rem); /* 蜈?′ 100% - 3rem 縺ｪ縺ｮ縺ｧ蟆代＠菴咏區UP */
  }
}


/* FAQ 蜈ｨ菴? */
.faq-list {
  margin-top: 3rem;
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}
/* 繧ｫ繝ｼ繝牙?菴? */
.faq-item {
  background: #fffef9;
  border-radius: 1.6rem;
  border: 2px solid #f6ecd1;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
  overflow: hidden;
  transition: box-shadow .25s ease;
}
.faq-item:hover {
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.10);
}
/* 雉ｪ蝠城Κ蛻?ｼ医?繧ｿ繝ｳ?? */
.faq-question {
  width: 100%;
  padding: 1.8rem 2rem;
  border: none;
  background: transparent;
  font-size: 1.7rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  font-weight: 700;
  color: #333;
}
/* 繧｢繧､繧ｳ繝ｳ?茨ｼ? 竊? ﾃ暦ｼ? */
.faq-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid #d8cfae;
  font-size: 1.7rem;
  transition: transform .3s ease;
}
/* 髢九＞縺滓凾?夲ｼ? 縺? ﾃ? 縺ｫ */
.faq-item.is-open .faq-icon {
  transform: rotate(45deg);
}
/* 遲斐∴驛ｨ蛻? */
.faq-answer {
  padding: 0 2rem;
  font-size: 1.55rem;
  line-height: 1.7;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition:
    max-height .4s ease, opacity .3s ease;
}
/* 髢九＞縺溽憾諷? */
.faq-item.is-open .faq-answer {
  padding-bottom: 2rem;
  max-height: 500px;
  opacity: 1;
}
.faq-icon {
  border: none;
  background: none;
  font-size: 2.2rem;
}
.faq-item .faq-icon::before {
  content: "汾ｾ"; /* 髢九＞縺ｦ縺ｪ縺?凾?夊ｉ逅? */
}
.faq-item.is-open .faq-icon::before {
  content: "洶ｴ"; /* 髢九＞縺ｦ繧区凾?夐ｪｨ繧｢繧､繧ｳ繝ｳ */
}
/* access */
.map-wrapper {
  margin-top: 2.5rem;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  height: 35rem;
}
.map-image {
  display: block;
  width: 100%;
  height: auto;
}
.access-text {
  text-align: center;
  margin-top: 2rem;
  font-size: 1.4rem;
}
.access-tel {
  font-size: 2.8rem;
  letter-spacing: 0.12em;
  margin: 0 0 0.5rem;
}
.access-address {
  font-size: 2rem;
  margin: 0 auto;
}
.access-station {
  font-size: 1.5rem;
}
.access-logo {
  text-align: center;
  margin-top: 2.5rem;
}
.access-logo img {
  height: 72px;
}
/* footer & page top */
.site-footer {
  text-align: center;
  padding: 2rem 0 3rem;
  font-size: 1.2rem;
  color: #777;
}
.pagetop {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
    z-index: 9999;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: none;
  background: #fff;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
  cursor: pointer;
  font-size: 2rem;
  line-height: 1;
  display: none;
}

/* =========================
險ｺ逋ゆｺ育ｴ?ｼ壼ｸｸ譎り｡ｨ遉ｺ繝懊ち繝ｳ?亥?騾壹?繝ｼ繧ｹ??
========================= */

/* 蜈ｱ騾夲ｼ壹ョ繧ｶ繧､繝ｳ縺ｨ縲郡P縺ｮ讓呎ｺ紋ｽ咲ｽｮ?育判髱｢荳具ｼ峨?? */
.reserve-fab {
  position: fixed;
  right: 1.5rem;
  bottom: 5.5rem; /* pagetop 繝懊ち繝ｳ縺ｮ荳翫≠縺溘ｊ縺ｫ驟咲ｽｮ */
  left: auto;
  top: auto;

  z-index: 200;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 1.0rem 2.2rem;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-align: center;
  text-decoration: none;

  /* 蜈ｱ騾壹ョ繧ｶ繧､繝ｳ??C/SP 蜈ｱ騾夲ｼ? */
  background: linear-gradient(135deg, #4A7BD5, #6CA3E6);
  color: #fff;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  box-shadow:
    0 6px 24px rgba(0, 0, 0, 0.15),
    0 1px 2px rgba(255, 255, 255, 0.4) inset;
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    background 0.25s ease;
}

/* 蟾ｦ縺ｮ荳ｸ繧｢繧､繧ｳ繝ｳ */
.reserve-fab::before {
  content: "泓";
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.95);
  color: #4A7BD5;
  border-radius: 50%;
  font-size: 1.2rem;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* 繝帙ヰ繝ｼ??け繝ｪ繝?け??C荳ｭ蠢?□縺悟?騾壹〒OK?? */
.reserve-fab:hover {
  /*transform: translateY(-2px);*/
  background: linear-gradient(135deg, #5B8FE0, #7FB6F0);
  box-shadow:
    0 12px 28px rgba(0, 0, 0, 0.20),
    0 2px 4px rgba(255, 255, 255, 0.4) inset;
}
.reserve-fab:active {
  transform: translateY(0);
  box-shadow:
    0 4px 16px rgba(0, 0, 0, 0.18) inset;
}

/* 繧?＆縺励＞窶懷他蜷ｸ窶昴い繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ?亥虚縺康G迺ｰ蠅?〒縺ｯ辟｡蜉ｹ?? */
@media (prefers-reduced-motion: no-preference) {
  .reserve-fab {
    animation: reservePulse 2.8s ease-in-out infinite;
  }
}
@keyframes reservePulse {
  0%, 100% {
    transform: translateY(0);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
  }
  50% {
    transform: translateY(-2px);
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.26);
  }
}

/* =========================
SP?夂判髱｢荳九そ繝ｳ繧ｿ繝ｼ蝗ｺ螳夲ｼ医い繝九Γ縺ｪ縺暦ｼ?
========================= */
@media (max-width: 640px) {
  .reserve-fab {
    position: fixed;
    left: 50%;
    right: auto;              /* 繝吶?繧ｹ縺ｮ right:1.5rem 繧呈遠縺｡豸医☆ */
    top: auto;
    bottom: 5rem;
    transform: translateX(-50%);  /* 荳ｭ螟ｮ蟇?○ */

    /* 縺薙％縺ｧ繧｢繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ繧偵が繝輔↓縺吶ｋ縺ｮ縺碁崎ｦ?ｼ? */
    animation: none !important;

    z-index: 200;

    white-space: nowrap;      /* 1陦瑚｡ｨ遉ｺ */
    max-width: 90%;
    padding: 0.85rem 1.6rem;
    font-size: 1.8rem;
    line-height: 1.2;
    box-sizing: border-box;
  }

  .reserve-fab::before {
    width: 18px;
    height: 18px;
    font-size: 1.05rem;
  }
}



/* =========================
PC?壼承荳雁崋螳?
========================= */
@media (min-width: 769px) {
  .reserve-fab {
    top: 1.8rem;
    right: 2.0rem;
    bottom: auto;
    left: auto;
    transform: none; /* SP縺ｧ莉倥¢縺? translateX 繧偵Μ繧ｻ繝?ヨ */
    padding: 0.85rem 1.8rem;
    font-size: 1.35rem;
  }
}

/* responsive */
@media (max-width: 768px) {
  :root {
    font-size: 58%;
  }
  .global-header {
    position: static;
  }
  .header-inner {
    flex-direction: column;
    gap: 0.8rem;
  }
  .site-logo img {
    height: 44px;
  }
  .site-nav ul {
    justify-content: center;
  }
  .hero {
    padding-top: 2rem;
  }
  .about-card, .about-card.-reverse, .guide-grid, .director-grid {
    grid-template-columns: minmax(0, 1fr);
  }
  .about-card.-reverse .about-photo {
    order: -1;
  }
  .guide-grid {
    gap: 2rem;
  }
  .hero-reserve {
    width: 78px;
    height: 78px;
    font-size: 1.2rem;
  }
}
/*  繝ｭ繧ｴ蟾ｦ縲√ヲ繝ｼ繝ｭ繝ｼ蜿ｳ縺ｮ繝ｬ繧､繧｢繧ｦ繝?  */
.header-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  padding: 2rem 0;
}
/* 繝ｭ繧ｴ */
.site-logo img {
  width: 160px;
  height: auto;
  display: block;
}
.hero-visual img {
  width: 100%;
  display: block;
}
/* 莠育ｴ??繧ｿ繝ｳ */
.hero-reserve {
  position: absolute;
  right: 1.2rem;
  top: 1.2rem;
  background: #fff;
  border-radius: 50%;
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--main);
  font-size: 1.2rem;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}
/* 繧ｹ繝槭??井ｸ九↓邵ｦ荳ｦ縺ｳ?? */
@media (max-width: 768px) {
  .header-flex {
    flex-direction: column;
  }
  .site-logo img {
    width: 130px;
  }
  .hero-visual {
    max-width: 100%;
    position: relative; /* 笘? 霑ｽ蜉 */
  }
}
.global-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(251, 251, 232, 0.9);
  backdrop-filter: blur(6px);
  padding: 0.6rem 0;
}
.hero-row {
  padding: 2rem 0 4rem;
}
.hero-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3rem;
}
.site-logo img {
  width: 160px;
  height: auto;
}
.hero-visual {
  flex: 1;
  /*max-width: 600px;*/
  position: relative;
  border-radius: 4rem;
  overflow: hidden;
}
.hero-visual img {
  width: 100%;
  display: block;
}
/* 繧ｹ繝槭? */
@media (max-width: 768px) {
  .hero-flex {
    flex-direction: column;
  }
  .site-logo img {
    width: 130px;
  }
  .hero-visual {
    max-width: 100%;
  }
}
.site-logo {
  text-align: center;
}
.site-logo-text {
  margin-top: 0.5rem;
  font-size: 1.4rem;
  line-height: 1.4;
  color: var(--text);
}
.site-logo-text p {
  margin: 0;
}
.kv-blob-wrapper {
  width: min(100%, 960px);
  margin: 0 auto;
}
/* 繝?ヵ繧ｩ繝ｫ繝茨ｼ售VG 迚医□縺題｡ｨ遉ｺ */
.kv-blob-svg {
  display: block;
  width: 100%;
  height: auto;
}
.kv-blob-css {
  display: none;
}
/* Safari 縺ｮ縺ｨ縺阪□縺大?繧頑崛縺医ｋ */
.is-safari .kv-blob-svg {
  display: none;
}
.is-safari .kv-blob-css {
  display: block;
}
/* CSS 迚医?縺ｵ繧上?繧上?繧ｹ繧ｯ */
.kv-blob-css {
  overflow: hidden;
  clip-path: polygon(10% 30%, 30% 10%, 60% 15%, 80% 35%, 90% 60%, 70% 85%, 40% 90%, 15% 70%);
  animation: kvBlobMove 10s ease-in-out infinite alternate;
}
.kv-blob-css img {
  width: 100%;
  display: block;
}
@keyframes kvBlobMove {
  0% {
    clip-path: polygon(10% 30%, 30% 10%, 60% 15%, 80% 35%, 90% 60%, 70% 85%, 40% 90%, 15% 70%);
  }
  50% {
    clip-path: polygon(15% 25%, 35% 15%, 65% 10%, 85% 30%, 95% 55%, 75% 80%, 45% 88%, 12% 72%);
  }
  100% {
    clip-path: polygon(8% 28%, 28% 12%, 58% 18%, 78% 37%, 92% 62%, 72% 86%, 38% 92%, 13% 68%);
  }
}
/* ===== Hero 繝ｬ繧､繧｢繧ｦ繝? ===== */
.hero {
  padding: 4rem var(--side);
}
/* 蟾ｦ繝ｭ繧ｴ */
.hero-logo {
  flex: 0 0 auto;
}
.hero-logo img {
  display: block;
  max-width: 220px; /* 縺雁･ｽ縺ｿ縺ｧ */
  height: auto;
}
/* 蜿ｳKV */
.hero-visual {
  position: relative;
  flex: 1 1 auto;
}
.hero {
  width: 100%;
}
.hero-inner {
  width: min(var(--inner-width), 100% - 3rem); /* .inner 縺ｨ蜷後§蟷? */
  margin-inline: auto; /* 荳ｭ螟ｮ蟇?○ */
  display: flex;
  align-items: center;
  justify-content: space-between; /* 蟾ｦ繝ｭ繧ｴ / 蜿ｳKV 繧貞ｷｦ蜿ｳ縺ｫ驟咲ｽｮ */
  gap: 4rem;
}
/* ===== 縺ｵ繧上?繧上?繧ｹ繧ｯ蜈ｱ騾? ===== */
.kv-blob-wrapper {
  width: 100%;
}
/* 繝?ヵ繧ｩ繝ｫ繝茨ｼ售VG迚医ｒ菴ｿ縺? */
.kv-blob-svg {
  display: block;
  width: 100%;
  height: auto;
}
.kv-blob-css {
  display: none;
}
/* Safari 縺ｮ縺ｨ縺阪? CSS clip-path 迚医↓蛻?ｊ譖ｿ縺? */
.is-safari .kv-blob-svg {
  display: none;
}
.is-safari .kv-blob-css {
  display: block;
}
/* CSS 迚医?縺ｵ繧上?繧上?繧ｹ繧ｯ */
.kv-blob-css {
  overflow: hidden;
  clip-path: polygon(10% 30%, 30% 10%, 60% 15%, 80% 35%, 90% 60%, 70% 85%, 40% 90%, 15% 70%);
  animation: kvBlobMove 10s ease-in-out infinite alternate;
}
.kv-blob-css img {
  width: 100%;
  display: block;
}
@keyframes kvBlobMove {
  0% {
    clip-path: polygon(10% 30%, 30% 10%, 60% 15%, 80% 35%, 90% 60%, 70% 85%, 40% 90%, 15% 70%);
  }
  50% {
    clip-path: polygon(15% 25%, 35% 15%, 65% 10%, 85% 30%, 95% 55%, 75% 80%, 45% 88%, 12% 72%);
  }
  100% {
    clip-path: polygon(8% 28%, 28% 12%, 58% 18%, 78% 37%, 92% 62%, 72% 86%, 38% 92%, 13% 68%);
  }
}
/* ===== SP 繝ｬ繧､繧｢繧ｦ繝郁ｪｿ謨ｴ ===== */
@media (max-width: 640px) {
  .hero {
    padding: 3rem var(--side);
  }
  .hero-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 2.4rem;
  }
  .hero-logo {
    align-self: center;
  }
}
.hero-logo {
  flex: 0 0 auto;
  text-align: center; /* 竊? 荳ｭ螟ｮ謠?∴ */
}
.hero-logo img {
  display: block;
  max-width: 220px; /* 隱ｿ謨ｴ蜿ｯ閭ｽ */
  height: auto;
  margin: 0 auto;
}
.hero-logo-text {
  margin-top: 1.2rem; /* 繝ｭ繧ｴ縺ｨ縺ｮ菴咏區 */
  font-size: 1.6rem; /* 縺雁･ｽ縺ｿ縺ｧ隱ｿ謨ｴ */
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: .05em;
  text-align: center; /* 蠢ｵ縺ｮ縺溘ａ謖?ｮ? */
  color: #333; /* 蠢?ｦ√↑繧牙､画峩 */
}
@media (max-width: 640px) {
  .hero-logo-text {
    font-size: 1.4rem;
  }
}
.blob-wrapper {
  position: relative;
  width: 100%;
}
.blob-svg {
  display: block;
  width: 100%;
  height: auto;
}
.blob-css {
  display: none;
}
/* Safari fallback */
.is-safari .blob-svg {
  display: none;
}
.is-safari .blob-css {
  display: block;
}
/* CSS fallback 縺ｮ繧｢繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ */
.blob-css {
  overflow: hidden;
  /* 讓ｪ繧偵⊇縺ｼ蜈ｨ蟷?∪縺ｧ & 荳九?蜃ｺ縺｣蠑ｵ繧翫ｒ蠑ｷ繧√↓ */
  clip-path: polygon(5% 35%, /* 蟾ｦ荳雁ｯ?ｊ */ 18% 15%, /* 蟾ｦ荳? */ 40% 5%, /* 荳贋ｸｭ螟ｮ蟾ｦ */ 60% 5%, /* 荳贋ｸｭ螟ｮ蜿ｳ */ 82% 15%, /* 蜿ｳ荳? */ 95% 35%, /* 蜿ｳ荳雁ｯ?ｊ */ 98% 55%, /* 蜿ｳ荳ｭ谿ｵ */ 90% 75%, /* 蜿ｳ荳句ｯ?ｊ */ 70% 92%, /* 荳句承 */ 45% 98%, /* 縺?■縺ｰ繧謎ｸ具ｼ壹⊃縺薙ｓ */ 25% 92%, /* 荳句ｷｦ */ 8% 72% /* 蟾ｦ荳句ｯ?ｊ */
    );
  animation: blobMove 10s ease-in-out infinite alternate;
}
/* 蜍輔″繧偵⊇繧薙?繧贋ｻ倥¢縺溘＞蝣ｴ蜷? */
@keyframes blobMove {
  0% {
    clip-path: polygon(5% 35%, 18% 15%, 40% 5%, 60% 5%, 82% 15%, 95% 35%, 98% 55%, 90% 75%, 70% 92%, 45% 98%, 25% 92%, 8% 72%);
  }
  50% {
    clip-path: polygon(6% 33%, 20% 17%, 42% 7%, 58% 6%, 80% 17%, 96% 37%, 99% 57%, 91% 76%, 69% 93%, 44% 99%, 24% 93%, 7% 73%);
  }
  100% {
    clip-path: polygon(5% 35%, 18% 15%, 40% 5%, 60% 5%, 82% 15%, 95% 35%, 98% 55%, 90% 75%, 70% 92%, 45% 98%, 25% 92%, 8% 72%);
  }
}
/* ===== Concept sticky note?井ｻ倡ｮ具ｼ?===== */
.sticky-note {
  display: inline-block;
  background: #fff9c9; /* 繧?ｏ繧峨°縺?ｻ倡ｮ玖牡 */
  padding: 1.2rem 2rem;
  border-radius: 0.4rem; /* 莉倡ｮ九ｉ縺励￥隗偵?蟆代＠荳ｸ繧√ｋ */
  transform: rotate(-2.5deg); /* 霆ｽ縺丞だ縺代※莉倡ｮ区─UP */
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 2.4rem;
}
/* SP隱ｿ謨ｴ */
@media (max-width: 640px) {
  .sticky-note {
    font-size: 2rem;
    padding: 1rem 1.6rem;
    transform: rotate(-2deg); /* SP縺ｯ蛯ｾ縺阪ｒ蟆代＠謗ｧ縺医ａ縺ｫ */
  }
}
/* ===== Concept ===== */
.concept {
  padding: 6rem var(--side) 4rem;
  text-align: center;
}
.concept-lead {
  font-size: 1.7rem;
  line-height: 1.8;
  color: var(--text);
}
@media (max-width: 640px) {
  .concept {
    padding: 4rem var(--side) 3rem;
  }
  .concept-lead {
    font-size: 1.5rem;
  }
}
/* 荳ｭ螟ｮ縺ｫ莉倡ｮ九ｒ鄂ｮ縺上◆繧√?繝ｩ繝?ヱ?句･･縺ｮ莉倡ｮ? */
.concept-sticky {
  position: relative;
  display: flex;
  justify-content: center;
  margin-bottom: 3rem;
}
/* 螂･縺ｫ繧ゅ≧荳?譫壻ｻ倡ｮ九ｒ謨ｷ縺? */
.concept-sticky::before {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 75%;
  max-width: 420px;
  height: 70%;
  background: #fff4b8; /* 蟆代＠豼?＞莉倡ｮ玖牡縺ｧ螂･陦後″ */
  border-radius: 0.5rem;
  transform: translate(0.8rem, 0.9rem) rotate(1.5deg);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.10);
  z-index: 0;
  opacity: 0;
  animation: stickyBackIn 0.7s ease-out forwards;
}
/* 螂･縺ｮ莉倡ｮ? 逋ｻ蝣ｴ繧｢繝九Γ */
@keyframes stickyBackIn {
  0% {
    opacity: 0;
    transform: translate(0, 0.5rem) scale(0.96) rotate(0deg);
  }
  100% {
    opacity: 1;
    transform: translate(0.8rem, 0.9rem) scale(1) rotate(1.5deg);
  }
}
/* 謇句燕縺ｮ莉倡ｮ区悽菴? */
.sticky-note {
  position: relative;
  display: inline-block;
  background: #fff9c9;
  padding: 3.4rem 5.2rem;
  border-radius: 0.4rem;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.5;
  color: var(--text);
  z-index: 1;
  transform: rotate(-2.5deg);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
  margin-bottom: 0;
  opacity: 0;
  animation:
    stickyNoteIn 0.7s ease-out forwards, stickyNoteFloat 4s ease-in-out 0.7s infinite;
}
/* 荳玖ｾｺ繧ｮ繧ｶ繧ｮ繧ｶ??lip-path 縺御ｽｿ縺医ｋ繝悶Λ繧ｦ繧ｶ縺ｧ縺ｮ縺ｿ驕ｩ逕ｨ?? */
@supports (clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)) {
  .sticky-note {
    clip-path: polygon(0% 0%, 100% 0%, 100% 80%, 90% 84%, 80% 80%, 70% 84%, 60% 80%, 50% 84%, 40% 80%, 30% 84%, 20% 80%, 10% 84%, 0% 80%);
  }
}
/* 縺ｵ繧上▲縺ｨ迴ｾ繧後ｋ繧｢繝九Γ */
@keyframes stickyNoteIn {
  0% {
    opacity: 0;
    transform: translateY(-1rem) rotate(-6deg) scale(0.96);
  }
  100% {
    opacity: 1;
    transform: translateY(0) rotate(-2.5deg) scale(1);
  }
}
/* 縺昴?縺ゅ→縲√ｆ繧峨ｆ繧画昭繧後ｋ繧｢繝九Γ */
@keyframes stickyNoteFloat {
  0% {
    transform: translateY(0) rotate(-2.5deg);
  }
  25% {
    transform: translateY(-0.4rem) rotate(-1.8deg);
  }
  50% {
    transform: translateY(0.2rem) rotate(-2.8deg);
  }
  75% {
    transform: translateY(-0.2rem) rotate(-2deg);
  }
  100% {
    transform: translateY(0) rotate(-2.5deg);
  }
}
/* 繝斐Φ?夐ｭ?句ｽｱ */
.sticky-note::before {
  /* 繝斐Φ縺ｮ鬆ｭ */
  content: "";
  position: absolute;
  top: -0.9rem;
  left: 50%;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  background: #ff7f7f; /* 襍､縺｣縺ｽ縺?ヴ繝ｳ */
  border: 2px solid #f7d2d2;
  transform: translateX(-50%);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
  z-index: 3;
}
.sticky-note::after {
  /* 繝斐Φ縺ｮ蠖ｱ?亥｣√∈縺ｮ蠖ｱ縺ｮ繧医≧縺ｪ繝九Η繧｢繝ｳ繧ｹ?? */
  content: "";
  position: absolute;
  top: -0.3rem;
  left: 50%;
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 0, 0, 0.18) 0%, transparent 60%);
  transform: translateX(-50%);
  filter: blur(1px);
  opacity: 0.7;
  z-index: 0;
}
/* ===== About蜀??繝溘ル莉倡ｮ玖ｦ句?縺暦ｼ域隼濶ｯ迚茨ｼ?===== */
.about-text .label-sticky {
  position: relative;
  display: inline-block;
  background: #fff9c9; /* 莉倡ｮ玖牡?医ｄ縺輔＠縺?ｻ?牡?? */
  padding: 0.8rem 1.8rem; /* 笘? 菴咏區繧貞｢励ｄ縺励※隱ｭ縺ｿ繧?☆縺? */
  border-radius: 0.5rem;
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1.6;
  color: var(--text);
  margin-bottom: 1.6rem;
  transform: rotate(-1.8deg); /* 蟆代＠蛯ｾ縺代※莉倡ｮ区─UP */
  /* 笘? 蠖ｱ繧呈?遒ｺ縺ｫ縺励※遶倶ｽ捺─繧貞?縺? */
  box-shadow:
    0 3px 6px rgba(0, 0, 0, 0.15), 0 6px 18px rgba(0, 0, 0, 0.10);
}
/* 荳玖ｾｺ繧ｮ繧ｶ繧ｮ繧ｶ??lip-Path蟇ｾ蠢懊ヶ繝ｩ繧ｦ繧ｶ逕ｨ?? */
@supports (clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)) {
  .about-text .label-sticky {
    clip-path: polygon(0% 0%, 100% 0%, 100% 82%, 92% 86%, 84% 82%, 76% 86%, 68% 82%, 60% 86%, 52% 82%, 44% 86%, 36% 82%, 28% 86%, 20% 82%, 12% 86%, 0% 82%);
  }
}
/* SP隱ｿ謨ｴ?亥ｰ代＠謗ｧ縺医ａ?? */
@media (max-width: 640px) {
  .about-text .label-sticky {
    font-size: 1.55rem;
    padding: 0.6rem 1.5rem;
    transform: rotate(-1.5deg);
  }
}
/* ===== About蜀??繝溘ル莉倡ｮ玖ｦ句?縺暦ｼ亥?驛ｨ逶帙ｊ??===== */
.about-text .label-sticky {
  --tilt: -1.8deg; /* 蝓ｺ譛ｬ縺ｮ蛯ｾ縺搾ｼ医き繝ｼ繝峨＃縺ｨ縺ｫ蠕後〒荳頑嶌縺搾ｼ? */
  position: relative;
  display: inline-block;
  background: #fff9c9; /* 莉倡ｮ玖牡 */
  padding: 2.8rem 4.8rem; /* 菴咏區螟壹ａ縺ｧ繧?▲縺溘ｊ */
  border-radius: 0.5rem;
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1.6;
  color: var(--text);
  margin-bottom: 1.6rem;
  transform: translateY(0) rotate(var(--tilt));
  transform-origin: center center;
  /* 遶倶ｽ捺─縺ｮ縺ゅｋ蠖ｱ?句ｰ代＠濶ｲ蜻ｳ縺ｮ縺ゅｋ蠖ｱ */
  box-shadow:
    0 3px 6px rgba(0, 0, 0, 0.16), 0 8px 20px rgba(169, 142, 95, 0.22);
  z-index: 0;
  /* 縺ｵ繧上▲縺ｨ謠ｺ繧後ｋ繧｢繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ */
  animation: labelStickyFloat 4s ease-in-out infinite;
}
/* 螂･縺ｫ繧ゅ≧1譫壹?莉倡ｮ九▲縺ｽ縺?Ξ繧､繝､繝ｼ */
.about-text .label-sticky::before {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  background: #fff4b8; /* 蟆代＠豼?＞莉倡ｮ玖牡 */
  border-radius: 0.6rem;
  transform: translate(0.4rem, 0.45rem) rotate(1.4deg);
  z-index: -1;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}
/* 蟆上＆縺ｪ繝斐Φ?磯ｭ縺ｮ縺ｿ繧ｷ繝ｳ繝励Ν縺ｫ?? */
.about-text .label-sticky::after {
  content: "";
  position: absolute;
  top: -0.7rem;
  left: 1.3rem;
  width: 0.9rem;
  height: 0.9rem;
  border-radius: 50%;
  background: #ff8686; /* 襍､繝斐Φ */
  border: 2px solid #ffd0d0;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
}
/* 荳玖ｾｺ繧ｮ繧ｶ繧ｮ繧ｶ?亥ｯｾ蠢懊ヶ繝ｩ繧ｦ繧ｶ縺ｮ縺ｿ?? */
@supports (clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)) {
  .about-text .label-sticky {
    clip-path: polygon(0% 0%, 100% 0%, 100% 82%, 92% 86%, 84% 82%, 76% 86%, 68% 82%, 60% 86%, 52% 82%, 44% 86%, 36% 82%, 28% 86%, 20% 82%, 12% 86%, 0% 82%);
  }
}
/* 繧?ｉ繧?ｉ謠ｺ繧後ｋ繧｢繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ */
@keyframes labelStickyFloat {
  0% {
    transform: translateY(0) rotate(var(--tilt));
  }
  25% {
    transform: translateY(-0.3rem) rotate(calc(var(--tilt) + 0.2deg));
  }
  50% {
    transform: translateY(0.2rem) rotate(calc(var(--tilt) - 0.2deg));
  }
  75% {
    transform: translateY(-0.15rem) rotate(calc(var(--tilt) + 0.1deg));
  }
  100% {
    transform: translateY(0) rotate(var(--tilt));
  }
}
/* 蜷?き繝ｼ繝峨＃縺ｨ縺ｫ蛯ｾ縺阪ｒ蟆代＠螟峨∴繧具ｼ医Λ繝ｳ繝?繝諢滂ｼ? */
.about-card:nth-child(1) .label-sticky {
  --tilt: -2deg;
}
.about-card:nth-child(2) .label-sticky {
  --tilt: 1.2deg;
}
.about-card:nth-child(3) .label-sticky {
  --tilt: -1deg;
}
/* SP隱ｿ謨ｴ */
@media (max-width: 640px) {
  .about-text .label-sticky {
    font-size: 2.55rem;
    padding: 2.6rem 3.5rem;
  }
}
/* =========================================================
About 繧ｻ繧ｯ繧ｷ繝ｧ繝ｳ?夊レ譎ｯ縺願干繝?さ繝ｬ繝ｼ繧ｷ繝ｧ繝ｳ?亥ｮ悟?迚茨ｼ?
繧ｹ繧ｯ繝ｭ繝ｼ繝ｫ縺ｧ縺ｵ繧上▲縺ｨ逋ｻ蝣ｴ 竊? 縺上ｋ繧翫ｓ 竊? 縺励?繧峨￥髱呎ｭ｢ 竊? 縺ｾ縺溘￥繧九ｊ繧凪?ｦ
========================================================= */
/* About 繧ｻ繧ｯ繧ｷ繝ｧ繝ｳ閾ｪ菴薙ｒ繝?さ繝ｬ繝ｼ繧ｷ繝ｧ繝ｳ蜿ｯ閭ｽ縺ｫ縺吶ｋ */
.section-about {
  position: relative;
  overflow: visible; /* 縺願干縺悟ｰ代＠縺ｯ縺ｿ蜃ｺ縺励※繧０K */
}
/* 縺願干繝ｬ繧､繝､繝ｼ?医そ繧ｯ繧ｷ繝ｧ繝ｳ蜈ｨ菴薙ｒ繧ｫ繝舌??? */
.about-deco {
  position: absolute;
  inset: 0;
  pointer-events: none; /* 繧ｯ繝ｪ繝?け縺ｪ縺ｩ縺ｫ蟷ｲ貂峨＠縺ｪ縺? */
  z-index: 0; /* 繧ｳ繝ｳ繝?Φ繝?ｈ繧願レ髱｢ */
}
/* About譛ｬ譁??蜑埼擇縺ｫ */
.section-about .inner, .section-about .about-grid, .section-about .about-card {
  position: relative;
  z-index: 1;
}
/* 縺願干1縺､1縺､縺ｮ繝吶?繧ｹ繧ｹ繧ｿ繧､繝ｫ */
.about-flower {
  position: absolute;
  left: var(--fx, 50%);
  top: var(--fy, 50%);
  transform: translate(-50%, -50%) scale(0.8);
  width: clamp(40px, 6vw, 80px);
  aspect-ratio: 1 / 1;
  opacity: 0; /* 蛻晄悄縺ｯ髱櫁｡ｨ遉ｺ */
  filter: blur(8px); /* 縺｡繧?▲縺ｨ繝懊こ縺溽憾諷九°繧峨せ繧ｿ繝ｼ繝? */
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
/* 闃ｱ縺ｮ繝舌Μ繧ｨ繝ｼ繧ｷ繝ｧ繝ｳ?医ヱ繧ｹ縺ｯ迺ｰ蠅?↓蜷医ｏ縺帙※縺上□縺輔＞?? */
.about-flower.flower-1 {
  background-image: url("../img/flower-01.png");
}
.about-flower.flower-2 {
  background-image: url("../img/flower-02.png");
}
.about-flower.flower-3 {
  background-image: url("../img/flower-03.png");
}
.about-flower.flower-4 {
  background-image: url("../img/flower-04.png");
}
.about-flower.flower-5 {
  background-image: url("../img/flower-05.png");
}
/* ---------------------------------
繧ｹ繧ｯ繝ｭ繝ｼ繝ｫ繧､繝ｳ縺励◆繧会ｼ壹?繧上▲縺ｨ逋ｻ蝣ｴ 竊? 縺上ｋ繧翫ｓ繧堤ｹｰ繧願ｿ斐☆
窶ｻ .section-about 縺ｫ JS 縺ｧ .is-inview 縺御ｻ倥￥蜑肴署
--------------------------------- */
.section-about.is-inview .about-flower {
  /* 闃ｱ縺斐→縺ｫ --intro-delay / --loop-delay 縺ｧ繧ｿ繧､繝溘Φ繧ｰ繧偵★繧峨☆ */
  animation:
    flowerIntro 1.0s ease-out forwards var(--intro-delay, 0s), flowerLoop 14s ease-in-out infinite var(--loop-delay, 2s);
}
/* 譛?蛻昴?縺ｵ繧上▲縺ｨ逋ｻ蝣ｴ?玖ｻｽ縺丞屓霆｢ */
@keyframes flowerIntro {
  0% {
    opacity: 0;
    transform: translate(-50%, -45%) scale(0.5) rotate(-15deg);
    filter: blur(10px);
  }
  60% {
    opacity: 1;
    transform: translate(-50%, -52%) scale(1.05) rotate(10deg);
    filter: blur(2px);
  }
  100% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1) rotate(0deg);
    filter: blur(0);
  }
}
/* 縺昴?蠕後?縲後＠縺ｰ繧峨￥髱呎ｭ｢ 竊? 縺上ｋ繧翫ｓ 竊? 髱呎ｭ｢縲阪ｒ郢ｰ繧願ｿ斐☆繝ｫ繝ｼ繝? */
@keyframes flowerLoop {
  /* 0縲?20%?壹⊇縺ｼ髱呎ｭ｢ */
  0%, 15% {
    transform: translate(-50%, -50%) scale(1) rotate(0deg);
  }
  /* 20縲?35%?壹￥繧九ｊ繧灘屓霆｢?亥ｰ代＠縺縺代?繧上▲縺ｨ?? */
  25% {
    transform: translate(-50%, -51%) scale(1.02) rotate(180deg);
  }
  35% {
    transform: translate(-50%, -50%) scale(1) rotate(360deg);
  }
  /* 40縲?100%?壹∪縺滄撕豁｢?域ｬ｡縺ｮ繝ｫ繝ｼ繝励∪縺ｧ髢薙ｒ縺翫￥?? */
  40%, 100% {
    transform: translate(-50%, -50%) scale(1) rotate(0deg);
  }
}
/* ---------------------------------
譌ｧJS縺ｨ縺ｮ莠呈鋤逕ｨ??.is-spin/.spin-cw 遲峨′莉倥＞縺ｦ繧ょ｣翫ｌ縺ｪ縺?ｈ縺?↓??
窶ｻ JS縺ｧ .is-spin 繧? .spin-cw / .spin-ccw 繧剃ｻ倥¢縺ｦ縺?※繧ゅ??
縺薙％縺ｧ縺ｯ迚ｹ縺ｫ繧｢繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ繧剃ｸ頑嶌縺阪＠縺ｪ縺???
--------------------------------- */
.about-flower.is-spin, .about-flower.spin-cw, .about-flower.spin-ccw, .about-flower.spin-cw.is-spin, .about-flower.spin-ccw.is-spin {
  /* animation 繧呈嶌縺九↑縺?％縺ｨ縺ｧ縲∽ｸ翫? .section-about.is-inview .about-flower 繧貞━蜈医＆縺帙ｋ */
}
/* PC繝?ヵ繧ｩ繝ｫ繝井ｽ咲ｽｮ?医?懊ち繝悶Ξ繝?ヨ?? */
.about-flower.flower-1 {
  --fx: 21%;
  --fy: 12%;
  --intro-delay: 0s;
  --loop-delay: 2s;
}
.about-flower.flower-2 {
  --fx: 78%;
  --fy: 18%;
  --intro-delay: 0.25s;
  --loop-delay: 5s;
}
.about-flower.flower-3 {
  --fx: 10%;
  --fy: 55%;
  --intro-delay: 0.5s;
  --loop-delay: 8s;
}
.about-flower.flower-4 {
  --fx: 85%;
  --fy: 65%;
  --intro-delay: 0.75s;
  --loop-delay: 11s;
}
.about-flower.flower-5 {
  --fx: 14%;
  --fy: 95%;
  --intro-delay: 1s;
  --loop-delay: 14s;
}
/* 繧ｹ繝槭?蜷代¢縺ｫ菴咲ｽｮ縺ｨ繧ｵ繧､繧ｺ繧貞ｾｮ隱ｿ謨ｴ */
@media (max-width: 640px) {
  .about-flower {
    width: clamp(32px, 10vw, 60px);
  }
  .about-flower.flower-1 {
    --fx: 12%;
    --fy: 8%;
  }
  .about-flower.flower-2 {
    --fx: 88%;
    --fy: 10%;
  }
  .about-flower.flower-3 {
    --fx: 10%;
    --fy: 55%;
  }
  .about-flower.flower-4 {
    --fx: 90%;
    --fy: 58%;
  }
  .about-flower.flower-5 {
    --fx: 80%;
    --fy: 83%;
  }
}
/* 繧ｻ繧ｯ繧ｷ繝ｧ繝ｳ蜈ｨ菴薙ｒ縲檎ｴ吶?阪?荳翫↓縺ｮ縺帙ｋ逕ｨ */
.paper-section {
  position: relative;
  padding: 4rem var(--side);
}
.paper-section-inner {
  position: relative;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 3rem 3rem;
  background: #fffdf7; /* 縺ｻ繧薙?繧翫け繝ｪ繝ｼ繝 */
  border-radius: 1.6rem;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.06);
  overflow: hidden;
}
/* 邏吶?雉ｪ諢滂ｼ医ヮ繧､繧ｺ縺｣縺ｽ縺?げ繝ｩ繝?ｼ? */
.paper-section-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 0 0, rgba(255, 255, 255, 0.9), transparent 55%), radial-gradient(circle at 100% 0, rgba(255, 255, 255, 0.75), transparent 55%), linear-gradient(135deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0));
  opacity: 0.9;
  mix-blend-mode: multiply;
}
/* 縺｡繧?▲縺ｨ縺縺鯛?懃ｴ吶?豁ｪ縺ｿ窶晄─ */
.paper-section-inner::after {
  content: "";
  position: absolute;
  inset: -20%;
  background-image: radial-gradient(circle at 50% 0%, rgba(0, 0, 0, 0.04), transparent 60%);
  opacity: 0.35;
  mix-blend-mode: soft-light;
}
/* NEWS繧ｫ繝ｼ繝峨′蛻?ｌ縺ｪ縺?ｈ縺?↓縲゜V繧ｳ繝ｳ繝?リ縺ｧ繧ｯ繝ｪ繝?ヴ繝ｳ繧ｰ縺励↑縺? */
.hero-visual {
  border-radius: 0;
  overflow: visible;
}
/* ===== Hero 隱ｿ謨ｴ??2025-11-22??===================== */
/* PC 蝓ｺ譛ｬ?夐ｫ倥＆繧偵＠縺｣縺九ｊ遒ｺ菫昴＠縺ｦ KV 繧貞､ｧ縺阪￥隕九○繧? */
.hero {
  width: 100%;
  padding: 5rem var(--side);
  min-height: 85vh; /* 笘? 縺薙％縺ｧ縲?85vh縲? */
  display: flex; /* 荳ｭ霄ｫ??.hero-inner?峨ｒ邵ｦ譁ｹ蜷代そ繝ｳ繧ｿ繝ｼ蟇?○ */
  align-items: center;
}
/* 繝偵?繝ｭ繝ｼ蜈ｨ菴薙?讓ｪ蟷?ｒ蟆代＠縺縺大ｺ?£繧具ｼ?V繧貞､ｧ縺阪￥?? */
.hero-inner {
  width: min(1080px, 100% - 3rem); /* 960px 竊? 1080px 逶ｸ蠖薙↓諡｡蠑ｵ */
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4rem;
}
/* SP 縺ｮ縺ｨ縺搾ｼ夂ｸｦ髟ｷ縺ｫ縺ｪ繧翫☆縺弱↑縺?ｨ句ｺｦ縺ｫ鬮倥＆繧堤｢ｺ菫? */
@media (max-width: 640px) {
  .hero {
    padding: 3rem var(--side) 4rem;
    min-height: 70vh; /* 笘? SP 逕ｨ縺ｮ窶懊⊇縺ｩ繧医＞鬮倥＆窶? */
  }
}
/* ===== Hero 繝ｭ繧ｴ繧ｿ繧､繝苓ｪｿ謨ｴ ===================== */
/* 蜈ｨ菴薙?縺ｾ縺ｨ縺ｾ繧? */
.hero-logo-text {
  margin-top: 1.6rem;
  text-align: center;
  line-height: 1.6;
}
/* 繧ｵ繝悶さ繝斐?縲後＞縺ｬ縺ｨ縺ｭ縺薙?繧ｯ繝ｪ繝九ャ繧ｯ縲? */
.hero-logo-sub {
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  color: #555;
  display: inline-block;
  margin-bottom: 0.3rem;
}
/* 繝｡繧､繝ｳ繝ｭ繧ｴ縲後％縺ｨ縺ｶ縺阪?搾ｼ壼､ｪ蟄? + 蟆代＠螟ｧ縺阪￥ + 蟄鈴俣 */
.hero-logo-main {
  font-size: clamp(2.8rem, 4vw, 4rem);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-indent: 0.18em;
  color: var(--main);
}
/* SP 縺ｮ縺ｨ縺阪?蟆代＠縺縺第而縺医ａ縺ｫ */
@media (max-width: 640px) {
  .hero-logo-sub {
    font-size: 1.2rem;
  }
  .hero-logo-main {
    font-size: 2.4rem;
    padding: 0.35rem 1.4rem;
  }
}
/* ============================
KV??C縺ｧ繧ょ､ｧ縺阪￥隕九∴繧九ｈ縺?↓??
============================ */
/* Hero 蜈ｨ菴薙?鬮倥＆繧偵＠縺｣縺九ｊ遒ｺ菫? */
.hero {
  min-height: 85vh; /* 笘? 縺薙％縺ｧ縲悟､ｧ縺阪￥縲? */
  display: flex;
  align-items: center;
  padding: 4rem 0;
}
/* 讓ｪ蟷?ｒ蟆代＠蠎?£繧具ｼ育ｪｮ螻医＆繧定ｧ｣豸茨ｼ? */
.hero-inner {
  width: min(1200px, 100% - 4rem);
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: 5rem;
}
/* KV 縺ｮ 窶懷?繧檎黄窶? 繧貞､ｧ縺阪￥隕九○繧? */
.hero-visual {
  flex: 1;
  display: flex;
  align-items: center;
}
/* 笘? SVG 繧帝ｫ倥＆100%縺ｧ莨ｸ縺ｳ繧九ｈ縺?↓ */
.kv-blob-svg {
  width: 100%;
  height: auto;
}
/* ============================
SP迚茨ｼ育ｸｦ髟ｷ縺ｫ縺ｪ繧翫☆縺弱↑縺?ｈ縺?ｪｿ謨ｴ??
============================ */
@media (max-width: 640px) {
  .hero {
    min-height: 72vh; /* 笘? SP 縺ｧ驕ｩ豁｣繝懊Μ繝･繝ｼ繝 */
    padding: 2rem 0 3rem;
  }
  .hero-inner {
    flex-direction: column;
    text-align: center;
    gap: 2rem;
  }
  .kv-blob-wrapper {
    max-width: 320px; /* SP 縺ｯ蠢?ｦ∽ｻ･荳翫↓螟ｧ縺阪￥縺励↑縺? */
    margin-inline: auto;
  }
}
/* ========== Hero & KV?医％縺ｨ縺ｶ縺搾ｼ? - 繝輔Ν菫ｮ豁｣迚? ========== */
.hero {
  width: 100%;
  padding: 3rem 0 5rem;
  min-height: 60vh; /* 笘? PC?哮V繧ｻ繧ｯ繧ｷ繝ｧ繝ｳ蜈ｨ菴薙?鬮倥＆ */
  display: flex;
  align-items: center;
}
.hero-inner {
  /* 笘? Hero 縺縺大ｰ代＠繝ｯ繧､繝峨↓縺励※ KV 繧貞､ｧ縺阪￥ */
  width: min(1100px, 100% - 3rem); /* 蜈?: min(var(--inner-width), 100% - 3rem) */
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between; /* 蟾ｦ繝ｭ繧ｴ / 蜿ｳKV 繧貞ｷｦ蜿ｳ縺ｫ驟咲ｽｮ */
  gap: 4rem;
}
/* 蟾ｦ繝ｭ繧ｴ */
.hero-logo {
  flex: 0 0 auto;
}
.hero-logo img {
  display: block;
  max-width: 220px;
  height: auto;
}
.hero-logo-text {
  margin-top: 1.6rem;
  line-height: 1.6;
}
/* 繧ｵ繝悶さ繝斐?縲後＞縺ｬ縺ｨ縺ｭ縺薙?繧ｯ繝ｪ繝九ャ繧ｯ縲? */
.hero-logo-sub {
  font-size: 1.4rem;
  letter-spacing: 0.12em;
  color: #555;
  display: inline-block;
  margin-bottom: 0.3rem;
}
/* 繝｡繧､繝ｳ繝ｭ繧ｴ縲後％縺ｨ縺ｶ縺阪?? */
.hero-logo-main {
  font-size: clamp(2.8rem, 4vw, 4rem);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-indent: 0.18em;
  color: var(--main);
}
/* 蜿ｳKV */
.hero-visual {
  position: relative;
  flex: 1 1 auto;
  /* NEWS 繝斐Ν縺後?縺ｿ蜃ｺ縺帙ｋ繧医≧縺ｫ縲？ero 蜈ｨ菴薙〒縺ｯ繧ｯ繝ｪ繝?ヴ繝ｳ繧ｰ縺励↑縺? */
  border-radius: 0;
  overflow: visible;
}
/* KV譛ｬ菴薙?繧ｵ繧､繧ｺ隱ｿ謨ｴ?遺?縺薙％縺御ｸ?逡ｪ蜉ｹ縺擾ｼ? */
.kv-blob-wrapper {
  position: relative;
  width: 100%;
  max-width: 1100px; /* 笘? PC縺ｧ縺励▲縺九ｊ螟ｧ縺阪￥隕九○繧具ｼ?1100px縺ｫ諡｡螟ｧ?? */
  margin-left: auto;
}
.kv-blob-svg {
  display: block;
  width: 100%;
  height: auto;
}
/* Safari fallback 逕ｨ縺ｮ逕ｻ蜒上さ繝ｳ繝?リ縺ｯ繝?ヵ繧ｩ繝ｫ繝磯撼陦ｨ遉ｺ */
.kv-blob-css {
  display: none;
}
/* ==== Safari逕ｨ clip-path 繝槭せ繧ｯ ==== */
.is-safari .kv-blob-svg {
  display: none;
}
.is-safari .kv-blob-css {
  display: block;
  overflow: hidden;
  clip-path: polygon(10% 30%, 30% 10%, 60% 15%, 80% 35%, 90% 60%, 70% 85%, 40% 90%, 15% 70%);
  animation: kvBlobMove 10s ease-in-out infinite alternate;
}
.is-safari .kv-blob-css img {
  width: 100%;
  display: block;
}
@keyframes kvBlobMove {
  0% {
    clip-path: polygon(10% 30%, 30% 10%, 60% 15%, 80% 35%, 90% 60%, 70% 85%, 40% 90%, 15% 70%);
  }
  50% {
    clip-path: polygon(15% 25%, 35% 15%, 65% 10%, 85% 30%, 95% 55%, 75% 80%, 45% 88%, 12% 72%);
  }
  100% {
    clip-path: polygon(8% 28%, 28% 12%, 58% 18%, 78% 37%, 92% 62%, 72% 86%, 38% 92%, 13% 68%);
  }
}
/* ==== SP繝ｬ繧､繧｢繧ｦ繝? ==== */
@media (max-width: 640px) {
  .hero {
    min-height: 60vh; /* 笘? SP縺ｧ縺ｯ蟆代＠謗ｧ縺医ａ縺ｫ */
    padding: 2.4rem 0 3.2rem;
  }
  .hero-inner {
    width: min(100%, 100% - 3rem);
    flex-direction: column;
    text-align: center;
    gap: 2.4rem;
  }
  .hero-logo img {
    margin-inline: auto;
  }
  .hero-logo-sub {
    font-size: 1.2rem;
  }
  .hero-logo-main {
    font-size: 2.6rem;
  }
  .kv-blob-wrapper {
    max-width: 360px; /* 笘? SP縺ｯ縺ｻ縺ｩ繧医＞螟ｧ縺阪＆縺ｫ */
    margin-inline: auto;
  }
}
/* ===== Footer logo (Hero 縺ｨ蜷医ｏ縺帙ｋ) ===== */
.footer-logo-block {
  text-align: center;
}
.footer-logo-link img {
  width: 200px; /* Hero 縺ｨ縺ｻ縺ｼ蜷後§隕九∴譁ｹ */
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}
.footer-logo-text {
  margin-top: 1.2rem;
  line-height: 1.6;
}
.footer-logo-sub {
  font-size: 1.4rem; /* Hero 縺ｨ蜷後§ */
  letter-spacing: 0.12em;
  color: #555; /* 繝輔ャ繧ｿ繝ｼ閭梧勹縺ｫ鬥ｴ譟薙?譏弱ｋ縺?牡 */
  display: inline-block;
  margin-bottom: 0.3rem;
}
.footer-logo-main {
  font-size: 2.8rem; /* Hero 縺ｨ蜷後§ */
  font-weight: 700;
  letter-spacing: 0.18em;
  text-indent: 0.18em;
  color: var(--main); /* 繝｡繧､繝ｳ縺ｯ逋ｽ縺ｧ蠑ｷ隱ｿ */
}
/* SP隱ｿ謨ｴ */
@media (max-width: 640px) {
  .footer-logo-link img {
    width: 160px;
    margin: 8rem auto 0;
  }
  .footer-logo-sub {
    font-size: 1.2rem;
  }
  .footer-logo-main {
    font-size: 2.4rem;
  }
}
/* =========================
繧ｻ繧ｯ繧ｷ繝ｧ繝ｳ閭梧勹逕ｨ繧ｫ繝ｩ繝ｼ
========================= */ :root {
  --bg-concept: #FAFFF0;
  --bg-about: #FAFFF0; /* Concept 縺ｨ About 縺ｯ蜷瑚牡 */
  --bg-guide: #F4F7FF;
  --bg-director: #FFF0F5;
  --bg-first: #F6FFFA;
  --bg-repeat: #F4F9FF;
  --bg-parking: #FFF9E8;
  --bg-faq: #F7F5FF;
  --bg-access: #FFFFFF;
  --bg-footer: #FAFAFA;
}
/* 閭梧勹繧貞ｮ滄圀縺ｫ蜿肴丐縺輔○繧九け繝ｩ繧ｹ */
.bg-concept {
  background: var(--bg-concept);
}
.bg-about {
  background: var(--bg-about);
}
.bg-guide {
  background: var(--bg-guide);
}
.bg-director {
  background: var(--bg-director);
}
.bg-first {
  background: var(--bg-first);
}
.bg-repeat {
  background: var(--bg-repeat);
}
.bg-parking {
  background: var(--bg-parking);
}
.bg-faq {
  background: var(--bg-faq);
}
.bg-access {
  background: var(--bg-access);
}
.bg-footer {
  background: var(--bg-footer);
}
/* =========================
豕｢邱壼?騾?
========================= */
.section-divider {
  line-height: 0;
}
.section-divider svg {
  width: 100%;
  height: 80px;
  display: block;
}
/* =========================
2濶ｲ豕｢邱夲ｼ井ｸ翫→荳九〒濶ｲ繧貞､峨∴繧九ち繧､繝暦ｼ?
========================= */
/* Hero 竊? Concept??ero縺ｯ body 縺ｮ --bg 繧貞茜逕ｨ?? */
.wave-hero-concept .wave-top {
  fill: var(--bg); /* 荳奇ｼ唏ero (body閭梧勹) */
}
.wave-hero-concept .wave-bottom {
  fill: var(--bg-concept); /* 荳具ｼ咾oncept */
}
/* About 竊? Guide */
.wave-about-guide .wave-top {
  fill: var(--bg-about);
}
.wave-about-guide .wave-bottom {
  fill: var(--bg-guide);
}
/* Guide 竊? Director */
.wave-guide-director .wave-top {
  fill: var(--bg-guide);
}
.wave-guide-director .wave-bottom {
  fill: var(--bg-director);
}
/* Director 竊? First */
.wave-director-first .wave-top {
  fill: var(--bg-director);
}
.wave-director-first .wave-bottom {
  fill: var(--bg-first);
}
/* First 竊? Repeat */
.wave-first-repeat .wave-top {
  fill: var(--bg-first);
}
.wave-first-repeat .wave-bottom {
  fill: var(--bg-repeat);
}
/* Repeat 竊? Parking */
.wave-repeat-parking .wave-top {
  fill: var(--bg-repeat);
}
.wave-repeat-parking .wave-bottom {
  fill: var(--bg-parking);
}
/* Parking 竊? FAQ */
.wave-parking-faq .wave-top {
  fill: var(--bg-parking);
}
.wave-parking-faq .wave-bottom {
  fill: var(--bg-faq);
}
/* FAQ 竊? Access */
.wave-faq-access .wave-top {
  fill: var(--bg-faq);
}
.wave-faq-access .wave-bottom {
  fill: var(--bg-access);
}
/* ACCESS 竊? FOOTER?医ヵ繝?ち繝ｼ縺ｯ逋ｽ繝吶ち諠ｳ螳夲ｼ? */
.wave-access-footer .wave-top {
  fill: var(--bg-access); /* 荳奇ｼ哂CCESS 縺ｮ閭梧勹濶ｲ */
}
.wave-access-footer .wave-bottom {
  fill: var(--bg-footer); /* 荳具ｼ壹ヵ繝?ち繝ｼ縺ｮ閭梧勹濶ｲ?育區?? */
}
/* 繧ｫ繝ｼ繝峨ｒ蝓ｺ貅悶↓邨ｶ蟇ｾ驟咲ｽｮ縺ｧ縺阪ｋ繧医≧縺ｫ */
.about-card {
  position: relative;
}
/* 豬ｮ縺九○繧九う繝ｩ繧ｹ繝医?繝吶?繧ｹ */
.about-illust-floating {
  position: absolute;
  z-index: 2; /* 繧ｫ繝ｼ繝峨?荳翫↓荵励○縺溘＞蝣ｴ蜷? */
  pointer-events: none; /* 繧ｯ繝ｪ繝?け謫堺ｽ懊ｒ驍ｪ鬲斐＠縺ｪ縺?ｈ縺?↓ */
}
/* 逕ｻ蜒上?蝓ｺ譛ｬ繧ｵ繧､繧ｺ?医?繝ｼ繧ｹ?? */
.about-illust-floating img {
  display: block;
  width: 100%;
  height: auto;
}
/* 1譫夂岼縺ｮ繧ｫ繝ｼ繝臥畑繧､繝ｩ繧ｹ繝?
竊? 蜿ｳ荳翫↓蟆代＠縺九?縺帙ｋ繧､繝｡繝ｼ繧ｸ */
.about-illust-floating.illust-1 {
  top: 21.5rem;
  left: -2rem;
  width: 120px;
  transform: rotate(-4deg);
}
/* 2譫夂岼縺ｮ繧ｫ繝ｼ繝臥畑繧､繝ｩ繧ｹ繝?
竊? 蟾ｦ荳九↓縺九?縺帙ｋ繧､繝｡繝ｼ繧ｸ */
.about-illust-floating.illust-2 {
  top: -4rem;
  right: -5.5rem;
  width: 177px;
  transform: rotate(3deg);
}
/* 3譫夂岼縺ｮ繧ｫ繝ｼ繝臥畑繧､繝ｩ繧ｹ繝?
竊? 蜿ｳ蛛ｴ荳ｭ螟ｮ縺ゅ◆繧翫↓雋ｼ繧九う繝｡繝ｼ繧ｸ */
.about-illust-floating.illust-3 {
  top: 38rem;
  right: 18rem;
  width: 165px;
  transform: translateY(-50%) rotate(-6deg);
}
@media (max-width: 640px) {
  .about-illust-floating {
    position: static;
    margin: 1.5rem auto 0;
    width: 160px; /* SP縺ｯ蟆代＠螟ｧ縺阪ａ縺ｪ縺ｩ */
    transform: none; /* 蝗櫁ｻ｢繧ゅΜ繧ｻ繝?ヨ */
  }
}
@media (max-width: 640px) {
  .site-nav { display:none; }   /* PCナビ非表示 */
  .hamburger { display:flex; }  /* ハンバーガー表示 */
  /* .mobile-nav には display:block を書かない！！ */
}


/* ===== PC繝倥ャ繝?繝ｼ?壻ｸ九せ繧ｯ繝ｭ繝ｼ繝ｫ縺ｧ髫繧後?∽ｸ翫せ繧ｯ繝ｭ繝ｼ繝ｫ縺ｧ蜀崎｡ｨ遉ｺ ===== */
@media (min-width: 769px) {
  /* 繝倥ャ繝?繝ｼ繧堤判髱｢荳企Κ縺ｫ蝗ｺ螳? */
  .global-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    transform: translateY(0);
  }
  /* 繝倥ャ繝?繝ｼ蛻?□縺第悽譁?ｒ荳九£繧具ｼ医?繝?ム繝ｼ鬮倥＆縺ｫ蜷医ｏ縺帙※隱ｿ謨ｴ縺励※縺上□縺輔＞?? */
  body.has-sticky-header {
    padding-top: 72px; /* 60縲?80px縺舌ｉ縺?〒蠕ｮ隱ｿ謨ｴ */
  }
  /* 髫縺吶→縺阪?迥ｶ諷具ｼ井ｸ翫↓繧ｹ繝ｩ繧､繝会ｼ? */
  .global-header.is-hidden {
    transform: translateY(-100%);
  }
}
#first > div > article > p {
  margin: 0px auto 0px;
}
@media (max-width: 640px) {
  .hero {
    min-height: 70vh;
    padding: 2.4rem 0 3.2rem;
  }
  .hero-inner {
    flex-direction: column;
    text-align: center;
    gap: 2.4rem;
  }
  .hero-logo img {
    margin-inline: auto;
  }
  .hero-logo-sub {
    font-size: 1.8rem;
  }
  .hero-logo-main {
    font-size: 4rem;
  }
  /* 笘? KV縺ｾ繧上ｊ?夂ｸｦ縺ｫ荳ｦ縺ｹ繧? */
  .kv-blob-wrapper {
    max-width: 340px;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.6rem;
    position: relative;
  }
  /* 逕ｻ蜒丞?縺ｯ蜈医↓?井ｸ翫↓?? */
  .kv-blob-svg, .kv-blob-css {
    order: 1;
    width: 120%;
  }
  /* 逶ｴ蜑阪?繝九Η繝ｼ繧ｹ?医せ繝ｩ繧､繝峨い繧ｦ繝井ｸｭ?? */
  .about-illust-floating.illust-1 {
    transform: rotate(14deg);
    width: 120px;
  }
  .about-illust-floating.illust-2 {
    width: 177px;
    transform: rotate(-4deg);
  }
  .about-illust-floating.illust-3 {
    top: auto;
    bottom: auto;
    left: 50%;
    right: auto;
    transform: translateX(-50%) translateY(0) rotate(-2deg);
    width: 160px;
    margin-top: 1.2rem;
  }
}
@media (max-width: 640px) {
  /* SP縺ｧ縺ｯPC繝翫ン繧帝撼陦ｨ遉ｺ縺ｫ縺吶ｋ */
  .global-header .nav-inner, .global-header .site-nav {
    display: none;
  }
  /* 繝倥ャ繝?繝ｼ蟶ｯ縺ｮ閭梧勹縺悟?縺ｪ縺?ｈ縺?↓縺吶ｋ */
  .global-header, .global-header.is-scrolled {
    background: transparent;
    box-shadow: none;
  }
  /* 繝上Φ繝舌?繧ｬ繝ｼ縺縺代′隕九∴繧九ｈ縺?↓縲∽ｽ咏區繧貞ｰ代＠縺縺? */
  .global-header {
    position: fixed; /* 縺昴?縺ｾ縺ｾ蝗ｺ螳壹〒OK縺ｪ繧画ｮ九☆ */
    top: 0;
    left: 0;
    right: 0;
    padding: 0;
    height: auto;
  }
}
/* =============== ハンバーガーアイコン =============== */
.hamburger {
  display: none;             /* PC では非表示、SP だけで表示 */
  width: 32px;
  height: 28px;
  flex-direction: column;
  justify-content: space-between;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  position: absolute;
  right: 2rem;
  top: 1.6rem;
  z-index: 1001;
}

.hamburger span {
  display: block;
  height: 3px;
  width: 100%;
  background: #1e4a90;
  border-radius: 3px;
  transition: 0.3s;
}

/* X 形状 */
.hamburger.active span:nth-child(1) {
  transform: translateY(12px) rotate(45deg);
}
.hamburger.active span:nth-child(2) {
  opacity: 0;
}
.hamburger.active span:nth-child(3) {
  transform: translateY(-12px) rotate(-45deg);
}

/* =============== モバイルナビ =============== */
/* 基本（非表示＆右からスライドするパネル） */
.mobile-nav {
  position: fixed;
  top: 64px;                 /* ヘッダー直下に配置 */
  right: 0;
  width: 78%;
  max-width: 340px;
  padding: 2rem 2rem 2.4rem;
  border-radius: 1.6rem 0 0 1.6rem;
  z-index: 1000;

  background-color: #fffdf5;
  background-image:
    radial-gradient(circle at 0 0, rgba(255, 255, 255, 0.9), transparent 55%),
    radial-gradient(circle at 100% 0, rgba(255, 255, 255, 0.9), transparent 55%),
    linear-gradient(135deg, rgba(248, 240, 210, 0.6), rgba(255, 255, 255, 0.9));
  border: 2px solid #f2e4bf;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);

  /* 初期状態では画面外＆非表示 */
  display: none;
  transform: translateX(105%);
  opacity: 0;
  transition: transform 0.28s ease-out, opacity 0.28s ease-out;
}

/* 開いているとき */
.mobile-nav.is-open {
  display: block;
  transform: translateX(0);
  opacity: 1;
}

/* 吹き出しっぽい三角 */
.mobile-nav::after {
  content: "";
  position: absolute;
  top: -10px;
  right: 32px;
  width: 18px;
  height: 18px;
  background: #fffdf5;
  border-left: 2px solid #f2e4bf;
  border-top: 2px solid #f2e4bf;
  transform: rotate(45deg);
  box-shadow: -3px -3px 6px rgba(0, 0, 0, 0.08);
}

/* メニューの中身 */
.mobile-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.mobile-nav li {
  position: relative;
  padding-left: 2.4rem;
}
.mobile-nav li + li {
  margin-top: 1.2rem;
}

/* 小さなアイコン風マーク */
.mobile-nav li::before {
  content: "汾ｾ";
  position: absolute;
  left: 0;
  top: 0.1rem;
  font-size: 1.6rem;
}
.mobile-nav li:nth-child(even)::before {
  content: "洶ｴ";
}

.mobile-nav a {
  font-size: 1.7rem;
  text-decoration: none;
  color: #333;
  padding: 0.4rem 0;
  display: block;
  border-bottom: 1px dotted #d8cfae;
}
.mobile-nav li:last-child a {
  border-bottom: none;
}
.mobile-nav a:hover {
  color: #1e4a90;
  text-decoration: underline;
}

/* =============== ブレイクポイントごとの挙動 =============== */
@media (max-width: 640px) {
  /* SP では PC ナビを消してハンバーガーを出す */
  .site-nav {
    display: none;
  }
  .hamburger {
    display: flex;
  }

  /* SP のときはヘッダーを固定（今の仕様に合わせて維持） */
  .global-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    padding: 0;
    height: auto;
    background: rgba(251, 251, 232, 0.9);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  }
}

/* PC 側ではモバイルナビを完全に無効にしておいて OK */
@media (min-width: 641px) {
  .mobile-nav {
    display: none !important;
    transform: none;
    opacity: 1;
  }
}


/* =========================================================
Hero NEWS?壹ヴ繝ｫ?九?繧上▲縺ｨ蛻?ｊ譖ｿ縺茨ｼ医す繝ｳ繝励Ν迚茨ｼ?
========================================================= */
/* 蜿ｳKV縺ｯ繝斐Ν縺後?縺ｿ蜃ｺ縺帙ｋ繧医≧縺ｫ */
.hero-visual {
  position: relative;
  flex: 1 1 auto;
  overflow: visible;
}
/* NEWS繝斐Ν譛ｬ菴? */
.hero-news {
  position: absolute;
  left: 50%;
  bottom: -1.6rem;
  transform: translateX(-50%);
  z-index: 3;
  background: rgba(255, 255, 255, 0.96);
  padding: 1.1rem 1.8rem;
  border-radius: 999px;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
  max-width: min(480px, 90%);
  display: flex;
  align-items: center;
  text-align: left;
  font-size: 1.3rem;
}
/* 縲君EWS縲阪Λ繝吶Ν */
.hero-news-label {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  margin-right: 1.2rem;
  white-space: nowrap;
}
/* 譛ｬ譁?ヶ繝ｭ繝?け??1莉ｶ縺縺題｡ｨ遉ｺ縺輔ｌ繧狗ｮｱ?? */
.hero-news-body {
  margin: 0;
  min-height: 3.8rem; /* 繝九Η繝ｼ繧ｹ1陦鯉ｼ勤ｱ縺上ｉ縺??ょｿ?ｦ√↓蠢懊§縺ｦ隱ｿ謨ｴ */
  display: block;
}
/* 蛻?ｊ譖ｿ縺域凾縺ｮ繧｢繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ */
.hero-news-body.is-enter {
  animation: heroNewsEnter .45s ease;
}
@keyframes heroNewsEnter {
  from {
    opacity: 0;
    transform: translateY(30%);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* 譌･莉倥?譛ｬ譁??繧ｹ繧ｿ繧､繝ｫ??ero蜀?□縺代↓髯仙ｮ夲ｼ? */
.hero-news-body .news-date {
  margin: 0 0 0.2rem;
  font-weight: 700;
  font-size: 1.2rem;
  color: #666;
}
.hero-news-body .news-text {
  margin: 0;
  line-height: 1.6;
  font-size: 1.4rem;
  color: var(--text);
}
/* ===== SP 隱ｿ謨ｴ ===== */
@media (max-width: 640px) {
  .hero-news {
    font-size: 1.2rem;
  }
  .hero-news-label {
    font-size: 1.1rem;
    margin-right: 1rem;
  }
  .hero-news-body .news-date {
    font-size: 1.1rem;
    bottom: -9.8rem;
  }
  .hero-news-body .news-text {
    font-size: 1.3rem;
  }
}
/* SP譎ゑｼ壹ヴ繝ｫ繧呈ｨｪ髟ｷ縺ｫ縺吶ｋ縺溘ａ縺ｮ蠑ｷ蛻ｶ隱ｿ謨ｴ */
@media (max-width: 640px) {
  .hero-news {
    bottom: -10rem; /* 菴咲ｽｮ縺ｯ縺雁･ｽ縺ｿ縺ｧ隱ｿ謨ｴ */
    padding: 0.8rem 2.0rem; /* 蟾ｦ蜿ｳ繧貞ｺ?£繧具ｼ医％縺馴崎ｦ?ｼ? */
    max-width: 95%; /* SP蟷?＞縺｣縺ｱ縺?↓霑代▼縺代ｋ */
    width: auto; /* 閾ｪ蜍募ｹ?↓縺吶ｋ */
    border-radius: 9999px; /* 螳悟?縺ｪ pill 蠖｢迥ｶ */
  }
  .hero-news-body {
    max-width: 100%;
    white-space: normal; /* 繝?く繧ｹ繝域釜繧願ｿ斐＠險ｱ蜿ｯ */
  }
  .hero-news {
    min-width: 340px; /* 譛?菴取ｨｪ蟷?ｒ蠑ｷ蛻ｶ */
  }
}
.kv-img {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.2s ease;
}
.kv-img.is-active {
  opacity: 1;
}
/* KV?喘lob繝槭せ繧ｯ蜀??逕ｻ蜒上せ繝ｩ繧､繝会ｼ規en Burns??ransition迚茨ｼ? */
.kv-blob-svg .kv-slide {
  opacity: 0;
  transform: scale(1.02); /* 縺ｻ縺ｼ遲牙?阪↓霑代＞迥ｶ諷九°繧? */
  transform-origin: center center; /* 荳ｭ蠢?°繧峨ぜ繝ｼ繝 */
  transition:
    opacity 1.4s ease, /* 繝輔ぉ繝ｼ繝画凾髢? */ transform 6s ease-in-out; /* 繧ｺ繝ｼ繝譎る俣??S縺ｮINTERVAL縺ｨ謠?∴繧具ｼ? */
}
/* 陦ｨ遉ｺ荳ｭ縺ｮ1譫壹□縺代?√ヵ繧ｧ繝ｼ繝会ｼ九§繧上▲縺ｨ繧ｺ繝ｼ繝繧､繝ｳ */
.kv-blob-svg .kv-slide.is-active {
  opacity: 1;
  transform: scale(1.10); /* 譛?邨ら噪縺ｪ諡｡螟ｧ蛟咲紫 */
}
/* 蜍輔″縺瑚協謇九↑迺ｰ蠅?髄縺托ｼ壹ぜ繝ｼ繝繧丹FF */
@media (prefers-reduced-motion: reduce) {
  .kv-blob-svg .kv-slide {
    transform: none;
    transition: opacity 0.3s ease;
  }
}
/* Ken Burns?壹ｆ縺｣縺上ｊ繧ｺ繝ｼ繝繧､繝ｳ */
@keyframes kvKenBurns {
  from {
    transform: scale(1.02); /* 縺ｻ縺ｼ遲牙?阪↓霑代＞縺ｨ縺薙ｍ縺九ｉ */
  }
  to {
    transform: scale(1.10); /* 縺倥ｏ縺｣縺ｨ10%諡｡螟ｧ */
  }
}
/* PC縺縺第隼陦? */
.pc-br {
  display: none;
}
@media (min-width: 769px) {
  .pc-br {
    display: inline;
  }
}
/* SP縺縺第隼陦? */
.sp-br {
  display: none;
}
@media (max-width: 768px) {
  .sp-br {
    display: inline;
  }
}
/* PC/SP縺ｧ譁?ｫ繧貞?縺怜?縺代ｋ */
.pc-only {
  display: none;
}
.sp-only {
  display: inline;
}
@media (min-width: 769px) {
  .pc-only {
    display: inline;
  }
  .sp-only {
    display: none;
  }
}
/* ---- Director?壹ヶ繝ｭ繝門?逵? ---- */
.director-photo {
  max-width: 320px; /* SP縺ｧ縺ｯ縺縺?◆縺?％縺ｮ縺上ｉ縺??隕九◆逶ｮ */
  margin: 0 auto 3rem;
}
@media (min-width: 769px) {
  .director-photo {
    max-width: 360px; /* PC縺ｧ蟆代＠螟ｧ縺阪ａ縺ｫ */
  }
}
.director-blob-svg {
  width: 100%;
  height: auto;
  display: block;
}
/* 蜷?そ繧ｯ繧ｷ繝ｧ繝ｳ縺ｫ繧､繝ｩ繧ｹ繝医ｒ豬ｮ縺九○縺ｦ驟咲ｽｮ縺吶ｋ繝吶?繧ｹ */
.section-has-illust {
  position: relative; /* 邨ｶ蟇ｾ驟咲ｽｮ縺ｮ蝓ｺ貅悶↓縺吶ｋ */
}
/* 蜈ｱ騾壹?豬ｮ驕翫う繝ｩ繧ｹ繝育畑繝懊ャ繧ｯ繧ｹ */
.illust-floating {
  position: absolute;
  left: var(--ix, 85%); /* X菴咲ｽｮ??%縺ｧ蠕ｮ隱ｿ謨ｴ?? */
  top: var(--iy, 20%); /* Y菴咲ｽｮ??%縺ｧ蠕ｮ隱ｿ謨ｴ?? */
  transform: translate(-50%, -50%);
  z-index: 0; /* 繧ｳ繝ｳ繝?Φ繝??蜑榊ｾ後?縺雁･ｽ縺ｿ縺ｧ 0縲?2 縺上ｉ縺?↓ */
  pointer-events: none; /* 繧ｯ繝ｪ繝?け縺ｫ蟷ｲ貂峨＆縺帙↑縺? */
}
.illust-floating img {
  display: block;
  width: var(--isize, clamp(80px, 14vw, 200px)); /* 繧ｵ繧､繧ｺ縺ｯ縺薙％縺ｧ邨ｱ荳?逧?↓邂｡逅? */
  height: auto;
}
/* SP 縺ｮ蝣ｴ蜷医?繧ｵ繧､繧ｺ繝ｻ菴咲ｽｮ繧定ｪｿ謨ｴ縺励◆縺?ｴ蜷? */
@media (max-width: 640px) {
  .illust-floating {
    position: static; /* 笘??壼ｸｸ繝輔Ο繝ｼ縺ｫ謌ｻ縺? */
    top: auto;
    left: auto;
    transform: none; /* 荳ｭ螟ｮ遘ｻ蜍輔ｂ隗｣髯､ */
    width: auto;
    margin: var(--imargin-sp, 2rem auto 0); /* 笘?ｸｦ縺ｮ菴咏區縺縺大､画焚縺ｧ隱ｿ謨ｴ */
    text-align: center; /* 荳ｭ霄ｫ縺ｮimg繧偵そ繝ｳ繧ｿ繝ｼ縺ｫ */
    z-index: auto;
    pointer-events: none; /* 繧ｿ繝??縺ｯ荳崎ｦ√↑繧峨％縺ｮ縺ｾ縺ｾ */
  }
  .illust-floating img {
    display: inline-block;
    width: var(--isize-sp, var(--isize, clamp(60px, 24vw, 140px)));
    height: auto;
  }
}
.illust-hero {
  --ix: 87%;
  --iy: 103%;
  --isize: 280px;
}
@media (max-width: 640px) {
  .illust-hero {
    --ix: 88%;
    --iy: 30%;
    margin: var(--imargin-sp, 10rem auto 0rem);
  }
}
.illust-concept {
  --ix: 22%;
  --iy: 66%;
}
@media (max-width: 640px) {
  .illust-concept {
    --ix: 90%;
    --iy: 10%;
  }
  .illust-concept img {
    width: 20rem;
  }
}
.illust-about {
  --ix: 12%;
  --iy: 25%;
}
@media (max-width: 640px) {
  .illust-about {
    --ix: 8%;
    --iy: 14%;
  }
}
.illust-guide {
  --ix: 87%;
  --iy: 20%;
  --isize: 126px;
}
@media (max-width: 640px) {
  .illust-guide {
    --ix: 90%;
    --iy: 14%;
  }
    .illust-guide img {
    width: 11rem;
  }
}
.illust-director {
  --ix: 17%;
  --iy: 22%;
  --isize: 150px;
}
@media (max-width: 640px) {
  .illust-director {
    --ix: 12%;
    --iy: 18%;
  }
    .illust-director img {
    width: 12rem;
  }
}
.illust-first {
  --ix: 90%;
  --iy: 22%;
  --isize: 180px;
}
@media (max-width: 640px) {
  .illust-first {
    --ix: 88%;
    --iy: 16%;
  }
    .illust-first img {
    width: 14rem;
  }
}
.illust-repeat {
  --ix: 10%;
  --iy: 28%;
}
@media (max-width: 640px) {
  .illust-repeat {
    --ix: 12%;
    --iy: 20%;
  }
  .illust-repeat img {
    width: 14rem;
  }
}
.illust-parking {
  --ix: 86%;
  --iy: 18%;
  --isize: 150px;
}
@media (max-width: 640px) {
  .illust-parking {
    --ix: 90%;
    --iy: 14%;
  }
    .illust-parking img {
    width: 12rem;
  }
}
.illust-faq {
  --ix: 10%;
  --iy: 16%;
  --isize: 150px;
}
@media (max-width: 640px) {
  .illust-faq {
    --ix: 12%;
    --iy: 10%;
  }
    .illust-faq img {
    width: 10rem;
  }
}
.illust-access {
  --ix: 88%;
  --iy: 26%;
  --isize: 150px;
}
@media (max-width: 640px) {
  .illust-access {
    --ix: 90%;
    --iy: 20%;
  }
    .illust-access img {
        width: 10rem;
  }
}
/* =========================================
   繝昴さ繝?→霍ｳ縺ｭ繧九い繝九Γ繝ｼ繧ｷ繝ｧ繝ｳ?亥ｼｷ繧√?繝舌え繝ｳ繝会ｼ?
   ========================================= */
.illust-floating img,
.about-illust-floating img {
  transform-origin: center bottom;
  animation-name: pokoBounce;
  animation-timing-function: ease-out;
  animation-iteration-count: infinite;
  animation-duration: var(--poko-dur, 10s);   /* JS縺ｧ繝ｩ繝ｳ繝?繝 */
  animation-delay: var(--poko-delay, 0s);       /* JS縺ｧ繝ｩ繝ｳ繝?繝 */
}

@keyframes pokoBounce {
  0%, 92%, 100% {
    transform: translateY(0) scale(1);
  }
  10% {
    transform: translateY(1px) scale(1.08); /* 繝昴さ繝?ｼ? */
  }
  18% {
    transform: translateY(1px) scale(0.98);     /* 繝舌え繝ｳ繝画─?域綾繧奇ｼ? */
  }
  28% {
    transform: translateY(0px) scale(1);  /* 菴咎渊縺ｮ繝励メ霍ｳ縺ｭ */
  }
}
/* 全体ラッパーでフッターを画面下に押し下げる */
.page-wrap {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.site-main {
  flex: 1 0 auto;
}

.site-footer {
  flex-shrink: 0;
}
/* ===== お知らせレイアウト：ロゴ＋右コンテンツ ===== */
.news-layout {
  display: flex;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: flex-start;
}

/* 左カラム：ロゴ */
.news-logo-block {
  flex: 0 0 clamp(180px, 22vw, 240px);
}

.news-logo-link {
  display: inline-block;
}

.news-logo-img {
  display: block;
  max-width: 100%;
  height: auto;
}

.news-logo-text {
  margin-top: 1rem;
  font-size: 1.4rem;
  line-height: 1.5;
}

.news-logo-sub {
  font-size: 1.2rem;
  opacity: .8;
}

.news-logo-main {
  font-size: 1.8rem;
  font-weight: 700;
}

/* 右カラム：一覧／詳細 */
.news-main {
  flex: 1 1 auto;
}

/* ===== お知らせ一覧 ===== */
.news-list {
  list-style: none;
  margin: 2.4rem 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.4rem;
}

.news-item-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.news-item-date,
.news-single-date {
  font-size: 1.3rem;
  margin: 0 0 .4rem;
  color: var(--muted, #777);
}

.news-item-title {
  font-size: 1.8rem;
  margin: 0 0 .6rem;
}

.news-item-excerpt {
  margin: 0;
  font-size: 1.5rem;
}

/* ===== お知らせ詳細 ===== */
.news-single.card {
  margin-top: 2.4rem;
}

.news-single-title {
  font-size: 2.2rem;
  margin: 0 0 1.2rem;
}

.news-single-content {
  font-size: 1.6rem;
  line-height: 1.9;
}

.news-single-content p {
  margin-bottom: 1.2rem;
}

.news-single-back {
  margin-top: 2.4rem;
  text-align: right;
}

.news-single-back a {
  font-size: 1.4rem;
  text-decoration: underline;
}

/* SP レイアウト調整 */
@media (max-width: 768px) {
  .news-layout {
    flex-direction: column;
    align-items: center; /* 全体センター寄せ */
  }

  .news-logo-block {
    flex-basis: auto;
    width: 100%;
    max-width: 260px;       /* ロゴ周りの最大幅 */
    margin: 0 auto 2rem;    /* 下に少し余白 */
  }

  .news-logo-text {
    margin-top: 1rem;       /* ロゴとテキストの間に余白 */
  }

  .news-main {
    width: 100%;
  }
}
/* ===== 共通：ロゴブロック（トップと同じトーン） ===== */

.news-logo {
  text-align: center;
}

.news-logo img {
  width: clamp(120px, 18vw, 180px); /* トップと同等伸縮 */
  height: auto;
  display: block;
  margin-inline: auto;
}

.news-logo-text {
  margin-top: 1rem;
  line-height: 1.3;
    text-align: center;
}

.news-logo-sub {
  font-size: clamp(1.2rem, 1.4vw, 1.6rem); /* トップのサブ見出し級 */
  display: block;
    text-align: center;
}

.news-logo-main {
  font-size: clamp(2rem, 2.8vw, 3.2rem);   /* トップのメイン見出し級 */
  font-weight: 700;
  display: block;
}

/* ===== お知らせページ用：デコのお花をロゴに当たらない位置へ ===== */

#news .about-deco .about-flower,
#news-single .about-deco .about-flower {
  opacity: 0.9;
}

/* 個別に位置を軽くズラす（トップと被らないように調整） */
#news .about-flower.flower-1,
#news-single .about-flower.flower-1 {
  --fx: 15%;
  --fy: 12%;
}

#news .about-flower.flower-2,
#news-single .about-flower.flower-2 {
  --fx: 80%;
  --fy: 8%;
}

#news .about-flower.flower-3,
#news-single .about-flower.flower-3 {
  --fx: 10%;
  --fy: 85%;
}

#news .about-flower.flower-4,
#news-single .about-flower.flower-4 {
  --fx: 85%;
  --fy: 88%;
}

#news .about-flower.flower-5,
#news-single .about-flower.flower-5 {
  --fx: 50%;
  --fy: 95%;
}
.hero-news-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.hero-news-link:hover .news-text {
  text-decoration: underline;
}
/* ================================================
   NEWSページのロゴ部分をトップと完全に揃える
   ================================================ */

/* ロゴ画像のサイズ（トップに合わせる） */
.news-logo img {
  width: clamp(120px, 18vw, 180px); /* hero と同じ値 */
  height: auto;
  display: block;
  margin-inline: auto;
}

/* テキスト周り */
.news-logo-text {
  margin-top: 1rem;              /* hero と同じ余白 */
  line-height: 1.3;
  text-align: center;            /* 縦横センター揃え */
  color: #1e4a90;                /* トップの文字色に合わせる（hero と同じ色を指定） */
}

/* サブテキスト（いぬとねこのクリニック） */
.news-logo-sub {
  font-family: "Zen Maru Gothic", "Hiragino Kaku Gothic ProN", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.04em;         /* 読みやすく（hero と同じ値に） */
  display: block;
}

/* メインテキスト（ことぶき） */
.news-logo-main {
  font-family: "Zen Maru Gothic", "Hiragino Kaku Gothic ProN", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  display: block;
  margin-top: 0.2rem;
}

