:root {
      --navy: #15243B;
      --gray: #6B7280;
      --gold: #B89B5E;
      --bg: #F5F6F8;
      --text: #293241;
      --line: #D9DEE7;
      --white: #FFFFFF;
      --shadow: 0 24px 70px rgba(21, 36, 59, 0.12);
      --serif: "BIZ UDPMincho", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
      --sans: "BIZ UDPGothic", "Yu Gothic", "YuGothic", "Hiragino Kaku Gothic ProN", sans-serif;
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    html, body {
      overflow-x: hidden;
    }
    body {
      margin: 0;
      color: var(--text);
      font-family: var(--sans);
      font-size: 17px;
      line-height: 1.8;
      background: var(--white);
    }
    img { max-width: 100%; display: block; }
    a { color: inherit; text-decoration: none; }
    h1, h2, h3, .lead, .btn, summary {
      word-break: auto-phrase;
      text-wrap: balance;
    }
    h1, h2, h3, p { margin-top: 0; }
    h1, h2, h3 {
      color: var(--navy);
      font-family: var(--serif);
      font-weight: 600;
      line-height: 1.35;
    }
    h1 { font-size: 58px; margin-bottom: 26px; }
    h2 { font-size: 38px; margin-bottom: 28px; }
    h3 { font-size: 24px; margin-bottom: 12px; }
    p { margin-bottom: 0; }
    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 14px;
      color: var(--gray);
      font-size: 13px;
      font-weight: 700;
    }
    .eyebrow::before {
      content: "";
      width: 54px;
      height: 1px;
      background: var(--gold);
    }
    .lead {
      max-width: 620px;
      font-size: 19px;
      color: #384456;
    }
    .section {
      position: relative;
      padding: 96px 24px;
      overflow: hidden;
    }
    .section-inner {
      position: relative;
      z-index: 1;
      max-width: 1120px;
      margin: 0 auto;
    }
    .band { background: var(--bg); }
    .dark {
      color: rgba(255, 255, 255, 0.82);
      background: var(--navy);
    }
    .dark h2, .dark h3 { color: var(--white); }
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 52px;
      padding: 13px 24px;
      border: 1px solid var(--navy);
      color: var(--white);
      background: var(--navy);
      font-weight: 700;
      transition: transform 180ms ease, background 180ms ease, color 180ms ease;
    }
    .btn:hover { transform: translateY(-2px); }
    .btn.secondary {
      color: var(--navy);
      background: var(--white);
    }
    .btn.gold {
      color: var(--navy);
      border-color: var(--gold);
      background: var(--gold);
    }
    .btn-row {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      margin-top: 34px;
    }
    .deco {
      position: absolute;
      z-index: 0;
      pointer-events: none;
      opacity: 0.42;
      mix-blend-mode: multiply;
    }

    /* ZOROYA:HEADER */
    .site-header {
      position: sticky;
      top: 0;
      z-index: 20;
      border-bottom: 1px solid rgba(217, 222, 231, 0.92);
      background: rgba(255, 255, 255, 0.95);
      backdrop-filter: blur(10px);
    }
    .header-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
      max-width: 1320px;
      min-height: 82px;
      margin: 0 auto;
      padding: 0 24px;
    }
    .logo {
      display: flex;
      align-items: center;
      width: 258px;
    }
    .nav {
      display: flex;
      align-items: center;
      gap: 24px;
      color: #384456;
      font-size: 14px;
      font-weight: 700;
    }
    .header-actions {
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .phone {
      color: var(--navy);
      font-weight: 800;
      white-space: nowrap;
    }
    .header-actions .btn { min-height: 44px; padding: 9px 16px; font-size: 14px; }
    /* /ZOROYA:HEADER */

    /* ZOROYA:MAIN */
    .hero {
      position: relative;
      width: 100%;
      min-height: 760px;
      padding: 62px 24px 70px;
      overflow: hidden;
      background: linear-gradient(90deg, #FFFFFF 0%, #FFFFFF 49%, #EEF1F5 49%, #EEF1F5 100%);
    }
    .hero-inner {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: minmax(0, 0.45fr) minmax(0, 0.55fr);
      align-items: center;
      gap: 56px;
      max-width: 1360px;
      min-height: 650px;
      margin: 0 auto;
    }
    .hero-copy {
      padding-top: 24px;
      min-width: 0;
    }
    .hero-note {
      display: grid;
      grid-template-columns: 112px 1fr;
      gap: 24px;
      align-items: start;
      max-width: 600px;
      margin-top: 42px;
      border-top: 1px solid var(--line);
      padding-top: 24px;
      color: var(--gray);
      font-size: 14px;
    }
    .hero-note strong {
      color: var(--navy);
      font-family: var(--serif);
      font-size: 36px;
      line-height: 1;
    }
    .hero-visual {
      position: relative;
      min-height: 520px;
      min-width: 0;
    }
    .hero-visual img.main {
      width: 100%;
      aspect-ratio: 16 / 9;
      object-fit: cover;
      box-shadow: var(--shadow);
    }
    .hero-card {
      position: absolute;
      right: 5%;
      bottom: -38px;
      width: min(420px, 76%);
      border-left: 3px solid var(--gold);
      padding: 26px 28px;
      background: var(--white);
      box-shadow: var(--shadow);
    }
    .hero-card p {
      color: var(--gray);
      font-size: 14px;
    }
    /* 16.Service band */
    .legal-ticker {
      position: relative; z-index: 2; overflow: hidden;
      display: flex; flex-wrap: wrap; align-items: stretch;
      background: var(--navy); color: #fff; border-top: 3px solid var(--gold);
    }
    .legal-ticker .lt-label {
      display: flex; align-items: center; padding: 0 24px; white-space: nowrap;
      background: var(--gold); color: var(--navy);
      font-family: var(--serif); font-weight: 700; font-size: 13px;
    }
    .legal-ticker .mq { display: flex; flex: 1 1 420px; flex-wrap: wrap; gap: 0 22px; padding: 10px 24px; }
    .legal-ticker .mq span { padding: 6px 0; font-family: var(--serif); font-size: 15px; color: rgba(255,255,255,.92); }
    .legal-ticker .mq span::before { content: "／"; padding-right: 10px; color: var(--gold); }
    .hero-frame {
      top: 24px;
      right: 3%;
      width: 360px;
    }

    .worry-layout {
      display: grid;
      grid-template-columns: 0.92fr 1.08fr;
      gap: 64px;
      align-items: start;
    }
    .inline-visual {
      margin: 34px 0 0;
    }
    .inline-visual img {
      width: 100%;
      aspect-ratio: 3 / 2;
      object-fit: cover;
      box-shadow: 0 16px 42px rgba(21, 36, 59, 0.10);
    }
    .inline-visual figcaption {
      margin-top: 10px;
      color: var(--gray);
      font-size: 13px;
    }
    .ruled-list {
      border-top: 1px solid var(--line);
    }
    .ruled-item {
      display: grid;
      grid-template-columns: 82px 1fr;
      gap: 24px;
      border-bottom: 1px solid var(--line);
      padding: 24px 0;
    }
    .ruled-item span {
      color: var(--gold);
      font-family: var(--serif);
      font-size: 28px;
    }
    .split {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 60px;
      align-items: center;
    }
    .large-statement {
      position: relative;
      padding: 72px 24px;
      background: var(--navy);
      color: rgba(255, 255, 255, 0.84);
    }
    .large-statement-inner {
      display: grid;
      grid-template-columns: 1.05fr 0.95fr;
      gap: 48px;
      align-items: center;
      max-width: 1120px;
      margin: 0 auto;
    }
    .large-statement strong {
      display: block;
      max-width: 720px;
      margin: 0 0 18px;
      color: var(--white);
      font-family: var(--serif);
      font-size: 40px;
      font-weight: 600;
      line-height: 1.5;
    }
    .statement-media img {
      width: 100%;
      aspect-ratio: 3 / 2;
      object-fit: cover;
      border: 1px solid rgba(255, 255, 255, 0.24);
    }
    .proof-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
      margin-top: 40px;
    }
    .proof-grid img {
      aspect-ratio: 4 / 3;
      object-fit: contain;
      background: var(--white);
      box-shadow: 0 12px 34px rgba(21, 36, 59, 0.08);
    }
    .profile-block {
      display: grid;
      grid-template-columns: 320px 1fr;
      gap: 42px;
      align-items: center;
      margin-top: 48px;
      border-top: 1px solid rgba(255, 255, 255, 0.24);
      padding-top: 44px;
    }
    .profile-block img {
      aspect-ratio: 1;
      object-fit: cover;
      border-radius: 50%;
      border: 1px solid rgba(255, 255, 255, 0.32);
    }
    .case-zigzag {
      display: grid;
      gap: 34px;
      margin-top: 46px;
    }
    .case-item {
      display: grid;
      grid-template-columns: 0.95fr 1.05fr;
      gap: 36px;
      align-items: center;
    }
    .case-item:nth-child(even) {
      grid-template-columns: 1.05fr 0.95fr;
    }
    .case-item:nth-child(even) img { order: 2; }
    .case-item img {
      width: 100%;
      aspect-ratio: 4 / 3;
      object-fit: cover;
    }
    .case-text {
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      padding: 30px 0;
    }
    .voice-row {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 28px;
      margin-top: 44px;
    }
    .voice {
      border-top: 1px solid var(--line);
      padding-top: 24px;
    }
    .voice img {
      width: 108px;
      height: 108px;
      border-radius: 50%;
      object-fit: cover;
      margin-bottom: 18px;
    }
    .index-table {
      margin-top: 38px;
      border-top: 1px solid rgba(255, 255, 255, 0.28);
    }
    .service-visual-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 14px;
      margin-top: 34px;
    }
    .service-visual-grid img {
      width: 100%;
      aspect-ratio: 1.45 / 1;
      object-fit: cover;
      border: 1px solid rgba(255, 255, 255, 0.18);
      opacity: 0.94;
    }
    .index-row {
      display: grid;
      grid-template-columns: 190px 1fr 190px;
      gap: 28px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.22);
      padding: 24px 0;
    }
    .index-row strong {
      color: var(--white);
      font-family: var(--serif);
      font-size: 22px;
    }
    .index-row .price {
      color: var(--white);
      font-weight: 800;
      text-align: right;
    }
    .steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
      margin-top: 42px;
      counter-reset: step;
    }
    .flow-intro {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 40px;
      align-items: end;
      margin-top: 12px;
    }
    .flow-intro img {
      width: 100%;
      aspect-ratio: 3 / 2;
      object-fit: cover;
      box-shadow: 0 16px 42px rgba(21, 36, 59, 0.10);
    }
    .step {
      position: relative;
      min-height: 260px;
      border-top: 1px solid var(--line);
      padding-top: 76px;
    }
    .step::before {
      counter-increment: step;
      content: counter(step, decimal-leading-zero);
      position: absolute;
      top: 0;
      left: 0;
      color: rgba(184, 155, 94, 0.46);
      font-family: var(--serif);
      font-size: 64px;
      line-height: 1;
    }
    .faq {
      display: grid;
      grid-template-columns: 0.75fr 1.25fr;
      gap: 56px;
    }
    .faq-visual {
      margin-top: 28px;
    }
    .faq-visual img {
      width: 100%;
      aspect-ratio: 3 / 2;
      object-fit: cover;
    }
    details {
      border-top: 1px solid var(--line);
      padding: 22px 0;
    }
    details:last-child { border-bottom: 1px solid var(--line); }
    summary {
      cursor: pointer;
      color: var(--navy);
      font-weight: 800;
      list-style: none;
    }
    summary::-webkit-details-marker { display: none; }
    details p {
      margin-top: 12px;
      color: var(--gray);
    }
    .final-cta {
      display: grid;
      grid-template-columns: 1.1fr 0.9fr;
      gap: 48px;
      align-items: center;
      padding: 72px;
      background: var(--white);
      box-shadow: var(--shadow);
    }
    .final-cta .note-list {
      border-left: 1px solid var(--line);
      padding-left: 34px;
      color: var(--gray);
    }
    .contact-visual {
      margin-bottom: 24px;
    }
    .contact-visual img {
      width: 100%;
      aspect-ratio: 3 / 2;
      object-fit: cover;
    }
    .thin-rule {
      left: 50%;
      bottom: 28px;
      width: min(86vw, 980px);
      transform: translateX(-50%);
    }
    /* /ZOROYA:MAIN */

    /* ZOROYA:FOOTER */
    .footer {
      padding: 58px 24px;
      color: rgba(255, 255, 255, 0.78);
      background: #101B2C;
    }
    .footer-inner {
      display: grid;
      grid-template-columns: 1fr 1.2fr;
      gap: 48px;
      max-width: 1120px;
      margin: 0 auto;
    }
    .footer-logo {
      width: 260px;
      padding: 12px;
      background: var(--white);
    }
    .footer dl {
      display: grid;
      grid-template-columns: 140px 1fr;
      gap: 10px 22px;
      margin: 0;
      font-size: 14px;
    }
    .footer dt { color: rgba(255, 255, 255, 0.52); }
    .footer dd { margin: 0; }
    .copyright {
      max-width: 1120px;
      margin: 38px auto 0;
      border-top: 1px solid rgba(255, 255, 255, 0.16);
      padding-top: 24px;
      color: rgba(255, 255, 255, 0.48);
      font-size: 13px;
    }
    /* /ZOROYA:FOOTER */

    @media (max-width: 980px) {
      .nav { display: none; }
      h1 { font-size: 46px; }
      .hero-inner,
      .worry-layout,
      .split,
      .large-statement-inner,
      .flow-intro,
      .profile-block,
      .faq,
      .final-cta,
      .footer-inner {
        grid-template-columns: 1fr;
      }
      .proof-grid,
      .voice-row,
      .steps {
        grid-template-columns: repeat(2, 1fr);
      }
      .index-row {
        grid-template-columns: 150px 1fr;
      }
      .index-row .price {
        grid-column: 2;
        text-align: left;
      }
    }

    @media (max-width: 768px) {
      body { font-size: 16px; }
      h1 { font-size: 35px; }
      h2 { font-size: 29px; }
      h3 { font-size: 21px; }
      .section { padding: 64px 20px; }
      .header-inner {
        min-height: auto;
        padding: 12px 18px;
      }
      .logo { width: 190px; }
      .phone { display: none; }
      .header-actions .btn { min-height: 40px; padding: 8px 12px; font-size: 13px; }
      .hero {
        min-height: auto;
        padding: 42px 20px 76px;
        background: var(--white);
      }
      .hero-inner {
        grid-template-columns: 1fr;
        min-height: auto;
        gap: 32px;
      }
      .hero-visual { min-height: auto; }
      .hero-card {
        position: relative;
        right: auto;
        bottom: auto;
        width: 100%;
        margin-top: 16px;
      }
      .hero-note {
        grid-template-columns: 1fr;
      }
      .large-statement strong { font-size: 28px; }
      .ruled-item,
      .case-item,
      .case-item:nth-child(even),
      .proof-grid,
      .voice-row,
      .steps,
      .service-visual-grid,
      .index-row {
        grid-template-columns: 1fr;
      }
      .case-item:nth-child(even) img { order: 0; }
      .profile-block img {
        width: 220px;
        margin: 0 auto;
      }
      .step { min-height: 210px; }
      .final-cta {
        padding: 36px 24px;
      }
      .final-cta .note-list {
        border-left: 0;
        border-top: 1px solid var(--line);
        padding: 24px 0 0;
      }
      .footer dl {
        grid-template-columns: 1fr;
      }
    }
  
/* ZOROYA fixed pages / WordPress migration support */
.zoroya-sub-nav{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.zoroya-sub-nav a,.wp-page-links a{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line,rgba(0,0,0,.14));border-radius:999px;padding:.55em 1em;font-weight:700;font-size:13px;background:rgba(255,255,255,.72)}
.zoroya-sub-nav a[aria-current="page"]{background:var(--ink,#222);color:#fff;border-color:var(--ink,#222)}
.wp-page-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.page-main{background:var(--bg,#f7f3ed);color:var(--body,#333);min-height:60vh}
.page-hero{padding:clamp(76px,10vw,132px) 0 clamp(44px,7vw,82px);border-bottom:1px solid var(--line,rgba(0,0,0,.12));background:linear-gradient(135deg,rgba(255,255,255,.75),rgba(255,255,255,.28))}
.page-hero .section-inner,.page-section .section-inner,.zoroya-final .section-inner{width:min(1120px,calc(100% - 44px));margin:0 auto}
.page-hero h1{font-size:clamp(32px,5vw,56px);margin:.18em 0 .28em}
.page-hero p{max-width:42em;color:var(--muted,var(--body,#555));font-size:clamp(15px,1.8vw,18px)}
.page-section{padding:clamp(58px,8vw,100px) 0;border-bottom:1px solid var(--line-soft,var(--line,rgba(0,0,0,.08)))}
.page-section h2{font-size:clamp(25px,3.4vw,40px);margin-bottom:24px}
.zoroya-sub-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.zoroya-sub-card{background:var(--paper,#fff);border:1px solid var(--line,rgba(0,0,0,.12));border-radius:12px;padding:24px;box-shadow:0 18px 44px -34px rgba(0,0,0,.34)}
.zoroya-sub-card h3{font-size:clamp(19px,2vw,24px);margin-bottom:10px}
.zoroya-sub-card p,.zoroya-sub-card li{color:var(--muted,var(--body,#555));font-size:15px}
.zoroya-sub-card ul{margin:12px 0 0;padding-left:1.25em}
.zoroya-flow{display:grid;gap:14px;counter-reset:flow}
.zoroya-flow li{list-style:none;display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;background:rgba(255,255,255,.58);border:1px solid var(--line,rgba(0,0,0,.12));padding:18px;border-radius:10px}
.zoroya-flow li::before{counter-increment:flow;content:counter(flow,decimal-leading-zero);font-weight:800;color:var(--accent,#9a6a33);font-family:inherit}
.zoroya-info{display:grid;grid-template-columns:180px 1fr;gap:0;border-top:1px solid var(--line,rgba(0,0,0,.12));background:rgba(255,255,255,.5)}
.zoroya-info dt,.zoroya-info dd{margin:0;padding:14px 16px;border-bottom:1px solid var(--line,rgba(0,0,0,.12))}
.zoroya-info dt{font-weight:800;color:var(--ink,#222)}
.zoroya-faq{display:grid;gap:14px}
.zoroya-faq details{background:var(--paper,#fff);border:1px solid var(--line,rgba(0,0,0,.12));border-radius:10px;padding:18px 20px}
.zoroya-faq summary{cursor:pointer;font-weight:800;color:var(--ink,#222)}
.zoroya-faq p{margin-top:12px;color:var(--muted,var(--body,#555))}
.zoroya-form-slot{background:var(--paper,#fff);border:1px dashed var(--accent,#9a6a33);border-radius:12px;padding:26px}
.zoroya-final{padding:clamp(56px,8vw,94px) 0;background:var(--ink,#222);color:#fff}
.zoroya-final h2{color:#fff}
.zoroya-final p{color:rgba(255,255,255,.78);max-width:40em}
.zoroya-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px}
@media (max-width:768px){
  .zoroya-sub-grid,.zoroya-info{grid-template-columns:1fr}
  .zoroya-info dt{padding-bottom:4px;border-bottom:0}
  .zoroya-info dd{padding-top:4px}
  .page-hero .section-inner,.page-section .section-inner,.zoroya-final .section-inner{width:min(100% - 28px,1120px)}
}
