/* =========================================================================
   須佐おもてなし協会 — フロントCSS(デザインパス v0.3)
   方針: 暖かみ・自然・読みやすさ・モバイル優先。土台(theme.json)の配色を活用。
   コンテンツが欠けても崩れない設計(実写フォールバック/グレースフル非表示)を維持。
   ========================================================================= */

:root{
  --c-sea:#1f5f8b; --c-sea-light:#63b3ed; --c-squid:#c0413b; --c-sunset:#e08a3c;
  --c-myth:#b08433; --c-forest:#3f6f4f; --c-ink:#23303a; --c-paper:#faf8f4; --c-mist:#e9eef2;
  --radius:12px;
  --shadow:0 1px 2px rgba(35,48,58,.06), 0 6px 20px rgba(35,48,58,.06);
  --shadow-hover:0 4px 10px rgba(35,48,58,.10), 0 14px 36px rgba(35,48,58,.12);
  --measure:720px; --ease:cubic-bezier(.2,.7,.2,1);
  --serif:var(--wp--preset--font-family--serif, "Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ overflow-x:hidden; } /* メインビジュアルの full-bleed(100vw)による横スクロール(スクロールバー幅)を抑止。root に置くので sticky ヘッダーには影響しない */
body{ margin:0; background:var(--c-paper); color:var(--c-ink); -webkit-font-smoothing:antialiased; }
img{ max-width:100%; height:auto; }
a{ color:var(--c-sea); }
a:hover{ color:var(--c-squid); }

.susa-container{ width:min(1140px,92vw); margin-inline:auto; }
.susa-main{ width:min(1140px,92vw); margin-inline:auto; padding-block:clamp(24px,4vw,56px); }
.susa-skip{ position:absolute; left:-9999px; top:0; background:var(--c-ink); color:#fff; padding:.6em 1em; z-index:1000; }
.susa-skip:focus{ left:8px; top:8px; }

/* ---------- ヘッダー ---------- */
.susa-header{ position:sticky; top:0; z-index:100; background:rgba(250,248,244,.94);
  backdrop-filter:saturate(1.1) blur(8px); border-bottom:1px solid var(--c-mist); }
.susa-header__accent{ height:3px; background:linear-gradient(90deg, var(--c-sea), var(--c-sea-light) 35%, var(--c-sunset) 70%, var(--c-squid)); }
.susa-header__inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:74px; }

.susa-brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:inherit; }
.susa-seal{ flex:0 0 auto; width:42px; height:42px; display:grid; place-items:center; border-radius:11px;
  background:linear-gradient(140deg, var(--c-sea), var(--c-sea-light)); color:#fff;
  font-family:var(--serif); font-size:1.4rem; font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.25), 0 2px 8px rgba(31,95,139,.30); }
.susa-brand__text{ display:flex; flex-direction:column; line-height:1.2; }
.susa-brand__name{ font-family:var(--serif); font-weight:700; font-size:clamp(1.05rem,2.3vw,1.4rem); letter-spacing:.04em; white-space:nowrap; } /* サイト名は常に1行(「会」が折返す問題の解消・全幅で) */
.susa-brand__tagline{ font-size:.7rem; letter-spacing:.06em; color:var(--c-sea); opacity:.85; margin-top:3px; white-space:nowrap; }

.susa-nav__list{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; justify-content:flex-end; gap:2px 4px; align-items:center; }
.susa-nav__list a{ position:relative; display:block; text-decoration:none; color:var(--c-ink); white-space:nowrap;
  padding:.5em .8em; font-weight:600; font-size:.9rem; letter-spacing:.02em; transition:color .2s var(--ease); }
.susa-nav__list a > span{ position:relative; }
.susa-nav__list a > span::after{ content:""; position:absolute; left:0; right:100%; bottom:-5px; height:2px; background:var(--c-sea); transition:right .25s var(--ease); }
.susa-nav__list a:hover{ color:var(--c-sea); }
.susa-nav__list a:hover > span::after{ right:0; }
.current-menu-item > a{ color:var(--c-sea); }

.susa-navtoggle{ display:none; align-items:center; gap:9px; background:#fff; border:1px solid var(--c-mist);
  border-radius:10px; padding:.55em .9em; cursor:pointer; color:var(--c-ink); font-weight:700; font-size:.85rem;
  white-space:nowrap; flex:0 0 auto; } /* 「メニュー」を必ず1行に(折返しで「ー」が落ちる問題の解消) */
.susa-navtoggle__bars{ display:block; width:20px; height:2px; background:currentColor; border-radius:2px; position:relative; }
.susa-navtoggle__bars::before, .susa-navtoggle__bars::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:currentColor; border-radius:2px; }
.susa-navtoggle__bars::before{ top:-6px; }
.susa-navtoggle__bars::after{ top:6px; }

/* ---------- グリッド / カード ---------- */
.susa-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(250px,1fr)); gap:clamp(14px,2vw,26px); list-style:none; padding:0; margin:0; }
.susa-card{ display:flex; flex-direction:column; text-decoration:none; color:inherit; background:#fff;
  border:1px solid var(--c-mist); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  transition:transform .22s var(--ease), box-shadow .22s var(--ease); height:100%; }
.susa-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-hover); }
.susa-card__title{ font-size:1.02rem; margin:0; padding:.7em .85em .15em; line-height:1.4; }
.susa-card__blurb{ font-size:.86rem; opacity:.8; margin:0; padding:0 .95em .9em; }
.susa-card__ext{ font-size:.72rem; opacity:.7; padding:0 .95em .8em; }
.susa-card > .susa-card__title:last-child{ padding-bottom:.85em; }

/* ---------- カード種別バッジ(画像隅に重ねる・色で分類を視認) ---------- */
.susa-card__media .susa-tags{ position:absolute; top:8px; left:8px; z-index:2; display:flex; flex-wrap:wrap; gap:4px; max-width:calc(100% - 16px); }
.susa-tag{ font-size:.7rem; font-weight:700; line-height:1; padding:.34em .62em; border-radius:6px; color:#fff;
  letter-spacing:.03em; background:rgba(35,48,58,.85); box-shadow:0 1px 3px rgba(0,0,0,.25); white-space:nowrap; }
.susa-tag--spot{ background:rgba(31,95,139,.94); }
.susa-tag--event{ background:rgba(192,65,59,.94); }
.susa-tag--eat{ background:rgba(214,120,40,.96); }
.susa-tag--stay{ background:rgba(63,111,79,.96); }
.susa-tag--shop{ background:rgba(176,132,51,.96); }
.susa-tag--exp{ background:rgba(31,95,139,.94); }
.susa-tag--gen{ background:rgba(35,48,58,.88); }
.susa-tag--post{ background:rgba(90,99,108,.94); }
.susa-tag--person{ background:rgba(44,122,123,.94); }

/* ---------- 画像レジリエンス(比率固定/object-fit) ---------- */
.susa-thumb, .susa-thumb--fallback{ display:block; width:100%; height:100%; object-fit:cover; object-position:center; background:var(--c-mist); }
.susa-card__media{ position:relative; aspect-ratio:3/2; overflow:hidden; background:var(--c-mist); }
.susa-card__media .susa-thumb, .susa-card__media .susa-ph{ position:absolute; inset:0; }
@supports not (aspect-ratio:1){ .susa-card__media{ height:0; padding-top:66.667%; } }
.susa-hero__media{ position:relative; aspect-ratio:16/9; overflow:hidden; border-radius:var(--radius); background:var(--c-mist); }
.susa-hero__media .susa-thumb, .susa-hero__media .susa-ph{ position:absolute; inset:0; }
@media (max-width:600px){ .susa-hero__media{ aspect-ratio:4/3; } }

/* 画像が一切無いときのみ出る CSS プレースホルダ(壊れ画像にしない) */
.susa-ph{ position:absolute; inset:0; display:block; width:100%; height:100%; background:linear-gradient(135deg,#2c5282,#4a5568); }
.susa-ph::after{ content:"須"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:clamp(2rem,6vw,4rem); color:rgba(255,255,255,.18); }
.susa-ph--susa_spot{ background:linear-gradient(135deg, var(--c-sea), var(--c-sea-light)); }
.susa-ph--susa_event{ background:linear-gradient(135deg, var(--c-squid), var(--c-sunset)); }
.susa-ph--susa_place{ background:linear-gradient(135deg,#744210, var(--c-myth)); }
.susa-ph--post{ background:linear-gradient(135deg, var(--c-forest),#6fae84); }
.susa-ph--susa_person{ background:linear-gradient(135deg,#2c7a7b,#68a7a0); }

.wp-block-gallery .wp-block-image{ aspect-ratio:1/1; overflow:hidden; border-radius:8px; }
.wp-block-gallery .wp-block-image img{ width:100%; height:100%; object-fit:cover; }

/* ---------- セクション見出し ---------- */
.susa-section-title{ font-family:var(--serif); border-left:5px solid var(--c-sea); padding-left:.6em; margin:clamp(34px,5vw,56px) 0 1em; font-size:clamp(1.25rem,3vw,1.7rem); }
.susa-feature-zone__title{ font-family:var(--serif); border-left:5px solid var(--c-squid); padding-left:.6em; margin:clamp(8px,2vw,20px) 0 1em; font-size:clamp(1.3rem,3.2vw,1.9rem); }

/* ---------- フロント: 世界観メインビジュアル ---------- */
.susa-keyvisual{ position:relative; width:100vw; margin-left:calc(50% - 50vw);
  margin-top:calc(-1 * clamp(24px,4vw,56px)); /* main 上余白を打ち消し、ヘッダー直下に密着 */
  min-height:clamp(360px,62vh,640px); display:flex; align-items:flex-end;
  background:var(--c-ink) center/cover no-repeat; color:#fff; overflow:hidden; }
.susa-keyvisual--plain{ background:linear-gradient(135deg, var(--c-sea), var(--c-ink)); }
/* スライド層(1枚なら静止、複数なら JS でクロスフェード) */
.susa-kv__slides{ position:absolute; inset:0; z-index:0; }
.susa-kv__slide{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1.2s ease-in-out; }
.susa-kv__slide.is-active{ opacity:1; }
.susa-keyvisual__inner{ position:relative; z-index:1; width:min(1140px,92vw); margin-inline:auto; padding-block:clamp(30px,6vw,80px); }
.susa-keyvisual__scroll{ z-index:1; }
.susa-keyvisual__tagline{ color:#fff; font-family:var(--serif); font-weight:700; margin:0;
  font-size:clamp(1.8rem,5.4vw,3.4rem); line-height:1.5; letter-spacing:.05em; text-shadow:0 2px 16px rgba(0,0,0,.55); }
/* h1 になったことで theme.json の見出し色(濃色)が効くのを打ち消す */
.susa-keyvisual h1.susa-keyvisual__tagline{ color:#fff; }
.susa-keyvisual__sub{ font-family:var(--serif); margin:.9em 0 0; opacity:.96;
  font-size:clamp(.95rem,2vw,1.25rem); letter-spacing:.05em; text-shadow:0 1px 10px rgba(0,0,0,.5); }
/* 真上下に弾むよう、移動はラッパー(中央寄せ済み)で行い、回転は子要素で静的に分離 */
.susa-keyvisual__scroll{ position:absolute; left:50%; bottom:16px; width:22px; height:22px; z-index:1;
  transform:translateX(-50%); animation:susa-bounce 1.8s ease-in-out infinite; }
.susa-keyvisual__scroll::before{ content:""; display:block; width:11px; height:11px; margin:0 auto;
  border-right:2px solid rgba(255,255,255,.85); border-bottom:2px solid rgba(255,255,255,.85);
  transform:rotate(45deg); }
@keyframes susa-bounce{ 0%,100%{ transform:translateX(-50%) translateY(0);} 50%{ transform:translateX(-50%) translateY(6px);} }
@media (max-width:600px){ .susa-keyvisual{ min-height:clamp(300px,54vh,460px); } }
@media (prefers-reduced-motion: reduce){ .susa-keyvisual__scroll{ animation:none; } }

/* ---------- フロント: 入口カード ---------- */
.susa-entry__grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:clamp(12px,1.8vw,20px); list-style:none; padding:0; margin:0; }
.susa-entry__item a{ display:flex; flex-direction:column; gap:.35em; justify-content:flex-end; min-height:140px;
  padding:clamp(18px,2.6vw,30px); border-radius:var(--radius); text-decoration:none; color:#fff;
  background:linear-gradient(135deg, var(--c-sea), var(--c-sea-light)); box-shadow:var(--shadow);
  transition:transform .22s var(--ease), box-shadow .22s var(--ease); }
.susa-entry__item a:hover{ transform:translateY(-3px); box-shadow:var(--shadow-hover); }
.susa-entry--live a{ background:linear-gradient(135deg, var(--c-forest),#6fae84); }
.susa-entry--business a{ background:linear-gradient(135deg, var(--c-myth),#d9b25f); }
.susa-cats .susa-entry__item a{ background:linear-gradient(135deg, var(--c-squid), var(--c-sunset)); }
.susa-entry__item--photo .susa-entry__title{ text-shadow:0 1px 4px rgba(0,0,0,.55); }
.susa-entry__title{ font-weight:700; font-size:1.15rem; }
.susa-entry__desc{ font-size:.82rem; opacity:.92; line-height:1.5; }

/* ---------- フロント: 寄り道係(窓口バナー) ---------- */
.susa-yorimichi{ margin-block:clamp(28px,4vw,52px); }
.susa-yorimichi__inner{ display:block; max-width:430px; margin-inline:auto; background:#fff; border:1px solid var(--c-mist); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); text-decoration:none; color:inherit; transition:transform .22s var(--ease), box-shadow .22s var(--ease); }
.susa-yorimichi__inner:hover{ transform:translateY(-3px); box-shadow:var(--shadow-hover); }
.susa-yorimichi__media{ display:block; }
.susa-yorimichi__media img{ display:block; width:100%; height:auto; } /* バナーは切り取らず全体表示(焼き込み文字を保持) */
.susa-yorimichi__body{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:.9em; padding:clamp(14px,2.5vw,22px); }
.susa-yorimichi__text{ flex:1 1 58%; min-width:200px; line-height:1.75; font-size:.92rem; }
.susa-yorimichi__btn{ flex:0 0 auto; background:var(--c-forest); color:#fff; font-weight:700; padding:.6em 1.4em; border-radius:8px; white-space:nowrap; }
.susa-yorimichi__inner:hover .susa-yorimichi__btn{ background:var(--c-squid); }

/* ---------- フロント: お知らせ(コンパクトなリスト) ---------- */
.susa-news{ margin-block:clamp(28px,4vw,48px); }
.susa-news__head{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.susa-news__head .susa-section-title{ margin-block:0 .2em; }
.susa-news__more{ font-size:.85rem; white-space:nowrap; text-decoration:none; font-weight:700; }
.susa-news__list{ list-style:none; margin:.4em 0 0; padding:0; }
.susa-news__item{ border-bottom:1px solid var(--c-mist); }
.susa-news__item a{ display:flex; align-items:center; gap:14px; padding:.9em .2em; text-decoration:none; color:inherit; transition:color .2s var(--ease); }
.susa-news__item a:hover{ color:var(--c-sea); }
.susa-news__date{ flex:0 0 auto; min-width:5.6em; font-size:.8rem; font-weight:700; color:var(--c-sea); font-variant-numeric:tabular-nums; }
.susa-news__thumb{ flex:0 0 auto; width:48px; height:48px; border-radius:6px; overflow:hidden; }
.susa-news__thumb .susa-thumb{ width:100%; height:100%; object-fit:cover; }
.susa-news__title{ flex:1 1 auto; line-height:1.5; }
@media (max-width:600px){ .susa-news__date{ min-width:0; font-size:.74rem; } .susa-news__thumb{ width:42px; height:42px; } .susa-news__item a{ gap:10px; } }

/* ---------- single ---------- */
.susa-hero{ position:relative; margin-bottom:clamp(18px,3vw,32px); }
.susa-hero__head{ margin-top:1em; }
.susa-single__title{ font-family:var(--serif); font-size:clamp(1.5rem,4vw,2.4rem); line-height:1.3; margin:.2em 0; }
.susa-single__body{ max-width:var(--measure); }
.susa-single__body > section, .susa-single__body > .susa-body, .susa-single__body > .susa-cta{ margin-block:clamp(22px,3vw,38px); }
.susa-single__body h2{ font-family:var(--serif); font-size:1.3rem; border-bottom:2px solid var(--c-mist); padding-bottom:.3em; }
.susa-body{ line-height:1.9; }
.susa-body :where(h2,h3){ font-family:var(--serif); }
.susa-hero__band{ position:absolute; left:0; right:0; bottom:0; padding:clamp(18px,4vw,44px); background:linear-gradient(to top, rgba(0,0,0,.74), rgba(0,0,0,.18) 55%, rgba(0,0,0,0)); color:#fff; }
.susa-hero__catch{ margin:0; font-family:var(--serif); font-weight:700; font-size:clamp(1.3rem,3.4vw,2.4rem); line-height:1.55; letter-spacing:.03em; text-shadow:0 2px 10px rgba(0,0,0,.55); max-width:26em; }

/* ---------- 基本情報 ---------- */
.susa-basic{ background:#fff; border:1px solid var(--c-mist); border-radius:var(--radius); padding:clamp(16px,2.5vw,26px); box-shadow:var(--shadow); }
.susa-basic h2{ margin-top:0; border:0; font-size:1.15rem; }
.susa-basic dl{ display:grid; grid-template-columns:max-content 1fr; gap:.55em 1.4em; margin:0; }
.susa-basic dt{ font-weight:700; color:var(--c-sea); }
.susa-basic dd{ margin:0; }
@media (max-width:480px){ .susa-basic dl{ grid-template-columns:1fr; gap:.1em; } .susa-basic dd{ margin-bottom:.6em; } }

/* ---------- バッジ / ボタン ---------- */
.susa-badges{ display:flex; flex-wrap:wrap; gap:.5em; list-style:none; padding:0; margin:.6em 0; }
.susa-badges .badge{ font-size:.78rem; padding:.25em .8em; border-radius:999px; }
.susa-badges a{ text-decoration:none; color:inherit; }
.susa-badges--cat .badge{ background:var(--c-sea); color:#fff; }
.susa-badges--cert .badge{ background:var(--c-myth); color:#fff; }
.susa-badges--tag{ margin-top:1.6em; }
.susa-badges--tag .badge{ background:var(--c-mist); color:var(--c-ink); }
.susa-cta{ margin-block:1.4em; }
.susa-btn{ display:inline-block; background:var(--c-sea); color:#fff; padding:.7em 1.5em; border-radius:8px; text-decoration:none; font-weight:700; transition:background .2s var(--ease), transform .2s var(--ease); }
.susa-btn:hover{ background:var(--c-squid); color:#fff; transform:translateY(-1px); }
.susa-btn--ghost{ background:transparent; color:var(--c-sea); border:1.5px solid currentColor; }
.susa-btn--ghost:hover{ background:var(--c-sea); color:#fff; }

/* ---------- イベント ---------- */
.susa-event__period{ font-weight:700; }
.susa-event__period-label{ display:inline-block; background:var(--c-sea); color:#fff; font-size:.72rem; padding:.2em .7em; border-radius:4px; margin-right:.6em; vertical-align:middle; }
.susa-status{ display:inline-block; font-size:.72rem; padding:.25em .8em; border-radius:999px; margin-left:.5em; vertical-align:middle; color:#fff; }
.susa-status.is-cancelled{ background:#b03030; } .susa-status.is-partial{ background:#c08a2c; } .susa-status.is-ended{ background:#6b7280; }
.susa-notice{ border-radius:var(--radius); padding:1em 1.2em; margin-block:1.2em; } .susa-notice--warn{ background:#fff6e5; border:1px solid #e0b65c; } .susa-notice p{ margin:0; }

/* ---------- アーカイブ / 関連 ---------- */
.susa-archive-header{ margin-bottom:clamp(18px,3vw,32px); }
.susa-archive-title{ font-family:var(--serif); border-left:5px solid var(--c-sea); padding-left:.6em; font-size:clamp(1.4rem,3.4vw,2rem); }
.susa-archive-desc{ opacity:.8; margin-top:.5em; }
.susa-archive-intro{ max-width:760px; margin:.8em 0 0; line-height:1.9; opacity:.92; }
.susa-empty{ padding:48px 0; text-align:center; opacity:.7; }
.pagination,.nav-links{ display:flex; gap:.4em; flex-wrap:wrap; margin-top:2em; }
.pagination .page-numbers{ display:inline-block; padding:.45em .8em; border:1px solid var(--c-mist); border-radius:8px; text-decoration:none; }
.pagination .page-numbers.current{ background:var(--c-sea); color:#fff; border-color:var(--c-sea); }
.susa-related{ margin-top:clamp(36px,5vw,64px); padding-top:clamp(24px,3vw,40px); border-top:1px solid var(--c-mist); }
.susa-related h2{ font-family:var(--serif); }

/* ---------- 須佐のひと(プロフィール / 一覧) ---------- */
.susa-person-head{ display:flex; gap:clamp(18px,3vw,36px); align-items:center; margin-bottom:clamp(20px,3vw,36px); }
.susa-person-head__photo{ flex:0 0 auto; width:clamp(140px,28vw,240px); aspect-ratio:1/1; border-radius:14px; overflow:hidden; position:relative; background:var(--c-mist); box-shadow:var(--shadow); }
.susa-person-head__photo .susa-thumb, .susa-person-head__photo .susa-ph{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.susa-person-head__meta{ flex:1 1 auto; }
.susa-person__role{ font-weight:700; color:var(--c-sea); margin:.2em 0; }
.susa-person__motto{ font-family:var(--serif); font-size:clamp(1.05rem,2.4vw,1.4rem); line-height:1.6; margin:.4em 0; }
@media (max-width:560px){ .susa-person-head{ flex-direction:column; align-items:flex-start; text-align:left; } }

.susa-people{ display:grid; grid-template-columns:repeat(auto-fill, minmax(150px,1fr)); gap:clamp(14px,2vw,26px); list-style:none; padding:0; margin:0; }
.susa-person-card a{ display:flex; flex-direction:column; align-items:center; text-align:center; text-decoration:none; color:inherit; }
.susa-person-card__photo{ position:relative; width:clamp(96px,28vw,150px); aspect-ratio:1/1; border-radius:50%; overflow:hidden; background:var(--c-mist); box-shadow:var(--shadow); transition:transform .22s var(--ease), box-shadow .22s var(--ease); }
.susa-person-card a:hover .susa-person-card__photo{ transform:translateY(-3px); box-shadow:var(--shadow-hover); }
.susa-person-card__photo .susa-thumb, .susa-person-card__photo .susa-ph{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.susa-person-card__name{ font-weight:700; margin-top:.7em; line-height:1.4; }
.susa-person-card__role{ font-size:.8rem; color:var(--c-sea); margin-top:.2em; }
.susa-person-card__motto{ font-size:.8rem; opacity:.8; margin-top:.3em; }

/* 須佐のひとに聞く(フリー Q&A)。.susa-qa h2 は .susa-single__body h2 を継承。 */
.susa-qa dl{ margin:0; }
.susa-qa__q{ font-weight:700; color:var(--c-sea); margin-top:1.1em; line-height:1.6; }
.susa-qa__q::before{ content:"Q. "; }
.susa-qa__a{ margin:.35em 0 0; line-height:1.85; }
.susa-qa__a::before{ content:"A. "; color:var(--c-squid); font-weight:700; }

/* ---------- SNS・リンクアイコン(須佐のひと / フッター) ---------- */
.susa-sns-links{ list-style:none; margin:.7em 0 0; padding:0; display:flex; flex-wrap:wrap; gap:4px; align-items:center; }
.susa-sns-link{ display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:10px; color:var(--c-ink); transition:transform .18s var(--ease), background .18s var(--ease); }
.susa-sns-link:hover{ transform:translateY(-2px); background:rgba(31,95,139,.08); }
.susa-sns-icon{ width:26px; height:26px; display:block; }
.susa-sns--facebook{ color:#1877f2; }
.susa-sns--instagram{ color:#e4405f; }
.susa-sns--line{ color:#06c755; }
.susa-sns--youtube{ color:#ff0000; }
.susa-sns--x{ color:#000; }
.susa-sns--note{ color:#222; }
.susa-sns--web{ color:var(--c-sea); }
/* フッター(暗い背景)は単色の白で統一 */
.susa-fsns{ margin-top:.6em; }
.susa-fsns__label{ display:block; font-size:.78rem; opacity:.8; margin-bottom:.2em; }
.susa-footer .susa-sns-link{ color:#fff; }
.susa-footer .susa-sns-link:hover{ background:rgba(255,255,255,.14); }

/* ---------- 固定ページ / 投稿 / 404 ---------- */
.susa-page{ max-width:920px; margin-inline:auto; }
.susa-page__header{ margin-bottom:clamp(16px,3vw,28px); }
.susa-page__title{ font-family:var(--serif); font-size:clamp(1.5rem,4vw,2.3rem); line-height:1.35; margin:.1em 0; }
.susa-post__meta{ font-size:.82rem; opacity:.7; margin:0 0 .4em; }
.susa-page__thumb{ margin:0 0 clamp(18px,3vw,32px); border-radius:var(--radius); overflow:hidden; }
.susa-page__thumb img{ width:100%; height:auto; display:block; }
.susa-404{ text-align:center; padding:clamp(40px,8vw,90px) 0; }
.susa-404 .susa-cta{ display:flex; gap:.8em; justify-content:center; flex-wrap:wrap; }

/* legacy(旧サイト)本文の安全な正規化:はみ出し防止・画像/表/埋め込みのレスポンシブ化 */
.susa-legacy{ line-height:1.9; overflow-wrap:break-word; }
.susa-legacy img{ max-width:100%; height:auto; }
.susa-legacy iframe, .susa-legacy embed, .susa-legacy object, .susa-legacy video{ max-width:100%; }
.susa-legacy table{ max-width:100%; display:block; overflow-x:auto; }
.susa-legacy figure{ max-width:100%; margin-inline:0; }
.susa-legacy *{ max-width:100%; }

/* ---------- フッター ---------- */
.susa-footer{ position:relative; margin-top:clamp(48px,7vw,96px); background:var(--c-ink); color:#e8edf1; overflow:hidden; }
.susa-footer__accent{ height:3px; background:linear-gradient(90deg, var(--c-squid), var(--c-sunset) 40%, var(--c-sea-light) 75%, var(--c-sea)); }
.susa-footer__watermark{ position:absolute; right:-2vw; bottom:-8vw; font-family:var(--serif); font-size:40vw; line-height:1; color:rgba(255,255,255,.035); pointer-events:none; user-select:none; }
.susa-footer__inner{ position:relative; display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:clamp(20px,3vw,48px); padding-block:clamp(36px,5vw,64px); }
.susa-footer__name{ font-family:var(--serif); font-weight:700; font-size:1.25rem; margin:0; }
.susa-footer__tagline{ font-family:var(--serif); color:var(--c-sea-light); font-size:.98rem; line-height:1.7; margin:.6em 0; }
.susa-footer__area{ font-size:.8rem; opacity:.65; margin:.4em 0 0; letter-spacing:.04em; }
.susa-fcol__head{ font-size:.82rem; font-weight:700; letter-spacing:.12em; color:#fff; opacity:.9; margin:0 0 1em; padding-bottom:.6em; border-bottom:1px solid rgba(255,255,255,.12); }
.susa-fcol__list{ list-style:none; margin:0; padding:0; display:grid; gap:.7em; }
.susa-fcol__list a{ color:#e8edf1; text-decoration:none; opacity:.82; font-size:.9rem; transition:opacity .2s var(--ease), color .2s var(--ease); }
.susa-fcol__list a:hover{ opacity:1; color:var(--c-sea-light); }
.susa-fcol__note{ font-size:.82rem; opacity:.7; line-height:1.7; margin:0; }
.susa-footer__bar{ position:relative; border-top:1px solid rgba(255,255,255,.1); }
.susa-footer__barinner{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.susa-copy{ font-size:.76rem; opacity:.6; padding-block:1.1em; margin:0; }
.susa-totop{ font-size:.78rem; color:#e8edf1; opacity:.7; text-decoration:none; } .susa-totop:hover{ opacity:1; color:var(--c-sea-light); }
@media (max-width:760px){ .susa-footer__inner{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .susa-footer__inner{ grid-template-columns:1fr; } }

/* ---------- レスポンシブ: スマホは2カラムで一覧の回遊性を上げる ---------- */
@media (max-width:600px){
  .susa-grid{ grid-template-columns:repeat(2,1fr); gap:10px; }
  .susa-card__title{ font-size:.88rem; padding:.5em .6em .1em; line-height:1.35; }
  .susa-card__blurb{ display:none; } /* スマホのカードはコンパクトに(タイトル+写真+種別バッジ) */
  .susa-tag{ font-size:.64rem; padding:.3em .5em; }
  /* ヘッダー: サイト名を必ず1行で(スマホで「会」が折り返す問題の解消) */
  .susa-header__inner{ min-height:62px; }
  .susa-brand{ gap:9px; }
  .susa-seal{ width:36px; height:36px; font-size:1.2rem; border-radius:9px; }
  .susa-brand__name{ font-size:1rem; white-space:nowrap; letter-spacing:.02em; }
  .susa-brand__tagline{ white-space:normal; font-size:.62rem; line-height:1.3; max-width:62vw; } /* スマホでもキャッチを表示(2行折り返し可) */
}

/* ---------- レスポンシブ: モバイルナビ ---------- */
@media (max-width:768px){
  .susa-navtoggle{ display:inline-flex; }
  .susa-header__inner{ position:relative; }
  /* メニューボタンが出る幅では、ブランドを残り幅に収め、タグラインは折返し可に
     (601〜768px でもボタンが画面外にはみ出さないようにする) */
  .susa-brand{ flex:1 1 0; min-width:0; }
  .susa-brand__tagline{ white-space:normal; }
  .susa-nav{ position:absolute; left:0; right:0; top:100%; background:var(--c-paper); border-bottom:1px solid var(--c-mist); box-shadow:var(--shadow); display:none; }
  .susa-nav.is-open{ display:block; }
  .susa-nav__list{ flex-direction:column; gap:0; padding:8px 0; }
  .susa-nav__list a{ padding:.95em 6vw; }
  .susa-nav__list a > span::after{ display:none; }
}
