    :root {
      --midnight: #0a0a12;
      --deep-navy: #0d1428;
      --royal-purple: #2d1b5e;
      --mystic-violet: #4a2d8a;
      --gold: #c9a84c;
      --gold-light: #e8c96a;
      --gold-dim: #7a5f2a;
      --emerald: #1a4a3c;
      --teal: #1d6e5e;
      --mist: #e8e4f0;
      --cloud: #f5f3fa;
      --white: #ffffff;
      --text-dark: #1a1520;
      --text-mid: #4a4060;
      --text-light: #8a80a0;
      --border-gold: rgba(201, 168, 76, 0.3);
      --border-purple: rgba(74, 45, 138, 0.2);
      --star-yellow: #f5c518;
      --card-shadow: 0 4px 32px rgba(74, 45, 138, 0.07);
      --card-hover-shadow: 0 20px 60px rgba(74, 45, 138, 0.14);
    }

    *,
    *::before,
    *::after {
      margin: 0;
      padding: 0;
      box-sizing: border-box
    }

    html {
      scroll-behavior: smooth
    }

    body {
      font-family: 'Noto Serif JP', serif;
      background: var(--cloud);
      color: var(--text-dark);
      overflow-x: hidden
    }

    .testimonials-section {
      padding: 80px 80px 100px;
      max-width: 1440px;
      margin: 0 auto
    }

    .grid-header {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      margin-bottom: 48px
    }

    .grid-count {
      font-family: 'Cormorant Garamond', serif;
      font-size: 14px;
      color: var(--text-light);
      letter-spacing: .15em;
      font-style: italic
    }

    .grid-count strong {
      color: var(--gold);
      font-size: 20px;
      font-style: normal
    }

    /* ─── Voice post list (CMS連携想定) ─── */
    .voice-list-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 28px
    }

    .voice-post-card {
      background: var(--white);
      border: 1px solid rgba(74, 45, 138, .08);
      box-shadow: var(--card-shadow);
      display: flex;
      flex-direction: column;
      overflow: hidden;
      transition: transform .35s cubic-bezier(.25, .8, .25, 1), box-shadow .35s cubic-bezier(.25, .8, .25, 1), border-color .35s
    }

    .voice-post-card:hover {
      transform: translateY(-6px);
      box-shadow: var(--card-hover-shadow);
      border-color: rgba(201, 168, 76, .3)
    }

    .voice-post-thumb {
      display: block;
      overflow: hidden
    }

    .voice-post-thumb .img-box {
      transition: transform .5s
    }

    .voice-post-card:hover .voice-post-thumb .img-box {
      transform: scale(1.03)
    }

    .voice-post-body {
      padding: 24px 26px 28px;
      flex: 1;
      display: flex;
      flex-direction: column
    }

    .voice-post-meta {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-bottom: 14px
    }

    .voice-post-date {
      font-family: 'Cinzel', serif;
      font-size: 11px;
      letter-spacing: .14em;
      color: var(--text-light)
    }

    .voice-post-cat {
      display: inline-block;
      padding: 3px 10px;
      font-size: 10px;
      letter-spacing: .1em;
      color: var(--gold);
      border: 1px solid rgba(201, 168, 76, .35);
      background: rgba(201, 168, 76, .06)
    }

    .voice-post-title {
      font-family: 'Noto Serif JP', serif;
      font-size: 17px;
      font-weight: 500;
      line-height: 1.65;
      letter-spacing: .04em;
      color: var(--text-dark);
      margin-bottom: 14px
    }

    .voice-post-title a {
      color: inherit;
      text-decoration: none;
      transition: color .2s
    }

    .voice-post-title a:hover {
      color: var(--gold)
    }

    .voice-post-excerpt {
      font-size: 13px;
      line-height: 1.95;
      color: var(--text-mid);
      letter-spacing: .04em;
      margin-bottom: 20px;
      flex: 1;
      display: -webkit-box;
      -webkit-line-clamp: 3;
      -webkit-box-orient: vertical;
      overflow: hidden
    }

    .voice-post-readmore {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-family: 'Cinzel', serif;
      font-size: 11px;
      color: var(--gold);
      letter-spacing: .18em;
      margin-top: auto;
      text-decoration: none;
      transition: color .2s
    }

    .voice-post-readmore .svg-icon {
      width: 12px;
      height: 12px;
      transition: transform .3s
    }

    .voice-post-card:hover .voice-post-readmore .svg-icon {
      transform: translateX(4px)
    }

    .voice-post-card.hidden {
      display: none
    }

    .cta-section {
      background: linear-gradient(135deg, var(--royal-purple) 0%, var(--midnight) 45%, var(--emerald) 100%);
      padding: 130px 80px;
      text-align: center;
      position: relative;
      overflow: hidden
    }

    .cta-section::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image: radial-gradient(1px 1px at 15% 30%, rgba(201, 168, 76, .4) 0%, transparent 100%), radial-gradient(1.5px 1.5px at 70% 20%, rgba(255, 255, 255, .25) 0%, transparent 100%), radial-gradient(1px 1px at 85% 70%, rgba(201, 168, 76, .3) 0%, transparent 100%), radial-gradient(1px 1px at 35% 80%, rgba(255, 255, 255, .15) 0%, transparent 100%), radial-gradient(2px 2px at 55% 45%, rgba(201, 168, 76, .2) 0%, transparent 100%)
    }

    .cta-inner {
      position: relative;
      z-index: 1;
      max-width: 720px;
      margin: 0 auto
    }

    .cta-eyebrow {
      font-family: 'Cinzel', serif;
      font-size: 11px;
      letter-spacing: .3em;
      color: var(--gold);
      margin-bottom: 20px
    }

    .cta-title {
      font-size: 46px;
      font-weight: 300;
      color: var(--white);
      line-height: 1.5;
      letter-spacing: .08em;
      margin-bottom: 16px
    }

    .cta-title em {
      font-style: italic;
      color: var(--gold-light)
    }

    .cta-subtitle {
      font-size: 15px;
      color: rgba(255, 255, 255, .55);
      line-height: 2;
      letter-spacing: .08em;
      margin-bottom: 56px
    }

    .cta-btn-primary {
      display: inline-block;
      background: linear-gradient(135deg, var(--gold), var(--gold-light));
      color: var(--midnight);
      padding: 22px 64px;
      font-size: 15px;
      font-weight: 600;
      letter-spacing: .2em;
      text-decoration: none;
      font-family: 'Noto Serif JP', serif;
      border: none;
      cursor: pointer;
      position: relative;
      overflow: hidden;
      transition: all .35s;
      box-shadow: 0 6px 40px rgba(201, 168, 76, .35);
      margin-bottom: 24px;
      animation: pulse-gold 3s ease-in-out infinite
    }

    @keyframes pulse-gold {

      0%,
      100% {
        box-shadow: 0 6px 40px rgba(201, 168, 76, .35)
      }

      50% {
        box-shadow: 0 6px 60px rgba(201, 168, 76, .6)
      }
    }

    .cta-btn-primary::before {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 100%;
      background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .35), transparent);
      transition: left .5s
    }

    .cta-btn-primary:hover::before {
      left: 100%
    }

    .cta-btn-primary:hover {
      transform: translateY(-3px);
      box-shadow: 0 16px 64px rgba(201, 168, 76, .55);
      animation: none
    }

    .cta-tel-row {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      flex-wrap: wrap;
      margin-top: 8px
    }

    .cta-tel-label {
      font-size: 14px;
      color: rgba(255, 255, 255, .4);
      letter-spacing: .15em
    }

    .cta-tel-link {
      font-family: 'Cinzel', serif;
      font-size: 28px;
      color: #fff;
      text-decoration: none;
      letter-spacing: .05em;
      transition: color .2s
    }

    .cta-tel-link:hover {
      color: var(--gold-light)
    }

    .cta-note {
      display: block;
      margin-top: 16px;
      font-size: 11px;
      color: #fff;
      letter-spacing: .15em
    }

    .reveal {
      opacity: 0;
      transform: translateY(32px);
      transition: opacity .7s ease, transform .7s ease
    }

    .reveal.visible {
      opacity: 1;
      transform: translateY(0)
    }

    .reveal-delay-1 {
      transition-delay: .1s
    }

    .reveal-delay-2 {
      transition-delay: .2s
    }

    .reveal-delay-3 {
      transition-delay: .3s
    }

    @media(max-width:1100px) {
      .voice-list-grid {
        grid-template-columns: repeat(2, 1fr)
      }
    }

    @media(max-width:768px) {

      .page-hero {
        padding: 70px 24px 60px
      }

      .page-title-ja {
        font-size: 28px
      }

      .testimonials-section {
        padding: 48px 20px 70px
      }

      .voice-list-grid {
        grid-template-columns: 1fr;
        gap: 20px
      }

      .cta-section {
        padding: 80px 24px
      }

      .cta-title {
        font-size: 30px
      }

      .cta-btn-primary {
        padding: 18px 40px;
        font-size: 14px
      }

    }
