/* ══════════════════════════════════════════════
   RESET & VARIABLES
══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --g1: #CCDE5B;   /* lime — ボタン・装飾背景 */
  --g2: #4A8262;   /* medium green — テキストアクセント・ボーダー */
  --teal: #435E60; /* teal — ダーク要素・アクセント */
  --gold: #F8C746; --gold2: #e8a820;
  --red: #e53935;
  --dark: #273824;  /* 主見出し・ダーク文字 */
  --dark2: #435E60; /* 補助テキスト・セカンダリ */
  --mid: #dceee4;   /* ライトセクション背景（緑薄め） */
  --mid2: #cce4d6;  /* やや深いライト背景 */
  --white: #ffffff;
  --gray: #3d5848;  /* 本文補助テキスト（コントラスト強化） */
  --gray2: #2e4a38; /* セカンダリテキスト */
  --border: rgba(74,130,98,0.32);
  --card: #ffffff;
  --glow-g: 0 4px 28px rgba(74,130,98,0.22);
  --glow-s: 0 2px 14px rgba(74,130,98,0.16);
}
html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family: 'Noto Sans JP', sans-serif; background: var(--white); color: var(--dark); overflow-x: hidden; }
::selection { background: var(--g1); color: var(--dark); }

/* ══════════════════════════════════════════════
   SCROLL PROGRESS
══════════════════════════════════════════════ */
#progress-bar {
  position: fixed; top: 0; left: 0; height: 3px; width: 0%;
  background: linear-gradient(90deg, var(--g1), var(--gold));
  z-index: 9999; box-shadow: 0 0 10px rgba(204,222,91,.6);
  transition: width 0.1s linear;
}

/* ══════════════════════════════════════════════
   LOADER
══════════════════════════════════════════════ */
#loader {
  position: fixed; inset: 0; background: var(--dark);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  z-index: 10000; transition: opacity 0.7s, visibility 0.7s;
}
#loader.hidden { opacity: 0; visibility: hidden; }
.ld-panda { font-size: 4.5rem; animation: ldBounce 0.55s ease-in-out infinite alternate; margin-bottom: 20px; }
@keyframes ldBounce { from{transform:translateY(0) scale(1)} to{transform:translateY(-18px) scale(1.06)} }
.ld-text { font-size: 1rem; font-weight: 700; color: var(--g1); letter-spacing: .2em; margin-bottom: 20px; animation: blink 1.2s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.ld-track { width: 180px; height: 3px; background: rgba(255,255,255,.12); border-radius: 3px; overflow: hidden; }
.ld-fill  { height: 100%; background: linear-gradient(90deg,var(--g1),var(--gold)); border-radius: 3px; animation: ldFill 1.8s ease-out forwards; }
@keyframes ldFill { from{width:0} to{width:100%} }

/* ══════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════ */
header {
  position: fixed; top: 0; left: 0; right: 0; height: 66px;
  display: flex; align-items: center; z-index: 1000;
  background: var(--dark);
  border-bottom: 1px solid rgba(204,222,91,.18);
  box-shadow: 0 2px 16px rgba(0,0,0,.15);
  transition: background .4s, border-color .4s, box-shadow .4s;
}
header.scrolled {
  background: var(--dark); backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(204,222,91,.22); box-shadow: 0 3px 24px rgba(0,0,0,.2);
}
.nav-in {
  max-width: 1140px; margin: 0 auto; padding: 0 28px;
  width: 100%; display: flex; align-items: center; justify-content: space-between;
}
.logo { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.logo-em { font-size: 2.1rem; filter: drop-shadow(0 0 8px rgba(74,130,98,.4)); transition: transform .3s; }
.logo:hover .logo-em { transform: rotate(-12deg) scale(1.1); }
.logo-tx strong { display: block; font-size: 1.3rem; font-weight: 900; color: #fff; line-height: 1; }
.logo-tx small  { font-size: .6rem; color: var(--g1); letter-spacing: .14em; }
.nav-links { display: flex; align-items: center; gap: 10px; }
.nav-links a {
  color: rgba(255,255,255,.8); font-size: .84rem; font-weight: 600; text-decoration: none;
  letter-spacing: .04em; padding: 7px 16px; border-radius: 40px;
  border: 1px solid rgba(255,255,255,.2);
  transition: color .2s, border-color .2s, background .2s;
}
.nav-links a::after { display: none; }
.nav-links a:hover { color: #fff; border-color: rgba(204,222,91,.6); background: rgba(204,222,91,.08); }
.nav-cta {
  background: linear-gradient(135deg,var(--g1),#a8bc3a);
  color: var(--dark) !important; font-weight: 900 !important;
  padding: 10px 22px; border-radius: 40px;
  box-shadow: 0 4px 18px rgba(204,222,91,.4);
  transition: transform .2s, box-shadow .2s !important;
}
.nav-cta:hover { transform: translateY(-2px) !important; box-shadow: 0 8px 28px rgba(204,222,91,.55) !important; }
.nav-cta::after { display:none !important; }

/* ══════════════════════════════════════════════
   HERO
══════════════════════════════════════════════ */
#hero {
  min-height: 110vh; position: relative; overflow: hidden;
  display: flex; align-items: center; padding-top: 66px;
  background: var(--white);
  transform: translateZ(0); /* Safari: overflow:hidden でブロブを正しくクリップ */
}

/* ── Aurora Blobs (multiply on white) ── */
.aurora-wrap {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
}
.aurora-wrap::after {
  content: ''; position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none;
}
.blob {
  position: absolute; border-radius: 50%;
  filter: blur(100px); opacity: .45; mix-blend-mode: multiply;
  will-change: transform;
}
.blob-1 {
  width: 640px; height: 640px;
  background: radial-gradient(circle, #CCDE5B 0%, transparent 70%);
  top: -20%; left: -12%;
  animation: blobMove1 18s ease-in-out infinite alternate;
}
.blob-2 {
  width: 520px; height: 520px;
  background: radial-gradient(circle, #4A8262 0%, transparent 70%);
  top: 15%; right: -10%;
  animation: blobMove2 22s ease-in-out infinite alternate;
}
.blob-3 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, #F8C746 0%, transparent 70%);
  bottom: 0%; left: 28%;
  animation: blobMove3 26s ease-in-out infinite alternate;
  opacity: .35;
}
.blob-4 {
  width: 320px; height: 320px;
  background: radial-gradient(circle, #435E60 0%, transparent 70%);
  top: 45%; left: 42%;
  animation: blobMove4 20s ease-in-out infinite alternate;
  opacity: .3;
}
.blob-5 {
  width: 280px; height: 280px;
  background: radial-gradient(circle, #CCDE5B 0%, transparent 70%);
  top: 8%; right: 28%;
  animation: blobMove1 15s ease-in-out infinite alternate-reverse;
  opacity: .3;
}
@keyframes blobMove1 {
  0%   { transform: translate(0px, 0px) scale(1); }
  33%  { transform: translate(60px, -40px) scale(1.08); }
  66%  { transform: translate(-30px, 50px) scale(.95); }
  100% { transform: translate(40px, 30px) scale(1.05); }
}
@keyframes blobMove2 {
  0%   { transform: translate(0, 0) scale(1); }
  40%  { transform: translate(-70px, 50px) scale(1.1); }
  80%  { transform: translate(40px, -60px) scale(.9); }
  100% { transform: translate(-20px, 20px) scale(1.04); }
}
@keyframes blobMove3 {
  0%   { transform: translate(0, 0) scale(1) rotate(0deg); }
  50%  { transform: translate(-50px, -30px) scale(1.12) rotate(10deg); }
  100% { transform: translate(50px, 20px) scale(.92) rotate(-8deg); }
}
@keyframes blobMove4 {
  0%   { transform: translate(0, 0) scale(1); }
  50%  { transform: translate(80px, -40px) scale(1.15); }
  100% { transform: translate(-40px, 60px) scale(.88); }
}

/* hero overlay — テキスト側を少し明くする程度 */
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(to right, rgba(255,255,255,.55) 0%, rgba(255,255,255,.25) 50%, transparent 100%);
}

/* ── Hero Layout ── */
.hero-inner {
  max-width: 1200px; width: 100%; margin: 0 auto; padding: 130px 40px;
  display: grid; grid-template-columns: 0.75fr 1.25fr; gap: 56px; align-items: center;
  position: relative; z-index: 2;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--dark); border: 1px solid var(--dark);
  color: var(--g1); font-size: .77rem; font-weight: 700;
  padding: 7px 18px; border-radius: 30px; letter-spacing: .1em;
  margin-bottom: 22px;
  animation: popUp .6s .2s both;
}
.badge-dot { width:7px; height:7px; border-radius:50%; background:var(--g2); animation:blink 1.4s ease-in-out infinite; box-shadow:0 0 6px rgba(74,130,98,.5); }
.hero-title {
  font-size: clamp(2rem, 4vw, 3rem); font-weight: 900; line-height: 1.18;
  color: var(--dark);
  margin-bottom: 24px;
  text-shadow: none;
  animation: popUp .8s .3s both;
}
.hero-title .grad {
  background: linear-gradient(135deg, #4A8262 0%, #CCDE5B 50%, #F8C746 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  background-size: 200% auto;
  animation: gradShift 4s linear infinite;
}
@keyframes gradShift { 0%{background-position:0% center} 100%{background-position:200% center} }
.hero-desc { color: var(--dark); font-size: 1rem; line-height: 1.9; margin-bottom: 36px; animation: popUp .8s .5s both; }
.hero-desc strong { color: var(--g2); font-weight: 900; }
.hero-btns { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; animation: popUp .8s .7s both; }

@keyframes popUp { from{opacity:0;transform:translateY(36px)} to{opacity:1;transform:translateY(0)} }

.btn-main {
  display: inline-flex; align-items: center; gap: 9px;
  background: linear-gradient(135deg, var(--g1), #a8bc3a);
  color: var(--dark); font-weight: 900; font-size: 1rem;
  padding: 15px 34px; border-radius: 50px; text-decoration: none;
  white-space: nowrap;
  box-shadow: 0 6px 24px rgba(204,222,91,.45); transition: all .3s; position: relative; overflow: hidden;
}
.btn-main::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.3),transparent); transform:translateX(-100%); transition:transform .4s; }
.btn-main:hover::before { transform:translateX(100%); }
.btn-main:hover { transform:translateY(-3px); box-shadow:0 12px 34px rgba(204,222,91,.55); }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  border: 2px solid var(--dark); color: var(--dark);
  font-weight: 800; font-size: 1rem;
  padding: 14px 28px; border-radius: 50px; text-decoration: none;
  white-space: nowrap;
  background: transparent;
  transition: all .3s;
}
.btn-ghost:hover { background: var(--dark); color: #fff; transform:translateY(-2px); box-shadow: 0 8px 24px rgba(39,56,36,.25); }

/* ── Route Animation (hero right) ── */
.hero-route {
  position: relative; display: flex; flex-direction: column; align-items: stretch; justify-content: center; gap: 12px;
  animation: fadeRight 1s .4s both;
}
@keyframes fadeRight { from{opacity:0;transform:translateX(50px)} to{opacity:1;transform:translateX(0)} }
.route-svg-wrap {
  width: 100%; max-width: 100%;
  background: rgba(12, 24, 18, 0.94);
  border: 1px solid rgba(74,130,98,.38);
  border-radius: 28px; padding: 24px;
  box-shadow: 0 12px 56px rgba(0,0,0,.35), inset 0 1px 0 rgba(74,130,98,.2);
}
.route-svg-wrap svg { display: block; width: 100%; height: auto; overflow: visible; }

/* city pulse rings */
.city-ring {
  animation: cityPulse 2.4s ease-out infinite;
  transform-box: fill-box; transform-origin: center;
}
.city-ring-2 { animation-delay: .8s; }
@keyframes cityPulse {
  0%   { r: 8px;  opacity: .8; }
  100% { r: 22px; opacity: 0; }
}

/* dashed flight path draw-on */
.flight-path {
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  animation: drawPath 2s .6s ease-out forwards;
}
@keyframes drawPath { to { stroke-dashoffset: 0; } }

/* plane motion */
#plane {
  font-size: 22px;
  animation: planeFly 4s 2.6s ease-in-out infinite;
}
@keyframes planeFly {
  0%,100% { opacity: 0; }
  5%       { opacity: 1; }
  95%      { opacity: 1; }
}

/* route label tags */
.route-label {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 17px; font-weight: 700; fill: rgba(255,255,255,0.92);
}
.route-sublabel { font-size: 11px; fill: rgba(255,255,255,0.55); }
.route-city { font-size: 14px; font-weight: 700; fill: #7dcfa0; }

/* cargo dots that fly along route */
.cargo-dot { animation: cargoPop 4s 3s ease-in-out infinite; }
@keyframes cargoPop { 0%,100%{opacity:0} 10%,85%{opacity:1} }

/* scroll hint */
.scroll-hint {
  position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 7px;
  color: var(--gray); font-size: .7rem; letter-spacing: .15em;
  animation: fadeIn 1s 1.8s both;
}
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.scroll-pill { width: 22px; height: 38px; border: 1.5px solid rgba(74,130,98,.3); border-radius: 11px; display: flex; align-items: flex-start; justify-content: center; padding-top: 5px; }
.scroll-dot-el { width: 4px; height: 4px; border-radius: 50%; background: var(--g2); animation: scrollDot 1.8s ease-in-out infinite; }
@keyframes scrollDot { 0%{transform:translateY(0);opacity:1} 80%{transform:translateY(16px);opacity:.2} 100%{transform:translateY(0);opacity:1} }

/* ══════════════════════════════════════════════
   STATS
══════════════════════════════════════════════ */
#stats {
  background: var(--dark);
  border-top: none; border-bottom: none;
  padding: 56px 0;
}
.stats-grid { max-width:1140px; margin:0 auto; padding:0 28px; display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }
.stat-item { text-align:center; }
.stat-num {
  font-size: 2rem; font-weight:900; line-height:1.2; margin-bottom:6px;
  background: linear-gradient(135deg,var(--g1),var(--gold));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-label { font-size:.8rem; color: rgba(255,255,255,.6); line-height:1.6; }

/* ══════════════════════════════════════════════
   SECTION UTILITIES
══════════════════════════════════════════════ */
.container { max-width:1140px; margin:0 auto; padding:0 28px; }
.sec-pad { padding: 100px 0; }
.text-center { text-align: center; }
.sec-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: .7rem; font-weight: 700; letter-spacing: .22em;
  color: var(--g2); text-transform: uppercase; margin-bottom: 14px;
}
.sec-eyebrow::before,.sec-eyebrow::after { content:''; width:22px; height:1px; background:var(--g2); opacity:.5; }
.sec-title { font-size: clamp(1.7rem,3.2vw,2.6rem); font-weight:900; line-height:1.22; margin-bottom:14px; color: var(--dark); }
.sec-title .hl {
  background: linear-gradient(135deg, var(--g2), var(--g1), var(--gold));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.sec-sub { color:var(--dark); font-size:.95rem; line-height:1.8; margin-bottom:56px; }

/* Reveal */
.reveal { opacity:0; transform:translateY(44px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-l { opacity:0; transform:translateX(-44px); transition:opacity .7s ease,transform .7s ease; }
.reveal-l.visible { opacity:1; transform:translateX(0); }
.reveal-r { opacity:0; transform:translateX(44px); transition:opacity .7s ease,transform .7s ease; }
.reveal-r.visible { opacity:1; transform:translateX(0); }

/* ══════════════════════════════════════════════
   FLOW
══════════════════════════════════════════════ */
#flow { background: var(--mid); padding: 100px 0; }
.flow-track { display:flex; align-items:flex-start; position:relative; }
.flow-connector {
  position:absolute; top:35px; left:36px; right:36px; height:2px;
  background: linear-gradient(90deg,var(--g2) 0%,var(--g1) 50%,var(--gold) 100%);
  transform-origin:left; transform:scaleX(0);
  transition:transform 1.4s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 0 8px rgba(204,222,91,.5);
}
.flow-connector.on { transform:scaleX(1); }
.flow-node {
  flex:1; text-align:center; position:relative; z-index:1;
  opacity:0; transform:translateY(28px);
  transition:opacity .5s,transform .5s;
}
.flow-node.visible { opacity:1; transform:translateY(0); }
.flow-bubble {
  width:70px; height:70px; border-radius:50%;
  background: var(--mid); border:2px solid rgba(74,130,98,.3);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; margin:0 auto 14px;
  position:relative; transition:all .3s;
  box-shadow: 0 2px 12px rgba(39,56,36,.08);
}
.flow-node:hover .flow-bubble {
  border-color:var(--g2); box-shadow:0 4px 20px rgba(74,130,98,.2);
  transform:scale(1.08);
}
.flow-badge {
  position:absolute; top:-7px; right:-7px;
  width:20px; height:20px; border-radius:50%;
  background:linear-gradient(135deg,var(--g1),var(--gold));
  color:var(--dark); font-size:.65rem; font-weight:900;
  display:flex; align-items:center; justify-content:center;
}
.flow-node h3 { font-size:.88rem; font-weight:700; margin-bottom:5px; color: var(--dark); }
.flow-node p  { font-size:.72rem; color:var(--dark); line-height:1.6; padding:0 6px; }

/* ══════════════════════════════════════════════
   SERVICES
══════════════════════════════════════════════ */
#services { background: var(--white); padding:100px 0; }
.svc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.svc-card {
  background: var(--white); border:1px solid rgba(74,130,98,.15);
  border-radius:20px; padding:32px 22px;
  display:grid; grid-template-columns: 58px 1fr; gap: 0 14px;
  transition:all .35s; position:relative; overflow:hidden;
  box-shadow: 0 2px 12px rgba(39,56,36,.06);
}
.svc-card::before {
  content:''; position:absolute; inset:0; border-radius:20px;
  background: linear-gradient(135deg, rgba(204,222,91,.08), transparent);
  opacity:0; transition:opacity .35s;
}
.svc-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--g2),var(--g1),var(--gold));
  transform:scaleX(0); transform-origin:left; transition:transform .4s;
}
.svc-card:hover { border-color:rgba(74,130,98,.3); transform:translateY(-6px); box-shadow:var(--glow-g); }
.svc-card:hover::before { opacity:1; }
.svc-card:hover::after  { transform:scaleX(1); }
.svc-icon-wrap {
  width:58px; height:58px; border-radius:14px;
  background:rgba(204,222,91,.2); border:1px solid rgba(74,130,98,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem;
  grid-column: 1; grid-row: 1;
  align-self: center;
  transition:transform .3s, box-shadow .3s;
}
.svc-card:hover .svc-icon-wrap { transform:scale(1.1) rotate(-4deg); box-shadow:0 0 16px rgba(74,130,98,.2); }
.svc-card h3 { font-size:1.02rem; font-weight:900; color: var(--dark); grid-column: 2; grid-row: 1; align-self: center; }
.svc-card p  { font-size:.8rem; color:var(--dark); line-height:1.75; margin-bottom:16px; grid-column: 1 / -1; margin-top: 14px; }
.svc-list { list-style:none; display:flex; flex-direction:column; gap:6px; margin-top:auto; grid-column: 1 / -1; }
.svc-list li {
  font-size:.76rem; color:var(--dark); display:flex; align-items:flex-start; gap:8px;
}
.svc-list li::before { content:'✓'; color:var(--g2); font-weight:700; flex-shrink:0; }

/* ══════════════════════════════════════════════
   STRENGTH
══════════════════════════════════════════════ */
#strength { background:var(--mid); padding:100px 0; }
.str-layout { display:grid; grid-template-columns:.85fr 1.15fr; gap:72px; align-items:center; }
.str-visual { position:relative; display:flex; align-items:center; justify-content:center; }
.str-orb-wrap { width:300px; height:300px; position:relative; }
.str-aurora { position:absolute; border-radius:50%; filter:blur(50px); }
.str-aurora-1 { width:220px;height:220px;top:10%;left:10%; background:radial-gradient(circle,#CCDE5B,transparent); animation:blobMove1 14s ease-in-out infinite alternate; opacity:.5; }
.str-aurora-2 { width:180px;height:180px;bottom:5%;right:5%; background:radial-gradient(circle,#F8C746,transparent); animation:blobMove2 18s ease-in-out infinite alternate; opacity:.4; }
.str-orb-core {
  position:absolute; inset:40px;
  border-radius:50%;
  border:2px solid rgba(74,130,98,.2);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  background:rgba(255,255,255,.9);
  box-shadow: 0 4px 24px rgba(39,56,36,.12);
}
.str-panda { font-size:3.2rem; animation:float 3.5s ease-in-out infinite; filter:drop-shadow(0 0 12px rgba(74,130,98,.3)); }
@keyframes float { 0%,100%{transform:translateY(0) rotate(-3deg)} 50%{transform:translateY(-12px) rotate(3deg)} }
.str-orb-label { font-size:.68rem; font-weight:700; color:var(--g2); letter-spacing:.12em; }
.str-orbit-item {
  position:absolute; width:44px; height:44px; border-radius:50%;
  background:var(--white); border:1px solid rgba(74,130,98,.25);
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
  box-shadow:0 2px 10px rgba(39,56,36,.1);
}
.str-orbit-item:nth-child(4) { top:0;  left:50%; transform:translateX(-50%); }
.str-orbit-item:nth-child(5) { top:50%;right:0;  transform:translateY(-50%); }
.str-orbit-item:nth-child(6) { bottom:0; left:50%; transform:translateX(-50%); }
.str-orbit-item:nth-child(7) { top:50%;left:0;  transform:translateY(-50%); }
.str-list { display:flex; flex-direction:column; gap:18px; }
.str-item {
  background:var(--white); border:1px solid rgba(74,130,98,.15); border-radius:14px;
  padding:22px 26px; display:flex; gap:18px; align-items:flex-start;
  transition:all .3s; position:relative; overflow:hidden;
  box-shadow: 0 2px 10px rgba(39,56,36,.05);
}
.str-item::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:linear-gradient(180deg,var(--g2),var(--g1));
  transform:scaleY(0); transform-origin:top; transition:transform .4s;
}
.str-item:hover { border-color:rgba(74,130,98,.3); transform:translateX(5px); box-shadow:var(--glow-s); }
.str-item:hover::before { transform:scaleY(1); }
.str-ico { width:48px; height:48px; flex-shrink:0; border-radius:11px; background:rgba(204,222,91,.18); border:1px solid rgba(74,130,98,.2); display:flex; align-items:center; justify-content:center; font-size:1.3rem; }
.str-txt h3 { font-size:.97rem; font-weight:700; margin-bottom:5px; color: var(--dark); }
.str-txt p  { font-size:.8rem; color:var(--dark); line-height:1.7; }

/* ══════════════════════════════════════════════
   CTA BAND — ダークセクション(アクセント)
══════════════════════════════════════════════ */
#cta-band {
  padding:80px 0; text-align:center; position:relative; overflow:hidden;
  background: linear-gradient(135deg,#273824 0%,#354d40 50%,#435E60 100%);
  transform: translateZ(0); /* Safari: overflow:hidden でブロブを正しくクリップ */
}
.cta-blob { position:absolute; border-radius:50%; filter:blur(100px); pointer-events:none; }
.cta-blob-1 { width:400px;height:400px;top:-30%;left:-10%;background:radial-gradient(circle,#CCDE5B,transparent);opacity:.25;animation:blobMove1 16s ease-in-out infinite alternate; }
.cta-blob-2 { width:360px;height:360px;bottom:-20%;right:-8%;background:radial-gradient(circle,#F8C746,transparent);opacity:.2;animation:blobMove2 20s ease-in-out infinite alternate; }
.cta-inner { position:relative; z-index:1; }
.cta-title { font-size:clamp(1.7rem,3.8vw,2.8rem); font-weight:900; margin-bottom:14px; color:#fff; }
.cta-title .hl { background:linear-gradient(135deg,var(--g1),var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.cta-sub { color:rgba(255,255,255,.75); margin-bottom:36px; font-size:.93rem; line-height:1.8; }
.cta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ══════════════════════════════════════════════
   PRICING
══════════════════════════════════════════════ */
#price { background:var(--white); padding:100px 0; }
.price-wrap { overflow-x:auto; border-radius:20px; box-shadow:0 4px 24px rgba(39,56,36,.08); }
table {
  width:100%; border-collapse:collapse;
  background: var(--white); border-radius:20px; overflow:hidden;
  border: 1.5px solid rgba(74,130,98,.3);
}
thead tr { background:linear-gradient(135deg,#273824,#435E60); border-bottom:none; }
thead th {
  padding:17px 22px; text-align:center; font-size:.84rem; font-weight:700;
  color:rgba(255,255,255,.85); letter-spacing:.05em;
  border-right: 1px solid rgba(255,255,255,.1);
}
thead th:first-child { text-align:left; color:var(--g1); }
thead th:last-child { border-right:none; }
tbody tr { border-bottom:1px solid rgba(74,130,98,.15); transition:background .2s; }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background:rgba(204,222,91,.1); }
tbody td {
  padding:14px 22px; text-align:center; font-size:.86rem; color: var(--dark);
  border-right: 1px solid rgba(74,130,98,.12);
}
tbody td:first-child { font-weight:700; text-align:left; color:var(--dark); }
tbody td:last-child { border-right:none; }
.pv { color:#4a7a20; font-weight:700; }
.pvb { color:#c04020; font-weight:700; }
.pvd { color:rgba(74,130,98,.3); }
.price-note { margin-top:14px; display:flex; gap:20px; flex-wrap:wrap; font-size:.78rem; color:var(--dark); justify-content:flex-end; }
.price-note span::before { content:'※ '; }

/* ══════════════════════════════════════════════
   CONTACT
══════════════════════════════════════════════ */
#contact { background:var(--mid); padding:100px 0; }
.contact-card {
  max-width:680px; margin:0 auto; text-align:center;
  background:var(--white); border:1px solid rgba(74,130,98,.18); border-radius:28px;
  padding:56px 48px; position:relative; overflow:hidden;
  box-shadow: 0 8px 40px rgba(39,56,36,.1);
}
.contact-card::before { content:''; position:absolute; top:-100px;right:-100px; width:260px;height:260px; border-radius:50%; background:radial-gradient(circle,rgba(204,222,91,.15),transparent); pointer-events:none; }
.contact-card::after  { content:''; position:absolute; bottom:-80px;left:-80px;  width:200px;height:200px; border-radius:50%; background:radial-gradient(circle,rgba(248,199,70,.1),transparent);  pointer-events:none; }
.contact-panda { font-size:3.2rem; display:block; margin-bottom:18px; animation:float 3s ease-in-out infinite; filter:drop-shadow(0 0 12px rgba(74,130,98,.3)); }
.contact-card h3 { font-size:1.5rem; font-weight:900; margin-bottom:10px; color:var(--dark); }
.contact-card > p { color:var(--dark); font-size:.88rem; line-height:1.85; margin-bottom:32px; }
.contact-card > p strong { color:var(--g2); }
.contact-btn {
  display:inline-flex; align-items:center; gap:11px;
  background:linear-gradient(135deg,var(--g1),#a8bc3a);
  color:var(--dark); font-weight:900; font-size:1.02rem;
  padding:17px 42px; border-radius:50px; text-decoration:none;
  box-shadow:0 8px 28px rgba(204,222,91,.45); transition:all .3s;
  position:relative; overflow:hidden; margin-bottom:18px;
}
.contact-btn::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.25),transparent); transform:translateX(-100%); transition:transform .4s; }
.contact-btn:hover::before { transform:translateX(100%); }
.contact-btn:hover { transform:translateY(-3px); box-shadow:0 14px 38px rgba(204,222,91,.55); }
.contact-mail-addr { display:block; font-size:.85rem; color:var(--dark); margin-bottom:24px; letter-spacing:.04em; font-weight:600; }
.contact-meta { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; font-size:.78rem; color:var(--dark); border-top:1px solid var(--border); padding-top:22px; }
.contact-meta span { display:flex; align-items:center; gap:5px; }

/* ══════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════ */
footer { background:var(--dark); border-top:none; padding:32px 28px; text-align:center; }
.ft-logo { font-size:.88rem; font-weight:700; color:rgba(255,255,255,.5); margin-bottom:6px; }
.ft-logo strong { color:var(--g1); }
.ft-copy { font-size:.72rem; color:rgba(255,255,255,.25); }
.sp-br { display: none; } /* PC では非表示 */

/* ══════════════════════════════════════════════
   SPARKLE
══════════════════════════════════════════════ */
.sp-btn { position:relative; }
.sparkle { position:absolute; pointer-events:none; width:5px; height:5px; border-radius:50%; background:var(--gold); animation:sparkPop .6s ease-out forwards; }
@keyframes sparkPop { 0%{transform:scale(0) translate(0,0);opacity:1} 100%{transform:scale(1.5) translate(var(--tx),var(--ty));opacity:0} }

/* ── rate card ── */
.rate-card {
  margin-top: 12px;
  padding: 2px;
  background: linear-gradient(135deg, rgba(74,130,98,.35) 0%, rgba(248,199,70,.25) 100%);
  border-radius: 18px;
}
.rate-card-inner {
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(14px);
  border-radius: 16px;
  padding: 14px 20px 10px;
}
.rate-card-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
}
.rate-currency {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 6px;
}
.rate-flag { font-size: 18px; line-height: 1; }
.rate-currency-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  color: #888;
}
.rate-cny .rate-amount { font-size: 15px; font-weight: 700; color: var(--g2); }
.rate-jpy .rate-amount { font-size: 18px; font-weight: 900; color: var(--dark); }
.rate-arrow { color: rgba(74,130,98,.5); flex-shrink: 0; }
.rate-card-footer {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding-top: 8px;
  border-top: 1px solid rgba(74,130,98,.12);
  font-size: 10px;
}
.rate-live-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(0,200,83,.1);
  border: 1px solid rgba(0,200,83,.25);
  border-radius: 999px;
  padding: 2px 8px;
  font-weight: 700;
  font-size: 9px;
  color: #00a846;
  letter-spacing: .06em;
}
.rate-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #00c853;
  flex-shrink: 0;
  animation: ratePulse 2s ease-in-out infinite;
}
@keyframes ratePulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(1.5); }
}
.rate-source { color: #aaa; }
.rate-time   { color: #bbb; margin-left: auto; }

/* ── page top ── */
#pageTop {
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 900;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: var(--dark);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(39,56,36,.3);
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
  transition: opacity .3s, transform .3s;
}
#pageTop.show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
#pageTop:hover { background: var(--g2); transform: translateY(-3px); }

/* cursor glow */
#cursor-glow { position:fixed; pointer-events:none; z-index:9990; width:280px; height:280px; border-radius:50%; background:radial-gradient(circle,rgba(204,222,91,.06) 0%,transparent 70%); transform:translate(-50%,-50%); transition:left .12s ease,top .12s ease; }

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;text-align:center;padding:100px 28px}
  .hero-btns{justify-content:center}
  .hero-route{order:-1;margin-bottom:16px}
  .route-svg-wrap{max-width:460px;margin:0 auto}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .str-layout{grid-template-columns:1fr}
  .str-visual{display:none}
}
@media(max-width:768px){
  /* ブロブを縮小して横はみ出しを防止 */
  .blob-1{width:280px;height:280px}
  .blob-2{width:240px;height:240px}
  .blob-3{width:180px;height:180px}
  .blob-4{width:150px;height:150px}
  .blob-5{width:130px;height:130px}
  .cta-blob-1{width:200px;height:200px}
  .cta-blob-2{width:180px;height:180px}

  /* ヘッダー */
  .nav-in{padding:0 16px}

  /* ヒーロー */
  .hero-inner{padding:80px 16px}

  /* フロー — 縦並びに変更 */
  .flow-track{flex-direction:column;align-items:center}
  .flow-connector{display:none}
  .flow-node{flex:none;width:100%;max-width:400px;padding-bottom:24px;border-bottom:1px solid rgba(74,130,98,.15);margin-bottom:0}
  .flow-node:last-child{padding-bottom:0;border-bottom:none}

  /* セクション余白を縮小 */
  .sec-pad{padding:72px 0}
  #flow,#services,#strength,#price,#contact{padding:72px 0}
  #cta-band{padding:60px 0}

  /* スクロールアイコンを非表示（コンテンツに被るため） */
  .scroll-hint{display:none}
  /* スマホ専用改行を表示 */
  .sp-br{display:inline}

  /* テキストのはみ出し防止 */
  .str-txt p,.svc-card p,.flow-node p,.contact-card > p{overflow-wrap:break-word;word-break:normal}

  /* 料金表注釈 */
  .price-note{justify-content:flex-start}

  /* お問い合わせカード */
  .contact-card{padding:40px 24px}
}
@media(max-width:580px){
  /* ナビ */
  .nav-links>a:not(.nav-cta){display:none}

  /* ヒーロー */
  .hero-inner{padding:60px 16px}
  .hero-title{font-size:clamp(1.6rem,7vw,2.4rem)}

  /* スタッツ */
  .stats-grid{gap:16px}

  /* サービス */
  .svc-grid{grid-template-columns:1fr}

  /* 料金表 */
  .price-note{flex-direction:column;align-items:flex-start;gap:6px}

  /* レートカード — 横並びを維持 */
  .rate-card-row{flex-wrap:nowrap}

  /* お問い合わせ */
  .contact-card{padding:32px 16px}
  .contact-btn{padding:14px 24px;font-size:.95rem}

  /* CTAボタン */
  .cta-btns .btn-ghost{padding:12px 20px}

  /* セクション余白をさらに縮小 */
  .sec-pad{padding:56px 0}
  #flow,#services,#strength,#price,#contact{padding:56px 0}
  #cta-band{padding:48px 0}
  #stats{padding:40px 0}
}
