/* ===== Extracted from inline <style> blocks in overview.html ===== */


    :root{
      --txt:#e9eef6; --muted:#a9b3c3;
      --shadow: 0 10px 30px rgba(0,0,0,.35);
      --radius-lg: 20px;
      --navH: 72px; --navH-small: 56px;
      --navAlpha: .22; --navAlphaSolid: .86;
    }
    html[data-theme="corporate"]{
      --bg1:#0b1020; --bg2:#0f1b36;
      --acc1:#3ad7bd; --acc2:#6aa4ff;
      --navBg: rgba(0,0,0,var(--navAlpha));
      --navBgSolid: rgba(6,10,20,var(--navAlphaSolid));
    }
    *{box-sizing:border-box}
    html,body{height:100%}
    body{ margin:0; color:var(--txt); background:linear-gradient(180deg,var(--bg1),var(--bg2)); font-weight:500; }

    /* ===== Global Nav（index.htmlと同仕様） ===== */
    .g-nav{ position:fixed; inset-inline:0; top:0; z-index:100; height:var(--navH);
      display:flex; align-items:center; justify-content:center; background:var(--navBg);
      border-bottom:1px solid rgba(255,255,255,.18); backdrop-filter:saturate(115%) blur(6px);
      transition: height .28s ease, background-color .28s ease, border-color .28s ease; }
    .g-wrap{ width:100%; max-width:min(1380px, 96vw); display:flex; align-items:center; justify-content:space-between; gap:20px; padding:0 10px; }
    .brand{ display:flex; align-items:center; gap:10px; text-decoration:none; color:#fff; white-space:nowrap; }
    .brand img{ height:28px; width:auto; display:block; }
    .brand .name{ font-weight:800; font-size:clamp(12px, 1.9vw, 16px); white-space:nowrap; }

    .nav-right{ display:flex; align-items:center; gap:18px; flex-wrap: nowrap; } /* 折り返し防止 */
    .nav-links{ display:flex; align-items:center; gap: clamp(18px, 3.2vw, 32px); }
    .nav-links > a, .nav-links > .dd > a{
      color:#e8f3ff; text-decoration:none; font-weight:800; font-size: 13px;
      padding:6px 8px; border-radius:8px; border:1px solid transparent;
    }
    .nav-links > a:hover, .nav-links > .dd:hover > a{ border-color:rgba(255,255,255,.2); background:rgba(255,255,255,.06); }

    .dd{ position:relative; }
    .dd-menu{
      position:absolute; top: calc(100% + 8px); left:0; min-width:240px; max-width: 80vw;
      max-height:min(60vh,520px); overflow:auto; -webkit-overflow-scrolling:touch;
      background:var(--navBgSolid); border:1px solid rgba(255,255,255,.14); border-radius:12px;
      padding:8px; display:none; box-shadow:var(--shadow);
    }
    .dd.open .dd-menu{ display:block; }
    .dd-menu a{ display:block; padding:10px 12px; border-radius:10px; color:#e8f3ff; text-decoration:none; font-weight:800; }
    .dd-menu a:hover{ background:rgba(255,255,255,.06); }

    .lang-switch{ display:flex; gap:8px; }
    .lang-switch a{ color:#cfe1ff; text-decoration:none; font-weight:800; font-size:13px; opacity:.9; padding:6px 10px; border-radius:8px; border:1px solid rgba(255,255,255,.2); }
    .lang-switch a:hover{ background:rgba(255,255,255,.06); }

    .nav-cta{ display:inline-flex; align-items:center; gap:.6em; padding:10px 12px; border-radius:12px; text-decoration:none; border:1px solid transparent; font-weight:800; letter-spacing:.02em; background:linear-gradient(135deg,var(--acc1),var(--acc2)); color:#071018; box-shadow:var(--shadow); white-space:nowrap; }
    .tel-cta{ display:none; }
    .sp-toggle{ display:none; }

    .g-nav.shrink{ height:var(--navH-small); background:var(--navBgSolid); border-color: rgba(255,255,255,.12); }

    /* Drawer（SP：index.html同等の挙動） */
    .drawer{ display:none; }
    @media (max-width: 960px){
      .nav-links, .lang-switch, .nav-cta{ display:none; }
      .tel-cta{ display:inline-flex; }
      .sp-toggle{ display:inline-flex; align-items:center; gap:6px; }
      .brand{ min-width: 0; }
      .brand .name{ max-width: 44vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
      @media (max-width: 520px){ .brand .name{ display:none; } }
      .sp-toggle button{
        background: transparent; border:1px solid rgba(255,255,255,.25); color:#fff; padding:8px 12px; border-radius:10px; font-weight:800;
        display:inline-flex; align-items:center; white-space:nowrap; line-height:1;
      }
      .drawer{ position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:99; display:none; }
      .drawer-panel{ position:fixed; top:0; right:0; height:100%; width:min(86vw, 320px);
        background:var(--navBgSolid); border-left:1px solid rgba(255,255,255,.16);
        padding:16px; padding-top:max(16px, env(safe-area-inset-top));
        padding-right:max(16px, env(safe-area-inset-right));
        padding-bottom:max(16px, env(safe-area-inset-bottom));
        overflow-y:auto; -webkit-overflow-scrolling:touch; overscroll-behavior: contain;
        transform: translateX(100%); transition: transform .28s ease; box-shadow:-20px 0 40px rgba(0,0,0,.35); }
      .drawer.show{ display:block; }
      .drawer.show .drawer-panel{ transform: translateX(0); }
      .drawer a{ color:#e8f3ff; text-decoration:none; font-weight:700; padding:12px 10px; border-bottom:1px solid rgba(255,255,255,.12); display:block; }
      .drawer a:last-child{ border-bottom: 0; }
      .drawer .group-title{ margin:8px 0 6px; color:#9fb8ff; font-weight:800; }
      .drawer .close{ position:sticky; top:0; text-align:right; padding:6px 0 8px; background: linear-gradient(180deg, rgba(6,10,20,.95), rgba(6,10,20,.75)); z-index:1; }
      .drawer .close button{ border:1px solid rgba(255,255,255,.25); background:transparent; color:#fff; padding:8px 10px; border-radius:8px; }

      /* アコーディオン（index.html同様にJSで生成） */
      .acc-head{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin:6px 0 2px; }
      .acc-link{ display:inline-flex; align-items:center; padding:12px 10px; border:1px solid rgba(255,255,255,.18);
        border-radius:10px; background:rgba(255,255,255,.06); font-weight:800; flex:1 1 auto; }
      .acc-link:hover{ background: rgba(255,255,255,.10); }
      .acc-btn{ width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center;
        border:1px solid rgba(255,255,255,.18); border-radius:10px; background:rgba(255,255,255,.06); color:#e8f3ff; font-weight:800; }
      .acc-btn .chev{ transition: transform .2s ease }
      .acc-btn[aria-expanded="true"] .chev{ transform: rotate(90deg) }
      .acc-panel{ display:none }
      .acc-panel.open{ display:block }

      /* === サブメニュー“光る演出”（シマー） === */
      .drawer .acc-panel a{ position: relative; overflow: hidden; }
      .drawer .acc-panel a::before{ content:""; position:absolute; inset:-1px; border-radius:10px;
        background: linear-gradient(135deg, rgba(61,215,189,0), rgba(61,215,189,.30), rgba(106,164,255,.30), rgba(61,215,189,0));
        opacity:0; transition: opacity .18s ease; pointer-events:none; }
      .drawer .acc-panel a::after{ content:""; position:absolute; top:-120%; bottom:-120%; left:-30%; width:40%;
        transform: translateX(-120%) rotate(20deg); background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
        mix-blend-mode: screen; opacity:0; pointer-events:none; }
      .drawer .acc-panel a:hover::before{ opacity:.7; }
      .drawer .acc-panel a:hover::after{ opacity:1; animation: submenuShimmer 1.0s ease; }
      @keyframes submenuShimmer{ 0%{ transform: translateX(-120%) rotate(20deg); opacity:0; }
        10%{ opacity:.7; } 100%{ transform: translateX(220%) rotate(20deg);  opacity:0; } }
      @media (prefers-reduced-motion: reduce){ .drawer .acc-panel a:hover::after{ animation:none; opacity:.15; } }
    }
      /* --- スマホ時: 電話・メニューの改行防止 --- */
      .tel-cta,
      .sp-toggle button{
        white-space: nowrap;
        word-break: keep-all;
      }
      .sp-toggle,
      .tel-cta{
        flex: 0 0 auto;  /* 幅の圧縮を防ぐ */
      }

      /* --- iPhone調整: ブランド名が「電話」「メニュー」と重ならないようにする --- */
      .brand{ min-width: 0; }
      .brand .name{
        display:block;
        max-width:52vw;        /* 必要に応じて 48〜56vw で微調整可 */
        overflow:hidden;
        white-space:nowrap;
        text-overflow:ellipsis;
      }
    /* ===== Hero ===== */
    html{ scroll-padding-top: var(--navH); }
    @media (max-width:960px){ html{ scroll-padding-top: var(--navH-small); } }
    .hero{ position:relative; min-height: 42svh; display:grid; place-items:center; padding-top: calc(var(--navH) + 16px);
      background: linear-gradient(180deg, rgba(15,27,54,.7), rgba(15,27,54,.3)), url("https://www.nikko-kikai.co.jp/img/profile3.png") center/cover no-repeat;
      border-bottom:1px solid rgba(255,255,255,.12); overflow:hidden; }
    .hero .title{ margin:0; font-size: clamp(22px, 4.4vw, 40px); font-weight:900; text-shadow:0 2px 12px rgba(0,0,0,.45); }
    .hero .lead{ margin:.4em 0 0; color:var(--muted); }

    /* ===== Content ===== */
    .section{ max-width:min(1100px, 92vw); margin: clamp(28px, 6vw, 72px) auto; }
    .sec{ margin-bottom: clamp(24px, 3vw, 36px); }
    .box{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.15); border-radius:16px; padding:18px; box-shadow:var(--shadow); }

    .h3{ margin:0 0 10px; font-weight:800; font-size: clamp(18px, 2.8vw, 24px); border-left: 3px solid rgba(255,255,255,.35); padding-left: 10px; }

    /* ▼ サイズ微調整（少しだけ小さく） */
    .msg{ background: linear-gradient(145deg, rgba(240,248,255,.85), rgba(255,255,255,.85));
      border-left: 2px solid #89b6ff; border-radius: 10px; padding: 18px; color:#1c2636;
      font-size: .96rem; }
    .msg p{ margin: .8em 0; line-height: 1.85; }
    .msg .author{ text-align: right; margin-top: 1em; font-style: italic; color:#48556a; font-size: .92rem; }

    .timeline{ display:grid; grid-template-columns: 150px 1fr; gap: 8px 10px; align-items:start; }
    .tl-year{ font-weight: 900; color:#9fd2ff; padding-top:.4em; font-size: .95rem; }
    .tl-txt{ background:rgba(255,255,255,.9); color:#222; padding:.8em 1em; border-left: 3px solid #8fb4ff; border-radius:6px; line-height:1.6; font-size: .95rem; }
    @media (max-width: 768px){ .timeline{ grid-template-columns: 1fr; } .tl-year{ padding-top:0; } }

    .company{ display:flex; flex-wrap:wrap; gap: 16px; font-size: .96rem; }
    .c-card{ flex: 1 1 calc(50% - 16px); background:rgba(255,255,255,.96); border: 1px solid rgba(0,0,0,.08);
      border-left: 3px solid #8fb4ff; border-radius:6px; padding:.8em 1em; color:#1c2636; }
    .c-card strong{ display:block; font-size:.9em; color:#5a6a82; margin-bottom:4px; }
    .c-card span{ font-size:1.0em; color:#111; }
    @media (max-width: 600px){ .c-card{ flex: 1 1 100%; } }

    footer{ color:#9fb0c0; text-align:center; padding:40px 12px 60px; }
  

/* ---- Next block ---- */


/* === Drawer under fixed nav (SP): offset slightly lower than nav height === */
@media (max-width: 960px){
  .drawer{ z-index: 90 !important; }
  .drawer-panel{
    top: calc(var(--navH-small, 56px) + 8px) !important;
    height: calc(100% - (var(--navH-small, 56px) + 8px)) !important;
    padding-top: max(8px, env(safe-area-inset-top));
  }
}

/* === Hover glow for top-level nav items (desktop) === */
.nav-links > .dd > a{
  position: relative;
  overflow: hidden;
}
.nav-links > .dd > a::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius:10px;
  background: linear-gradient(135deg,
    rgba(61,215,189,0),
    rgba(61,215,189,.35),
    rgba(106,164,255,.35),
    rgba(61,215,189,0));
  opacity:0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.nav-links > .dd:hover > a::before{ opacity:.75; }
.nav-links > .dd > a::after{
  content:"";
  position:absolute;
  top:-120%; bottom:-120%; left:-30%;
  width:40%;
  transform: translateX(-120%) rotate(20deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  mix-blend-mode: screen;
  opacity:0;
  pointer-events:none;
}
.nav-links > .dd:hover > a::after{
  opacity:1;
  animation: navShimmer 1.0s ease;
}
@keyframes navShimmer{
  0%{ transform: translateX(-120%) rotate(20deg); opacity:0; }
  10%{ opacity:.7; }
  100%{ transform: translateX(220%) rotate(20deg); opacity:0; }
}

/* === Hover glow for drawer headers (SP) === */
@media (max-width: 960px){
  .acc-link{
    position: relative;
    overflow: hidden;
  }
  .acc-link::before{
    content:"";
    position:absolute; inset:-1px;
    border-radius:10px;
    background: linear-gradient(135deg,
      rgba(61,215,189,0),
      rgba(61,215,189,.30),
      rgba(106,164,255,.30),
      rgba(61,215,189,0));
    opacity:0; transition: opacity .18s ease; pointer-events:none;
  }
  .acc-link::after{
    content:"";
    position:absolute; top:-120%; bottom:-120%; left:-30%; width:40%;
    transform: translateX(-120%) rotate(20deg);
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
    mix-blend-mode: screen; opacity:0; pointer-events:none;
  }
  .acc-link:hover::before{ opacity:.7; }
  .acc-link:hover::after{ opacity:1; animation: drawerShimmer 1.0s ease; }
  @keyframes drawerShimmer{
    0%{ transform: translateX(-120%) rotate(20deg); opacity:0; }
    10%{ opacity:.7; }
    100%{ transform: translateX(220%) rotate(20deg); opacity:0; }
  }
}

.white-box {
  background: #ffffff !important;
  color: #111;
  border: 1px solid rgba(0,0,0,.1);
}
.white-box .h3 {
  border-left: 3px solid #6aa4ff;
  color: #111;
}



/* ---- Next block ---- */


.dark-box {
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(255,255,255,0.15);
  color: #ffffff;
}
.dark-box .h3 { color: #ffffff; border-left: 3px solid rgba(255,255,255,.35); }
.dark-box p, .dark-box span, .dark-box li, .dark-box strong { color: #ffffff; }


/* ---- Next block ---- */


.dark-box .msg {
  background: rgba(255,255,255,0.05) !important;
  border-left: 2px solid #6aa4ff !important;
  color: #ffffff !important;
}
.dark-box .msg p,
.dark-box .msg .author {
  color: #ffffff !important;
}


/* ---- Next block ---- */


.dark-box .timeline .tl-txt {
  background: rgba(255,255,255,0.05) !important;
  color: #ffffff !important;
  border-left: 3px solid #6aa4ff !important;
}
.dark-box .timeline .tl-year {
  color: #cfe1ff !important;
}
.dark-box .company .c-card {
  background: rgba(255,255,255,0.05) !important;
  border-left: 3px solid #6aa4ff !important;
  color: #ffffff !important;
}
.dark-box .company .c-card strong,
.dark-box .company .c-card span {
  color: #ffffff !important;
}


/* ---- Next block ---- */


    footer .copyright {
      font-size: 10px;
      color: #ffffff;
      text-align: center;
      margin: 10px 0;
    }

/* ===== Emotion Enhancements (Hero, Headings, Timeline, Scroll-in) ===== */

/* Hero zoom + scroll hint */
.hero {
  position: relative;
  min-height: 60svh;
  text-align: center;
  animation: heroZoom 10s ease-out forwards;
}
@keyframes heroZoom {
  from { transform: scale(1); }
  to   { transform: scale(1.05); }
}
.hero::after {
  content:"";
  position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:2px; height:60px; background:linear-gradient(to bottom, transparent, var(--acc2));
  animation: scrollHint 2s ease-in-out infinite;
}
@keyframes scrollHint {
  0%,100%{ opacity:0; transform:translate(-50%,0); }
  50%{ opacity:1; transform:translate(-50%,20px); }
}
.hero .title { animation: fadeInUp 1.2s ease-out both; }
.hero .lead  { opacity:0; animation: fadeInUp 1.6s ease-out both 0.3s; }
.hero .subcopy {
  margin-top: 1em;
  color:#cfe1ff;
  font-size: clamp(14px,2vw,20px);
  opacity:0;
  animation: fadeInUp 1.8s ease-out both 0.6s;
}
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(30px); }
  to   { opacity:1; transform:translateY(0); }
}

/* Section heading glow line */
.h3 {
  position: relative;
  overflow: hidden;
}
.h3::after {
  content:"";
  position:absolute;
  bottom:0; left:-30%;
  width:60%; height:2px;
  background:linear-gradient(90deg, transparent, var(--acc2), transparent);
  animation: h3Glow 3s ease-in-out infinite;
}
@keyframes h3Glow {
  0%   { transform:translateX(-100%); opacity:0; }
  50%  { transform:translateX(0);     opacity:1; }
  100% { transform:translateX(100%);  opacity:0; }
}

/* Scroll-in cards */
.box {
  opacity:0;
  transform: translateY(40px);
  transition: opacity .8s ease-out, transform .8s ease-out;
}
.box.visible {
  opacity:1;
  transform: translateY(0);
}

/* Timeline flowing light */
.timeline {
  position: relative;
  border-left: 2px solid rgba(255,255,255,.2);
  padding-left: 10px;
}
.timeline::before {
  content:"";
  position:absolute;
  top:0; left:-1px;
  width:2px; height:100%;
  background: linear-gradient(to bottom, var(--acc2), rgba(106,164,255,0) 60%);
  background-size: 100% 200%;
  animation: flowLine 6s linear infinite;
}
@keyframes flowLine {
  0%   { background-position: 0 0; }
  100% { background-position: 0 100%; }
}

/* Footer anniversary */
footer .anniv {
  font-size: 12px;
  color: var(--acc2);
  margin-top: 6px;
  letter-spacing: .08em;
}


/* === White sections (理念＋メッセージ) の文字色を完全統一 === */
.white-box {
  background: #ffffff !important;
  color: #111 !important;
  border: 1px solid rgba(0,0,0,.1);
  box-shadow: 0 6px 20px rgba(0,0,0,.12);
}
.white-box .h3 {
  border-left: 3px solid #6aa4ff;
  color: #111 !important;
}
.white-box p,
.white-box li,
.white-box span,
.white-box strong,
.white-box .author {
  color: #111 !important;
}
.white-box .msg {
  background: rgba(255,255,255,.95) !important;
  border-left: 2px solid #6aa4ff !important;
  color: #111 !important;
  box-shadow: 0 3px 12px rgba(0,0,0,.08);
}
.white-box .msg p { line-height: 1.85; margin: .8em 0; }
.white-box .msg .author { text-align: right; font-style: italic; opacity: .85; }

/* === 理念 + 会社情報の2カラム表示 === */
.sec-row {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  margin-bottom: clamp(24px, 3vw, 36px);
}
.half-box {
  flex: 1 1 calc(50% - 12px);
}
@media (max-width: 960px) {
  .half-box {
    flex: 1 1 100%;
  }
}

/* === 取扱商品（カテゴリ）4カラム === */
.cat-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 8px;
}
.cat-item{
  display:flex; align-items:center; justify-content:center;
  min-height: 64px;
  padding: 14px 10px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  color: #e8f3ff; text-decoration: none; font-weight: 800;
  letter-spacing: .02em;
  box-shadow: var(--shadow);
  transition: transform .18s ease, border-color .18s ease, background-color .18s ease;
}
.cat-item:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.10);
}

/* SP・タブレット時の折り返し（PCでは1行4列を維持） */
@media (max-width: 960px){
  .cat-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 480px){
  .cat-grid{ grid-template-columns: 1fr; }
}

/* === 取扱商品（親子カテゴリ） === */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 8px;
}

.cat-item {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  padding: 12px 10px;
  box-shadow: var(--shadow);
  transition: 0.2s ease;
}

.cat-item:hover {
  background: rgba(255,255,255,0.10);
  transform: translateY(-1px);
}

.cat-title {
  font-weight: 700;
  color: #e8f3ff;
  font-size: 1rem;
  margin-bottom: 6px;
  text-align: center;
}

.cat-sub {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: center;
}

.cat-sub li {
  font-size: 0.88rem;
  color: #cfd8e3;
  line-height: 1.4;
}

/* スマホ対応 */
@media (max-width: 960px){
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px){
  .cat-grid { grid-template-columns: 1fr; }
}

/* === 取扱商品（縦列スタイル） === */
.cat-vertical {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 8px;
}

.cat-block {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  padding: 12px 16px;
  box-shadow: var(--shadow);
  transition: background 0.2s ease, transform 0.2s ease;
}

.cat-block:hover {
  background: rgba(255,255,255,0.10);
  transform: translateY(-2px);
}

.cat-title {
  font-weight: 700;
  color: #e8f3ff;
  font-size: 1rem;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.2);
  padding-bottom: 4px;
}

.cat-sub {
  list-style: none;
  padding: 0;
  margin: 4px 0 0 0;
}

.cat-sub li {
  font-size: 0.88rem;
  color: #cfd8e3;
  line-height: 1.6;
  margin-left: 0.5em;
}

/* === 取扱商品（親子構造 + 4列グリッド） === */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 8px;
}

.cat-block {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  padding: 12px 16px;
  box-shadow: var(--shadow);
  transition: background 0.2s ease, transform 0.2s ease;
}

.cat-block:hover {
  background: rgba(255,255,255,0.10);
  transform: translateY(-2px);
}

.cat-title {
  font-weight: 700;
  color: #e8f3ff;
  font-size: 1rem;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.2);
  padding-bottom: 4px;
  text-align: center;
}

.cat-sub {
  list-style: none;
  padding: 0;
  margin: 6px 0 0 0;
  text-align: center;
}

.cat-sub li {
  font-size: 0.88rem;
  color: #cfd8e3;
  line-height: 1.6;
}

/* レスポンシブ対応 */
@media (max-width: 960px){
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px){
  .cat-grid { grid-template-columns: 1fr; }
}


/* ===== Overview v2 Enhancements: KPI / Values / Journey ===== */
.hero .subcopy{
  font-weight: 900;
  letter-spacing: .06em;
}

/* Small section kicker */
.kicker{
  margin: 0 0 6px;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(207,225,255,.85);
  font-weight: 900;
}

/* Secondary lead */
.lead2{
  margin: 0 0 14px;
  color: var(--muted);
  line-height: 1.85;
}

/* KPI */
.kpi-box{ position: relative; overflow: hidden; }
.kpi-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.kpi{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 16px;
  padding: 14px 14px;
  box-shadow: var(--shadow);
}
.kpi-num{
  font-weight: 950;
  font-size: clamp(22px, 3.2vw, 36px);
  line-height: 1.0;
  letter-spacing: .02em;
  display:flex;
  align-items: baseline;
  justify-content: center;
  gap: 6px;
}
.kpi-num .unit{
  font-size: 14px;
  font-weight: 900;
  opacity: .9;
}
.kpi-label{
  margin-top: 8px;
  font-weight: 800;
  color: rgba(233,238,246,.92);
  text-align:center;
  font-size: 13px;
  line-height: 1.5;
}
.note2{
  margin-top: 10px;
  color: rgba(169,179,195,.85);
  font-size: 12px;
}

/* Values */
.value-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.vcard{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 18px;
  padding: 16px;
  box-shadow: var(--shadow);
  transition: transform .18s ease, border-color .18s ease, background-color .18s ease;
}
.vcard:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.09);
}
.vicon{
  width: 44px; height: 44px;
  display:grid; place-items:center;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(58,215,189,.18), rgba(106,164,255,.18));
  border: 1px solid rgba(255,255,255,.14);
  font-size: 22px;
}
.vtitle{
  margin-top: 0;
  font-weight: 950;
  font-size: 16px;
  letter-spacing: .02em;
  color: var(--txt);
  text-shadow:
    0 0 10px rgba(58,215,189,.35),
    0 0 18px rgba(106,164,255,.25);
}
.vdesc{
  margin: 8px 0 0;
  color: rgba(233,238,246,.9);
  line-height: 1.9;
  font-size: 14px;
}

/* CTA */
.cta-row{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.cta-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 14px;
  border-radius: 14px;
  text-decoration:none;
  font-weight: 950;
  letter-spacing: .02em;
  background: linear-gradient(135deg, var(--acc1), var(--acc2));
  color: #071018;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
}
.cta-btn.ghost{
  /* “気軽に相談する”などのサブCTA：控えめに着色（テーマのアクセントを薄く反映） */
  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--acc1) 18%, rgba(255,255,255,.04)),
    color-mix(in oklab, var(--acc2) 18%, rgba(255,255,255,.04))
  );
  color: #eaf3ff;
  border: 1px solid color-mix(in oklab, var(--acc1) 38%, rgba(255,255,255,.18));
  box-shadow: 0 10px 26px rgba(0,0,0,.22);
}
.cta-btn.ghost:hover{
  background: linear-gradient(
    135deg,
    color-mix(in oklab, var(--acc1) 26%, rgba(255,255,255,.06)),
    color-mix(in oklab, var(--acc2) 26%, rgba(255,255,255,.06))
  );
  border-color: color-mix(in oklab, var(--acc2) 48%, rgba(255,255,255,.22));
  transform: translateY(-1px);
}
.cta-btn.ghost:active{ transform: translateY(0); }
.cta-btn:focus-visible{
  outline: 3px solid color-mix(in oklab, var(--acc2) 55%, rgba(255,255,255,.25));
  outline-offset: 3px;
}

/* Journey steps */
.steps{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.step{
  display:flex; gap: 12px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
}
.step-no{
  width: 44px; height: 44px;
  border-radius: 14px;
  display:grid; place-items:center;
  font-weight: 950;
  background: linear-gradient(135deg, rgba(58,215,189,.18), rgba(106,164,255,.18));
  border: 1px solid rgba(255,255,255,.14);
}
.step-title{ font-weight: 950; }
.step-desc{
  margin: 6px 0 0;
  color: rgba(233,238,246,.9);
  line-height: 1.9;
  font-size: 14px;
}

/* Quote */
.quote{
  margin: 14px 0 0;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.12);
}
.quote p{
  margin: 0;
  font-weight: 900;
  line-height: 1.9;
  color: rgba(233,238,246,.96);
}
.quote footer{
  margin-top: 8px;
  color: rgba(169,179,195,.92);
  font-weight: 800;
  font-size: 12px;
}

/* Responsive */
@media (max-width: 960px){
  .kpi-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .value-grid{ grid-template-columns: 1fr; }
  .steps{ grid-template-columns: 1fr; }
}


/* ===== Recruit section ===== */
.recruit-box{
  position: relative;
  overflow: hidden;
}
.recruit-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.r-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 14px 14px;
  box-shadow: 0 10px 25px rgba(0,0,0,.18);
}
.r-title{
  font-weight: 800;
  letter-spacing: .02em;
  margin-bottom: 8px;
}
.r-desc{
  color: var(--muted);
  line-height: 1.85;
  margin: 0;
}
.r-list{
  margin: 0;
  padding-left: 1.1em;
  color: var(--muted);
  line-height: 1.9;
}
.recruit-note{
  margin: 10px 0 0;
  color: rgba(233,238,246,.72);
  font-size: .95rem;
}

@media (max-width: 980px){
  .recruit-grid{ grid-template-columns: 1fr; }
}

