/* ============================================
   PAAN Corporate Site v2
   menupaan.com 完全踏襲、 色のみ Royal Navy 系に置換
   ============================================ */

:root {
  /* === Color tokens === */
  /* menupaan: 主軸赤 #9B1C31 → PAAN: 主軸紺 #1A2E5C */
  --paan-primary:      #1A2E5C;   /* 主軸 royal navy (= menupaan #9B1C31 相当) */
  --paan-primary-deep: #0E1C3D;   /* hover 用 deep (= menupaan #7A1025 相当) */
  --paan-primary-soft: #6B7DA0;   /* sub label 紺グレー (= menupaan #C27680 相当) */
  --paan-gold:         #C9A961;   /* heritage gold (= menupaan diners theme と共通) */

  /* === Surfaces & lines === */
  --paan-bg:        #FFFFFF;
  --paan-card:      #FDFAFB;       /* menupaan #FDFAF7 相当 (微寒色寄り) */
  --paan-line:      #E4E8F0;       /* menupaan #F0E4D9 相当 (紺系) */
  --paan-line-2:    #E8DDD6;       /* menupaan footer border 相当 */

  /* === Type colors === */
  --paan-ink:       #1A2040;       /* 本文 (= menupaan #3A1420 相当の濃紺) */
  --paan-ink-mid:   #5A6378;       /* 中間 (= menupaan #7A6968 相当) */
  --paan-ink-soft:  #8898B2;       /* 弱 (= menupaan #C27680 相当) */
}

* { margin:0; padding:0; box-sizing:border-box; }

body {
  font-family:'Noto Sans JP', -apple-system, 'Helvetica Neue', sans-serif;
  background:#FFFFFF;
  color:var(--paan-ink);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  /* fixed header オフセット (menupaan踏襲) */
  padding-top:96px;
}

html { scroll-padding-top:108px; scroll-behavior:smooth; }

a { color:inherit; text-decoration:none; }

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

/* ============================================
   HEADER — menupaan.com 完全踏襲 (fixed + blur)
   ============================================ */
.mp-site-header {
  padding:20px 32px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid var(--paan-line);
  background:rgba(255,255,255,0.96);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  font-family:'Noto Sans JP', -apple-system, sans-serif;
  position:fixed;
  top:0; left:0; right:0;
  z-index:1000;
  will-change:transform;
  -webkit-transform:translate3d(0,0,0);
  transform:translate3d(0,0,0);
  box-shadow:0 1px 0 rgba(0,0,0,0.04);
}

.mp-site-header.mp-scrolled {
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}

.mp-site-header a { text-decoration:none; color:inherit; }

/* ロゴ — menupaan の MENU-PAAN 表記と完全同形式
   v3 (2026-05-10 ろくちゃん指示「ヘッダーnavの中央揃え微調整」):
   flex:1 を持たせて右側の mp-header-spacer (= flex:1) と対称化、
   ロゴ幅に依存せず mp-lp-nav が画面物理中央に揃う仕組み。 */
.mp-site-logo {
  font-family:'Marcellus', 'Noto Serif JP', serif;
  font-size:26px;
  color:var(--paan-primary);
  letter-spacing:3px;
  line-height:1;
  display:inline-flex;
  align-items:baseline;
  gap:10px;
  white-space:nowrap;
  flex-shrink:0;
  flex:1;
  justify-content:flex-start;
}

/* LP ナビ (menupaan踏襲: 中央寄せ、 下線 active 表示) */
.mp-lp-nav {
  display:flex;
  align-items:center;
  gap:28px;
  flex:1;
  justify-content:center;
}

.mp-lp-link {
  font-size:13px;
  letter-spacing:0.06em;
  color:#5a6378;
  padding:6px 2px;
  position:relative;
  transition:color 0.15s;
  white-space:nowrap;
}

.mp-lp-link:hover {
  color:var(--paan-primary);
}

.mp-lp-link.active {
  color:var(--paan-primary);
  font-weight:500;
}

.mp-lp-link.active::after {
  content:'';
  position:absolute;
  bottom:-2px;
  left:0; right:0;
  height:2px;
  border-radius:2px;
  background:var(--paan-primary);
}

/* 右側スペーサー (LP nav 物理中央揃えの対称用)
   v3: flex:1 でロゴ側 (= flex:1) と完全対称。 mp-lp-nav (= flex:1 + justify-content:center)
   が画面物理中央に揃う。 ロゴ幅変化にも追随。 */
.mp-header-spacer {
  flex:1;
  flex-shrink:0;
}

@media (max-width:720px) {
  body { padding-top:72px; }
  html { scroll-padding-top:84px; }
  .mp-site-header { padding:14px 18px; }
  .mp-site-logo { font-size:20px; letter-spacing:2px; flex:0 0 auto; }
  .mp-lp-nav { gap:14px; flex:0 1 auto; }
  .mp-lp-link { font-size:12px; }
  .mp-header-spacer { display:none; }
}

@media (max-width:480px) {
  .mp-lp-nav { gap:10px; }
  .mp-lp-link { font-size:11.5px; }
}

/* ============================================
   HERO (menupaan踏襲: 背景画像 + 白いoverlay)
   ============================================ */
.hero {
  position:relative;
  padding:24px 24px 32px;
  text-align:center;
  background-color:var(--paan-card);
  background-image:url('/assets/hero/hero-london-1600.webp');
  background-size:cover;
  background-position:center;
  overflow:hidden;
}

@media (max-width:480px) {
  .hero {
    background-image:url('/assets/hero/hero-london-800.webp');
  }
}

@media (min-width:1280px) and (-webkit-min-device-pixel-ratio:2),
       (min-width:1280px) and (min-resolution:192dpi) {
  .hero {
    background-image:url('/assets/hero/hero-london-2400.webp');
  }
}

.hero::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(255,255,255,0.86) 50%, rgba(247,249,252,0.96) 100%);
  z-index:1;
}

.hero > * { position:relative; z-index:2; }

.hero-title {
  font-family:'Noto Serif JP', serif;
  font-size:30px;
  font-weight:500;
  color:var(--paan-primary);
  letter-spacing:0.03em;
  line-height:1.55;
  margin:48px auto 16px;
  max-width:640px;
}

.hero-sub {
  font-family:'Noto Serif JP', serif;
  font-size:16px;
  font-weight:400;
  color:var(--paan-ink-mid);
  letter-spacing:0.04em;
  line-height:2;
  margin:0 auto 24px;
  max-width:520px;
}

.hero-tagline {
  font-family:'Noto Serif JP', serif;
  font-size:15px;
  color:var(--paan-primary);
  letter-spacing:0.04em;
  margin-bottom:36px;
}

.hero-tagline .brand {
  font-family:'Marcellus', serif;
  font-size:17px;
  letter-spacing:0.18em;
  margin-right:4px;
}

@media (max-width:720px) {
  .hero { padding:20px 20px 28px; }
  .hero-title { font-size:24px; line-height:1.55; margin:32px auto 14px; }
  .hero-sub { font-size:14.5px; line-height:1.95; }
  .hero-tagline { font-size:13px; margin-bottom:24px; }
  .hero-tagline .brand { font-size:15px; }
}

/* ============================================
   PAGE WRAP (menupaan踏襲: 760px / 48-24-40)
   ============================================ */
.page-wrap {
  max-width:760px;
  margin:0 auto;
  padding:48px 24px 40px;
}

.page-eyebrow {
  font-family:'Marcellus', serif;
  font-size:13px;
  color:var(--paan-primary-soft);
  letter-spacing:0.22em;
  text-transform:uppercase;
  text-align:center;
  margin-bottom:14px;
}

.page-title {
  font-family:'Noto Serif JP', serif;
  font-size:30px;
  font-weight:500;
  letter-spacing:0.05em;
  line-height:1.55;
  color:var(--paan-ink);
  text-align:center;
  margin-bottom:32px;
}

/* ============================================
   SECTIONS (menupaan info-section 完全踏襲)
   ============================================ */
.info-section {
  margin-bottom:40px;
}

.info-h {
  font-family:'Noto Serif JP', serif;
  font-size:20px;
  font-weight:500;
  letter-spacing:0.06em;
  color:var(--paan-ink);
  margin-bottom:20px;
  padding-bottom:14px;
  border-bottom:1px solid var(--paan-line);
}

.info-grid {
  background:var(--paan-card);
  border:1px solid var(--paan-line);
  border-radius:6px;
  padding:8px 24px;
}

.info-row {
  display:grid;
  grid-template-columns:140px 1fr;
  gap:20px;
  padding:16px 0;
  border-bottom:1px solid var(--paan-line);
}

.info-row:last-child { border-bottom:none; }

.info-key {
  font-family:'Noto Serif JP', serif;
  font-size:13.5px;
  color:var(--paan-ink-mid);
  letter-spacing:0.06em;
}

.info-val {
  font-size:14px;
  color:var(--paan-ink);
  line-height:1.75;
  letter-spacing:0.02em;
}

.info-val a {
  color:var(--paan-primary);
  border-bottom:1px solid var(--paan-primary);
  padding-bottom:1px;
}

/* ============================================
   NEWS LIST (info-section 内に置く想定)
   ============================================ */
.news-list {
  list-style:none;
  border-top:1px solid var(--paan-line);
}

.news-item {
  display:grid;
  grid-template-columns:120px 90px 1fr;
  gap:20px;
  align-items:center;
  padding:16px 4px;
  border-bottom:1px solid var(--paan-line);
}

.news-date {
  font-family:'Marcellus', serif;
  font-size:13.5px;
  letter-spacing:0.10em;
  color:var(--paan-ink-mid);
}

.news-tag {
  display:inline-block;
  font-family:'Noto Serif JP', serif;
  font-size:11px;
  font-weight:500;
  letter-spacing:0.10em;
  padding:3px 10px;
  border-radius:2px;
  text-align:center;
  white-space:nowrap;
}

.tag-release { background:var(--paan-primary); color:#FFFFFF; }
.tag-product { background:var(--paan-gold); color:#FFFFFF; }
.tag-info    { background:var(--paan-card); color:var(--paan-primary); border:1px solid var(--paan-line); }

.news-body {
  font-size:14px;
  color:var(--paan-ink);
  letter-spacing:0.02em;
  line-height:1.75;
}

.news-body a {
  color:var(--paan-primary);
  border-bottom:1px solid var(--paan-primary);
  padding-bottom:1px;
}

@media (max-width:720px) {
  .news-item {
    grid-template-columns:1fr;
    gap:6px;
    padding:14px 4px;
  }
  .news-tag { justify-self:start; }
}

/* ============================================
   MISSION PAGE — menupaan 完全踏襲、 5章構成 + Founder's Story
   ============================================ */

/* セクション (info-section と並列の汎用) */
.section {
  margin-bottom:48px;
}

.section-eyebrow-sm {
  font-family:'Marcellus', serif;
  font-size:12px;
  color:var(--paan-primary-soft);
  letter-spacing:0.18em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.section-h {
  font-family:'Noto Serif JP', serif;
  font-size:22px;
  font-weight:500;
  letter-spacing:0.05em;
  line-height:1.6;
  color:var(--paan-ink);
  margin-bottom:24px;
  padding-bottom:16px;
  border-bottom:1px solid var(--paan-line);
}

.section-body p {
  font-family:'Noto Serif JP', serif;
  font-size:15.5px;
  line-height:1.95;
  letter-spacing:0.04em;
  color:var(--paan-ink);
  margin-bottom:20px;
}

.section-body p strong {
  color:var(--paan-primary);
  font-weight:500;
}

.section-body p:last-child { margin-bottom:0; }

/* page-title 内の strong (= 強調) */
.page-title strong {
  color:var(--paan-primary);
  font-weight:500;
}

/* ============ FOUNDER'S STORY (menupaan v315 踏襲) ============ */
.founder-section {
  margin-top:64px;
  padding:48px 0 0;
  border-top:1px solid var(--paan-line);
}

.founder-section .section-eyebrow-sm {
  font-family:'Marcellus', serif;
  font-size:11px;
  color:var(--paan-primary-soft);
  letter-spacing:0.24em;
  text-transform:uppercase;
  margin-bottom:14px;
  text-align:center;
}

.founder-section .section-h {
  font-family:'Noto Serif JP', serif;
  font-size:24px;
  font-weight:500;
  line-height:1.6;
  letter-spacing:0.04em;
  color:var(--paan-ink);
  text-align:center;
  margin-bottom:32px;
  padding-bottom:0;
  border-bottom:none;
}

.founder-story-body {
  font-family:'Noto Serif JP', serif;
  font-size:15px;
  line-height:1.95;
  color:var(--paan-ink);
  letter-spacing:0.03em;
}

.founder-story-body p {
  margin:0 0 18px;
}

.founder-story-body p:last-of-type {
  margin-bottom:0;
}

.founder-story-body em {
  font-family:'Marcellus', 'Noto Serif JP', serif;
  font-style:normal;
  font-weight:500;
  color:var(--paan-primary);
  letter-spacing:0.05em;
}

.founder-story-body strong {
  color:var(--paan-primary);
  font-weight:500;
}

.founder-divider {
  width:32px;
  height:1px;
  background:var(--paan-primary-soft);
  margin:24px auto;
  border:none;
}

/* 著者署名 (右揃え、 menupaan v316-perf15 踏襲) */
.founder-signature {
  text-align:right;
  margin-top:32px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.founder-signature-name {
  font-family:'Noto Serif JP', serif;
  font-size:18px;
  color:var(--paan-ink);
  letter-spacing:0.18em;
  font-weight:500;
  line-height:1.4;
}

.founder-signature-title {
  font-family:'Noto Serif JP', serif;
  font-size:12.5px;
  color:var(--paan-ink-mid);
  letter-spacing:0.06em;
  line-height:1.5;
  font-style:italic;
}

@media (max-width:720px) {
  .section { margin-bottom:32px; }
  .founder-section { margin-top:48px; padding-top:36px; }
  .founder-section .section-h { font-size:20px; line-height:1.55; margin-bottom:22px; }
  .founder-story-body { font-size:14px; line-height:1.9; }
  .founder-story-body p { margin-bottom:14px; }
}

/* ============================================
   MISSION PAGE — 旧 v3 の mission-statement / values は削除済
   (menupaan の section ベース構造に統一)
   ============================================ */

/* ============================================
   BRAND PAGE
   ============================================ */
.brand-card {
  background:var(--paan-card);
  border:1px solid var(--paan-line);
  border-radius:6px;
  padding:32px 28px;
  margin-bottom:20px;
}

.brand-card-status {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Marcellus', serif;
  font-size:11.5px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--paan-ink-mid);
  margin-bottom:18px;
}

.status-dot {
  width:7px;
  height:7px;
  border-radius:50%;
  display:inline-block;
}

.status-dot-live {
  background:var(--paan-primary);
  box-shadow:0 0 0 0 rgba(26,46,92,0.55);
  animation:pulse 2.4s infinite;
}

@keyframes pulse {
  0%   { box-shadow:0 0 0 0   rgba(26,46,92,0.55); }
  70%  { box-shadow:0 0 0 9px rgba(26,46,92,0); }
  100% { box-shadow:0 0 0 0   rgba(26,46,92,0); }
}

.status-dot-soon { background:var(--paan-line); border:1px solid var(--paan-ink-soft); }

.brand-card-name {
  font-family:'Marcellus', serif;
  font-size:28px;
  letter-spacing:0.10em;
  color:var(--paan-primary);
  margin-bottom:6px;
  font-weight:400;
}

.brand-card-name-sm {
  font-family:'Noto Serif JP', serif;
  font-size:17px;
  letter-spacing:0.05em;
  color:var(--paan-ink);
  margin-bottom:6px;
  font-weight:500;
}

.brand-card-tagline {
  font-family:'Noto Serif JP', serif;
  font-size:14px;
  letter-spacing:0.06em;
  color:var(--paan-primary);
  font-weight:500;
  margin-bottom:22px;
}

.brand-card-tagline-sm {
  font-size:12.5px;
  letter-spacing:0.04em;
  color:var(--paan-ink-soft);
  margin-bottom:18px;
}

.brand-card-body {
  font-family:'Noto Serif JP', serif;
  font-size:14px;
  line-height:1.95;
  color:var(--paan-ink);
  margin-bottom:22px;
  letter-spacing:0.03em;
}

.brand-card-body p { margin-bottom:14px; }
.brand-card-body p:last-child { margin-bottom:0; }

.brand-card-body strong {
  color:var(--paan-primary);
  font-weight:500;
}

.brand-features {
  list-style:none;
  background:#FFFFFF;
  border:1px solid var(--paan-line);
  padding:14px 18px;
  margin-top:14px;
  border-radius:4px;
}

.brand-features li {
  font-size:13px;
  line-height:1.95;
  color:var(--paan-ink-mid);
  padding:3px 0;
  letter-spacing:0.02em;
}

.brand-features strong {
  color:var(--paan-primary);
  font-weight:500;
  margin-right:6px;
}

/* CTA — menupaan の hero-cta 踏襲 */
.brand-card-cta {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.brand-cta-primary {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:'Noto Sans JP', sans-serif;
  font-size:13px;
  letter-spacing:0.10em;
  color:#FFFFFF;
  background:var(--paan-primary);
  padding:14px 32px;
  border:1.5px solid var(--paan-primary);
  border-radius:999px;
  font-weight:500;
  transition:all 0.15s;
}

.brand-cta-primary:hover {
  background:var(--paan-primary-deep);
  border-color:var(--paan-primary-deep);
  transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(26,46,92,0.25);
}

.cta-arrow {
  transition:transform 0.15s;
}

.brand-cta-primary:hover .cta-arrow { transform:translateX(2px); }

.brand-cta-secondary {
  display:inline-flex;
  align-items:center;
  font-family:'Noto Sans JP', sans-serif;
  font-size:13px;
  letter-spacing:0.10em;
  color:var(--paan-primary);
  background:#FFFFFF;
  padding:14px 28px;
  border:1.5px solid var(--paan-primary);
  border-radius:999px;
  font-weight:500;
  transition:all 0.15s;
}

.brand-cta-secondary:hover {
  background:rgba(26,46,92,0.06);
  transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(26,46,92,0.15);
}

@media (max-width:720px) {
  .brand-card { padding:26px 22px; }
  .brand-card-name { font-size:24px; }
  .brand-card-cta { flex-direction:column; }
  .brand-cta-primary, .brand-cta-secondary { justify-content:center; text-align:center; }
}

/* ============================================
   FOUNDERS GRID — menupaan完全踏襲
   ============================================ */
.founders-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
  margin-top:8px;
}

.founder-card {
  padding:32px 28px;
  background:var(--paan-card);
  border:1px solid var(--paan-line);
  border-radius:6px;
}

.founder-role {
  font-family:'Marcellus', serif;
  font-size:11.5px;
  color:var(--paan-primary-soft);
  letter-spacing:0.22em;
  margin-bottom:10px;
  text-transform:uppercase;
}

.founder-name {
  font-family:'Noto Serif JP', serif;
  font-size:20px;
  font-weight:500;
  letter-spacing:0.04em;
  color:var(--paan-ink);
  margin-bottom:6px;
}

.founder-name-en {
  font-family:'Marcellus', serif;
  font-size:13px;
  color:var(--paan-ink-mid);
  letter-spacing:0.06em;
  margin-bottom:18px;
}

.founder-bio {
  font-family:'Noto Serif JP', serif;
  font-size:13.5px;
  line-height:1.95;
  color:var(--paan-ink);
  letter-spacing:0.02em;
}

@media (max-width:720px) {
  .founders-grid { grid-template-columns:1fr; gap:14px; }
  .founder-card { padding:24px 22px; }
  .founder-name { font-size:18px; }
  .founder-bio { font-size:13px; }
}

/* ============================================
   CONTACT
   ============================================ */
.contact-lead {
  font-family:'Noto Serif JP', serif;
  font-size:14.5px;
  line-height:2.0;
  color:var(--paan-ink-mid);
  text-align:center;
  max-width:600px;
  margin:0 auto 28px;
  letter-spacing:0.03em;
}

.contact-card {
  background:var(--paan-primary);
  color:#FFFFFF;
  padding:40px 32px;
  border-radius:6px;
  text-align:center;
}

.contact-card-eyebrow {
  font-family:'Marcellus', serif;
  font-size:12px;
  color:rgba(255,255,255,0.7);
  letter-spacing:0.22em;
  text-transform:uppercase;
  margin-bottom:14px;
}

.contact-email {
  display:inline-block;
  font-family:'Marcellus', serif;
  font-size:24px;
  color:#FFFFFF;
  letter-spacing:0.06em;
  border-bottom:1px solid rgba(255,255,255,0.5);
  padding-bottom:5px;
  margin-bottom:20px;
  transition:opacity 0.15s ease;
}

.contact-email:hover { opacity:0.8; }

.contact-note {
  font-family:'Noto Serif JP', serif;
  font-size:13px;
  line-height:1.95;
  color:rgba(255,255,255,0.8);
  max-width:500px;
  margin:0 auto;
  letter-spacing:0.02em;
}

.inquiry-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:8px;
}

.inquiry-item {
  background:var(--paan-card);
  border:1px solid var(--paan-line);
  padding:22px 22px;
  border-radius:6px;
}

.inquiry-title {
  font-family:'Noto Serif JP', serif;
  font-size:14.5px;
  font-weight:500;
  letter-spacing:0.04em;
  color:var(--paan-primary);
  margin-bottom:8px;
}

.inquiry-body {
  font-family:'Noto Serif JP', serif;
  font-size:13px;
  line-height:1.95;
  color:var(--paan-ink-mid);
  letter-spacing:0.02em;
}

.inquiry-body a {
  color:var(--paan-primary);
  border-bottom:1px solid var(--paan-primary);
}

@media (max-width:720px) {
  .inquiry-grid { grid-template-columns:1fr; gap:10px; }
  .contact-card { padding:32px 22px; }
  .contact-email { font-size:18px; letter-spacing:0.04em; word-break:break-all; }
}

/* ============================================
   FOOTER — menupaan.com 完全踏襲
   ============================================ */
.mp-site-footer {
  background:#FFFFFF;
  color:var(--paan-primary);
  padding:24px 20px 32px;
  margin-top:48px;
  border-top:1px solid var(--paan-line-2);
  text-align:center;
  font-family:'Noto Sans JP', -apple-system, sans-serif;
}

.mp-site-footer a { text-decoration:none; color:inherit; }

.mp-footer-logo-link {
  display:inline-block;
  transition:opacity 0.15s;
}

.mp-footer-logo-link:hover { opacity:0.75; }

.mp-footer-logo {
  font-family:'Marcellus', serif;
  font-size:18px;
  letter-spacing:2.5px;
  color:var(--paan-primary);
  margin-bottom:2px;
}

.mp-footer-tag {
  font-family:'Playfair Display', serif;
  font-size:10px;
  letter-spacing:0.18em;
  font-style:italic;
  color:var(--paan-primary-soft);
  margin-bottom:10px;
  text-transform:uppercase;
}

.mp-footer-links {
  display:flex;
  justify-content:center;
  gap:14px;
  font-size:12px;
  margin-bottom:8px;
  flex-wrap:wrap;
}

.mp-footer-link {
  color:var(--paan-primary);
  opacity:0.85;
}

.mp-footer-link:hover {
  opacity:1;
  text-decoration:underline;
}

.mp-footer-cross-wrap {
  margin-top:2px;
  margin-bottom:8px;
  display:flex;
  justify-content:center;
}

.mp-footer-cross-link {
  display:inline-block;
  font-size:11px;
  letter-spacing:0.10em;
  color:var(--paan-primary);
  font-style:italic;
  font-family:'Playfair Display', serif;
  padding:6px 16px;
  border:1px solid rgba(26,46,92,0.3);
  border-radius:999px;
  text-decoration:none;
  transition:all 0.2s;
  background:#FFFFFF;
}

.mp-footer-cross-link:hover {
  color:#FFFFFF;
  background:var(--paan-primary);
  border-color:var(--paan-primary);
}

.mp-footer-copy {
  font-size:10px;
  color:var(--paan-primary-soft);
  letter-spacing:0.08em;
  margin-top:10px;
}

@media (max-width:380px) {
  .mp-footer-copy { font-size:9px; letter-spacing:0.04em; }
}

/* ============================================
   RESPONSIVE (menupaan踏襲)
   ============================================ */
@media (max-width:720px) {
  .page-wrap { padding:32px 22px 32px; }
  .page-title { font-size:23px; line-height:1.5; margin-bottom:20px; }
  .info-section { margin-bottom:32px; }
  .info-h { font-size:18px; }
  .info-grid { padding:4px 18px; }
  .info-row { grid-template-columns:100px 1fr; gap:14px; padding:14px 0; font-size:12.5px; }
  .info-key { font-size:12.5px; }
  .info-val { font-size:13px; }
  .section-h { font-size:19px; line-height:1.6; }
  .section-body p { font-size:14.5px; }
}
