/* ============================================================
   svc.css — System Integration / Managed Service 専用ページ共有スタイル
   /system-integration/ と /managed-service/ から参照。
   ページシェル (.svc-hero / .svc-subnav / .svc-section / .svc-cta) は
   /cloud-cost-monitor/ の .ccm-* を踏襲。本文系の文字サイズは TOP の
   インライン版より +4px 程度拡大 (可読性、2026-05-29)。
   ============================================================ */
.svc-page { background: var(--color-bg); }

/* ----- Hero ----- */
.svc-hero {
  position: relative;
  /* 2026-06-03: breadcrumb が nav-height 確保するので hero 側は余白のみで OK */
  padding-block: clamp(3rem, 8vw, 6rem) clamp(4rem, 8vw, 7rem);
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-soft) 100%);
  overflow: hidden;
}
.svc-hero__inner { position: relative; z-index: 1; max-width: 880px; }
.svc-hero__eyebrow {
  font-family: var(--font-mono); font-size: 0.8125rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--color-text-sub); margin-bottom: var(--space-6);
  display: inline-flex; align-items: center; gap: var(--space-3);
}
.svc-hero__eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--svc-accent, var(--color-itsn-blue)); }
.svc-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5.5vw, 4.25rem);
  font-weight: 700; line-height: 1.02; letter-spacing: -0.03em;
  margin-bottom: var(--space-4);
}
.svc-hero__title .accent {
  background: linear-gradient(135deg, var(--color-itsn-blue) 0%, var(--color-itsn-green) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.svc-hero__sub {
  font-family: var(--font-sans); font-weight: 700;
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  color: var(--color-text); margin-bottom: var(--space-8);
}
.svc-hero__lead {
  font-size: clamp(1.0625rem, 1.3vw, 1.1875rem); line-height: 1.9;
  max-width: 62ch; color: var(--color-text-body);
  margin-bottom: var(--space-10);
}
.svc-hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.svc-btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: 999px; font-weight: 700; font-size: 1rem;
  text-decoration: none;
  transition: transform var(--duration-fast), box-shadow var(--duration-base);
}
.svc-btn--primary { background: var(--color-itsn-blue); color: #fff; }
.svc-btn--primary:hover { color: #fff; transform: translateY(-1px); box-shadow: 0 8px 24px rgba(23,150,213,0.32); }
.svc-btn--ghost { border: 1px solid var(--color-border); color: var(--color-text); }
.svc-btn--ghost:hover { border-color: var(--color-text); color: var(--color-text); }
.svc-btn svg { width: 16px; height: 16px; }

/* ----- Sticky subnav ----- */
.svc-subnav {
  position: sticky; top: var(--nav-height); z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-gray-100);
}
.svc-subnav__inner {
  display: flex; gap: clamp(0.5rem, 2vw, 2rem);
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  padding-block: var(--space-3); scrollbar-width: none;
}
.svc-subnav__inner::-webkit-scrollbar { display: none; }
.svc-subnav__link {
  font-family: var(--font-mono); font-size: 0.8125rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--color-text-sub); white-space: nowrap;
  padding-block: var(--space-2);
  border-bottom: 2px solid transparent;
  transition: color var(--duration-fast), border-color var(--duration-fast);
}
.svc-subnav__link:hover, .svc-subnav__link.is-active {
  color: var(--color-itsn-blue); border-bottom-color: var(--color-itsn-blue);
}

/* ----- Section base ----- */
.svc-section { padding-block: clamp(3.5rem, 7vw, 6rem); scroll-margin-top: calc(var(--nav-height) + 56px); }
.svc-section--soft { background: var(--color-bg-soft); }
.svc-section__head { margin-bottom: clamp(1.75rem, 4vw, 3rem); max-width: 920px; }
.svc-section__eyebrow {
  font-family: var(--font-mono); font-size: 0.8125rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-itsn-blue); margin-bottom: var(--space-3);
  display: inline-flex; align-items: center; gap: var(--space-2);
}
.svc-section__eyebrow::before { content: ""; width: 24px; height: 1px; background: currentColor; display: inline-block; }
.svc-section__title {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  font-weight: 700; line-height: 1.15; letter-spacing: -0.02em;
  margin-bottom: var(--space-3);
}
.svc-section__title .ja {
  font-family: var(--font-sans); font-size: clamp(1rem, 1.4vw, 1.1875rem);
  font-weight: 700; display: block; margin-top: var(--space-2);
  letter-spacing: 0; color: var(--color-text-sub);
}
.svc-section__lead { font-size: clamp(1.0625rem, 1.4vw, 1.1875rem); line-height: 1.9; max-width: 64ch; color: var(--color-text-body); }

/* ----- Content blocks (enlarged) ----- */
.svc-block { max-width: 1080px; }
.svc-block > h3 {
  font-family: var(--font-display); font-size: clamp(1.25rem, 2.2vw, 1.6rem);
  letter-spacing: -0.01em; margin-top: clamp(2.5rem, 5vw, 3.5rem); margin-bottom: var(--space-6);
  padding-bottom: var(--space-3); border-bottom: 2px solid var(--color-gray-100);
}
.svc-block > h3:first-child { margin-top: 0; }
.svc-block h4 { font-family: var(--font-sans); font-size: 1.25rem; font-weight: 700; color: var(--color-text); margin-top: var(--space-8); margin-bottom: var(--space-3); }
.svc-block p { font-size: 1.125rem; line-height: 1.9; color: var(--color-text-body); margin-bottom: var(--space-4); max-width: 74ch; }

.svc-problems { display: grid; grid-template-columns: repeat(auto-fit,minmax(320px,1fr)); gap: var(--space-3); margin-bottom: var(--space-8); list-style: none; padding: 0; }
.svc-problems li { position: relative; background: var(--color-white); border: 1px solid var(--color-gray-100); border-radius: var(--radius-md); padding: var(--space-4) var(--space-6) var(--space-4) calc(var(--space-8) + var(--space-2)); font-size: 1.1875rem; line-height: 1.7; color: var(--color-text-body); }
.svc-problems li::before { content: "!"; position: absolute; left: var(--space-4); top: 1.05rem; width: 1.4rem; height: 1.4rem; border-radius: 50%; background: rgba(224,59,20,0.1); color: var(--color-itsn-red); font-family: var(--font-mono); font-weight: 700; font-size: 0.875rem; display: inline-flex; align-items: center; justify-content: center; }

.svc-points { display: grid; gap: var(--space-4); margin-block: var(--space-6); }
.svc-point { background: var(--color-white); border: 1px solid var(--color-gray-100); border-left: 3px solid var(--svc-accent, var(--color-itsn-blue)); border-radius: 0 var(--radius-md) var(--radius-md) 0; padding: var(--space-6); }
.svc-point h4 { margin-top: 0; }
.svc-point p { margin-bottom: 0; }

.svc-process { display: grid; grid-template-columns: repeat(auto-fit,minmax(190px,1fr)); gap: var(--space-3); margin-block: var(--space-6); }
.svc-phase { background: var(--color-white); border: 1px solid var(--color-gray-100); border-radius: var(--radius-md); padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-2); }
.svc-phase__num { font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.12em; color: var(--svc-accent, var(--color-itsn-blue)); font-weight: 700; }
.svc-phase__title { font-weight: 700; color: var(--color-text); font-size: 1.1875rem; }
.svc-phase ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-1); }
.svc-phase li { font-size: 1.0625rem; line-height: 1.55; color: var(--color-text-body); padding-left: var(--space-4); position: relative; }
.svc-phase li::before { content: "\2013"; position: absolute; left: 0; color: var(--color-gray-300); }

.svc-list { display: grid; grid-template-columns: repeat(auto-fit,minmax(340px,1fr)); gap: var(--space-3); margin-block: var(--space-4); list-style: none; padding: 0; }
.svc-list li { position: relative; padding-left: var(--space-6); font-size: 1.1875rem; line-height: 1.7; color: var(--color-text-body); }
.svc-list li::before { content: ""; position: absolute; left: 0; top: 0.72em; width: 0.5rem; height: 0.5rem; border-radius: 50%; background: var(--color-itsn-green); }
.svc-list strong { color: var(--color-text); }

.svc-table-wrap { overflow-x: auto; margin-block: var(--space-6); }
.svc-table { width: 100%; border-collapse: collapse; font-size: 1.1875rem; min-width: 520px; }
.svc-table th, .svc-table td { text-align: left; padding: var(--space-4) var(--space-4); border-bottom: 1px solid var(--color-gray-100); vertical-align: top; line-height: 1.7; }
.svc-table th { width: 30%; color: var(--color-text); font-weight: 700; background: var(--color-bg-soft); white-space: nowrap; }
.svc-table td { color: var(--color-text-body); }

.svc-faq { display: grid; gap: var(--space-2); margin-block: var(--space-6); max-width: 860px; }
.svc-faq details { background: var(--color-white); border: 1px solid var(--color-gray-100); border-radius: var(--radius-md); overflow: hidden; }
.svc-faq summary { cursor: pointer; list-style: none; padding: var(--space-5) var(--space-6); font-weight: 700; color: var(--color-text); font-size: 1.1875rem; line-height: 1.5; display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); }
.svc-faq summary::-webkit-details-marker { display: none; }
.svc-faq summary::after { content: "+"; font-family: var(--font-mono); color: var(--color-itsn-blue); font-size: 1.5rem; flex: 0 0 auto; }
.svc-faq details[open] summary::after { content: "\2013"; }
.svc-faq__a { padding: 0 var(--space-6) var(--space-5); color: var(--color-text-body); font-size: 1.1875rem; line-height: 1.85; }

.svc-callout { background: var(--color-bg-soft); border-left: 3px solid var(--color-itsn-green); border-radius: 0 var(--radius-md) var(--radius-md) 0; padding: var(--space-6); margin-top: var(--space-6); font-size: 1.1875rem; line-height: 1.8; color: var(--color-text-body); }
.svc-callout strong { color: var(--color-text); }

/* ----- CTA / Contact ----- */
.svc-cta {
  background: var(--color-black); color: #fff;
  border-radius: var(--radius-lg, 16px);
  padding: clamp(3rem, 8vw, 6rem) clamp(2rem, 5vw, 4rem);
  position: relative; overflow: hidden;
  margin-block: clamp(3rem, 6vw, 5rem);
}
.svc-cta::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 80% 20%, rgba(23,150,213,0.28), transparent 50%),
    radial-gradient(circle at 20% 80%, rgba(0,160,108,0.18), transparent 50%);
  pointer-events: none;
}
.svc-cta__inner { position: relative; max-width: 880px; }
.svc-cta__eyebrow { font-family: var(--font-mono); font-size: 0.8125rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-itsn-green); margin-bottom: var(--space-4); }
.svc-cta__title { font-family: var(--font-display); font-size: clamp(1.75rem, 4vw, 2.75rem); letter-spacing: -0.02em; margin-bottom: var(--space-4); color: #fff; }
.svc-cta__lead { color: var(--color-gray-300); margin-bottom: var(--space-8); font-size: 1.1875rem; line-height: 1.85; max-width: 60ch; }
.svc-cta__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.svc-cta .svc-btn--ghost { border-color: rgba(255,255,255,0.3); color: #fff; }
.svc-cta .svc-btn--ghost:hover { border-color: #fff; color: #fff; }

/* ----- Mobile ----- */
@media (max-width: 767px) {
  .svc-hero__actions { flex-direction: column; align-items: stretch; }
  .svc-btn { justify-content: center; }
}

/* ============================================================
   Breadcrumb (2026-06-01): header 直下、main の直前に配置。
   両 repo (service + www) で共通の見た目。区切りは CSS で描画。
   ============================================================ */
/* 2026-06-03: sticky header (.itsn-header) の下にパンくずが隠れるのを防ぐ。
   margin-block-start で nav-height 分を必ず確保 + padding 増量 + z-index。
   各 .*-hero の padding-block-start: calc(var(--nav-height) + ...) と
   組み合わせると hero 前の余白がやや増えるが、視認性 (見切れゼロ) を優先。 */
.breadcrumb { position: relative; z-index: 5; margin-block-start: var(--nav-height, 72px); background: var(--color-bg-soft); border-bottom: 1px solid var(--color-gray-100); padding-block: clamp(0.875rem, 2vw, 1.125rem); font-size: 0.875rem; }
.breadcrumb__inner { max-width: var(--container-max, 1280px); margin-inline: auto; padding-inline: var(--container-pad, clamp(1.25rem, 4vw, 3rem)); }
.breadcrumb__list { display: flex; flex-wrap: wrap; align-items: center; gap: 0.4rem 0.75rem; list-style: none; margin: 0; padding: 0; }
.breadcrumb__item { display: inline-flex; align-items: center; color: var(--color-text-sub); }
.breadcrumb__item + .breadcrumb__item::before { content: "›"; margin-right: 0.75rem; color: var(--color-gray-300); font-weight: 700; }
.breadcrumb__link { color: var(--color-text-body); transition: color 200ms var(--ease-out-quint, ease); }
.breadcrumb__link:hover { color: var(--color-itsn-blue); }
.breadcrumb__item--current { color: var(--color-text); font-weight: 600; }
