@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/* 上部の余白を消す確認用 */
body,
.site,
#container,
#content,
#main {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

header,
.header,
#header,
#header-container,
#header-in {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.nav {
  margin-top: 0 !important;
}

/* 元HTMLのCSS部分 */
    /* =====================
       RESET & BASE
    ===================== */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --ink:    #1a1a18;
      --ink2:   #4a4a46;
      --ink3:   #888880;
      --cream:  #f8f6f0;
      --warm:   #e8e0cc;
      --accent: #c84b2a;
      --serif:  'Noto Serif JP', serif;
      --sans:   'Noto Sans JP', sans-serif;
    }
    html { scroll-behavior: smooth; }
    body {
      font-family: var(--sans);
      background: var(--cream);
      color: var(--ink);
      line-height: 1.7;
      -webkit-font-smoothing: antialiased;
    }
    img { display: block; max-width: 100%; height: auto; }
    a { color: inherit; }

    /* =====================
       UTILITY
    ===================== */
    .section-label {
      font-size: 10px;
      letter-spacing: .25em;
      color: var(--ink3);
      margin-bottom: 48px;
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .section-label::before {
      content: '';
      display: block;
      width: 24px;
      height: 1px;
      background: var(--accent);
    }

    /* =====================
       NAV
    ===================== */
    .nav {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 20px 48px;
      background: var(--cream);
      border-bottom: 1px solid var(--warm);
      position: sticky;
      top: 0;
      z-index: 100;
    }
    .nav-logo {
      font-family: var(--serif);
      font-size: 15px;
      font-weight: 400;
      letter-spacing: .12em;
      color: var(--ink);
      text-decoration: none;
    }
    .nav-logo span {
      font-size: 10px;
      display: block;
      letter-spacing: .2em;
      color: var(--ink3);
      font-family: var(--sans);
    }
    .nav-links {
      display: flex;
      gap: 32px;
      list-style: none;
    }
    .nav-links a {
      font-size: 12px;
      letter-spacing: .1em;
      color: var(--ink2);
      text-decoration: none;
      transition: color .2s;
    }
    .nav-links a:hover { color: var(--accent); }
    .nav-cta {
      font-size: 11px;
      letter-spacing: .12em;
      border: 1px solid var(--ink);
      padding: 8px 20px;
      color: var(--ink);
      text-decoration: none;
      transition: all .2s;
    }
    .nav-cta:hover { background: var(--ink); color: var(--cream); }
    .nav-hamburger { display: none; }

    /* =====================
       HERO
    ===================== */
    .hero {
      min-height: 88vh;
      display: grid;
      grid-template-columns: 1fr 1fr;
      padding: 80px 48px 64px;
      gap: 60px;
      align-items: center;
      background: var(--cream);
    }
    .hero-eyebrow {
      font-size: 10px;
      letter-spacing: .25em;
      color: var(--ink3);
      margin-bottom: 24px;
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .hero-eyebrow::after {
      content: '';
      display: block;
      width: 40px;
      height: 1px;
      background: var(--ink3);
    }
    .hero h1 {
      font-family: var(--serif);
      font-size: 42px;
      font-weight: 300;
      line-height: 1.55;
      letter-spacing: .04em;
      margin-bottom: 32px;
      color: var(--ink);
    }
    .hero h1 em {
      font-style: normal;
      color: var(--accent);
    }
    .hero-desc {
      font-size: 14px;
      line-height: 2.1;
      color: var(--ink2);
      max-width: 420px;
      margin-bottom: 40px;
    }
    .hero-actions {
      display: flex;
      gap: 24px;
      align-items: center;
    }
    .btn-primary {
      font-size: 12px;
      letter-spacing: .15em;
      background: var(--accent);
      color: #fff;
      padding: 14px 32px;
      text-decoration: none;
      transition: all .2s;
      display: inline-block;
    }
    .btn-primary:hover { background: #a83a1e; }
    .btn-secondary {
      font-size: 12px;
      letter-spacing: .1em;
      color: var(--ink2);
      text-decoration: none;
      border-bottom: 1px solid var(--ink3);
      padding-bottom: 2px;
    }
    /* Hero right column */
    .hero-visual { display: flex; flex-direction: column; gap: 16px; }
    .hero-kpi {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
    }
    .kpi-card {
      background: #fff;
      border: 1px solid var(--warm);
      padding: 24px 20px;
    }
    .kpi-num {
      font-family: var(--serif);
      font-size: 36px;
      font-weight: 300;
      color: var(--ink);
      line-height: 1;
      margin-bottom: 8px;
    }
    .kpi-num sup { font-size: 16px; vertical-align: super; }
    .kpi-label {
      font-size: 10px;
      letter-spacing: .1em;
      color: var(--ink3);
      line-height: 1.5;
    }
    .hero-quote {
      background: var(--ink);
      color: var(--cream);
      padding: 28px 32px;
    }
    .hero-quote p {
      font-family: var(--serif);
      font-size: 15px;
      font-weight: 300;
      line-height: 1.9;
      letter-spacing: .06em;
    }
    .hero-quote cite {
      font-size: 10px;
      letter-spacing: .15em;
      color: rgba(255,255,255,.4);
      margin-top: 12px;
      display: block;
      font-style: normal;
    }

    /* =====================
       POSITIONING
    ===================== */
    .positioning {
      padding: 100px 48px;
      background: #fff;
    }
    .positioning-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: start;
    }
    .positioning-title {
      font-family: var(--serif);
      font-size: 30px;
      font-weight: 300;
      line-height: 1.65;
      letter-spacing: .04em;
    }
    .positioning-title strong {
      font-weight: 600;
      color: var(--accent);
    }
    .pos-desc {
      font-size: 14px;
      line-height: 2.1;
      color: var(--ink2);
      margin-top: 24px;
    }
    /* Comparison table */
    .comp-table {
      border: 1px solid var(--warm);
      margin-top: 16px;
    }
    .comp-row {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      border-bottom: 1px solid var(--warm);
    }
    .comp-row:last-child { border-bottom: none; }
    .comp-cell {
      padding: 20px 18px;
      font-size: 12px;
      line-height: 1.7;
      border-right: 1px solid var(--warm);
    }
    .comp-cell:last-child { border-right: none; }
    .comp-cell.highlight {
      background: var(--ink);
      color: var(--cream);
    }
    .comp-cell h4 {
      font-size: 11px;
      letter-spacing: .1em;
      margin-bottom: 6px;
    }
    .comp-cell p { font-size: 11px; color: var(--ink3); line-height: 1.6; }
    .comp-cell.highlight p { color: rgba(255,255,255,.5); }
    .comp-cell.highlight h4 { color: var(--cream); }
    .comp-axis {
      display: flex;
      justify-content: space-between;
      font-size: 10px;
      letter-spacing: .1em;
      color: var(--ink3);
      margin-top: 10px;
      padding: 0 4px;
    }

    /* =====================
       PYRAMID / SERVICES
    ===================== */
    .pyramid-section {
      padding: 100px 48px;
      background: var(--cream);
    }
    .pyramid-wrap {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }
    .pyramid-svg { width: 100%; }
    .services-list { display: flex; flex-direction: column; gap: 24px; }
    .services-list-header {
      font-family: var(--serif);
      font-size: 28px;
      font-weight: 300;
      line-height: 1.6;
      letter-spacing: .04em;
      margin-bottom: 8px;
    }
    .services-list-sub {
      font-size: 13px;
      line-height: 2;
      color: var(--ink2);
      margin-bottom: 16px;
    }
    .service-item {
      border-left: 2px solid var(--warm);
      padding: 4px 0 4px 20px;
      transition: border-color .25s;
    }
    .service-item:hover { border-left-color: var(--accent); }
    .service-item.core { border-left-color: var(--accent); }
    .service-num { font-size: 10px; letter-spacing: .15em; color: var(--ink3); margin-bottom: 4px; }
    .service-name {
      font-family: var(--serif);
      font-size: 17px;
      font-weight: 400;
      color: var(--ink);
      margin-bottom: 5px;
    }
    .service-desc { font-size: 12px; line-height: 1.8; color: var(--ink2); }

    /* =====================
       STRENGTHS
    ===================== */
    .strengths { padding: 100px 48px; background: #fff; }
    .strengths-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 2px;
      background: var(--warm);
      margin-top: 48px;
    }
    .strength-card {
      background: #fff;
      padding: 40px 32px;
    }
    .strength-icon {
      font-size: 10px;
      letter-spacing: .15em;
      color: var(--accent);
      margin-bottom: 16px;
    }
    .strength-card h3 {
      font-family: var(--serif);
      font-size: 20px;
      font-weight: 400;
      margin-bottom: 16px;
      line-height: 1.5;
    }
    .strength-card p { font-size: 13px; line-height: 1.9; color: var(--ink2); }

    /* VS row */
    .vs-row {
      background: var(--ink);
      color: var(--cream);
      padding: 60px 48px;
      margin-top: 2px;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 0;
    }
    .vs-col { padding: 0 32px; }
    .vs-col.center-col {
      border-left: 1px solid rgba(255,255,255,.1);
      border-right: 1px solid rgba(255,255,255,.1);
    }
    .vs-label {
      font-size: 10px;
      letter-spacing: .2em;
      color: rgba(255,255,255,.3);
      margin-bottom: 14px;
    }
    .vs-label.accent { color: var(--accent); }
    .vs-title {
      font-family: var(--serif);
      font-size: 16px;
      font-weight: 300;
      color: rgba(255,255,255,.9);
      margin-bottom: 10px;
    }
    .vs-title.featured { font-size: 18px; color: #fff; }
    .vs-desc { font-size: 12px; line-height: 1.85; color: rgba(255,255,255,.45); }
    .vs-desc.featured { color: rgba(255,255,255,.75); }

    /* =====================
       CTA SECTION
    ===================== */
    .cta-section {
      padding: 120px 48px;
      background: var(--cream);
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: center;
    }
    .cta-title {
      font-family: var(--serif);
      font-size: 34px;
      font-weight: 300;
      line-height: 1.6;
      letter-spacing: .04em;
    }
    .cta-title em { font-style: normal; color: var(--accent); }
    .cta-body {
      font-size: 14px;
      line-height: 2.1;
      color: var(--ink2);
      margin-bottom: 32px;
    }
    .cta-link-list { list-style: none; display: flex; flex-direction: column; gap: 0; }
    .cta-link-list li { border-bottom: 1px solid var(--warm); }
    .cta-link-list a {
      font-size: 13px;
      letter-spacing: .06em;
      color: var(--ink);
      text-decoration: none;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 16px 0;
      transition: color .2s;
    }
    .cta-link-list a:hover { color: var(--accent); }
    .cta-link-list span {
      font-size: 10px;
      letter-spacing: .15em;
      color: var(--ink3);
    }

    /* =====================
       FOOTER
    ===================== */
    footer {
      padding: 40px 48px;
      background: var(--ink);
      color: rgba(255,255,255,.35);
      font-size: 11px;
      letter-spacing: .08em;
      display: flex;
      justify-content: space-between;
      align-items: center;
    }
    footer a { color: rgba(255,255,255,.35); text-decoration: none; }
    footer a:hover { color: rgba(255,255,255,.7); }

    /* =====================
       RESPONSIVE
    ===================== */
    @media (max-width: 900px) {
      .nav { padding: 16px 24px; }
      .nav-links { display: none; }
      .nav-hamburger {
        display: block;
        background: none;
        border: none;
        cursor: pointer;
        font-size: 20px;
        color: var(--ink);
      }
      .hero {
        grid-template-columns: 1fr;
        padding: 48px 24px;
        min-height: auto;
      }
      .hero h1 { font-size: 30px; }
      .hero-kpi { grid-template-columns: repeat(3, 1fr); gap: 8px; }
      .kpi-num { font-size: 24px; }
      .positioning { padding: 64px 24px; }
      .positioning-grid { grid-template-columns: 1fr; gap: 40px; }
      .positioning-title { font-size: 24px; }
      .pyramid-section { padding: 64px 24px; }
      .pyramid-wrap { grid-template-columns: 1fr; gap: 40px; }
      .strengths { padding: 64px 24px; }
      .strengths-grid { grid-template-columns: 1fr; }
      .vs-row { grid-template-columns: 1fr; padding: 48px 24px; gap: 32px; }
      .vs-col { padding: 0; }
      .vs-col.center-col { border: none; border-top: 1px solid rgba(255,255,255,.1); border-bottom: 1px solid rgba(255,255,255,.1); padding: 32px 0; }
      .cta-section { grid-template-columns: 1fr; padding: 64px 24px; gap: 40px; }
      .cta-title { font-size: 26px; }
      footer { padding: 32px 24px; flex-direction: column; gap: 8px; text-align: center; }
    }

/* 元HTMLのCSS部分ここまで */
/*サービスページCSS*/

    /* =====================
       PAGE HERO
    ===================== */
    .page-hero {
      padding: 80px 48px 64px;
      background: #fff;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: end;
      border-bottom: 1px solid var(--warm);
    }
    .page-eyebrow {
      font-size: 10px;
      letter-spacing: .25em;
      color: var(--ink3);
      margin-bottom: 16px;
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .page-eyebrow::before {
      content: '';
      display: block;
      width: 24px;
      height: 1px;
      background: var(--accent);
    }
    .page-hero h1 {
      font-family: var(--serif);
      font-size: 36px;
      font-weight: 300;
      line-height: 1.55;
      letter-spacing: .04em;
    }
    .page-hero h1 em { font-style: normal; color: var(--accent); }
    .page-hero-desc {
      font-size: 14px;
      line-height: 2.2;
      color: var(--ink2);
    }
    .page-hero-desc strong { color: var(--ink); font-weight: 500; }

   /* =====================
       PAIN POINTS
    ===================== */
    .pain {
      padding: 80px 48px;
      background: var(--ink);
    }
    .pain-label {
      font-size: 10px;
      letter-spacing: .25em;
      color: rgba(255,255,255,.3);
      margin-bottom: 40px;
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .pain-label::before {
      content: '';
      display: block;
      width: 24px;
      height: 1px;
      background: var(--accent);
    }
    .pain-title {
      font-family: var(--serif);
      font-size: 24px;
      font-weight: 300;
      color: rgba(255,255,255,.9);
      margin-bottom: 40px;
      line-height: 1.65;
      letter-spacing: .04em;
    }
    .pain-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1px;
      background: rgba(255,255,255,.08);
    }
    .pain-card {
      background: var(--ink);
      padding: 32px 24px;
    }
    .pain-tag {
      font-size: 9px;
      letter-spacing: .2em;
      color: var(--accent);
      margin-bottom: 14px;
    }
    .pain-q {
      font-family: var(--serif);
      font-size: 14px;
      font-weight: 300;
      color: rgba(255,255,255,.85);
      line-height: 1.8;
      margin-bottom: 14px;
    }
    .pain-a {
      font-size: 11px;
      line-height: 1.8;
      color: rgba(255,255,255,.4);
    }

    /* =====================
       SERVICE BLOCKS
    ===================== */
    .service-block {
      display: grid;
      grid-template-columns: 1fr 1fr;
      border-bottom: 1px solid var(--warm);
      background: var(--cream);
    }
    /* Alternate layout */
    .service-block:nth-child(even) .service-block-text { order: 2; }
    .service-block:nth-child(even) .service-block-visual { order: 1; }

    .service-block-text {
      padding: 72px 56px;
      display: flex;
      flex-direction: column;
      justify-content: center;
    }
    .service-block-visual {
      background: var(--warm);
      min-height: 420px;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 48px;
    }
    /* White bg on even blocks visual */
    .service-block:nth-child(even) .service-block-visual {
      background: #fff;
    }

    .service-num-label {
      font-size: 10px;
      letter-spacing: .2em;
      color: var(--ink3);
      margin-bottom: 14px;
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .service-num-label::before {
      content: '';
      display: block;
      width: 20px;
      height: 1px;
      background: var(--ink3);
    }
    .service-badge {
      display: inline-block;
      font-size: 9px;
      letter-spacing: .15em;
      background: var(--ink);
      color: var(--cream);
      padding: 5px 12px;
      margin-bottom: 18px;
    }
    .service-badge.core { background: var(--accent); }

    .service-block h2 {
      font-family: var(--serif);
      font-size: 26px;
      font-weight: 400;
      line-height: 1.55;
      margin-bottom: 10px;
      letter-spacing: .04em;
    }
    .service-tagline {
      font-size: 13px;
      color: var(--accent);
      margin-bottom: 20px;
      letter-spacing: .04em;
      line-height: 1.6;
    }
    .service-desc {
      font-size: 13px;
      line-height: 2.1;
      color: var(--ink2);
      margin-bottom: 28px;
    }
    .feature-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
    .feature-list li {
      font-size: 12px;
      color: var(--ink2);
      display: flex;
      align-items: flex-start;
      gap: 10px;
      line-height: 1.65;
    }
    .feature-list li::before {
      content: '';
      display: block;
      width: 4px;
      height: 4px;
      background: var(--accent);
      border-radius: 50%;
      margin-top: 7px;
      flex-shrink: 0;
    }

    /* =====================
       VISUAL PLACEHOLDERS
       （実際の制作時は画像に差し替え）
    ===================== */
    .mock-package {
      width: 200px;
      height: 280px;
      background: #fff;
      border: 1px solid var(--warm);
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      padding: 24px;
      position: relative;
      overflow: hidden;
    }
    .mock-package::after {
      content: '';
      position: absolute;
      bottom: 0; right: 0;
      width: 60px; height: 60px;
      background: var(--accent);
      opacity: .06;
    }
    .mock-package-label {
      font-size: 9px;
      letter-spacing: .2em;
      color: var(--accent);
      margin-bottom: 10px;
    }
    .mock-package-title {
      font-family: var(--serif);
      font-size: 16px;
      color: var(--ink);
      margin-bottom: 8px;
      line-height: 1.5;
    }
    .mock-package-sub { font-size: 10px; color: var(--ink3); line-height: 1.5; }

    .mock-studio-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px;
      width: 100%;
      max-width: 300px;
    }
    .mock-photo {
      aspect-ratio: 1;
      background: var(--cream);
      border: 1px solid var(--warm);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 10px;
      color: var(--ink3);
      letter-spacing: .08em;
      text-align: center;
      padding: 8px;
    }

    /* Flow steps */
    .mock-flow { width: 100%; max-width: 280px; }
    .flow-step {
      display: flex;
      align-items: flex-start;
      gap: 16px;
      margin-bottom: 0;
    }
    .flow-connector {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 0;
    }
    .flow-dot {
      width: 28px;
      height: 28px;
      background: var(--ink);
      border-radius: 50%;
      flex-shrink: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 10px;
      color: var(--cream);
      font-weight: 500;
    }
    .flow-dot.accent { background: var(--accent); }
    .flow-line-v {
      width: 1px;
      height: 20px;
      background: var(--warm);
    }
    .flow-text { padding: 4px 0 20px; }
    .flow-text h4 { font-size: 12px; font-weight: 500; margin-bottom: 2px; }
    .flow-text p { font-size: 11px; color: var(--ink3); line-height: 1.5; }

    /* Character mock */
    .mock-chara-circle {
      width: 140px;
      height: 140px;
      border-radius: 50%;
      background: #fff;
      border: 1px solid var(--warm);
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 16px;
    }
    .mock-chara-label {
      font-size: 10px;
      letter-spacing: .15em;
      color: var(--ink3);
      text-align: center;
    }

    /* =====================
       PROCESS
    ===================== */
    .process-section { padding: 80px 48px; background: #fff; }
    .process-title {
      font-family: var(--serif);
      font-size: 28px;
      font-weight: 300;
      line-height: 1.6;
      letter-spacing: .04em;
      margin-bottom: 12px;
    }
    .process-desc {
      font-size: 14px;
      line-height: 2.1;
      color: var(--ink2);
      max-width: 560px;
      margin-bottom: 48px;
    }
    .process-steps {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 1px;
      background: var(--warm);
    }
    .process-step { background: #fff; padding: 28px 20px; }
    .ps-num {
      font-size: 28px;
      font-family: var(--serif);
      font-weight: 300;
      color: var(--warm);
      margin-bottom: 14px;
      line-height: 1;
    }
    .ps-title { font-size: 13px; font-weight: 500; margin-bottom: 8px; }
    .ps-desc { font-size: 11px; line-height: 1.75; color: var(--ink3); }
    /* =====================
       CTA
    ===================== */
    .service-cta {
      padding: 80px 48px;
      background: var(--accent);
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 60px;
      align-items: center;
    }
    .service-cta h2 {
      font-family: var(--serif);
      font-size: 30px;
      font-weight: 300;
      color: #fff;
      line-height: 1.6;
      letter-spacing: .04em;
    }
    .cta-right p {
      font-size: 13px;
      line-height: 2.1;
      color: rgba(255,255,255,.75);
      margin-bottom: 28px;
    }
    .btn-white {
      font-size: 12px;
      letter-spacing: .15em;
      background: #fff;
      color: var(--accent);
      padding: 14px 32px;
      text-decoration: none;
      display: inline-block;
      transition: all .2s;
    }
    .btn-white:hover { background: var(--cream); }
    .btn-ghost {
      font-size: 12px;
      letter-spacing: .1em;
      color: rgba(255,255,255,.75);
      text-decoration: none;
      border-bottom: 1px solid rgba(255,255,255,.35);
      margin-left: 24px;
      padding-bottom: 2px;
    }
    
/*サービスページCSSここまで*/
/*メンバーページCSS*/
/* ===================== PHOTO MOSAIC ===================== */
    .photo-mosaic {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      grid-template-rows: 220px 220px;
      gap: 3px;
      background: var(--ink);
    }
    .photo-cell {
      overflow: hidden;
      position: relative;
      background: #2a2a28;
    }
    .photo-cell img {
      width: 100%; height: 100%; object-fit: cover;
      transition: transform .5s ease;
      filter: brightness(.85);
    }
    .photo-cell:hover img { transform: scale(1.04); filter: brightness(.95); }
    /* Featured cells – span */
    .photo-cell.span2h { grid-column: span 2; }
    .photo-cell.span2v { grid-row: span 2; }
    /* Placeholder style for cells without photo */
    .photo-placeholder {
      width: 100%; height: 100%;
      display: flex; align-items: center; justify-content: center;
      flex-direction: column; gap: 8px;
      background: #222220;
      color: rgba(255,255,255,.15);
    }
    .photo-placeholder .ph-icon { font-size: 24px; }
    .photo-placeholder .ph-label { font-size: 9px; letter-spacing: .2em; }

    /* ===================== MVV ===================== */
    .mvv-section { padding: 100px 48px; background: #fff; }
    .mvv-lead {
      display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
      align-items: start; margin-bottom: 72px;
    }
    .mvv-lead-title {
      font-family: var(--serif); font-size: 32px; font-weight: 300;
      line-height: 1.6; letter-spacing: .04em;
    }
    .mvv-lead-title em { font-style: normal; color: var(--accent); }
    .mvv-lead-body { font-size: 14px; line-height: 2.1; color: var(--ink2); }

    /* M/V/V blocks */
    .mvv-blocks { display: flex; flex-direction: column; gap: 2px; background: var(--warm); }
    .mvv-block {
      display: grid; grid-template-columns: 200px 1fr 1fr;
      background: #fff; gap: 0;
    }
    .mvv-block-head {
      padding: 48px 40px;
      display: flex; flex-direction: column; justify-content: space-between;
      border-right: 1px solid var(--warm);
    }
    .mvv-block-num { font-size: 10px; letter-spacing: .2em; color: var(--ink3); margin-bottom: 16px; }
    .mvv-block-label {
      font-family: var(--serif); font-size: 28px; font-weight: 300;
      color: var(--ink); letter-spacing: .04em; line-height: 1;
    }
    .mvv-block-en { font-size: 10px; letter-spacing: .2em; color: var(--ink3); margin-top: 8px; }
    .mvv-block-main {
      padding: 48px 40px;
      border-right: 1px solid var(--warm);
    }
    .mvv-block-tagline {
      font-family: var(--serif); font-size: 18px; font-weight: 400;
      color: var(--ink); line-height: 1.5; margin-bottom: 16px; letter-spacing: .04em;
    }
    .mvv-block-body { font-size: 13px; line-height: 2; color: var(--ink2); }
    .mvv-block-bg {
      padding: 48px 40px;
      background: var(--cream);
    }
    .mvv-block-bg-label {
      font-size: 9px; letter-spacing: .2em; color: var(--accent);
      margin-bottom: 12px;
    }
    .mvv-block-bg-text { font-size: 12px; line-height: 1.95; color: var(--ink3); }

    /* Value items (4つ) */
    .mvv-values { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; background: var(--warm); margin-top: 2px; }
    .mvv-value-card { background: #fff; padding: 36px 28px; }
    .value-num { font-size: 9px; letter-spacing: .2em; color: var(--accent); margin-bottom: 12px; }
    .value-title { font-family: var(--serif); font-size: 18px; font-weight: 400; color: var(--ink); margin-bottom: 12px; line-height: 1.4; }
    .value-body { font-size: 12px; line-height: 1.9; color: var(--ink2); }
    .value-detail {
      margin-top: 12px; padding-top: 12px;
      border-top: 1px solid var(--warm);
    }
    .value-detail-label { font-size: 9px; letter-spacing: .15em; color: var(--ink3); margin-bottom: 6px; }
    .value-detail-text { font-size: 11px; line-height: 1.8; color: var(--ink3); }

    /* ===================== GENBA / 現場主義 ===================== */
    .genba-section { padding: 100px 48px; background: var(--cream); }
    .genba-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
    .genba-title { font-family: var(--serif); font-size: 32px; font-weight: 300; line-height: 1.6; letter-spacing: .04em; margin-bottom: 20px; }
    .genba-title em { font-style: normal; color: var(--accent); }
    .genba-lead { font-size: 14px; line-height: 2.1; color: var(--ink2); margin-bottom: 24px; }
    .genba-tagline {
      font-family: var(--serif); font-size: 16px; font-weight: 400;
      color: var(--ink3); letter-spacing: .1em;
      border-left: 2px solid var(--accent); padding-left: 16px; margin-top: 32px;
    }
    .genba-pillars { display: flex; flex-direction: column; gap: 2px; background: var(--warm); }
    .genba-pillar {
      background: #fff; padding: 28px 32px;
      display: grid; grid-template-columns: 48px 1fr; gap: 20px; align-items: start;
    }
    .pillar-num { font-family: var(--serif); font-size: 28px; font-weight: 300; color: var(--warm); line-height: 1; margin-top: 2px; }
    .pillar-title { font-size: 14px; font-weight: 500; color: var(--ink); margin-bottom: 6px; letter-spacing: .02em; }
    .pillar-desc { font-size: 12px; line-height: 1.85; color: var(--ink2); }

    /* ===================== NPS ===================== */
    .nps-section { padding: 100px 48px; background: var(--ink); color: #fff; }
    .nps-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
    .nps-title { font-family: var(--serif); font-size: 28px; font-weight: 300; color: #fff; line-height: 1.6; letter-spacing: .04em; margin-bottom: 16px; }
    .nps-desc { font-size: 13px; line-height: 2; color: rgba(255,255,255,.5); margin-bottom: 32px; }
    .nps-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,.08); }
    .nps-stat { background: var(--ink); padding: 24px 20px; text-align: center; }
    .nps-stat-num { font-family: var(--serif); font-size: 34px; font-weight: 300; line-height: 1; margin-bottom: 6px; color: rgba(255,255,255,.7); }
    .nps-stat-num.accent { color: var(--accent); }
    .nps-stat-label { font-size: 10px; letter-spacing: .1em; color: rgba(255,255,255,.3); line-height: 1.5; }
    .nps-note { font-size: 11px; color: rgba(255,255,255,.2); margin-top: 16px; letter-spacing: .04em; }
    .nps-chart-wrap { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); padding: 32px; }
    .chart-title { font-size: 11px; letter-spacing: .15em; color: rgba(255,255,255,.3); margin-bottom: 24px; }
    .chart-bars { display: flex; flex-direction: column; gap: 10px; }
    .chart-row { display: grid; grid-template-columns: 28px 1fr 44px; gap: 12px; align-items: center; }
    .chart-label { font-size: 12px; font-family: var(--serif); color: rgba(255,255,255,.45); text-align: right; }
    .chart-bar-track { background: rgba(255,255,255,.06); height: 28px; position: relative; overflow: hidden; }
    .chart-bar-fill { height: 100%; position: absolute; left: 0; top: 0; width: 0; transition: width 1.2s cubic-bezier(.16,1,.3,1); }
    .chart-bar-fill.c10 { background: var(--accent); }
    .chart-bar-fill.c9  { background: rgba(200,75,42,.7); }
    .chart-bar-fill.c8  { background: rgba(200,75,42,.4); }
    .chart-bar-fill.c7  { background: rgba(255,255,255,.2); }
    .chart-bar-fill.c6  { background: rgba(255,255,255,.12); }
    .chart-bar-fill.c5  { background: rgba(255,255,255,.07); }
    .chart-pct { font-size: 11px; color: rgba(255,255,255,.4); text-align: right; }
    .chart-legend { display: flex; gap: 20px; margin-top: 20px; flex-wrap: wrap; }
    .legend-item { display: flex; align-items: center; gap: 6px; font-size: 10px; color: rgba(255,255,255,.3); letter-spacing: .06em; }
    .legend-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

    /* ===================== VOICES ===================== */
    .voice-section { padding: 100px 48px; background: #fff; }
    .voice-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; margin-bottom: 56px; align-items: end; }
    .voice-title { font-family: var(--serif); font-size: 30px; font-weight: 300; line-height: 1.6; letter-spacing: .04em; }
    .voice-title em { font-style: normal; color: var(--accent); }
    .voice-subtitle { font-size: 14px; line-height: 2.1; color: var(--ink2); }
    .voice-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: var(--warm); }
    .voice-grid-wide { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: var(--warm); margin-top: 2px; }
    .voice-card { background: var(--cream); padding: 36px 32px; display: flex; flex-direction: column; gap: 16px; }
    .voice-card.dark { background: var(--ink); }
    .voice-card.white { background: #fff; }
    .voice-quote-mark { font-family: var(--serif); font-size: 40px; line-height: 1; color: var(--warm); margin-bottom: -8px; }
    .voice-card.dark .voice-quote-mark { color: rgba(255,255,255,.1); }
    .voice-tag { font-size: 9px; letter-spacing: .18em; color: var(--accent); }
    .voice-text { font-family: var(--serif); font-size: 14px; font-weight: 300; line-height: 1.9; color: var(--ink); flex: 1; }
    .voice-card.dark .voice-text { color: rgba(255,255,255,.88); }
    .voice-meta { border-top: 1px solid var(--warm); padding-top: 16px; display: flex; align-items: center; justify-content: space-between; }
    .voice-card.dark .voice-meta { border-top-color: rgba(255,255,255,.1); }
    .voice-company { font-size: 11px; letter-spacing: .06em; color: var(--ink3); line-height: 1.5; }
    .voice-card.dark .voice-company { color: rgba(255,255,255,.35); }
    .voice-score-wrap { text-align: right; }
    .voice-score { font-family: var(--serif); font-size: 20px; font-weight: 300; color: var(--accent); display: block; line-height: 1; }
    .voice-score-label { font-size: 9px; letter-spacing: .1em; color: var(--ink3); }

    /* ===================== MEMBERS ===================== */
    .member-section { padding: 100px 48px; background: var(--cream); }
    .member-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; background: var(--warm); }
    .member-card {
      background: #fff; overflow: hidden;
      transition: transform .25s;
    }
    .member-card:hover { transform: translateY(-3px); }
    .member-photo {
      aspect-ratio: 4/5; overflow: hidden; background: var(--warm);
      position: relative;
    }
    .member-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform .4s; }
    .member-card:hover .member-photo img { transform: scale(1.03); }
    .member-photo-placeholder {
      width: 100%; height: 100%;
      display: flex; align-items: center; justify-content: center;
      background: #ede8de; color: var(--ink3); font-size: 11px; letter-spacing: .1em;
    }
    .member-info { padding: 20px 22px 24px; }
    .member-role { font-size: 10px; letter-spacing: .1em; color: var(--accent); margin-bottom: 4px; }
    .member-name { font-family: var(--serif); font-size: 18px; font-weight: 400; color: var(--ink); margin-bottom: 4px; }
    .member-name-en { font-size: 11px; letter-spacing: .1em; color: var(--ink3); }
    .member-title { font-size: 11px; color: var(--ink3); margin-top: 6px; line-height: 1.5; }

    /* ===================== COMPANY GROUP ===================== */
    .group-section { padding: 100px 48px; background: #fff; }
    .group-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; background: var(--warm); margin-top: 48px; }
    .group-card { background: #fff; padding: 40px 32px; }
    .group-logo-area { height: 64px; display: flex; align-items: center; margin-bottom: 24px; }
    .group-logo-placeholder { font-family: var(--serif); font-size: 16px; color: var(--ink); letter-spacing: .08em; }
    .group-name { font-size: 13px; font-weight: 500; color: var(--ink); margin-bottom: 6px; }
    .group-desc { font-size: 12px; line-height: 1.85; color: var(--ink2); margin-bottom: 16px; }
    .group-ceo { font-size: 11px; color: var(--ink3); margin-bottom: 16px; }
    .group-link { font-size: 11px; letter-spacing: .1em; color: var(--accent); border-bottom: 1px solid rgba(200,75,42,.3); padding-bottom: 2px; display: inline-block; }

    /* Company overview table */
    .overview-section { padding: 80px 48px; background: var(--cream); }
    .overview-table { width: 100%; border-collapse: collapse; margin-top: 48px; }
    .overview-table tr { border-bottom: 1px solid var(--warm); }
    .overview-table th {
      font-size: 12px; font-weight: 500; color: var(--ink); letter-spacing: .06em;
      padding: 20px 24px; text-align: left; width: 200px;
      background: #fff; vertical-align: top;
    }
    .overview-table td {
      font-size: 13px; color: var(--ink2); padding: 20px 24px; line-height: 1.85;
      background: var(--cream); vertical-align: top;
    }


/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  /*必要ならばここにコードを書く*/
}

/*834px以下*/
@media screen and (max-width: 834px){
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px){
  /*必要ならばここにコードを書く*/
}
