/* ============================================================
   renewal 共通ヘッダー スタイル
   feature 配下のページからも本家 TOP (index.html) と同じ
   緑系 lp-header を使うための外部化 CSS
   ============================================================ */

@import url('https://fonts.googleapis.com/icon?family=Material+Icons+Round');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700;900&display=swap');

:root {
  --lp-main: #07B459;
  --lp-main-dark: #05954A;
  --lp-hero-ink: #1C3244;
}

.material-icons-round {
  font-family: 'Material Icons Round', sans-serif;
  font-weight: normal; font-style: normal;
  display: inline-block; line-height: 1;
  text-transform: none; letter-spacing: normal;
  word-wrap: normal; white-space: nowrap; direction: ltr;
  -webkit-font-smoothing: antialiased;
}

/* 固定ヘッダー */
.lp-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 64px;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  border-bottom: 1px solid transparent;
  transition: border-color .25s ease, box-shadow .25s ease;
  box-sizing: border-box;
}
.lp-header.scrolled {
  border-bottom-color: rgba(28, 50, 68, 0.06);
  box-shadow: 0 8px 20px -12px rgba(28, 50, 68, 0.08);
}
.lp-logo {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 900; font-size: 22px;
  color: var(--lp-hero-ink);
  text-decoration: none;
  letter-spacing: 0.01em;
}
.lp-logo-mark {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
}
.lp-logo-mark img {
  width: 100%; height: 100%; object-fit: contain; display: block;
}
.lp-nav {
  display: flex; align-items: center; gap: 10px;
}
.lp-nav a { text-decoration: none; }
.lp-nav-cta {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--lp-main);
  color: #fff !important;
  border-radius: 999px;
  padding: 10px 22px;
  font-size: 14px; font-weight: 700;
  text-decoration: none;
  box-shadow: 0 6px 16px -4px rgba(7, 180, 89, 0.45);
  transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease;
  font-family: 'Noto Sans JP', sans-serif;
}
.lp-nav-cta:hover {
  background: var(--lp-main-dark);
  transform: translateY(-1px);
  box-shadow: 0 10px 22px -6px rgba(7, 180, 89, 0.55);
}
.lp-nav-cta .material-icons-round { font-size: 18px; }
.lp-nav-ghost {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--lp-hero-ink);
  text-decoration: none;
  font-size: 14px; font-weight: 700;
  padding: 10px 16px;
  border-radius: 999px;
  transition: background-color .2s;
  font-family: 'Noto Sans JP', sans-serif;
}
.lp-nav-ghost:hover { background-color: rgba(7, 180, 89, 0.06); }
@media (max-width: 720px) {
  .lp-header { height: 56px; padding: 0 16px; }
  .lp-logo { font-size: 18px; }
  .lp-nav-ghost { display: none; }
  .lp-nav-cta { padding: 8px 14px; font-size: 12px; }
  .lp-nav-cta .material-icons-round { font-size: 16px; }
}

/* ヘッダー分の本文余白 (固定ヘッダーで下に隠れないように) */
body.with-lp-header { padding-top: 64px; }
@media (max-width: 720px) {
  body.with-lp-header { padding-top: 56px; }
}

/* ============================================================
   フッター共通: CONTACT CTA + lp-sub-footer
   ============================================================ */
.r-sec { padding: 88px 24px; position: relative; font-family: 'Noto Sans JP', sans-serif; }
.r-sec .r-container { max-width: 1180px; margin: 0 auto; }

.r-cta {
  background: linear-gradient(135deg, var(--lp-main) 0%, var(--lp-main-dark) 100%);
  border-radius: 28px; padding: 56px 40px; text-align: center; color: #fff;
}
.r-cta h2 {
  font-size: clamp(24px, 3.2vw, 34px); font-weight: 900;
  margin: 0 0 14px; color: #fff;
}
.r-cta p {
  font-size: 14px; line-height: 1.85;
  margin: 0 0 28px; opacity: .95;
}
.r-cta-row {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}
.r-cta-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 16px 28px; border-radius: 999px;
  font-size: 15px; font-weight: 900; text-decoration: none;
  transition: transform .2s ease;
}
.r-cta-btn.primary { background: #fff; color: var(--lp-main) !important; }
.r-cta-btn.ghost { border: 2px solid #fff; color: #fff !important; }
.r-cta-btn:hover { transform: translateY(-2px); }
@media (max-width: 540px) {
  .r-sec { padding: 64px 16px; }
  .r-cta { padding: 44px 24px; border-radius: 20px; }
}

.lp-sub-footer {
  background: #F8F8F8;
  color: #5A6371;
  padding: 28px 20px 22px;
  text-align: center;
  font-size: 12px;
  line-height: 1.8;
  font-family: 'Noto Sans JP', sans-serif;
}
.lp-sub-footer strong { color: var(--lp-main-dark); font-size: 14px; font-weight: 900; }
.lp-sub-footer > p { margin: 0; }
.lp-sub-footer > p:nth-of-type(2) { margin-top: 4px !important; font-size: 11px; }

/* ============================================================
   #homeFooter (8カラム緑フッター) TOPページと統一のスタイル
   base.css の旧スタイルを上書き (renewal-header.css 後読み)
   ============================================================ */
#homeFooter {
  position: relative !important;
  padding: 40px 5% 20px !important;
  background: linear-gradient(135deg, #05954A 0%, #07B459 55%, #2FB484 100%) !important;
  color: #FFF !important;
  font-family: 'Noto Sans JP', sans-serif !important;
}
#homeFooter a {
  color: #FFF !important;
  text-decoration: none !important;
  transition: opacity .2s !important;
}
#homeFooter a:hover { opacity: 0.75; }
#homeFooter .vessel {
  max-width: 1600px !important;
  margin: 0 auto !important;
  width: auto !important;
  padding: 0 !important;
}
#homeFooter .nav01 {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  padding: 0 !important;
  margin: 0 !important;
}
#homeFooter .footer_wrap {
  width: 17% !important;
  padding: 16px 4% 10px 0 !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  background: transparent !important;
  border: none !important;
}
#homeFooter .footer_wrap h4 {
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  margin: 0 0 10px 0 !important;
  color: #FFF !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  text-align: left !important;
}
#homeFooter .footer_wrap ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
#homeFooter .footer_wrap li {
  font-size: 12px !important;
  line-height: 1.9 !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
  background: transparent !important;
}
#homeFooter .footer_wrap li::before { content: none !important; }
#homeFooter .footer_wrap li a {
  display: inline-block !important;
  padding: 0 !important;
}
#homeFooter .footer_text {
  margin-top: 20px !important;
  padding: 0 0 8px !important;
}
#homeFooter .footer_p {
  font-size: 11px !important;
  color: #FFF !important;
  line-height: 1.7 !important;
  margin: 0 0 14px 0 !important;
  opacity: 0.95 !important;
}
#homeFooter .copyright01 {
  text-align: center !important;
  font-size: 11px !important;
  padding: 12px 0 4px !important;
  color: #FFF !important;
  border-top: 1px solid rgba(255,255,255,0.25) !important;
  background: transparent !important;
}
@media (max-width: 1150px) {
  #homeFooter .footer_wrap { width: 25% !important; }
}
@media (max-width: 720px) {
  #homeFooter { padding: 24px 5% 16px !important; }
  #homeFooter .footer_wrap { width: 50% !important; padding: 12px 4% 8px 0 !important; }
  #homeFooter .footer_wrap h4 { font-size: 12px !important; }
  #homeFooter .footer_wrap li { font-size: 11.5px !important; }
}
@media (max-width: 420px) {
  #homeFooter .footer_wrap { width: 100% !important; }
}
