﻿/* =========================
  Base (mobile-first)
========================= */
:root{
  --navy:#19467d;
  --navy2:#173e60;
  --sky:#cfe0ee;
  --ink:#0b1b2a;
  --white:#fff;
  --line:#d6dee6;
  --shadow: 0 10px 28px rgba(0,0,0,.10);
  --radius:16px;
  --radius-lg:22px;
  --container:980px;
}

*,
*::before,
*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:"Shippori Mincho","Hiragino Mincho ProN","Yu Mincho",serif;
  line-height:1.7;
  color:var(--ink);
}

img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; }

.sp-br{
  display:block;
  height:6px; /* 改行余白調整 */
}

.container{
  width:min(100% - 32px, var(--container));
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:16px;
  top:16px;
  width:auto;
  height:auto;
  background:#fff;
  padding:10px 12px;
  border-radius:10px;
  box-shadow:var(--shadow);
  z-index:9999;
}

/* =========================
  Header
========================= */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0;
  gap:12px;
}
.header-nav{
  display:flex;
  align-items:center;
  gap:10px;
}
.brand-link{ text-decoration:none; }
.nav-link{
  text-decoration:none;
  font-size:14px;
  color:#0e2a40;
  opacity:.9;
}
.nav-link:hover{ opacity:1; text-decoration:underline; }

/* =========================
  Buttons (global)
========================= */
.btn{
  appearance:none;
  border:0;
  background:var(--navy);
  color:#fff;
  padding:12px 16px;
  border-radius:999px;
  font-weight:700;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  box-shadow:0 10px 20px rgba(31,79,120,.22);
}
.btn:hover{ filter:brightness(1.03); }
.btn:active{ transform:translateY(1px); }
.btn-sm{ padding:10px 12px; font-size:13px; }
.btn-center{ width:min(320px, 100%); margin:14px auto 0; display:flex; }

/* =========================
  Sections / Typography
========================= */
.section{ padding:44px 0; }
.section-muted{ background:var(--navy); }
.section-video{ background:var(--navy); }

.section-title{
  margin:0 0 10px;
  font-size:24px;
  font-weight:600;
  letter-spacing:.02em;
}
.section-title--center{ text-align:center; color:#fff; }

.lead{
  margin:0;
  color:rgba(255,255,255,.82);
  font-size:16px;
  font-weight:400;
}
.lead--center{ text-align:center; margin-top:10px; }

.bang{ display:inline-block; transform:rotate(7deg); }

.lead-subtitle{ text-align:center; margin:48px 0 14px; }
.lead-bracket{
  margin:0 0 5px;
  font-size:16px;
  font-weight:600;
  letter-spacing:.08em;
  color:#fff;
  text-align:center;
}
.lead-caption{
  margin:6px 0 0;
  font-size:16px;
  letter-spacing:.08em;
  color:#fff;
  text-align:center;
}

/* =========================
  Hero
========================= */
.hero{
  position:relative;
  padding:56px 0 44px;
  overflow:hidden;
  background:#fff;
}
.hero-bg{
  position:absolute;
  inset:-20px;
  background:
    radial-gradient(circle at 25% 15%, rgba(31,79,120,.12), transparent 40%),
    radial-gradient(circle at 80% 30%, rgba(255,200,80,.18), transparent 36%),
    radial-gradient(circle at 30% 70%, rgba(31,79,120,.10), transparent 44%),
    url("../images/hero-bg.jpg"),
    linear-gradient(180deg, #ffffff, #f7fbff);
  background-repeat:no-repeat;
  background-position:center;
  background-size:auto, auto, auto, cover, auto;
}
.hero-inner{ position:relative; text-align:center; }

.hero-eyebrow{
  margin:0 0 8px;
  font-weight:700;
  color:#000;
  font-size:16px;
}
.hero-title{
  margin:0 0 6px;
  line-height:1;
  display:flex;
  justify-content:center;
}
.hero-title img{
  width:min(80vw, 420px);
  height:auto;
}
.hero-sub{
  margin:0;
  letter-spacing:.06em;
  color:#000;
  font-size:16px;
  font-family:"Yu Mincho","YuMincho","Hiragino Mincho ProN",serif;
  font-weight:600;
}

/* =========================
  Band (Navy)
========================= */
.band{ padding:44px 0; }
.band-navy{ background:var(--navy); color:#fff; }
.band-navy .section-title{ color:#fff; }

/* emblem */
.band-emblem{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.band-emblem::before{
  content:"";
  position:absolute;
  top:-20px;
  left:-20px;
  width:200px;
  height:200px;
  background:url("../images/bg-emblem.webp") no-repeat left top / contain;
  opacity:.08;
  pointer-events:none;
  z-index:0;
}
.band-emblem > .container{ position:relative; z-index:1; }

/* =========================
  Cards (3 mini cards)
========================= */
.cards{ display:grid; gap:12px; margin-top:18px; }
.cards-3{ grid-template-columns:1fr; }

.mini-card{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);
  padding:14px 14px 12px;
  text-align:center;
}
.mini-card-title{
  display:inline-block;
  margin:0 0 10px;
  padding:8px 16px;
  letter-spacing:.08em;
  background:#fff;
  color:var(--navy);
  font-size:18px;
  font-weight:600;
  border-radius:4px;
}
.mini-list{
  margin:0;
  color:rgba(255,255,255,.9);
  display:inline-block;
  text-align:left;
  padding-left:1.2em;
}

/* =========================
  Video
========================= */
.video-wrap{ margin-top:16px; }
.video-thumb{
  position:relative;
  display:block;
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.05);
}
.play{
  position:absolute;
  left:18px;
  bottom:18px;
  width:54px;
  height:54px;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  box-shadow:0 10px 20px rgba(0,0,0,.18);
}
.play::before{
  content:"";
  position:absolute;
  left:22px;
  top:16px;
  width:0;
  height:0;
  border-top:11px solid transparent;
  border-bottom:11px solid transparent;
  border-left:16px solid var(--navy);
}

/* =========================
  Supporters (image link)
========================= */
.supporters{ margin-top:18px; }
.supporters-link{
  display:block;
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.06);
}
.supporters-link:hover{ filter:brightness(1.02); }
.supporters-note{
  margin:10px 0 0;
  text-align:center;
  color:#fff;
  font-size:12px;
}

/* =========================
  Slider (history)
========================= */
.slider-section{ background:#567fad; }

.slider2{ position:relative; margin-top:14px; }
.slider2-viewport{
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:10px 0 6px;
}
.slider2-track{
  display:flex;
  gap:14px;
  padding:0 10px;
}
.slider2-item{
  flex:0 0 78%;
  scroll-snap-align:start;
  margin:0;
  color:#fff;
}
.slider2-item img{
  width:100%;
  background:#fff;
  border:1px solid rgba(255,255,255,.15);
  box-shadow:var(--shadow);
}
.slider2-meta{
  margin:10px 0 0;
  font-size:12px;
  opacity:.9;
}
.slider2-title{
  margin:2px 0 0;
  font-size:14px;
  line-height:1.5;
}
.slider2-nav{
  display:none; /* PCで表示 */
  position:absolute;
  top:50%;
  transform:translateY(-65%);
  width:60px;
  height:60px;
  border:0;
  background:transparent;
  color:rgba(255,255,255,.9);
  cursor:pointer;
  z-index:5;
}
.slider2-nav i{ font-size:48px; line-height:60px; }

/* =========================
  Mentors
========================= */
.people-grid{
  display:grid;
  grid-template-columns:1fr; /* SP 1列 */
  gap:18px;
}
.person{ text-align:center; }

/* SP：画像＆テキストを同幅(90%)に揃える */
.person-photo,
.person-role,
.person-title,
.person-name{
  width:90%;
  margin-inline:auto;
}

.person-photo{
  position:relative;
  display:block;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
}
.person-photo img{ width:100%; }

.person-badge{
  position:absolute;
  right:10px;
  bottom:10px;
  padding:6px 10px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.06em;
  color:#fff;
  background:rgba(0,0,0,.38);
  border:1px solid rgba(255,255,255,.25);
  border-radius:999px;
  backdrop-filter: blur(4px);
}

@media (hover:hover){
  .person-photo:hover img{ filter:brightness(1.05); }
  .person-photo:hover .person-badge{ background:rgba(0,0,0,.5); }
}

/* role/title/name */
.person-role{ font-size:13px; opacity:.8; margin:8px auto 0; }
.person-title{ font-size:13px; margin:0 auto 6px; }
.person-name{ font-size:18px; font-weight:700; margin:6px auto 0; }

/* =========================
  Modal
========================= */
.greeting-modal{
  border:0;
  padding:0;
  width:min(92vw, 720px);
  border-radius:14px;
  background:#fff;
  color:#111;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}
.greeting-modal::backdrop{ background:rgba(0,0,0,.55); }

.greeting-modal__inner{
  position:relative;
  padding:18px 16px;
  max-height:80vh;
  overflow:auto;
}
.greeting-modal__close{
  position:absolute;
  top:10px;
  right:12px;
  width:36px;
  height:36px;
  border:0;
  border-radius:999px;
  background:rgba(0,0,0,.06);
  cursor:pointer;
  font-size:22px;
  line-height:36px;
}
.greeting-modal__name{
  margin:0 40px 6px 0;
  font-size:18px;
  font-weight:700;
  letter-spacing:.12em;
}
.greeting-modal__role{
  margin:0 0 2px;
  font-size:13px;
  opacity:.8;
}
.greeting-modal__title{
  margin:0 0 12px;
  font-size:13px;
  opacity:.8;
  letter-spacing:.04em;
}
.greeting-modal__divider{
  height:1px;
  background:rgba(0,0,0,.1);
  margin:12px 0 16px;
}
.greeting-modal__body{
  font-size:14px;
  line-height:1.9;
}
.greeting-modal__body p{ margin:0 0 12px; }

/* =========================
  JOIN（会員募集）
========================= */
.join-head{
  background:#567fad;
  color:#fff;
  padding:18px 0 16px;
}
.join-kicker{
  margin:0 0 6px;
  text-align:center;
  font-size:14px;
  letter-spacing:.08em;
  opacity:.95;
}
.join-title{
  margin:0;
  text-align:center;
  font-size:20px;
  font-weight:600;
  letter-spacing:.06em;
}

/* join-body blocks (navy / white) */
.join-body{ padding:18px 0 44px; }
.join-body--navy{ background:var(--navy); color:#fff; }
.join-body--white{ background:#fff; color:#17324a; }

.join-lead{
  margin:0;
  text-align:center;
  font-size:14px;
  line-height:1.9;
  color:rgba(255,255,255,.9);
}

/* 横長写真 */
.join-photo{
  margin:18px 0 18px;
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.16);
}
.join-photo img{ width:100%; }

/* -------------------------
  JOIN cards（ロゴ重なり対策込み）
------------------------- */
.join-cards{
  display:grid;
  gap:18px;
  margin-top:66px; /* 1枚目のロゴ分 */
}
.join-card{
  position:relative;
  background:#dfeaf1;
  color:#17324a;
  border-radius:6px;
  padding:56px 18px 20px; /* カード内ロゴ分 */
  text-align:center;
  z-index:0;

  /* スマホ縦並びでロゴが前カードと重なるのを防ぐ */
  margin-top:44px;
}
.join-card:first-child{ margin-top:0; }

.join-card-logo{
  position:absolute;
  top:-40px;
  left:50%;
  transform:translateX(-50%);
  width:78px;
  height:78px;
  border-radius:999px;
  background:#fff;
  padding:4px;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  z-index:2;
  object-fit:contain;
}

.join-card-title{
  margin:0;
  font-size:20px;
  font-weight:600;
  letter-spacing:.08em;
  color:var(--navy);
  line-height:1.6;
}
.join-card-title + .join-card-title{
  margin-top:10px;
  font-size:14px;
  font-weight:500;
  opacity:.95;
  line-height:1.7;
}
.join-card-text{
  margin:14px 0 0;
  font-size:13px;
  line-height:2.0;
}
.join-card-note{
  margin-top:12px;
  font-size:12px;
  opacity:.7;
}

/* -------------------------
  JOIN CTA（添付デザイン寄せ）
------------------------- */
.join-cta{
  margin-top:18px;
  display:grid;
  gap:18px;
}
.join-cta-item{ text-align:center; }

/* ★重要：サイズはブレークポイントで管理（ここではサイズ固定しない） */
.join-cta-label{
  margin:0 0 10px;
  font-size:12px;            /* SP */
  letter-spacing:.06em;
  color:rgba(255,255,255,.9); /* navy想定 */
}

/* 白背景のときは色だけ変更（サイズは変えない） */
.join-body--white .join-cta-label{ color:#000; }

.join-cta-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:min(520px, 100%);
  padding:16px 18px;
  border-radius:999px;
  font-weight:700;
  letter-spacing:.08em;
  text-decoration:none;
  box-shadow:0 12px 24px rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.14);
}

.join-cta-arrow{
  display:inline-block;
  width:0;
  height:0;
  border-top:6px solid transparent;
  border-bottom:6px solid transparent;
  border-left:9px solid currentColor;
  transform:translateY(1px);
}

.join-cta-btn--navy{
  color:#fff;
  background:linear-gradient(90deg, #1a4d86 0%, #102a68 55%, #0a0f3a 100%);
}
.join-cta-btn--gold{
  color:#1b2336;
  background:linear-gradient(90deg, #8a7857 0%, #d8c39a 55%, #a98b52 100%);
  border-color:rgba(0,0,0,.10);
}

.join-cta-note{
  margin:10px 0 0;
  font-size:11px;
  color:rgba(255,255,255,.85);
}
.join-body--white .join-cta-note{ color:#5b6b7c; }

.join-cta-btn:active{ transform:translateY(1px); }
@media (hover:hover){
  .join-cta-btn:hover{ filter:brightness(1.03); }
}

/* =========================
  CONTACT（添付デザイン寄せ）
========================= */
.contact{
  background:#fff;
  padding:56px 0 52px;
  color:#111;
}

.contact-title{
  margin:0 0 26px;
  text-align:center;
  font-size:28px;
  font-weight:600;
  letter-spacing:.10em;
}

.contact-form{
  width:min(920px, 100%);
  margin-inline:auto;
}

.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
}

.contact-field{
  display:grid;
  gap:10px;
}

.contact-field--full{
  grid-column:1 / -1;
}

.contact-label{
  font-size:14px;
  letter-spacing:.08em;
  color:#2b2b2b;
}

.req{
  margin-left:6px;
  font-size:12px;
  color:#2b2b2b;
  opacity:.85;
}

.contact-input{
  width:100%;
  height:75px;
  border:1px solid rgba(20,20,20,.35);
  border-radius:0 60px 0 60px;
  padding:14px 16px;
  font-size:16px;
  outline:none;
  background:#fff;
}

.contact-textarea{
  width:100%;
  border:1px solid rgba(20,20,20,.35);
  padding:16px;
  font-size:16px;
  line-height:1.8;
  resize:vertical;
  min-height:220px;
  background:#fff;
}

/* フォーカス（薄め） */
.contact-input:focus,
.contact-textarea:focus{
  border-color: rgba(25,70,125,.65);
  box-shadow: 0 0 0 4px rgba(25,70,125,.10);
}

.contact-consent{
  margin:24px 0 18px;
  text-align:center;
  font-size:12px;
  letter-spacing:.06em;
  color:#333;
}

.contact-submit{
  appearance:none;
  border:0;
  display:flex;
  margin:0 auto;
  padding:12px 28px;
  border-radius:999px;
  background:var(--navy);
  color:#fff;
  font-weight:700;
  letter-spacing:.10em;
  box-shadow:0 10px 20px rgba(0,0,0,.18);
  cursor:pointer;
}

.contact-submit:active{ transform: translateY(1px); }

/* =========================
  Footer
========================= */
.footer{
  font-family:"Noto Sans JP", sans-serif;
}

.footer-band{
  background:#bcd3ee; /* 添付の水色帯 */
  padding:22px 0;
}

.footer-inner{
  display:flex;
  flex-direction:column;
  gap:18px;
  align-items:flex-start;
}

.footer-sp-logo{
  width:140px;
  height:auto;
  display:block;
}

.footer-pc-logo{
  display:none;
}

.footer-logo{
  width:100px;
  height:auto;
}

.footer-right{
  width:100%;
}

.footer-primary{
  display:grid;
  gap:10px;
}

.footer-primary-row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.footer-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:62px;
  padding:4px 6px;
  background:#1e3b68;
  color:#fff;
  font-size:14px;
  font-weight:700;
  letter-spacing:.08em;
}

.footer-big{
  font-size:18px;
  font-weight:700;
  letter-spacing:.04em;
  color:#000;
}

.footer-mail{
  text-decoration:none;
}
.footer-mail:hover{
  text-decoration:underline;
  text-underline-offset:3px;
}

.footer-meta{
  margin-top:14px;
  font-size:12px;
  color:rgba(0,0,0,.75);
  line-height:1.8;
}

.footer-meta-line{
  margin:0;
}

.footer-meta a{
  color:inherit;
  text-decoration:underline;
  text-underline-offset:3px;
}

/* =========================
  Tablet+
========================= */
@media (min-width: 768px){
  .sp-br{ display:none; }

  .section-title{ font-size:30px; }
  .cards-3{ grid-template-columns:repeat(3, 1fr); }
  .lead-bracket{ font-size:21px; }

  .hero-eyebrow{ font-size:26px; }
  .hero-sub{ font-size:26px; }

  .band-emblem::before{
    top:-40px;
    left:-40px;
    width:400px;
    height:400px;
    opacity:.06;
  }

  /* slider: 4 visible */
  .slider2{ padding:10px 66px; }
  .slider2-viewport{ overflow-x:hidden; padding:0; }
  .slider2-track{ gap:22px; padding:0; }
  .slider2-item{ flex:0 0 calc((100% - 22px * 3) / 4); }
  .slider2-nav{ display:block; }
  .slider2-prev{ left:0; }
  .slider2-next{ right:0; }
  .slider2-meta{ font-size:14px; }
  .slider2-title{ font-size:18px; }

  /* mentors: 3 columns + widths reset */
  .people-grid{
    grid-template-columns:repeat(3, 1fr);
    gap:26px;
  }
  .person-photo,
  .person-role,
  .person-title,
  .person-name{ width:100%; }
  .person-title{ font-size:14px; }
  .person-name{ font-size:20px; letter-spacing:.16em; }
  .person-badge{ font-size:13px; padding:7px 12px; }

  /* join */
  .join-kicker{ font-size:21px; }
  .join-title{ font-size:32px; }

  .join-lead{
    font-size:15px;
    width:min(820px, 100%);
    margin-inline:auto;
  }

  .join-cards{
    grid-template-columns:repeat(3, 1fr);
    gap:28px;
    margin-top:72px;
  }
  .join-card{
    margin-top:0;               /* PCは横並びなので不要 */
    padding:70px 26px 26px;
  }
  .join-card-logo{
    width:92px;
    height:92px;
    top:-48px;
  }
  .join-card-title{ font-size:26px; }
  .join-card-title + .join-card-title{ font-size:16px; }
  .join-card-text{ font-size:14px; line-height:2.05; }

  .join-cta{
    grid-template-columns:1fr 1fr;
    gap:24px;
    align-items:start;
    width:min(980px, 100%);
    margin-inline:auto;
  }

  /* ★ここが修正点：白背景でもPCフォントサイズが確実に効く */
  .join-cta-label{
    font-size:18px;
    margin-bottom:12px;
  }
  .join-body--white .join-cta-label{
    font-size:18px; /* 強いセレクタでも同値を明示して打ち勝つ */
  }

  .join-cta-btn{
    width:min(420px, 100%);
    padding:18px 20px;
    font-size:18px;
  }
  .join-cta-note{ font-size:12px; }

  .contact-title{ font-size:34px; margin-bottom:34px; }
  .contact-grid{
    grid-template-columns:1fr 1fr;
    gap:26px 34px;
  }
  .contact-textarea{ min-height:260px; }
  .contact-consent{ font-size:18px; }

 .sp-br{ display:none; }

  .section-title{ font-size:30px; }
  .cards-3{ grid-template-columns:repeat(3, 1fr); }
  .lead-bracket{ font-size:21px; }

  .hero-eyebrow{ font-size:26px; }
  .hero-sub{ font-size:26px; }

  .band-emblem::before{
    top:-40px;
    left:-40px;
    width:400px;
    height:400px;
    opacity:.06;
  }

  /* slider: 4 visible */
  .slider2{ padding:10px 66px; }
  .slider2-viewport{ overflow-x:hidden; padding:0; }
  .slider2-track{ gap:22px; padding:0; }
  .slider2-item{ flex:0 0 calc((100% - 22px * 3) / 4); }
  .slider2-nav{ display:block; }
  .slider2-prev{ left:0; }
  .slider2-next{ right:0; }
  .slider2-meta{ font-size:14px; }
  .slider2-title{ font-size:18px; }

  /* mentors: 3 columns + widths reset */
  .people-grid{
    grid-template-columns:repeat(3, 1fr);
    gap:26px;
  }
  .person-photo,
  .person-role,
  .person-title,
  .person-name{ width:100%; }
  .person-title{ font-size:14px; }
  .person-name{ font-size:20px; letter-spacing:.16em; }
  .person-badge{ font-size:13px; padding:7px 12px; }

  /* join */
  .join-kicker{ font-size:21px; }
  .join-title{ font-size:32px; }

  .join-lead{
    font-size:15px;
    width:min(820px, 100%);
    margin-inline:auto;
  }

  .join-cards{
    grid-template-columns:repeat(3, 1fr);
    gap:28px;
    margin-top:72px;
  }
  .join-card{
    margin-top:0;               /* PCは横並びなので不要 */
    padding:70px 26px 26px;
  }
  .join-card-logo{
    width:92px;
    height:92px;
    top:-48px;
  }
  .join-card-title{ font-size:26px; }
  .join-card-title + .join-card-title{ font-size:16px; }
  .join-card-text{ font-size:14px; line-height:2.05; }

  .join-cta{
    grid-template-columns:1fr 1fr;
    gap:24px;
    align-items:start;
    width:min(980px, 100%);
    margin-inline:auto;
  }

  .join-cta-label{
    font-size:18px;
    margin-bottom:12px;
  }
  .join-body--white .join-cta-label{
    font-size:18px;
  }

  .join-cta-btn{
    width:min(420px, 100%);
    padding:18px 20px;
    font-size:18px;
  }
  .join-cta-note{ font-size:12px; }

  .contact-title{ font-size:34px; margin-bottom:34px; }
  .contact-grid{
    grid-template-columns:1fr 1fr;
    gap:26px 34px;
  }
  .contact-textarea{ min-height:260px; }
  .contact-consent{ font-size:18px; }

  /* =========================
    Footer（PC：左右横並び＆センター）
  ========================= */
  .footer-inner{
    display:flex;                 /* ← flexに戻す */
    flex-direction:row;
    justify-content:center;       /* 全体をセンター寄せ */
    align-items:center;           /* 縦位置揃え */
    gap:32px;                     /* 左右の間隔 */
    text-align:left;              /* 右側テキストを自然に */
  }

  .footer-left,
  .footer-right{
    margin:0;                     /* SP用のautoを無効化 */
  }

  .footer-sp-logo{ display:none; }
  .footer-pc-logo{
    display:block;
    width:130px;
    height:auto;
  }

  .footer-right{
    width:auto;                   /* SPのwidth:100%を打ち消す */
  }

  .footer-primary-row{
    justify-content:flex-start;
  }

  .footer-tag{ font-size:24px; }
  .footer-big{ font-size:30px; }
  .footer-meta{ font-size:12px; }
  .footer-meta-line{ font-size:18px; }

  /* modal */
  .greeting-modal__inner{ padding:22px; }
  .greeting-modal__name{ font-size:20px; }
  .greeting-modal__body{ font-size:15px; }
}
