@charset "UTF-8";

:root {
  --font-main: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --brand: #10b3aa;
  --brand-dark: #0aa19a;
  --ink: #0f1720;
  --muted: #6b7784;
  --ring: #e6edf2;
  --navy: #0b326f;
  --card: #fff;
  --brand-primary: #004225;
  --brand-primary-dark: #002E1A;
  --text-main: #0f1720;
  --text-muted: #5b6b78;
  --border-soft: #d4ddd9;
  --surface-soft: #f5f8f7;
  --ring-soft: #e6edf2
}

body.page-id-1216 {
  --brand-primary: #5A5A5A;
  --brand-primary-dark: #3b3b3b
}

/*AUDI*/
body.page-id-1217 {
  --brand-primary: #0052A5;
  --brand-primary-dark: #003a73
}

/*BMW*/
body.page-id-1218 {
  --brand-primary: #004225;
  --brand-primary-dark: #002E1A
}

/*Jaguar*/
body.page-id-1219 {
  --brand-primary: #A4A9AD;
  --brand-primary-dark: #8E9397
}

/*Landrover*/
body.page-id-1220 {
  --brand-primary: #0A0A0A;
  --brand-primary-dark: #000
}

/*Benz*/
body.page-id-1221 {
  --brand-primary: #D71920;
  --brand-primary-dark: #A31219
}

/*MINI*/
body.page-id-1222 {
  --brand-primary: #8E9196;
  --brand-primary-dark: #4A4F58
}

/*Porsche*/
body.page-id-1223 {
  --brand-primary: #001E50;
  --brand-primary-dark: #001238
}

/*VW*/
body.page-id-1224 {
  --brand-primary: #191C1F;
  --brand-primary-dark: #22252A
}

/*Volvo*/
body.page-id-532,
body.page-id-533,
body.page-id-534 {
  font-family: var(--font-main)
}

.mobile-only {
  display: none
}

@media(max-width:768px) {
  .mobile-only {
    display: block
  }
}

strong {
  font-weight: 700
}

.ft-scope {
  --brand: #10b3aa;
  --ink: #0f1720;
  --muted: #5b6b78;
  --ring: #e6edf2;
  --good: #0ea5a3;
  --mid: #f59e0b;
  --bad: #9aa7b4
}

.ft-noscroll {
  overflow: hidden
}

.ft-wrapper {
  max-width: 1100px;
  margin: 20px auto;
  border: 1px solid var(--ring);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .06);
  overflow: hidden;
  position: relative;
  cursor: zoom-in;
  outline: 0
}

.ft-wrapper:focus-visible {
  box-shadow: 0 0 0 3px rgba(16, 179, 170, .35)
}

.ft-grid {
  display: grid;
  grid-template-columns: minmax(90px, 1.2fr) repeat(4, 1fr)
}

.ft-row {
  display: contents
}

.ft-cell {
  padding: 14px 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-top: 1px solid var(--ring);
  border-left: 1px solid var(--ring);
  color: var(--ink)
}

.ft-row.head .ft-cell {
  background: #fbfcfe;
  font-weight: 800
}

.ft-row:first-child .ft-cell {
  border-top: 0
}

.ft-cell:first-child {
  border-left: 0
}

.ft-cell.feat {
  justify-content: flex-start;
  font-weight: 800
}

.ft-cell.head.brand {
  color: #fff;
  background: linear-gradient(135deg, var(--brand), #0aa19a)
}

.ft-row:not(.head) .brand {
  background: linear-gradient(180deg, rgba(16, 179, 170, .09), rgba(16, 179, 170, .06))
}

.ft-row:not(.head):hover .ft-cell {
  background: #f6fbfb
}

.ft-wrapper.fullscreen-mode .ft-row.head .ft-cell {
  white-space: nowrap
}

.ft-mk {
  display: inline-block;
  width: 22px;
  height: 22px;
  vertical-align: middle
}

.ft-mk-good {
  border-radius: 50%;
  box-shadow: inset 0 0 0 3px var(--good)
}

.ft-mk-mid {
  background: var(--mid);
  clip-path: polygon(50% 15%, 6% 88%, 94% 88%)
}

.ft-mk-bad {
  position: relative
}

.ft-mk-bad::before,
.ft-mk-bad::after {
  content: "";
  position: absolute;
  left: 10px;
  top: 2px;
  width: 3px;
  height: 18px;
  background: var(--bad);
  border-radius: 2px
}

.ft-mk-bad::before {
  transform: rotate(45deg)
}

.ft-mk-bad::after {
  transform: rotate(-45deg)
}

.ft-legend {
  display: flex;
  gap: 16px;
  align-items: center;
  margin: 10px auto;
  padding: 0;
  list-style: none;
  color: var(--muted);
  font-size: 13px;
  max-width: 1100px
}

.ft-legend li {
  display: flex;
  align-items: center
}

.ft-legend .ft-mk {
  margin-right: 6px
}

.ft-wrapper.fullscreen-mode {
  position: fixed !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 20px env(safe-area-inset-right) 28px env(safe-area-inset-left) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  z-index: 9999 !important;
  background: rgba(255, 255, 255, .92) !important;
  backdrop-filter: blur(5px);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: zoom-out !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  overflow: auto !important;
  animation: ft-fade-in .16s ease-out
}

.ft-wrapper.fullscreen-mode .ft-table-container {
  position: relative;
  background: #fff;
  border-radius: 16px;
  padding: 12px 12px 18px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .18), 0 8px 24px rgba(0, 0, 0, .08);
  max-width: calc(100% - 48px);
  width: 100%;
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column
}

@keyframes ft-fade-in {
  from {
    opacity: .001
  }

  to {
    opacity: 1
  }
}

@media(prefers-reduced-motion:reduce) {
  .ft-wrapper.fullscreen-mode {
    animation: none
  }
}

.ft-scroller {
  position: relative;
  overflow: visible
}

.ft-wrapper.fullscreen-mode .ft-scroller {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(16, 179, 170, .45) rgba(16, 179, 170, .08);
  flex: 1;
  min-height: 0
}

.ft-wrapper.fullscreen-mode .ft-scroller::-webkit-scrollbar {
  height: 6px
}

.ft-wrapper.fullscreen-mode .ft-scroller::-webkit-scrollbar-track {
  background: rgba(16, 179, 170, .08);
  border-radius: 8px
}

.ft-wrapper.fullscreen-mode .ft-scroller::-webkit-scrollbar-thumb {
  background: rgba(16, 179, 170, .45);
  border-radius: 8px
}

.ft-wrapper.fullscreen-mode .ft-row.head .ft-cell {
  position: sticky;
  top: 0;
  z-index: 2;
  border-top: 0;
  box-shadow: 0 2px 0 var(--ring);
  background: #fbfcfe !important
}

.ft-wrapper.fullscreen-mode .ft-cell.head.brand {
  background: linear-gradient(135deg, var(--brand), #0aa19a) !important
}

.ft-wrapper.fullscreen-mode .ft-grid {
  min-width: 700px
}

.ft-close-btn {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(50%, -50%);
  width: 40px;
  height: 40px;
  padding: 0;
  font-size: 20px;
  font-weight: 900;
  line-height: 38px;
  color: #fff;
  background: linear-gradient(135deg, #d7266b, #a31962);
  border: 0;
  border-radius: 50%;
  text-align: center;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 6px 22px rgba(0, 0, 0, .22)
}

.ft-close-btn:focus-visible {
  outline: 3px solid rgba(16, 179, 170, .6)
}

.ft-wrapper.fullscreen-mode .ft-close-btn {
  display: block !important
}

@media(max-width:767px) {
  .ft-grid {
    grid-template-columns: minmax(80px, 1fr) repeat(4, 1fr)
  }

  .ft-cell {
    padding: 10px 8px;
    font-size: 12px
  }

  .ft-legend {
    flex-wrap: wrap;
    justify-content: center
  }

  .ft-wrapper.fullscreen-mode {
    padding: 10px env(safe-area-inset-right) 24px env(safe-area-inset-left) !important
  }

  .ft-wrapper.fullscreen-mode .ft-grid {
    min-width: 600px
  }

  .ft-wrapper.fullscreen-mode .ft-scroller::before,
  .ft-wrapper.fullscreen-mode .ft-scroller::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 28px;
    pointer-events: none;
    opacity: 0;
    transition: opacity .2s ease
  }

  .ft-wrapper.fullscreen-mode .ft-scroller.show-left::before {
    left: 0;
    border-top-left-radius: 16px;
    border-bottom-left-radius: 16px;
    background: linear-gradient(to right, rgba(255, 255, 255, .95), rgba(255, 255, 255, 0));
    opacity: 1
  }

  .ft-wrapper.fullscreen-mode .ft-scroller.show-right::after {
    right: 0;
    border-top-right-radius: 16px;
    border-bottom-right-radius: 16px;
    background: linear-gradient(to left, rgba(255, 255, 255, .95), rgba(255, 255, 255, 0));
    opacity: 1
  }

  .ft-wrapper.fullscreen-mode .ft-scrollbar {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 6px;
    height: 4px;
    background: rgba(16, 179, 170, .12);
    border-radius: 999px;
    overflow: hidden;
    pointer-events: none;
    z-index: 9
  }

  .ft-wrapper.fullscreen-mode .ft-scrollbar__thumb {
    height: 100%;
    width: 30%;
    background: rgba(16, 179, 170, .55);
    border-radius: 999px;
    transform: translateX(0);
    transition: transform .08s linear
  }

  .ft-wrapper.fullscreen-mode .ft-scrollbar.hidden {
    opacity: 0
  }
}

.ba-section {
  padding: 24px 0
}

.ba-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: center
}

.ba-card {
  margin: 0;
  background: var(--card);
  border: 1px solid var(--ring);
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(15, 23, 32, .06);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease
}

.ba-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(15, 23, 32, .10);
  border-color: #d9e4ea
}

.ba-media {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  padding: 10px
}

.ba-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  transform: scale(1.01);
  transition: transform .35s ease
}

.ba-card:hover .ba-media img {
  transform: scale(1.04)
}

.ba-caption {
  padding: 14px 16px 18px;
  text-align: center
}

.ba-tag {
  display: inline-block;
  font-weight: 800;
  letter-spacing: .02em;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 1.6rem
}

.ba-tag--before {
  background: #eef3ff;
  color: var(--navy)
}

.ba-tag--after {
  background: linear-gradient(135deg, var(--brand), var(--brand-dark));
  color: #fff
}

.ba-meta {
  margin-top: 10px;
  color: var(--muted);
  font-size: 1.5rem;
  line-height: 1.6
}


.ba-connector {
  width: 56px;
  height: 56px;
  position: relative
}

.ba-arrow {
  width: 100%;
  height: 100%;
  background: #fff;
  border: 1px solid var(--ring);
  border-radius: 14px;
  box-shadow: 0 6px 18px rgba(15, 23, 32, .08);
  padding: 10px;
  display: block
}

.ba-arrow path {
  stroke: var(--navy);
  stroke-width: 3;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round
}

.ba-arrow::before,
.ba-arrow::after {
  content: none !important
}

@media(max-width:900px) {
  .ba-grid {
    gap: 18px
  }
}

@media(max-width:768px) {
  .ba-grid {
    grid-template-columns: 1fr;
    gap: 14px;
    justify-items: center
  }

  .ba-card {
    width: 100%;
    max-width: 560px
  }

  .ba-connector {
    width: 72px;
    height: 40px;
    justify-self: center;
    margin: 6px 0
  }

  .ba-arrow {
    transform: rotate(90deg);
    display: block;
    margin: 0 auto
  }
}

@media(prefers-reduced-motion:reduce) {

  .ba-card,
  .ba-media img {
    transition: none
  }
}


@media (min-width:768px) and  (max-width:1024px) {
.services-timeline {
  max-width: 92%!important;
  margin: -2% auto;
  padding: 0;
  font-family: 'Noto Sans JP', -apple-system, sans-serif
}
}


.services-timeline {
  max-width: 100%;
  margin: -2% auto;
  padding: 0;
  font-family: 'Noto Sans JP', -apple-system, sans-serif
}

.timeline-container {
  display: flex;
  flex-direction: column;
  gap: 40px
}
.service-spotlight {
  background: linear-gradient(135deg, #f0f9ff, #dbeafe);
  border-radius: 24px;
  padding: 48px;
  position: relative;
  overflow: hidden
}

.service-spotlight::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, #0d9087)
}

.spotlight-badge {
  display: inline-block;
  background: #10b3aa;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  padding: 8px 20px;
  border-radius: 20px;
  letter-spacing: .06em;
  margin-bottom: 24px
}

.spotlight-layout {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: center
}

.spotlight-text h2 {
  margin: 0 0 20px;
  font-size: 36px;
  font-weight: 900;
  color: #0f1720;
  line-height: 1.2;
  background: #ffffff00;
}

.spotlight-text p {
  margin: 0 0 24px;
  font-size: 16px;
  line-height: 1.8;
  color: #4a5568
}

.spotlight-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 16px;
  flex-wrap: wrap
}

.spotlight-list li {
  background: #fff;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 700;
  color: #10b3aa;
  white-space: nowrap
}

.spotlight-image {
  width: 100%;
  height: 300px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(0, 0, 0, .12)
}

.spotlight-image img {
  width: 100%;
  height: 100%;
  object-fit: cover
}

.service-section {
  position: relative
}

.section-header {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 0px
}

.header-line {
  width: 60px;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, transparent);
  border-radius: 2px;
  flex-shrink: 0
}

.section-header h3 {
  margin: 0;
  font-size: 28px;
  font-weight: 900;
  color: #0f1720;
  line-height: 1.3
}

.section-layout {
  display: grid;
  grid-template-columns: 400px 1fr;
  gap: 40px
}

.section-reverse .section-layout {
  grid-template-columns: 1fr 400px
}

.section-reverse .section-image {
  order: 2
}

.section-image {
  width: 100%;
  height: 100%;
  min-height: 400px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .1)
}

.section-image img {
  width: 100%;
  height: 100%;
  object-fit: cover
}

.section-list {
  display: flex;
  flex-direction: column;
  gap: 24px
}

.list-item {
  display: flex;
  gap: 20px;
  align-items: flex-start
}

.item-marker {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background: #10b3aa;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%
}

.item-content h4 {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 900;
  color: #0f1720;
  line-height: 1.4
}

.item-content p {
  margin: 0;
  font-size: 15px;
  line-height: 1.75;
  color: #5b6b78
}

@media(max-width:1024px) {
  .spotlight-layout {
    grid-template-columns: 1fr;
    gap: 32px
  }

  .spotlight-image {
    height: 260px
  }

  .section-layout {
    grid-template-columns: 1fr;
    gap: 28px
  }

  .section-reverse .section-layout {
    grid-template-columns: 1fr
  }

  .section-reverse .section-image {
    order: -1
  }

  .section-reverse .section-list {
    order: 1
  }

  .section-image {
    min-height: 280px;
    max-height: 320px
  }

  .service-spotlight {
    padding: 32px 24px
  }

  .spotlight-text h2 {
    font-size: 28px
  }

  .section-header h3 {
    font-size: 24px
  }
}

@media(max-width:640px) {
  .timeline-container {
     gap: 0px;
     margin: 0 auto 0 auto;
     width: 92%;
  }

  .service-spotlight {
    padding: 24px 20px
  }

  .spotlight-text h2 {
    font-size: 24px
  }

  .section-header h3 {
    font-size: 20px
  }

  .section-image {
    min-height: 220px;
    max-height: 260px
  }

  .spotlight-image {
    height: 220px
  }
}

.image-carousel {
  width: 100%;
  padding: 0;
  margin: 0;
  background-color: #f8f9fa
}

.image-carousel * {
  box-sizing: border-box
}

.image-container {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 20px 0
}

.image-container::-webkit-scrollbar {
  display: none
}

.image-track {
  display: flex;
  gap: 16px;
  padding: 0 20px
}

.image-card {
  min-width: 280px;
  width: 280px;
  flex-shrink: 0;
  background: #fff;
  border-radius: 12px;
  padding: 20px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .1);
  border: 1px solid #e5e7eb;
  position: relative
}

.image-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0
}

.image-avatar--green {
  background-color: #10b981
}

.image-avatar--purple {
  background-color: #8b5cf6
}

.image-avatar--blue {
  background-color: #3b82f6
}

.image-avatar--orange {
  background-color: #f97316
}

.image-avatar--indigo {
  background-color: #6366f1
}

.image-avatar--rose {
  background-color: #ec4899
}

.image-avatar--cyan {
  background-color: #06b6d4
}

.image-content {
  flex: 1
}

.image-title {
  font-size: 14px;
  font-weight: 600;
  color: #111827;
  margin-bottom: 8px;
  line-height: 1.4
}

.image-text {
  font-size: 12px;
  color: #6b7280;
  line-height: 1.5;
  margin: 0
}

@media(min-width:768px) {
  .image-card {
    min-width: 320px;
    width: 320px;
    padding: 24px
  }

  .image-title {
    font-size: 15px
  }

  .image-text {
    font-size: 13px
  }

  .image-track {
    gap: 20px;
    padding: 0 24px
  }
}

@media(min-width:1024px) {
  .image-card {
    min-width: 340px;
    width: 340px
  }

  .image-title {
    font-size: 16px
  }

  .image-text {
    font-size: 14px
  }

  .image-track {
    gap: 24px;
    padding: 0 32px
  }
}

.rv2-reviews {
  padding: 0rem 0;
  background: transparent;
  font-family: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  position: relative;
  overflow: hidden
}

.rv2-container {
  width: 100%;
  position: relative;
  overflow: hidden;
  padding: 0rem 0;
}

.rv2-track {
  display: flex;
  gap: 1.5rem;
  transition: transform .4s ease;
  width: fit-content
}

.rv2-card {
  background: #fff;
  border-radius: 16px;
  padding: 1.5rem;
  min-width: 320px;
  max-width: 320px;
  box-shadow: 0 4px 20px color-mix(in oklab, var(--brand-primary) 25%, #0000);
  transition: transform .3s ease, box-shadow .3s ease;
  flex-shrink: 0;
  position: relative;
  overflow: hidden
}

.rv2-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brand-primary), var(--brand-primary-dark));
  border-radius: 16px 16px 0 0
}

.rv2-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 30px rgba(59, 130, 246, .15)
}

.rv2-user {
  display: flex;
  align-items: center;
  margin-bottom: 1rem
}

.rv2-avatar {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 1rem;
  flex-shrink: 0
}

.rv2-av--teal {
  background: linear-gradient(135deg, #14b8a6, #0f766e)
}

.rv2-av--green {
  background: linear-gradient(135deg, #22c55e, #16a34a)
}

.rv2-av--purple {
  background: linear-gradient(135deg, #a855f7, #7c3aed)
}

.rv2-av--blue {
  background: linear-gradient(135deg, #3b82f6, #1d4ed8)
}

.rv2-av--orange {
  background: linear-gradient(135deg, #f97316, #ea580c)
}

.rv2-av--indigo {
  background: linear-gradient(135deg, #6366f1, #4f46e5)
}

.rv2-av--rose {
  background: linear-gradient(135deg, #f43f5e, #e11d48)
}

.rv2-av--cyan {
  background: linear-gradient(135deg, #06b6d4, #0891b2)
}

.rv2-ic {
  width: 1.5rem;
  height: 1.5rem
}

.rv2-body {
  padding-top: .5rem
}

.rv2-title {
  font-size: 1.4rem;
  font-weight: 600;
  color: #1e293b;
  margin-bottom: .75rem;
  line-height: 1.4
}

.rv2-text {
  font-size: 1.4rem;
  line-height: 1.6;
  color: #475569
}

@media(max-width:1024px) {
  .rv2-container {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    scroll-behavior: auto
  }

  .rv2-container::-webkit-scrollbar {
    display: none
  }

  .rv2-track {
    transition: none;
    transform: none !important
  }
}

@media(max-width:768px) {
  .ct-wrapper-container .ct-table-wrapper {
    padding: 0rem 0
  }

  .rv2-track {
    gap: 1rem;
    padding: 0% 0% 3% 0%;
  }

  .rv2-card {
    min-width: 280px;
    max-width: 280px;
    padding: 1.25rem
  }

  .rv2-title {
    font-size: 1rem
  }

  .rv2-text {
    font-size: 1.4rem;
  }
}

@media(prefers-reduced-motion:reduce) {

  .rv2-track,
  .rv2-card {
    transition: none
  }

  .rv2-card:hover {
    transform: none
  }
}

.troubles {
    --troubles-primary: #5b6cf5;
    --troubles-text: #1f2937;
    --troubles-card: #fff;
    --troubles-border: #e5e7eb;
    font-family: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, sans-serif;
    padding: 2px;
    width: 92%;
    display: block;
    margin: 0 auto 0 auto;
}

.troubles__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  gap: 16px
}

.trouble-category {
  background: var(--troubles-card);
  border: 2px solid var(--troubles-border);
  border-radius: 16px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .08);
  overflow: hidden;
  transition: all .3s
}

.trouble-category:hover {
  border-color: var(--troubles-primary);
  box-shadow: 0 8px 32px rgba(91, 108, 245, .12);
  transform: translateY(-2px)
}

.trouble-category[open] {
  border-color: var(--troubles-primary);
  box-shadow: 0 8px 32px rgba(91, 108, 245, .15)
}

.trouble-category__header {
padding: 24px;
  background: linear-gradient(135deg, #6d7beb, var(--troubles-primary), #4c5de3);
  color: #fff;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
  height: 76px;
}
.trouble-category__title {
  margin: -12px 0 0px;
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 900;
  color: #fff;
}
@media(max-width:1024px) {
  .trouble-category__header {
  padding: 24px;
  background: linear-gradient(135deg, #6d7beb, var(--troubles-primary), #4c5de3);
  color: #fff;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
  height: 86px;
}
.trouble-category__title {
  margin: 0 0 0px;
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 900;
  color: #fff;
  padding-top: 2%;
  line-height: 1;
}
@media(max-width:767px) {
.page-id-1229 .trouble-category__title {
  margin: 0 0 0px;
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 900;
  color: #fff;
  padding-top: 9%;
  line-height: 1;
}
}

}
@media (min-width:768px) and  (max-width:1024px) {
.trouble-category__title {
  margin: 0 0 0px;
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 900;
  color: #fff;
  padding-top: 4%;
  line-height: 1;
}
}

.trouble-category__header::-webkit-details-marker {
  display: none
}

.trouble-category__info {
  flex: 1
}



.trouble-category__subtitle {
  margin: 0px;
  font-size: 14px;
  opacity: .85;
  font-weight: 500;
  line-height: 1;
  padding-bottom: 0%;
}

.trouble-category__icon {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, .15);
  border-radius: 50%;
  display: grid;
  place-items: center;
  transition: transform .3s
}

.trouble-category[open] .trouble-category__icon {
  transform: rotate(180deg)
}

.trouble-category__content {
  padding: 0;
  animation: slideDown .3s ease-out
}

@keyframes slideDown {
  from {
    opacity: 0;
    max-height: 0
  }

  to {
    opacity: 1;
    max-height: 1000px
  }
}

.trouble-list {
  padding: 24px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr))
}

.trouble-list p {
  margin: 0;
  padding: 12px 16px 12px 36px;
  background: linear-gradient(135deg, #fafbfc, #fff);
  border: 1px solid #e8eaed;
  border-radius: 12px;
  color: var(--troubles-text);
  font-size: 14px;
  line-height: 1.6;
  font-weight: 500;
  position: relative;
  transition: all .2s;
  display: flex;
  align-items: center;
  min-height: 20px
}

.trouble-list p::before {
  content: "✓";
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: var(--troubles-primary);
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: 900
}

.trouble-list p:hover {
  background: linear-gradient(135deg, #f4f5ff, #fafbfc);
  border-color: #c4cbf5;
  transform: translateX(4px)
}

@media(max-width:768px) {
  .trouble-list {
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 16px;
  }

  .trouble-category__header,
  .trouble-list {
    padding:0px 20px 0px 20px;
  }
}

@media(prefers-reduced-motion:reduce) {

  .trouble-category,
  .trouble-category__icon,
  .trouble-list p {
    transition: none;
    animation: none
  }
}

.services-uniform {
  max-width: 1240px;
  margin: 8px auto;
  padding: 0 4px;
  font-family: 'Noto Sans JP', -apple-system, sans-serif
}

.services-wrapper {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 32px
}

.service-row {
  background: #fff;
  border-left: 4px solid #10b3aa;
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: all .3s ease
}

.service-row:hover {
  border-left-width: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .08);
  transform: translateX(4px)
}

.service-number-box {
  display: flex;
  align-items: center
}

.service-big-num {
  font-size: 48px;
  font-weight: 900;
  color: #10b3aa;
  line-height: 1;
  letter-spacing: -.02em
}

.service-text-area h3 {
  margin: 0 0 12px;
  font-size: 22px;
  font-weight: 900;
  color: #0f1720;
  letter-spacing: .02em;
  line-height: 1.4
}

.service-text-area p {
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
  color: #4a5568;
  font-weight: 500
}

.service-photo {
  width: 100%;
  height: 250px;
  border-radius: 8px;
  overflow: hidden;
  margin-top: 8px
}

.service-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease
}

.service-row:hover .service-photo img {
  transform: scale(1.05)
}

@media(max-width:900px) {
  .services-wrapper {
    grid-template-columns: 1fr;
    gap: 32px
  }

  .service-row {
    padding: 20px 24px
  }

  .service-big-num {
    font-size: 40px
  }

  .service-text-area h3 {
    font-size: 20px
  }

  .service-text-area p {
    font-size: 14px
  }

  .service-photo {
    height: 360px
  }
}

@media(max-width:599.98px) {
  .service-photo {
    height: 220px
  }
}

.symptoms-redesign {
  max-width: 1200px;
  margin: 8px auto;
  padding: 0 24px;
  font-family: 'Noto Sans JP', -apple-system, sans-serif
}

.symptoms-layout {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px
}

.symptom-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 16px rgba(0, 0, 0, .06);
  transition: all .35s cubic-bezier(.16, 1, .3, 1);
  position: relative
}

.symptom-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, .12)
}

.symptom-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  background: linear-gradient(135deg, #10b3aa, #0d9087);
  color: #fff;
  border-radius: 8px;
  padding: 8px 12px;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  box-shadow: 0 4px 12px rgba(16, 179, 170, .3)
}

.badge-num {
  font-size: 20px;
  font-weight: 900;
  line-height: 1
}

.badge-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em
}

.symptom-image-area {
  width: 100%;
  height: 220px;
  overflow: hidden;
  background: #f5f5f5
}

.symptom-image-area img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s ease
}

.symptom-card:hover .symptom-image-area img {
  transform: scale(1.08)
}

.symptom-info {
  padding: 24px 20px 28px
}

.symptom-info h3 {
  margin: 0 0 12px;
  font-size: 19px;
  font-weight: 900;
  color: #0f1720;
  letter-spacing: .02em
}

.symptom-info p {
  margin: 0;
  font-size: 14px;
  line-height: 1.75;
  color: #5b6b78;
  font-weight: 500
}

@media(max-width:1024px) {
  .symptoms-layout {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px
  }
}

@media(max-width:640px) {
  .symptoms-layout {
    grid-template-columns: 1fr
  }

  .symptom-image-area {
    height: 200px
  }

  .symptom-info {
    padding: 20px 16px 24px
  }

  .symptom-info h3 {
    font-size: 18px
  }
}



.whypro {
  --brand: var(--brand-primary);
  --brand-dark: var(--brand-primary-dark);
  --ink: var(--text-main);
  --muted: var(--text-muted);
  --ring: var(--ring-soft);
  --card: #fff;
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 12px
}

.whypro .whypro-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr))
}

@media(max-width:980px) {
  .whypro .whypro-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }
}

@media(max-width:640px) {
  .whypro .whypro-grid {
    grid-template-columns: 1fr
  }
}

.whypro .whypro-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--ring);
  border-radius: 18px;
  padding: 18px 16px 16px;
  box-shadow: 0 16px 18px rgba(15, 23, 42, .08), 0 1px 2px rgba(15, 23, 42, .06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
  will-change: transform
}

.whypro .whypro-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brand), transparent)
}
.page-id-1217 .whypro .whypro-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, #0052a5, transparent);
}

.whypro .whypro-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(15, 23, 42, .12), 0 2px 6px rgba(15, 23, 42, .06);
  border-color: #bcd4c8
}

.whypro .whypro-icon {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  margin-bottom: 10px;
  color: var(--brand);
  background: radial-gradient(100% 100% at 50% 0%, rgba(15, 23, 42, .12), rgba(15, 23, 42, .04));
  box-shadow: inset 0 0 0 2px rgba(15, 23, 42, .08)
}
.page-id-1217 .whypro .whypro-icon {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  margin-bottom: 10px;
  color: var(--brand);
  background: radial-gradient(100% 100% at 50% 0%, rgba(15, 23, 42, .12), rgba(15, 23, 42, .04));
  box-shadow: inset 0 0 0 2px rgba(15, 23, 42, .08)
}
.whypro .whypro-icon svg {
  width: 28px;
  height: 28px
}

.whypro .whypro-card h3 {
  margin: 0 0 6px;
  color: var(--ink);
  font-weight: 900;
  font-size: clamp(16px, 1.9vw, 18px);
  letter-spacing: .02em
}

.whypro .whypro-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: clamp(13.5px, 1.6vw, 14.5px)
}

.ct-scope {
  --brand: var(--brand-primary);
  --brand-dark: var(--brand-primary-dark);
  --ink: var(--text-main);
  --muted: var(--text-muted);
  --ring: #e1e7e5;
  --good: #0ea5a3;
  --mid: #f59e0b;
  --bad: #9aa7b4
}

.ct-noscroll {
  overflow: hidden
}



.ct-wrapper-container .ct-table-wrapper:focus-visible {
  box-shadow: 0 0 0 3px rgba(15, 23, 42, .35)
}

.ct-wrapper-container .ct-grid {
  display: grid;
  grid-template-columns: minmax(90px, 1.2fr) repeat(3, 1fr)
}

.ct-wrapper-container .ct-row {
  display: contents
}

.ct-wrapper-container .ct-cell {
  padding: 14px 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-top: 1px solid var(--ring);
  border-left: 1px solid var(--ring);
  color: var(--ink)
}

.ct-wrapper-container .ct-row.head .ct-cell {
  background: #fbfcfe;
  font-weight: 800
}

.ct-wrapper-container .ct-row:first-child .ct-cell {
  border-top: 0
}

.ct-wrapper-container .ct-cell:first-child {
  border-left: 0
}

.ct-wrapper-container .ct-cell.feat {
  justify-content: flex-start;
  font-weight: 800
}

.ct-wrapper-container .ct-cell.head.brand {
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-dark))
}

.ct-wrapper-container .ct-row:not(.head) .brand {
  background: linear-gradient(180deg, rgba(0, 0, 0, .04), rgba(0, 0, 0, .02))
}

.ct-wrapper-container .ct-row:not(.head):hover .ct-cell {
  background: rgba(247, 16, 0, 0.03)
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-row.head .ct-cell {
  white-space: nowrap
}

.ct-mark {
  display: inline-block;
  width: 22px;
  height: 22px;
  vertical-align: middle
}

.ct-mark-good {
  border-radius: 50%;
  box-shadow: inset 0 0 0 3px var(--good)
}

.ct-mark-mid {
  background: var(--mid);
  clip-path: polygon(50% 15%, 6% 88%, 94% 88%)
}

.ct-mark-bad {
  position: relative
}

.ct-mark-bad::before,
.ct-mark-bad::after {
  content: "";
  position: absolute;
  left: 10px;
  top: 2px;
  width: 3px;
  height: 18px;
  background: var(--bad);
  border-radius: 2px
}

.ct-mark-bad::before {
  transform: rotate(45deg)
}

.ct-mark-bad::after {
  transform: rotate(-45deg)
}

.ct-legend {
  display: flex;
  gap: 16px;
  align-items:baseline;
  margin: 10px auto;
  padding: 0;
  list-style: none;
  color: var(--muted);
  font-size: 13px;
  max-width: 100%;
}

.ct-legend li {
  display: flex;
  align-items: center
}

.ct-legend .ct-mark {
  margin-right: 6px
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode {
  position: fixed !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 20px env(safe-area-inset-right) 28px env(safe-area-inset-left) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  z-index: 9999 !important;
  background: rgba(255, 255, 255, .92) !important;
  backdrop-filter: blur(5px);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: zoom-out !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  overflow: auto !important;
  animation: ct-fade-in .16s ease-out
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-table-container {
  position: relative;
  background: #fff;
  border-radius: 16px;
  padding: 12px 12px 18px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .18), 0 8px 24px rgba(0, 0, 0, .08);
  max-width: calc(100% - 48px);
  width: 100%;
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column
}

@keyframes ct-fade-in {
  from {
    opacity: .001
  }

  to {
    opacity: 1
  }
}

@media(prefers-reduced-motion:reduce) {
  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode {
    animation: none
  }
}

.ct-wrapper-container .ct-scroller {
  position: relative;
  overflow: visible
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(15, 23, 42, .45) rgba(15, 23, 42, .08);
  flex: 1;
  min-height: 0
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller::-webkit-scrollbar {
  height: 6px
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller::-webkit-scrollbar-track {
  background: rgba(15, 23, 42, .08);
  border-radius: 8px
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller::-webkit-scrollbar-thumb {
  background: rgba(15, 23, 42, .45);
  border-radius: 8px
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-row.head .ct-cell {
  position: sticky;
  top: 0;
  z-index: 2;
  border-top: 0;
  box-shadow: 0 2px 0 var(--ring);
  background: #fbfcfe !important
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-cell.head.brand {
  background: linear-gradient(135deg, var(--brand), var(--brand-dark)) !important
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-grid {
  min-width: 600px
}

@media(max-width:767px) {
  .ct-wrapper-container .ct-grid {
    grid-template-columns: minmax(80px, 1fr) repeat(3, 1fr)
  }

  .ct-wrapper-container .ct-cell {
    padding: 10px 8px;
    font-size: 12px
  }

  .ct-legend {
    flex-wrap: wrap;
    justify-content: center
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode {
    padding: 10px env(safe-area-inset-right) 24px env(safe-area-inset-left) !important
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-grid {
    min-width: 500px
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller::before,
  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 28px;
    pointer-events: none;
    opacity: 0;
    transition: opacity .2s ease
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller.show-left::before {
    left: 0;
    border-top-left-radius: 16px;
    border-bottom-left-radius: 16px;
    background: linear-gradient(to right, rgba(255, 255, 255, .95), rgba(255, 255, 255, 0));
    opacity: 1
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scroller.show-right::after {
    right: 0;
    border-top-right-radius: 16px;
    border-bottom-right-radius: 16px;
    background: linear-gradient(to left, rgba(255, 255, 255, .95), rgba(255, 255, 255, 0));
    opacity: 1
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scrollbar {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 6px;
    height: 4px;
    background: rgba(15, 23, 42, .12);
    border-radius: 999px;
    overflow: hidden;
    pointer-events: none;
    z-index: 9
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scrollbar-thumb {
    height: 100%;
    width: 30%;
    background: rgba(15, 23, 42, .55);
    border-radius: 999px;
    transform: translateX(0);
    transition: transform .08s linear
  }

  .ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-scrollbar.hidden {
    opacity: 0
  }
}

.ct-wrapper-container .ct-close-btn {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(50%, -50%);
  width: 40px;
  height: 40px;
  padding: 0;
  font-size: 20px;
  font-weight: 900;
  line-height: 38px;
  color: #fff;
  background: linear-gradient(135deg, #d7266b, #a31962);
  border: 0;
  border-radius: 50%;
  text-align: center;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 6px 22px rgba(0, 0, 0, .22)
}

.ct-wrapper-container .ct-close-btn:focus-visible {
  outline: 3px solid rgba(15, 23, 42, .6)
}

.ct-wrapper-container .ct-table-wrapper.fullscreen-mode .ct-close-btn {
  display: block !important
}

.services-uniform-manufacturer {
  max-width: 1240px;
  margin: 8px auto;
  padding: 0 4px
}

.services-wrapper-manufacturer {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 32px
}

.service-row-manufacturer {
  background: #fff;
  border-left: 4px solid var(--brand-primary);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: all .3s ease
}

.service-row-manufacturer:hover {
  border-left-width: 6px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .15);
  transform: translateX(4px)
}

.service-number-box-manufacturer {
  display: flex;
  align-items: center
}

.service-big-num-manufacturer {
  font-size: 48px;
  font-weight: 900;
  color: var(--brand-primary);
  line-height: 1;
  letter-spacing: -.02em
}

.service-text-area-manufacturer h3 {
  margin: 0 0 12px;
  font-size: 22px;
  font-weight: 900;
  color: var(--text-main);
  letter-spacing: .02em;
  line-height: 1.4
}

.service-text-area-manufacturer p {
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
  color: #4a5568;
  font-weight: 500
}

.service-photo-manufacturer {
  width: 100%;
  height: 250px;
  border-radius: 8px;
  overflow: hidden;
  margin-top: 8px
}

.service-photo-manufacturer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease
}

.service-row-manufacturer:hover .service-photo-manufacturer img {
  transform: scale(1.05)
}

@media(max-width:900px) {
  .services-wrapper-manufacturer {
    grid-template-columns: 1fr;
    gap: 32px
  }

  .service-row-manufacturer {
    padding: 35px 24px;
  }

  .service-big-num-manufacturer {
    font-size: 40px
  }

  .service-text-area-manufacturer h3 {
    font-size: 20px
  }

  .service-text-area-manufacturer p {
    font-size: 14px
  }

  .service-photo-manufacturer {
    height: 360px
  }
}

@media(max-width:599.98px) {
  .service-photo-manufacturer {
    height: 220px
  }
}

.table-wrapper {
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 3px 10px rgba(0, 0, 0, .08);
  border: 1px solid var(--border-soft)
}

.table-title {
  background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-dark) 100%);
  color: #fff;
  text-align: center;
  padding: 18px;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: .5px
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  font-family: var(--font-main)
}

.data-table thead tr {
  background: var(--brand-primary-dark)
}

.data-table thead th {
  color: #fff;
  padding: 16px 20px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  vertical-align: middle;
  border-right: 1px solid rgba(255, 255, 255, .15)
}

.data-table thead th:first-child {
  text-align: left;
  width: 40%
}

.data-table thead th:last-child {
  border-right: none
}

.data-table tbody tr {
  border-bottom: 1px solid #e5e5e5;
  transition: background-color .2s ease
}

.data-table tbody tr:hover {
  background-color: #fafafa
}

.data-table tbody tr:last-child {
  border-bottom: none
}

.data-table tbody td {
  padding: 18px 20px;
  font-size: 15px;
  vertical-align: middle;
  text-align: center;
  border-right: 1px solid #e5e5e5
}

.data-table tbody td:first-child {
  text-align: left;
  color: var(--brand-primary);
  font-weight: 500;
  background: #f5f8f6;
  width: 40%;
  font-size: 14px
}

.data-table tbody td:last-child {
  border-right: none
}

.data-table tbody td:not(:first-child) {
  color: #333;
  font-size: 17px;
  font-weight: 600;
  white-space: nowrap
}

.mileage-table tbody td:not(:first-child) {
  font-size: 16px
}

.period-highlight {
  color: var(--brand-primary) !important;
  font-weight: 700
}

.weight-table thead th:first-child,
.weight-table tbody td:first-child {
  width: 25%
}

@media(max-width:768px) {
  .table-title {
    font-size: 17px;
    padding: 14px
  }

  .data-table thead th {
    padding: 12px 10px;
    font-size: 13px
  }

  .data-table thead th:first-child {
    width: 30%;
    padding: 12px 8px
  }

  .data-table tbody td {
    padding: 14px 10px;
    font-size: 13px
  }

  .data-table tbody td:first-child {
    width: 30%;
    padding: 14px 8px;
    font-size: 12px
  }

  .data-table tbody td:not(:first-child) {
    font-size: 15px
  }

  .mileage-table tbody td:not(:first-child) {
    font-size: 14px
  }
}

.mp-scope {
  --mp-brand: var(--brand-primary);
  --mp-brand-dark: var(--brand-primary-dark);
  --mp-ink: var(--text-main);
  --mp-muted: var(--text-muted);
  --mp-ring: var(--ring-soft);
  --mp-card: #fff
}

.mp-symptoms {
  max-width: 1200px;
  margin: 8px auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px
}

.mp-card {
  position: relative;
  background: var(--mp-card);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 16px rgba(0, 0, 0, .06);
  transition: all .35s cubic-bezier(.16, 1, .3, 1);
  border: 1px solid var(--mp-ring)
}

.mp-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, .12)
}

.mp-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  background: linear-gradient(135deg, var(--mp-brand), var(--mp-brand-dark));
  color: #fff;
  border-radius: 8px;
  padding: 8px 12px;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  box-shadow: 0 4px 12px color-mix(in oklab, var(--mp-brand) 40%, #0000)
}

.mp-badge__num {
  font-size: 20px;
  font-weight: 900;
  line-height: 1
}

.mp-badge__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em
}

.mp-media {
  width: 100%;
  height: 220px;
  overflow: hidden;
  background: #f5f5f5
}

.mp-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s ease
}

.mp-card:hover .mp-media img {
  transform: scale(1.08)
}

.mp-info {
  padding: 24px 20px 28px
}

.mp-info h3 {
  margin: 0 0 12px;
  font-size: 19px;
  font-weight: 900;
  color: var(--mp-ink);
  letter-spacing: .02em
}

.mp-info p {
  margin: 0;
  font-size: 14px;
  line-height: 1.75;
  color: var(--mp-muted);
  font-weight: 500
}

@media(max-width:1024px) {
  .mp-symptoms {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px
  }
}

@media(max-width:640px) {
  .mp-symptoms {
    grid-template-columns: 1fr
  }

  .mp-media {
    height: 200px
  }

  .mp-info {
    padding: 20px 16px 24px
  }

  .mp-info h3 {
    font-size: 18px
  }
}

.troubles-manufacturer {
  padding: 2px
}

.troubles__inner-manufacturer {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  gap: 16px
}

.trouble-category-manufacturer {
  background: #fff;
  border: 2px solid var(--border-soft);
  border-radius: 16px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .08);
  overflow: hidden;
  transition: all .3s
}

.trouble-category-manufacturer:hover {
  border-color: var(--brand-primary);
  box-shadow: 0 8px 32px rgba(0, 0, 0, .12);
  transform: translateY(-2px)
}

.trouble-category-manufacturer[open] {
  border-color: var(--brand-primary);
  box-shadow: 0 8px 32px rgba(0, 0, 0, .15)
}

.trouble-category__header-manufacturer {
  padding: 24px;
  background: linear-gradient(135deg, var(--brand-primary), var(--brand-primary-dark));
  color: #fff;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none
}

.trouble-category__header-manufacturer::-webkit-details-marker {
  display: none
}

.trouble-category__info-manufacturer {
  flex: 1
}

.trouble-category__title-manufacturer {
  margin: 0 0 4px;
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 900
}

.trouble-category__subtitle-manufacturer {
  margin: 0;
  font-size: 14px;
  opacity: .85;
  font-weight: 500
}

.trouble-category__icon-manufacturer {
  width: 40px;
  height: 40px;
  background: rgba(255, 255, 255, .15);
  border-radius: 50%;
  display: grid;
  place-items: center;
  transition: transform .3s
}

.trouble-category-manufacturer[open] .trouble-category__icon-manufacturer {
  transform: rotate(180deg)
}

.trouble-category__content-manufacturer {
  padding: 0;
  animation: slideDown .3s ease-out
}

.trouble-list-manufacturer {
  padding: 24px;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr))
}

.trouble-list-manufacturer p {
  margin: 0;
  padding: 12px 16px 12px 36px;
  background: linear-gradient(135deg, #f5f8f7, #fff);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  color: #1f2937;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 500;
  position: relative;
  transition: all .2s;
  display: flex;
  align-items: center;
  min-height: 20px
}

.trouble-list-manufacturer p::before {
  content: "✓";
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: var(--brand-primary);
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: 900
}

.trouble-list-manufacturer p:hover {
  background: linear-gradient(135deg, #ecf1ef, #f5f8f7);
  border-color: var(--brand-primary);
  transform: translateX(4px)
}

@media(max-width:768px) {
  .trouble-list-manufacturer {
    grid-template-columns: 1fr;
    gap: 8px
  }

  .trouble-category__header-manufacturer,
  .trouble-list-manufacturer {
    padding: 20px
  }
}

@media(prefers-reduced-motion:reduce) {

  .trouble-category-manufacturer,
  .trouble-category__icon-manufacturer,
  .trouble-list-manufacturer p {
    transition: none;
    animation: none
  }
}

.services-timeline-manufacturer {
  max-width: 100%;
  margin: 8px auto;
  padding: 0
}

.timeline-container-manufacturer {
  display: flex;
  flex-direction: column;
  gap: 60px
}

.service-spotlight-manufacturer {
  background: linear-gradient(135deg, #f5f8f7, #ecf1ef);
  border-radius: 24px;
  padding: 48px;
  position: relative;
  overflow: hidden
}

.service-spotlight-manufacturer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--brand-primary), var(--brand-primary-dark))
}

.spotlight-badge-manufacturer {
  display: inline-block;
  background: var(--brand-primary);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  padding: 8px 20px;
  border-radius: 20px;
  letter-spacing: .06em;
  margin-bottom: 24px
}

.spotlight-layout-manufacturer {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: center
}

.spotlight-text-manufacturer h2 {
  margin: 0 0 20px;
  font-size: 36px;
  font-weight: 900;
  color: var(--text-main);
  line-height: 1.2
}

.spotlight-text-manufacturer p {
  margin: 0 0 24px;
  font-size: 16px;
  line-height: 1.8;
  color: #4a5568
}

.spotlight-list-manufacturer {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 16px;
  flex-wrap: wrap
}

.spotlight-list-manufacturer li {
  background: #fff;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 700;
  color: var(--brand-primary);
  white-space: nowrap
}

.spotlight-image-manufacturer {
  width: 100%;
  height: 300px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(15, 23, 42, .12)
}

.spotlight-image-manufacturer img {
  width: 100%;
  height: 100%;
  object-fit: cover
}

.service-section-manufacturer {
  position: relative
}

.section-header-manufacturer {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 32px
}

.header-line-manufacturer {
  width: 60px;
  height: 4px;
  background: linear-gradient(90deg, var(--brand-primary), transparent);
  border-radius: 2px;
  flex-shrink: 0
}

.section-header-manufacturer h3 {
  margin: 0;
  font-size: 28px;
  font-weight: 900;
  color: var(--text-main);
  line-height: 1.3
}

.section-layout-manufacturer {
  display: grid;
  grid-template-columns: 400px 1fr;
  gap: 40px
}

.section-reverse-manufacturer .section-layout-manufacturer {
  grid-template-columns: 1fr 400px
}

.section-reverse-manufacturer .section-image-manufacturer {
  order: 2
}

.section-image-manufacturer {
  width: 100%;
  height: 100%;
  min-height: 400px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .1)
}

.section-image-manufacturer img {
  width: 100%;
  height: 100%;
  object-fit: cover
}

.section-list-manufacturer {
  display: flex;
  flex-direction: column;
  gap: 24px
}

.list-item-manufacturer {
  display: flex;
  gap: 20px;
  align-items: flex-start
}

.item-marker-manufacturer {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  background: var(--brand-primary);
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%
}

.item-content-manufacturer h4 {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 900;
  color: var(--text-main);
  line-height: 1.4
}

.item-content-manufacturer p {
  margin: 0;
  font-size: 15px;
  line-height: 1.75;
  color: #5b6b78
}

@media(max-width:1024px) {
  .spotlight-layout-manufacturer {
    grid-template-columns: 1fr;
    gap: 32px
  }

  .spotlight-image-manufacturer {
    height: 260px
  }

  .section-layout-manufacturer {
    grid-template-columns: 1fr;
    gap: 28px
  }

  .section-reverse-manufacturer .section-layout-manufacturer {
    grid-template-columns: 1fr
  }

  .section-reverse-manufacturer .section-image-manufacturer {
    order: -1
  }

  .section-reverse-manufacturer .section-list-manufacturer {
    order: 1
  }

  .section-image-manufacturer {
    min-height: 280px;
    max-height: 320px
  }

  .service-spotlight-manufacturer {
    padding: 32px 24px
  }

  .spotlight-text-manufacturer h2 {
    font-size: 28px
  }

  .section-header-manufacturer h3 {
    font-size: 24px
  }
}

@media(max-width:640px) {
  .timeline-container-manufacturer {
    gap: 48px
  }

  .service-spotlight-manufacturer {
    padding: 24px 20px
  }

  .spotlight-text-manufacturer h2 {
    font-size: 24px
  }

  .section-header-manufacturer h3 {
    font-size: 20px
  }

  .section-image-manufacturer {
    min-height: 220px;
    max-height: 260px
  }

  .spotlight-image-manufacturer {
    height: 220px
  }
}

.service-flow-manufacturer {
  padding: 32px 14px;
  max-width: 1200px;
  margin: 0 auto
}

.sf-grid-manufacturer {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) 420px
}

@media(max-width:1000px) {
  .sf-grid-manufacturer {
    grid-template-columns: 1fr
  }
}

.sf-steps-manufacturer {
  list-style: none;
  margin: 0;
  padding: 12px;
  background: var(--surface-soft);
  border: 1px solid var(--border-soft);
  border-radius: 18px
}

.sf-step-manufacturer {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  position: relative;
  padding: 16px 12px;
  margin: 0 0 12px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .06)
}

.sf-step-manufacturer:last-child {
  margin-bottom: 0
}

.sf-step-manufacturer::before {
  content: "";
  position: absolute;
  left: 34px;
  top: 58px;
  bottom: 16px;
  width: 2px;
  background: linear-gradient(180deg, var(--brand-primary), rgba(0, 0, 0, .06))
}

.sf-step-manufacturer:last-child::before {
  display: none
}

.sf-badge-manufacturer {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: var(--brand-primary-dark);
  font-weight: 900;
  background: radial-gradient(100% 100% at 50% 0%, rgba(15, 23, 42, .18), rgba(15, 23, 42, .08));
  box-shadow: inset 0 0 0 2px rgba(15, 23, 42, .18)
}

.sf-body-manufacturer h3 {
  margin: 2px 0 6px;
  color: var(--text-main);
  font-weight: 900;
  letter-spacing: .02em;
  font-size: clamp(16px, 2vw, 18px)
}

.sf-body-manufacturer p {
  margin: 0;
  color: #5e6d79;
  line-height: 1.85;
  font-size: clamp(13.5px, 1.8vw, 14.5px)
}

.sf-body-manufacturer .sf-note-manufacturer {
  margin-top: 6px;
  font-size: 12.5px;
  color: #7a8893
}

.sf-media-manufacturer {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px
}

.sf-media-item-manufacturer {
  margin: 0;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .06)
}

.sf-media-item-manufacturer img {
  width: 100%;
  height: auto;
  display: block
}

.sf-media-item-manufacturer figcaption {
  padding: 12px;
  color: #506070;
  font-size: 13px;
  line-height: 1.6
}

.sf-media--lineqr-manufacturer {
  display: grid;
  grid-template-rows: auto 1fr
}

.sf-media--lineqr-manufacturer .sf-lineqr-wrap-manufacturer {
  display: grid;
  place-items: center;
  padding: 14px;
  background: #fff;
  border-bottom: 1px solid var(--border-soft)
}

.sf-lineqr-link-manufacturer {
  display: block
}

.sf-lineqr-img-manufacturer {
  display: block;
  max-width: 300px;
  width: 70%;
  height: auto;
  margin: 8px auto 6px;
  border-radius: 8px
}

.sf-media--lineqr-manufacturer figcaption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap
}

.sf-media--lineqr-manufacturer .sf-caption-title-manufacturer {
  color: #506070
}

@media(max-width:600px) {
  .sf-media--illustration-manufacturer {
    order: -1
  }
}

.menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%
}

.menu-card {
  background: #fff;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04) !important;
  transition: all .5s cubic-bezier(.23, 1, .32, 1);
  cursor: pointer;
  position: relative;
  animation: fadeInUp .6s ease forwards;
  opacity: 0;
  text-decoration: none;
  display: block;
  color: inherit;
  position: absolute;
  z-index: 1;
}

.menu-card:nth-child(1) {
  animation-delay: .1s
}

.menu-card:nth-child(2) {
  animation-delay: .15s
}

.menu-card:nth-child(3) {
  animation-delay: .2s
}

.menu-card:nth-child(4) {
  animation-delay: .25s
}

.menu-card:nth-child(5) {
  animation-delay: .3s
}

.menu-card:nth-child(6) {
  animation-delay: .35s
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0)
  }

  from {
    opacity: 0;
    transform: translateY(30px)
  }
}

.menu-card:hover {
  transform: translateY(-12px) scale(1.02);
  box-shadow: 0 20px 60px rgba(0, 0, 0, .12), 0 8px 16px rgba(0, 0, 0, .06)
}

.card-image {
  position: relative;
  width: 100%;
  height: 200px;
  overflow: hidden;
  border-top-left-radius: 26px;
  border-top-right-radius: 26px;
}

.card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s cubic-bezier(.23, 1, .32, 1)
}

.menu-card:hover .card-image img {
  transform: scale(1.1) rotate(2deg)
}

.card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, .3) 100%);
  transition: all .4s ease
}

.menu-card:hover .card-overlay {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, .5) 100%)
}

.card-content {
  padding: 24px 20px 20px;
  position: relative
}

.card-title {
  font-size: 19px;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 16px;
  line-height: 1.5;
  letter-spacing: .5px;
  text-align: center;
  min-height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  text-decoration: none;
}

.card-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1e3a8a 0%, #3b82f6 100%);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: all .4s cubic-bezier(.23, 1, .32, 1);
  box-shadow: 0 4px 16px rgba(59, 130, 246, .4);
  position: relative;
  overflow: hidden;
  margin: 0 auto
}

.card-button::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, .3);
  transform: translate(-50%, -50%);
  transition: width .6s, height .6s
}

.menu-card:hover .card-button::before {
  width: 100px;
  height: 100px
}

.card-button:hover {
  transform: scale(1.1) rotate(90deg);
  box-shadow: 0 8px 24px rgba(59, 130, 246, .6)
}

.arrow-icon {
  width: 22px;
  height: 22px;
  position: relative;
  z-index: 1
}

@media(max-width:640px) {
  .menu-grid {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 0;
    width: 100%
  }
 .menu-card a {
   position: absolute;
    z-index: 12;
    display: flex;
    margin: 6% auto 0 4%;
}
  .menu-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    min-height: 80px
  }

  .card-image {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
    border-bottom-left-radius: 26px;
    border-top-right-radius: 0;
  }

  .card-content {
    padding: 0 16px;
    flex: 1;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 16px
  }

  .card-title {
    font-size: 14px;
    margin: 0;
    text-align: left;
    line-height: 1.4;
    text-decoration: none;
  }
  .card-title br {
    display: inline
  }

  .card-button {
    width: 36px;
    height: 36px;
    margin: 0;
    flex-shrink: 0
  }

  .arrow-icon {
    width: 14px;
    height: 14px
  }
}

@media(min-width:641px) and (max-width:1024px) {
  .menu-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px
  }
}

@media(min-width:1025px) {
  .menu-grid {
    grid-template-columns: repeat(3, 1fr)
  }
}

.service-flow {
  --sf-brand: #10b3aa;
  --sf-ink: #0f1720;
  --sf-muted: #5e6d79;
  --sf-ring: #e6edf2;
  --sf-panel: #f7fbfd;
  --sf-card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  padding: 0px 14px;
  max-width: 1200px;
  margin: 0 auto
}

.sf-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) 420px
}

@media(max-width:1000px) {
  .sf-grid {
    grid-template-columns: 1fr
  }
}

.sf-steps {
  list-style: none;
  margin: 0;
  padding: 12px;
  background: var(--sf-panel);
  border: 1px solid var(--sf-ring);
  border-radius: 18px
}

.sf-step {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: baseline;
  gap: 12px;
  position: relative;
  padding: 16px 12px;
  margin: 0 0 12px;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.sf-step:last-child {
  margin-bottom: 0
}

.sf-step::before {
  content: "";
  position: absolute;
  left: 34px;
  top: 58px;
  bottom: 16px;
  width: 2px;
  background: linear-gradient(180deg, var(--sf-brand), rgba(16, 179, 170, .1))
}

.sf-step:last-child::before {
  display: none
}

.sf-badge {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #0d3c3a;
  font-weight: 900;
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .24), rgba(16, 179, 170, .10));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .28)
}

.sf-body h3 {
  margin: 2px 0 6px;
  color: var(--sf-ink);
  font-weight: 900;
  letter-spacing: .02em;
  font-size: clamp(16px, 2vw, 18px)
}

.sf-body p {
  margin: 0;
  color: var(--sf-muted);
  line-height: 1.85;
  font-size: clamp(13.5px, 1.8vw, 14.5px)
}

.sf-body .sf-note {
  margin-top: 6px;
  font-size: 12.5px;
  color: #7a8893
}

.sf-media {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px
}

.sf-media-item {
  margin: 0;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.sf-media-item img {
  width: 100%;
  height: auto;
  display: block
}

.sf-media-item figcaption {
  padding: 12px;
  color: #506070;
  font-size: 13px;
  line-height: 1.6
}

.sf-media--lineqr {
  display: grid;
  grid-template-rows: auto 1fr
}

.sf-media--lineqr .sf-lineqr-wrap {
  display: grid;
  place-items: center;
  padding: 14px;
  background: #fff;
  border-bottom: 1px solid var(--sf-ring)
}

.sf-lineqr-link {
  display: block
}

.sf-lineqr-img {
  display: block;
  max-width: 300px;
  width: 70%;
  height: auto;
  margin: 8px auto 6px;
  border-radius: 8px
}

.sf-media--lineqr figcaption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap
}

.sf-media--lineqr .sf-caption-title {
  color: #506070
}

.sf-btn-line {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 800;
  text-decoration: none;
  background: #06c755;
  color: #fff;
  border: 2px solid #06c755;
  box-shadow: 0 2px 8px rgba(6, 199, 85, .25)
}

.sf-btn-line:focus-visible {
  outline: 3px solid #b1f2c8;
  outline-offset: 2px
}

@media(max-width:600px) {
  .sf-media--illustration {
    order: -1
  }
}

.troubles-section {
  padding: 10px 0;
  background: transparent
}

.troubles-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px
}

.troubles-section .section-header {
  text-align: center;
  margin-bottom: 60px
}

.troubles-section .section-title {
  font-size: 2.5rem;
  font-weight: 800;
  color: #1565c0;
  margin-bottom: 20px;
  letter-spacing: -.02em
}

.troubles-section .title-decoration {
  width: 80px;
  height: 4px;
  background: linear-gradient(90deg, #2196f3, #03a9f4);
  margin: 0 auto;
  border-radius: 2px
}

.troubles-section .troubles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px
}

.troubles-section .trouble-item {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 8px 30px rgba(33, 150, 243, .12);
  transition: all .3s ease;
  border: 1px solid rgba(33, 150, 243, .1)
}

.troubles-section .trouble-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(33, 150, 243, .2)
}

.troubles-section .trouble-image {
  position: relative;
  height: 200px;
  overflow: hidden
}

.troubles-section .trouble-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s ease
}

.troubles-section .trouble-item:hover .trouble-photo {
  transform: scale(1.05)
}

.troubles-section .image-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(33, 150, 243, .8);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s ease
}

.troubles-section .trouble-item:hover .image-overlay {
  opacity: 1
}

.troubles-section .overlay-icon {
  font-size: 3rem;
  animation: bounce 2s infinite
}

.troubles-section .trouble-content {
  padding: 25px
}

.troubles-section .trouble-title {
  font-size: 1.4rem;
  font-weight: 700;
  color: #1565c0;
  margin-bottom: 12px;
  text-align: center
}

.troubles-section .trouble-description {
  font-size: .95rem;
  color: #546e7a;
  line-height: 1.6;
  text-align: center;
  margin: 0
}

@media(max-width:1024px) {
  .troubles-section .troubles-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 25px
  }
}

@media(max-width:768px) {
  .troubles-section {
    padding: 60px 0
  }

  .troubles-section .section-title {
    font-size: 2rem
  }

  .troubles-section .troubles-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px
  }

  .troubles-section .trouble-image {
    height: 160px
  }

  .troubles-section .trouble-content {
    padding: 20px
  }

  .troubles-section .trouble-title {
    font-size: 1.2rem
  }

  .troubles-section .trouble-description {
    font-size: .9rem
  }
}

@media(max-width:480px) {
  .troubles-section .container {
    padding: 0 15px
  }

  .troubles-section .section-title {
    font-size: 1.8rem
  }

  .troubles-section .troubles-grid {
    grid-template-columns: 1fr;
    gap: 15px
  }

  .troubles-section .trouble-image {
    height: 180px
  }

  .troubles-section .trouble-content {
    padding: 20px 15px
  }
}

.commitment-section {
  padding: 10px 0;
  background: transparent;
  position: relative
}

.commitment-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none
}

.commitment-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1
}

.commitment-section .section-header {
  text-align: center;
  margin-bottom: 70px
}

.commitment-section .section-title {
  font-size: 2.8rem;
  font-weight: 800;
  color: #10b3aa;
  margin-bottom: 15px;
  letter-spacing: -.02em;
  text-transform: uppercase
}

.commitment-section .section-subtitle {
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  padding: 12px 30px;
  border-radius: 25px;
  font-size: 1.2rem;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 25px;
  letter-spacing: .1em;
  box-shadow: 0 4px 15px rgba(16, 179, 170, .3)
}

.commitment-section .title-decoration {
  width: 100px;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  margin: 0 auto;
  border-radius: 2px;
  position: relative
}

.commitment-section .title-decoration::after {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 10px;
  background: #10b3aa;
  border-radius: 5px
}

.commitment-section .commitment-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px
}

.commitment-section .commitment-item {
  background: #fff;
  border-radius: 25px;
  padding: 40px 35px;
  box-shadow: 0 10px 40px rgba(16, 179, 170, .08);
  border: 1px solid rgba(16, 179, 170, .1);
  position: relative;
  transition: all .4s cubic-bezier(.175, .885, .32, 1.275);
  overflow: hidden
}

.commitment-section .commitment-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb, #18d6cc)
}

.commitment-section .commitment-item::after {
  content: '';
  position: absolute;
  top: -50%;
  right: -50%;
  width: 100%;
  height: 200%;
  background: radial-gradient(circle, rgba(16, 179, 170, .02) 0%, transparent 70%);
  transition: all .6s ease;
  transform: scale(0)
}

.commitment-section .commitment-item:hover::after {
  transform: scale(1)
}

.commitment-section .commitment-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 25px 50px rgba(16, 179, 170, .15);
  border-color: rgba(16, 179, 170, .2)
}

.commitment-section .commitment-number {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.8rem;
  font-weight: 800;
  margin-bottom: 25px;
  box-shadow: 0 6px 20px rgba(16, 179, 170, .3);
  position: relative;
  transition: all .3s ease
}

.commitment-section .commitment-number::before {
  content: '';
  position: absolute;
  top: -3px;
  left: -3px;
  width: calc(100% + 6px);
  height: calc(100% + 6px);
  border-radius: 50%;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  opacity: 0;
  transition: opacity .3s ease;
  z-index: -1
}

.commitment-section .commitment-item:hover .commitment-number::before {
  opacity: .3
}

.commitment-section .commitment-item:hover .commitment-number {
  transform: scale(1.1);
  box-shadow: 0 8px 25px rgba(16, 179, 170, .4)
}

.commitment-section .commitment-content {
  position: relative;
  z-index: 2
}

.commitment-section .commitment-title {
  font-size: 2.6rem;
  font-weight: 700;
  color: #0f1720;
  margin-bottom: 18px;
  letter-spacing: -.01em;
  position: relative
}

.commitment-section .commitment-title::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 40px;
  height: 3px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  border-radius: 2px;
  transition: width .3s ease
}

.commitment-section .commitment-item:hover .commitment-title::after {
  width: 60px
}

.commitment-section .commitment-description {
  font-size: 100%;
  color: #4a5568;
  line-height: 1.8;
  margin: 0;
  font-weight: 500
}

@media(max-width:1024px) {
  .commitment-section .commitment-grid {
    gap: 30px
  }

  .commitment-section .commitment-item {
    padding: 35px 30px
  }
}

@media(max-width:768px) {
  .commitment-section {
    padding: 80px 0
  }

  .commitment-section .section-title {
    font-size: 2.2rem
  }

  .commitment-section .section-subtitle {
    font-size: 1rem;
    padding: 10px 25px
  }

  .commitment-section .commitment-grid {
    grid-template-columns: 1fr;
    gap: 25px
  }

  .commitment-section .commitment-item {
    padding: 30px 25px
  }

  .commitment-section .commitment-number {
    width: 50px;
    height: 50px;
    font-size: 1.5rem;
    margin-bottom: 20px
  }

  .commitment-section .commitment-title {
    font-size: 1.4rem;
    margin-bottom: 15px
  }

  .commitment-section .commitment-description {
    font-size: .95rem;
    line-height: 1.7
  }
}

@media(max-width:480px) {
  .commitment-section .container {
    padding: 0 15px
  }

  .commitment-section .section-title {
    font-size: 1.8rem
  }

  .commitment-section .section-subtitle {
    font-size: .9rem;
    padding: 8px 20px
  }

  .commitment-section .section-header {
    margin-bottom: 50px
  }

  .commitment-section .commitment-item {
    padding: 25px 20px
  }

  .commitment-section .commitment-title {
    font-size: 1.2rem
  }

  .commitment-section .commitment-description {
    font-size: .9rem
  }
}

.breakdown-section {
  padding: 10px 0;
  background: transparent;
  position: relative
}

.breakdown-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none
}

.breakdown-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1
}

.breakdown-section .section-header {
  text-align: center;
  margin-bottom: 70px
}

.breakdown-section .section-title {
  font-size: 2.8rem;
  font-weight: 800;
  color: #10b3aa;
  margin-bottom: 15px;
  letter-spacing: -.02em;
  text-transform: uppercase
}

.breakdown-section .section-subtitle {
  background: linear-gradient(135deg, #dc2626, #ef4444);
  color: #fff;
  padding: 12px 30px;
  border-radius: 25px;
  font-size: 1.2rem;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 25px;
  letter-spacing: .1em;
  box-shadow: 0 4px 15px rgba(220, 38, 38, .3)
}

.breakdown-section .title-decoration {
  width: 100px;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  margin: 0 auto;
  border-radius: 2px;
  position: relative
}

.breakdown-section .title-decoration::after {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 10px;
  background: #10b3aa;
  border-radius: 5px
}

.breakdown-section .breakdown-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 35px
}

.breakdown-section .breakdown-item {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(16, 179, 170, .08);
  border: 1px solid rgba(16, 179, 170, .1);
  position: relative;
  transition: all .4s cubic-bezier(.175, .885, .32, 1.275)
}

.breakdown-section .breakdown-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #dc2626, #ef4444);
  transition: height .3s ease
}

.breakdown-section .breakdown-item:hover::before {
  height: 6px
}

.breakdown-section .breakdown-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(16, 179, 170, .15);
  border-color: rgba(16, 179, 170, .2)
}

.breakdown-section .breakdown-image {
  position: relative;
  height: 200px;
  overflow: hidden
}

.breakdown-section .breakdown-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease
}

.breakdown-section .breakdown-item:hover .breakdown-photo {
  transform: scale(1.08)
}

.breakdown-section .image-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(16, 179, 170, .85);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s ease
}

.breakdown-section .breakdown-item:hover .image-overlay {
  opacity: 1
}

.breakdown-section .overlay-icon {
  font-size: 3.5rem;
  animation: pulse 2s infinite;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, .3))
}

@keyframes pulse {

  0%,
  100% {
    transform: scale(1)
  }

  50% {
    transform: scale(1.1)
  }
}

.breakdown-section .breakdown-content {
  padding: 30px 25px
}

.breakdown-section .breakdown-title {
  font-size: 1.4rem;
  font-weight: 900;
  color: #0f1720;
  margin-bottom: 15px;
  text-align: center;
  letter-spacing: .02em;
  position: relative
}

.breakdown-section .breakdown-title::after {
  content: '';
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 30px;
  height: 2px;
  background: #10b3aa;
  border-radius: 1px;
  transition: width .3s ease
}

.breakdown-section .breakdown-item:hover .breakdown-title::after {
  width: 50px
}

.breakdown-section .breakdown-description {
  font-size: .95rem;
  color: #4a5568;
  line-height: 1.8;
  text-align: center;
  margin: 0;
  font-weight: 500
}

@media(max-width:1024px) {
  .breakdown-section .breakdown-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px
  }
}

@media(max-width:768px) {
  .breakdown-section {
    padding: 80px 0
  }

  .breakdown-section .section-title {
    font-size: 2.2rem
  }

  .breakdown-section .section-subtitle {
    font-size: 1rem;
    padding: 10px 25px
  }

  .breakdown-section .breakdown-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px
  }

  .breakdown-section .breakdown-image {
    height: 160px
  }

  .breakdown-section .breakdown-content {
    padding: 25px 20px
  }

  .breakdown-section .breakdown-title {
    font-size: 1.2rem;
    margin-bottom: 12px
  }

  .breakdown-section .breakdown-description {
    font-size: .9rem;
    line-height: 1.7
  }

  .breakdown-section .overlay-icon {
    font-size: 2.8rem
  }
}

@media(max-width:600px) {
  .breakdown-section .breakdown-grid {
    grid-template-columns: 1fr;
    gap: 25px
  }

  .breakdown-section .breakdown-image {
    height: 180px
  }
}

@media(max-width:480px) {
  .breakdown-section .container {
    padding: 0 15px
  }

  .breakdown-section .section-title {
    font-size: 1.8rem
  }

  .breakdown-section .section-subtitle {
    font-size: .9rem;
    padding: 8px 20px
  }

  .breakdown-section .section-header {
    margin-bottom: 50px
  }

  .breakdown-section .breakdown-content {
    padding: 20px 15px
  }

  .breakdown-section .breakdown-title {
    font-size: 1.1rem
  }

  .breakdown-section .breakdown-description {
    font-size: .85rem
  }
}

.page-id-1225 .whypro {
  --brand: #10b3aa;
  --ink: #0f1720;
  --muted: #5e6d79;
  --ring: #e6edf2;
  --card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 12px
}

.page-id-1226 .whypro-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr))
}

@media(max-width:980px) {
  .page-id-1225 .whypro-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }
}

@media(max-width:640px) {
  .page-id-1225 .whypro-grid {
    grid-template-columns: 1fr
  }
}

.page-id-1225 .whypro-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--ring);
  border-radius: 18px;
  padding: 18px 16px 16px;
  box-shadow: 0 16px 18px rgba(17, 24, 39, .08), 0 1px 2px rgba(17, 24, 39, .06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
  will-change: transform
}

.page-id-1225 .whypro-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(16, 179, 170, .6), rgba(16, 179, 170, 0))
}
@media(max-width:767px) {
  .page-id-1225 .whypro-grid {
    grid-template-columns: 1fr
  }
}
.page-id-1225 .whypro-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(17, 24, 39, .12), 0 2px 6px rgba(17, 24, 39, .06);
  border-color: #dfe8ee
}

.page-id-1225 .whypro-icon {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  margin-bottom: 10px;
  color: var(--brand);
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .16), rgba(16, 179, 170, .06));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .16)
}

.page-id-1225 .whypro-icon svg {
  width: 28px;
  height: 28px
}

.page-id-1225 .whypro-card h3 {
  margin: 0 0 6px;
  color: var(--ink);
  font-weight: 900;
  font-size: 25px;
  letter-spacing: .02em
}

.page-id-1225 .whypro-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: clamp(15px, 1.8vw, 16.5px);
}

.page-id-1226 .whypro {
  --brand: #10b3aa;
  --ink: #0f1720;
  --muted: #5e6d79;
  --ring: #e6edf2;
  --card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 12px
}

.page-id-1226 .whypro-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr))
}

@media(max-width:980px) {
  .page-id-1226 .whypro-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }
}

@media(max-width:640px) {
  .page-id-1226 .whypro-grid {
    grid-template-columns: 1fr
  }
}

.page-id-1226 .whypro-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--ring);
  border-radius: 18px;
  padding: 18px 16px 16px;
  box-shadow: 0 16px 18px rgba(17, 24, 39, .08), 0 1px 2px rgba(17, 24, 39, .06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
  will-change: transform
}

.page-id-1226 .whypro-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(16, 179, 170, .6), rgba(16, 179, 170, 0))
}

.page-id-1226 .whypro-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(17, 24, 39, .12), 0 2px 6px rgba(17, 24, 39, .06);
  border-color: #dfe8ee
}

.page-id-1226 .whypro-icon {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  margin-bottom: 10px;
  color: var(--brand);
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .16), rgba(16, 179, 170, .06));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .16)
}

.page-id-1226 .whypro-icon svg {
  width: 28px;
  height: 28px
}

.page-id-1226 .whypro-card h3 {
  margin: 0 0 6px;
  color: var(--ink);
  font-weight: 900;
  font-size: clamp(16px, 1.9vw, 18px);
  letter-spacing: .02em
}

.page-id-1226 .whypro-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: clamp(13.5px, 1.6vw, 14.5px)
}

.page-id-1226 .troubles-section {
  padding: 10px 0;
  background: transparent
}

.page-id-1226 .troubles-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px
}

.page-id-1226 .troubles-section .section-header {
  text-align: center;
  margin-bottom: 60px
}

.page-id-1226 .troubles-section .section-title {
  font-size: 2.5rem;
  font-weight: 800;
  color: #1565c0;
  margin-bottom: 20px;
  letter-spacing: -.02em
}

.page-id-1226 .troubles-section .title-decoration {
  width: 80px;
  height: 4px;
  background: linear-gradient(90deg, #2196f3, #03a9f4);
  margin: 0 auto;
  border-radius: 2px
}

.page-id-1226 .troubles-section .troubles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px
}

.page-id-1226 .troubles-section .trouble-item {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 8px 30px rgba(33, 150, 243, .12);
  transition: all .3s ease;
  border: 1px solid rgba(33, 150, 243, .1)
}

.page-id-1226 .troubles-section .trouble-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(33, 150, 243, .2)
}

.page-id-1226 .troubles-section .trouble-image {
  position: relative;
  height: 200px;
  overflow: hidden
}

.page-id-1226 .troubles-section .trouble-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s ease
}

.page-id-1226 .troubles-section .trouble-item:hover .trouble-photo {
  transform: scale(1.05)
}

.page-id-1226 .troubles-section .image-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(33, 150, 243, .8);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s ease
}

.page-id-1226 .troubles-section .trouble-item:hover .image-overlay {
  opacity: 1
}

.page-id-1226 .troubles-section .overlay-icon {
  font-size: 3rem;
  animation: bounce 2s infinite
}

.page-id-1226 .troubles-section .trouble-content {
  padding: 25px
}

.page-id-1226 .troubles-section .trouble-title {
  font-size: 1.4rem;
  font-weight: 700;
  color: #1565c0;
  margin-bottom: 12px;
  text-align: center
}

.page-id-1226 .troubles-section .trouble-description {
  font-size: .95rem;
  color: #546e7a;
  line-height: 1.6;
  text-align: center;
  margin: 0
}

@media(max-width:1024px) {
  .page-id-1226 .troubles-section .troubles-grid {
    grid-template-columns: 1fr;
    gap: 25px
  }
}

@media(max-width:768px) {
  .page-id-1226 .troubles-section {
    padding: 17px 0;
    margin: 0 auto 0 auto;
    width: 92%;
  }

  .page-id-1226 .troubles-section .section-title {
    font-size: 2rem
  }

  .page-id-1226 .troubles-section .troubles-grid {
    grid-template-columns: 1fr;
    gap: 20px
  }

  .page-id-1226 .troubles-section .trouble-image {
    height: 160px
  }

  .page-id-1226 .troubles-section .trouble-content {
    padding: 20px
  }

  .page-id-1226 .troubles-section .trouble-title {
    font-size: 1.2rem
  }

  .page-id-1226 .troubles-section .trouble-description {
    font-size: .9rem
  }
}

@media(max-width:480px) {
  .page-id-1226 .troubles-section .container {
    padding: 0 15px
  }

  .page-id-1226 .troubles-section .section-title {
    font-size: 1.8rem
  }

  .page-id-1226 .troubles-section .troubles-grid {
    grid-template-columns: 1fr;
    gap: 15px
  }

  .page-id-1226 .troubles-section .trouble-image {
    height: 180px
  }

  .page-id-1226 .troubles-section .trouble-content {
    padding: 20px 15px
  }
}

.page-id-1226 .commitment-section {
  padding: 10px 0;
  background: transparent;
  position: relative
}

.page-id-1226 .commitment-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none
}

.page-id-1226 .commitment-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1
}

.page-id-1226 .commitment-section .section-header {
  text-align: center;
  margin-bottom: 70px
}

.page-id-1226 .commitment-section .section-title {
  font-size: 2.8rem;
  font-weight: 800;
  color: #10b3aa;
  margin-bottom: 15px;
  letter-spacing: -.02em;
  text-transform: uppercase
}

.page-id-1226 .commitment-section .section-subtitle {
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  padding: 12px 30px;
  border-radius: 25px;
  font-size: 1.2rem;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 25px;
  letter-spacing: .1em;
  box-shadow: 0 4px 15px rgba(16, 179, 170, .3)
}

.page-id-1226 .commitment-section .title-decoration {
  width: 100px;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  margin: 0 auto;
  border-radius: 2px;
  position: relative
}

.page-id-1226 .commitment-section .title-decoration::after {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 10px;
  background: #10b3aa;
  border-radius: 5px
}

.page-id-1226 .commitment-section .commitment-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px
}

.page-id-1226 .commitment-section .commitment-item {
  background: #fff;
  border-radius: 25px;
  padding: 40px 35px;
  box-shadow: 0 10px 40px rgba(16, 179, 170, .08);
  border: 1px solid rgba(16, 179, 170, .1);
  position: relative;
  transition: all .4s cubic-bezier(.175, .885, .32, 1.275);
  overflow: hidden
}

.page-id-1226 .commitment-section .commitment-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb, #18d6cc)
}

.page-id-1226 .commitment-section .commitment-item::after {
  content: '';
  position: absolute;
  top: -50%;
  right: -50%;
  width: 100%;
  height: 200%;
  background: radial-gradient(circle, rgba(16, 179, 170, .02) 0%, transparent 70%);
  transition: all .6s ease;
  transform: scale(0)
}

.page-id-1226 .commitment-section .commitment-item:hover::after {
  transform: scale(1)
}

.page-id-1226 .commitment-section .commitment-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 25px 50px rgba(16, 179, 170, .15);
  border-color: rgba(16, 179, 170, .2)
}

.page-id-1226 .commitment-section .commitment-number {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.8rem;
  font-weight: 800;
  margin-bottom: 25px;
  box-shadow: 0 6px 20px rgba(16, 179, 170, .3);
  position: relative;
  transition: all .3s ease
}

.page-id-1226 .commitment-section .commitment-number::before {
  content: '';
  position: absolute;
  top: -3px;
  left: -3px;
  width: calc(100% + 6px);
  height: calc(100% + 6px);
  border-radius: 50%;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  opacity: 0;
  transition: opacity .3s ease;
  z-index: -1
}

.page-id-1226 .commitment-section .commitment-item:hover .commitment-number::before {
  opacity: .3
}

.page-id-1226 .commitment-section .commitment-item:hover .commitment-number {
  transform: scale(1.1);
  box-shadow: 0 8px 25px rgba(16, 179, 170, .4)
}

.page-id-1226 .commitment-section .commitment-content {
  position: relative;
  z-index: 2
}

.page-id-1226 .commitment-section .commitment-title {
  font-size: 3.2rem;
  font-weight: 700;
  color: #0f1720;
  margin-bottom: 18px;
  letter-spacing: -.01em;
  position: relative
}

.page-id-1226 .commitment-section .commitment-title::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 0;
  width: 40px;
  height: 3px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  border-radius: 2px;
  transition: width .3s ease
}

.page-id-1226 .commitment-section .commitment-item:hover .commitment-title::after {
  width: 60px
}

.page-id-1226 .commitment-section .commitment-description {
  font-size: 1.7rem;
  color: #4a5568;
  line-height: 1.8;
  margin: 0;
  font-weight: 500
}

@media(max-width:1024px) {
  .page-id-1226 .commitment-section .commitment-grid {
    gap: 30px
  }

  .page-id-1226 .commitment-section .commitment-item {
    padding: 35px 30px
  }
}

@media(max-width:768px) {
  .page-id-1226 .commitment-section {
    padding: 80px 0
  }

  .page-id-1226 .commitment-section .section-title {
    font-size: 2.2rem
  }

  .page-id-1226 .commitment-section .section-subtitle {
    font-size: 1rem;
    padding: 10px 25px
  }

  .page-id-1226 .commitment-section .commitment-grid {
    grid-template-columns: 1fr;
    gap: 25px
  }

  .page-id-1226 .commitment-section .commitment-item {
    padding: 30px 25px
  }

  .page-id-1226 .commitment-section .commitment-number {
    width: 50px;
    height: 50px;
    font-size: 2.5rem;
    margin-bottom: 20px;
  }

  .page-id-1226 .commitment-section .commitment-title {
    font-size: 1.4rem;
    margin-bottom: 15px
  }

  .page-id-1226 .commitment-section .commitment-description {
    font-size: .95rem;
    line-height: 1.7
  }
}

@media(max-width:480px) {
  .page-id-1226 .commitment-section .container {
    padding: 0 15px
  }

  .page-id-1226 .commitment-section .section-title {
    font-size: 1.8rem
  }

  .page-id-1226 .commitment-section .section-subtitle {
    font-size: .9rem;
    padding: 8px 20px
  }

  .page-id-1226 .commitment-section .section-header {
    margin-bottom: 50px
  }

  .page-id-1226 .commitment-section .commitment-item {
    padding: 25px 20px
  }

  .page-id-1226 .commitment-section .commitment-title {
    font-size: 2.2rem
  }

  .page-id-1226 .commitment-section .commitment-description {
    font-size: 1.4rem;
  }
}

.page-id-1226 .breakdown-section {
  padding: 10px 0;
  background: transparent;
  position: relative
}

.page-id-1226 .breakdown-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none
}

.page-id-1226 .breakdown-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1
}

.page-id-1226 .breakdown-section .section-header {
  text-align: center;
  margin-bottom: 70px
}

.page-id-1226 .breakdown-section .section-title {
  font-size: 2.8rem;
  font-weight: 800;
  color: #10b3aa;
  margin-bottom: 15px;
  letter-spacing: -.02em;
  text-transform: uppercase
}

.page-id-1226 .breakdown-section .section-subtitle {
  background: linear-gradient(135deg, #dc2626, #ef4444);
  color: #fff;
  padding: 12px 30px;
  border-radius: 25px;
  font-size: 1.2rem;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 25px;
  letter-spacing: .1em;
  box-shadow: 0 4px 15px rgba(220, 38, 38, .3)
}

.page-id-1226 .breakdown-section .title-decoration {
  width: 100px;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  margin: 0 auto;
  border-radius: 2px;
  position: relative
}

.page-id-1226 .breakdown-section .title-decoration::after {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 10px;
  background: #10b3aa;
  border-radius: 5px
}

.page-id-1226 .breakdown-section .breakdown-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 35px
}

.page-id-1226 .breakdown-section .breakdown-item {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(16, 179, 170, .08);
  border: 1px solid rgba(16, 179, 170, .1);
  position: relative;
  transition: all .4s cubic-bezier(.175, .885, .32, 1.275)
}

.page-id-1226 .breakdown-section .breakdown-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #dc2626, #ef4444);
  transition: height .3s ease
}

.page-id-1226 .breakdown-section .breakdown-item:hover::before {
  height: 6px
}

.page-id-1226 .breakdown-section .breakdown-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(16, 179, 170, .15);
  border-color: rgba(16, 179, 170, .2)
}

.page-id-1226 .breakdown-section .breakdown-image {
  position: relative;
  height: 200px;
  overflow: hidden
}

.page-id-1226 .breakdown-section .breakdown-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease
}

.page-id-1226 .breakdown-section .breakdown-item:hover .breakdown-photo {
  transform: scale(1.08)
}

.page-id-1226 .breakdown-section .image-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(16, 179, 170, .85);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s ease
}

.page-id-1226 .breakdown-section .breakdown-item:hover .image-overlay {
  opacity: 1
}

.page-id-1226 .breakdown-section .overlay-icon {
  font-size: 3.5rem;
  animation: pulse 2s infinite;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, .3))
}

.page-id-1226 .breakdown-section .breakdown-content {
  padding: 30px 25px
}

.page-id-1226 .breakdown-section .breakdown-title {
  font-size: 1.4rem;
  font-weight: 900;
  color: #0f1720;
  margin-bottom: 15px;
  text-align: center;
  letter-spacing: .02em;
  position: relative
}

.page-id-1226 .breakdown-section .breakdown-title::after {
  content: '';
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 30px;
  height: 2px;
  background: #10b3aa;
  border-radius: 1px;
  transition: width .3s ease
}

.page-id-1226 .breakdown-section .breakdown-item:hover .breakdown-title::after {
  width: 50px
}

.page-id-1226 .breakdown-section .breakdown-description {
  font-size: .95rem;
  color: #4a5568;
  line-height: 1.8;
  text-align: center;
  margin: 0;
  font-weight: 500
}

@media(max-width:1024px) {
  .page-id-1226 .breakdown-section .breakdown-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px
  }
}

@media(max-width:768px) {
  .page-id-1226 .breakdown-section {
    padding: 0px 0
  }

  .page-id-1226 .breakdown-section .section-title {
    font-size: 2.2rem
  }

  .page-id-1226 .breakdown-section .section-subtitle {
    font-size: 1rem;
    padding: 10px 25px
  }

  .page-id-1226 .breakdown-section .breakdown-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px
  }

  .page-id-1226 .breakdown-section .breakdown-image {
    height: 160px
  }

  .page-id-1226 .breakdown-section .breakdown-content {
    padding: 25px 20px
  }

  .page-id-1226 .breakdown-section .breakdown-title {
    font-size: 1.2rem;
    margin-bottom: 12px
  }

  .page-id-1226 .breakdown-section .breakdown-description {
    font-size: .9rem;
    line-height: 1.7
  }

  .page-id-1226 .breakdown-section .overlay-icon {
    font-size: 2.8rem
  }
}

@media(max-width:600px) {
  .page-id-1226 .breakdown-section .breakdown-grid {
    grid-template-columns: 1fr;
    gap: 25px
  }

  .page-id-1226 .breakdown-section .breakdown-image {
    height: 180px
  }
}

@media(max-width:480px) {
  .page-id-1226 .breakdown-section .container {
    padding: 0 15px
  }

  .page-id-1226 .breakdown-section .section-title {
    font-size: 1.8rem
  }

  .page-id-1226 .breakdown-section .section-subtitle {
    font-size: .9rem;
    padding: 8px 20px
  }

  .page-id-1226 .breakdown-section .section-header {
    margin-bottom: 50px
  }

  .page-id-1226 .breakdown-section .breakdown-content {
    padding: 20px 15px
  }

  .page-id-1226 .breakdown-section .breakdown-title {
    font-size: 1.1rem
  }

  .page-id-1226 .breakdown-section .breakdown-description {
    font-size: .85rem
  }
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two {
  grid-template-columns: repeat(2, 1fr);
  gap: 32px
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-item {
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid #e7eef3;
  box-shadow: 0 8px 24px rgba(15, 23, 32, .08);
  transition: transform .2s ease, box-shadow .2s ease
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 34px rgba(15, 23, 32, .12)
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-image {
  position: relative;
  height: 260px;
  overflow: hidden
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-item:hover .breakdown-photo {
  transform: scale(1.04)
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-content {
  padding: 28px 26px
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-title {
  font-size: 3.4rem;
  font-weight: 800;
  letter-spacing: .01em;
  text-align: left;
  color: #173a8e;
  margin: 0 0 14px
}

.page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-description {
  font-size: 1.6rem;
  line-height: 1.9;
  color: #404b5a;
  margin: 0
}

@media(max-width:1024px) {
  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two {
    gap: 24px
  }

  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-image {
    height: 220px
  }

  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-title {
    font-size: 1.6rem
  }
}

@media(max-width:768px) {
  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two {
    grid-template-columns: 1fr;
    gap: 20px
  }

  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-image {
    height: 200px
  }

  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-content {
    padding: 22px 18px
  }

  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-title {
    font-size: 2.1rem
  }

  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-description {
    font-size: 1.4rem;
    line-height: 1.8
  }
}

@media(max-width:480px) {
  .page-id-1226 .breakdown-section .breakdown-grid.breakdown-grid--two .breakdown-image {
    height: 190px
  }
}

.page-id-1226 .service-flow {
  --sf-brand: #10b3aa;
  --sf-ink: #0f1720;
  --sf-muted: #5e6d79;
  --sf-ring: #e6edf2;
  --sf-panel: #f7fbfd;
  --sf-card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  padding: 32px 14px;
  max-width: 1200px;
  margin: 0 auto
}

.page-id-1226 .sf-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) 420px
}

@media(max-width:1000px) {
  .page-id-1226 .sf-grid {
    grid-template-columns: 1fr
  }
}

.page-id-1226 .sf-steps {
  list-style: none;
  margin: 0;
  padding: 12px;
  background: var(--sf-panel);
  border: 1px solid var(--sf-ring);
  border-radius: 18px
}

.page-id-1226 .sf-step {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  position: relative;
  padding: 16px 12px;
  margin: 0 0 12px;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.page-id-1226 .sf-step:last-child {
  margin-bottom: 0
}

.page-id-1226 .sf-step::before {
  content: "";
  position: absolute;
  left: 34px;
  top: 58px;
  bottom: 16px;
  width: 2px;
  background: linear-gradient(180deg, var(--sf-brand), rgba(16, 179, 170, .1))
}

.page-id-1226 .sf-step:last-child::before {
  display: none
}

.page-id-1226 .sf-badge {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #0d3c3a;
  font-weight: 900;
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .24), rgba(16, 179, 170, .10));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .28)
}

.page-id-1226 .sf-body h3 {
  margin: 2px 0 6px;
  color: var(--sf-ink);
  font-weight: 900;
  letter-spacing: .02em;
  font-size: clamp(16px, 2vw, 18px)
}

.page-id-1226 .sf-body p {
  margin: 0;
  color: var(--sf-muted);
  line-height: 1.85;
  font-size: clamp(13.5px, 1.8vw, 14.5px)
}

.page-id-1226 .sf-body .sf-note {
  margin-top: 6px;
  font-size: 12.5px;
  color: #7a8893
}

.page-id-1226 .sf-media {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px
}

.page-id-1226 .sf-media-item {
  margin: 0;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.page-id-1226 .sf-media-item img {
  width: 100%;
  height: auto;
  display: block
}

.page-id-1226 .sf-media-item figcaption {
  padding: 12px;
  color: #506070;
  font-size: 13px;
  line-height: 1.6
}

.page-id-1226 .sf-media--lineqr {
  display: grid;
  grid-template-rows: auto 1fr
}

.page-id-1226 .sf-media--lineqr .sf-lineqr-wrap {
  display: grid;
  place-items: center;
  padding: 14px;
  background: #fff;
  border-bottom: 1px solid var(--sf-ring)
}

.page-id-1226 .sf-lineqr-link {
  display: block
}

.page-id-1226 .sf-lineqr-img {
  display: block;
  max-width: 300px;
  width: 70%;
  height: auto;
  margin: 8px auto 6px;
  border-radius: 8px
}

.page-id-1226 .sf-media--lineqr figcaption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap
}

.page-id-1226 .sf-media--lineqr .sf-caption-title {
  color: #506070
}

.page-id-1226 .sf-btn-line {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 800;
  text-decoration: none;
  background: #06c755;
  color: #fff;
  border: 2px solid #06c755;
  box-shadow: 0 2px 8px rgba(6, 199, 85, .25)
}

.page-id-1226 .sf-btn-line:focus-visible {
  outline: 3px solid #b1f2c8;
  outline-offset: 2px
}

@media(max-width:600px) {
  .page-id-1226 .sf-media--illustration {
    order: -1
  }
}

.page-id-1227 .whypro {
  --brand: #10b3aa;
  --ink: #0f1720;
  --muted: #5e6d79;
  --ring: #e6edf2;
  --card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 12px
}

.page-id-1227 .whypro-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr))
}

@media(max-width:980px) {
  .page-id-1227 .whypro-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }
}

@media(max-width:640px) {
  .page-id-1227 .whypro-grid {
    grid-template-columns: 1fr
  }
}

.page-id-1227 .whypro-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--ring);
  border-radius: 18px;
  padding: 18px 16px 16px;
  box-shadow: 0 16px 18px rgba(17, 24, 39, .08), 0 1px 2px rgba(17, 24, 39, .06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
  will-change: transform
}

.page-id-1227 .whypro-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(16, 179, 170, .6), rgba(16, 179, 170, 0))
}

.page-id-1227 .whypro-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(17, 24, 39, .12), 0 2px 6px rgba(17, 24, 39, .06);
  border-color: #dfe8ee
}

.page-id-1227 .whypro-icon {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  margin-bottom: 10px;
  color: var(--brand);
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .16), rgba(16, 179, 170, .06));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .16)
}

.page-id-1227 .whypro-icon svg {
  width: 28px;
  height: 28px
}

.page-id-1227 .whypro-card h3 {
  margin: 0 0 6px;
  color: var(--ink);
  font-weight: 900;
  font-size: clamp(16px, 1.9vw, 18px);
  letter-spacing: .02em
}

.page-id-1227 .whypro-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: clamp(13.5px, 1.6vw, 14.5px)
}

.page-id-1227 .table-wrapper {
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 3px 10px rgba(0, 0, 0, .08);
  border: 1px solid #ddd
}

.page-id-1227 .table-title {
  background: linear-gradient(135deg, #10b3aa 0%, #0aa19a 100%);
  color: #fff;
  text-align: center;
  padding: 18px;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: .5px
}

.page-id-1227 .data-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif
}

.page-id-1227 .data-table thead tr {
  background: #445566
}

.page-id-1227 .data-table thead th {
  color: #fff;
  padding: 16px 20px;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
  vertical-align: middle;
  border-right: 1px solid rgba(255, 255, 255, .15)
}

.page-id-1227 .data-table thead th:first-child {
  text-align: left;
  width: 40%
}

.page-id-1227 .data-table thead th:last-child {
  border-right: 0
}

.page-id-1227 .data-table tbody tr {
  border-bottom: 1px solid #e5e5e5;
  transition: background-color .2s ease
}

.page-id-1227 .data-table tbody tr:hover {
  background: #fafafa
}

.page-id-1227 .data-table tbody tr:last-child {
  border-bottom: 0
}

.page-id-1227 .data-table tbody td {
  padding: 18px 20px;
  font-size: 15px;
  vertical-align: middle;
  text-align: center;
  border-right: 1px solid #e5e5e5
}

.page-id-1227 .data-table tbody td:first-child {
  text-align: left;
  color: #445566;
  font-weight: 500;
  background: #f9f9f9;
  width: 40%;
  font-size: 14px
}

.page-id-1227 .data-table tbody td:last-child {
  border-right: 0
}

.page-id-1227 .data-table tbody td:not(:first-child) {
  color: #333;
  font-size: 17px;
  font-weight: 600;
  white-space: nowrap
}

.page-id-1227 .mileage-table tbody td:not(:first-child) {
  font-size: 16px
}

.page-id-1227 .period-highlight {
  color: #10b3aa !important;
  font-weight: 700
}

.page-id-1227 .weight-table thead th:first-child,
.page-id-1227 .weight-table tbody td:first-child {
  width: 25%
}

.page-id-1227 .table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch
}

.page-id-1227 .data-table {
  border-collapse: separate;
  border-spacing: 0
}

.page-id-1227 .data-table thead th {
  white-space: nowrap
}

.page-id-1227 .data-table td {
  vertical-align: middle
}

@media(max-width:768px) {
  .page-id-1227 .table-title {
    font-size: 17px;
    padding: 14px
  }

  .page-id-1227 .data-table thead th {
    padding: 12px 10px;
    font-size: 13px;
    position: sticky;
    top: 0;
    z-index: 5;
    background: #445566;
    color: #fff
  }

  .page-id-1227 .data-table thead th:first-child {
    width: 30%;
    padding: 12px 8px;
    z-index: 6
  }

  .page-id-1227 .data-table tbody td {
    padding: 14px 10px;
    font-size: 13px
  }

  .page-id-1227 .data-table tbody td:first-child {
    width: 30%;
    padding: 14px 8px;
    font-size: 12px
  }

  .page-id-1227 .data-table tbody td:not(:first-child) {
    font-size: 15px
  }

  .page-id-1227 .mileage-table tbody td:not(:first-child) {
    font-size: 14px
  }

  .page-id-1227 .data-table th:first-child,
  .page-id-1227 .data-table td:first-child {
    position: sticky;
    left: 0;
    z-index: 4;
    min-width: 180px;
    white-space: nowrap;
    background: #fff
  }

  .page-id-1227 .data-table tbody tr:nth-child(even) td:first-child {
    background: #f9f9f9
  }

  .page-id-1227 .data-table th:nth-child(2),
  .page-id-1227 .data-table td:nth-child(2) {
    min-width: 92px;
    text-align: center;
    white-space: nowrap
  }

  .page-id-1227 .data-table th:nth-child(n+3),
  .page-id-1227 .data-table td:nth-child(n+3) {
    min-width: 110px;
    text-align: right;
    white-space: nowrap
  }
}

@media(max-width:480px) {

  .page-id-1227 .data-table th:first-child,
  .page-id-1227 .data-table td:first-child {
    min-width: 170px
  }

  .page-id-1227 .data-table th:nth-child(2),
  .page-id-1227 .data-table td:nth-child(2) {
    min-width: 86px
  }

  .page-id-1227 .data-table th:nth-child(n+3),
  .page-id-1227 .data-table td:nth-child(n+3) {
    min-width: 104px
  }

  .page-id-1227 .data-table thead th,
  .page-id-1227 .data-table tbody td {
    padding: 10px 8px;
    font-size: 12.5px
  }
}

.page-id-1227 .commitment-section {
  padding: 10px 0;
  background: transparent;
  position: relative
}

.page-id-1227 .commitment-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none
}

.page-id-1227 .commitment-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1
}

.page-id-1227 .commitment-section .section-header {
  text-align: center;
  margin-bottom: 70px
}

.page-id-1227 .commitment-section .section-title {
  font-size: 2.8rem;
  font-weight: 800;
  color: #10b3aa;
  margin-bottom: 15px;
  letter-spacing: -.02em;
  text-transform: uppercase
}

.page-id-1227 .commitment-section .section-subtitle {
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  padding: 12px 30px;
  border-radius: 25px;
  font-size: 1.2rem;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 25px;
  letter-spacing: .1em;
  box-shadow: 0 4px 15px rgba(16, 179, 170, .3)
}

.page-id-1227 .commitment-section .title-decoration {
  width: 100px;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  margin: 0 auto;
  border-radius: 2px;
  position: relative
}

.page-id-1227 .commitment-section .title-decoration::after {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 10px;
  background: #10b3aa;
  border-radius: 5px
}

.page-id-1227 .commitment-section .commitment-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px
}

.page-id-1227 .commitment-section .commitment-item {
  background: #fff;
  border-radius: 25px;
  padding: 40px 35px;
  box-shadow: 0 10px 40px rgba(16, 179, 170, .08);
  border: 1px solid rgba(16, 179, 170, .1);
  position: relative;
  transition: all .4s cubic-bezier(.175, .885, .32, 1.275);
  overflow: hidden
}

.page-id-1227 .commitment-section .commitment-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb, #18d6cc)
}

.page-id-1227 .commitment-section .commitment-item::after {
  content: '';
  position: absolute;
  top: -50%;
  right: -50%;
  width: 100%;
  height: 200%;
  background: radial-gradient(circle, rgba(16, 179, 170, .02) 0%, transparent 70%);
  transition: all .6s ease;
  transform: scale(0)
}

.page-id-1227 .commitment-section .commitment-item:hover::after {
  transform: scale(1)
}

.page-id-1227 .commitment-section .commitment-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 25px 50px rgba(16, 179, 170, .15);
  border-color: rgba(16, 179, 170, .2)
}

.page-id-1227 .commitment-section .commitment-number {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.8rem;
  font-weight: 800;
  margin-bottom: 25px;
  box-shadow: 0 6px 20px rgba(16, 179, 170, .3);
  position: relative;
  transition: all .3s ease
}

.page-id-1227 .commitment-section .commitment-number::before {
  content: '';
  position: absolute;
  top: -3px;
  left: -3px;
  width: calc(100% + 6px);
  height: calc(100% + 6px);
  border-radius: 50%;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  opacity: 0;
  transition: opacity .3s ease;
  z-index: -1
}

.page-id-1227 .commitment-section .commitment-item:hover .commitment-number::before {
  opacity: .3
}

.page-id-1227 .commitment-section .commitment-item:hover .commitment-number {
  transform: scale(1.1);
  box-shadow: 0 8px 25px rgba(16, 179, 170, .4)
}

.page-id-1227 .commitment-section .commitment-content {
  position: relative;
  z-index: 2
}

.page-id-1227 .commitment-section .commitment-title {
  font-size: 3.2rem;
  font-weight: 700;
  color: #0f1720;
  margin-bottom: 18px;
  letter-spacing: -.01em;
  position: relative
}

.page-id-1227 .commitment-section .commitment-title::after {
  content: '';
  position: absolute;
  bottom: -8px;
  left: 0;
  width: 40px;
  height: 3px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  border-radius: 2px;
  transition: width .3s ease
}

.page-id-1227 .commitment-section .commitment-item:hover .commitment-title::after {
  width: 60px
}

.page-id-1227 .commitment-section .commitment-description {
  font-size: 1.6rem;
  color: #4a5568;
  line-height: 1.8;
  margin: 0;
  font-weight: 500
}

@media(max-width:1024px) {
  .page-id-1227 .commitment-section .commitment-grid {
    gap: 30px
  }

  .page-id-1227 .commitment-section .commitment-item {
    padding: 35px 30px
  }
}

@media(max-width:768px) {
  .page-id-1227 .commitment-section {
    padding: 8px 0
  }

  .page-id-1227 .commitment-section .section-title {
    font-size: 2.2rem
  }

  .page-id-1227 .commitment-section .section-subtitle {
    font-size: 1rem;
    padding: 10px 25px
  }

  .page-id-1227 .commitment-section .commitment-grid {
    grid-template-columns: 1fr;
    gap: 25px
  }

  .page-id-1227 .commitment-section .commitment-item {
    padding: 30px 25px
  }

  .page-id-1227 .commitment-section .commitment-number {
    width: 50px;
    height: 50px;
    font-size: 1.4rem;
    margin-bottom: 20px
  }

  .page-id-1227 .commitment-section .commitment-title {
    font-size: 1.4rem;
    margin-bottom: 15px
  }

  .page-id-1227 .commitment-section .commitment-description {
    font-size: .95rem;
    line-height: 1.7
  }
}

@media(max-width:480px) {
  .page-id-1227 .commitment-section .container {
    padding: 0 15px
  }

  .page-id-1227 .commitment-section .section-title {
    font-size: 1.8rem
  }

  .page-id-1227 .commitment-section .section-subtitle {
    font-size: .9rem;
    padding: 8px 20px
  }

  .page-id-1227 .commitment-section .section-header {
    margin-bottom: 50px
  }

  .page-id-1227 .commitment-section .commitment-item {
    padding: 25px 20px
  }

  .page-id-1227 .commitment-section .commitment-title {
    font-size: 2.2rem
  }

  .page-id-1227 .commitment-section .commitment-description {
    font-size: 1.4rem;
  }
}

.page-id-1227 .service-flow {
  --sf-brand: #10b3aa;
  --sf-ink: #0f1720;
  --sf-muted: #5e6d79;
  --sf-ring: #e6edf2;
  --sf-panel: #f7fbfd;
  --sf-card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  padding: 32px 14px;
  max-width: 1200px;
  margin: 0 auto
}

.page-id-1227 .sf-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) 420px
}

@media(max-width:1000px) {
  .page-id-1227 .sf-grid {
    grid-template-columns: 1fr
  }
}

.page-id-1227 .sf-steps {
  list-style: none;
  margin: 0;
  padding: 12px;
  background: var(--sf-panel);
  border: 1px solid var(--sf-ring);
  border-radius: 18px
}

.page-id-1227 .sf-step {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  position: relative;
  padding: 16px 12px;
  margin: 0 0 12px;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.page-id-1227 .sf-step:last-child {
  margin-bottom: 0
}

.page-id-1227 .sf-step::before {
  content: "";
  position: absolute;
  left: 34px;
  top: 58px;
  bottom: 16px;
  width: 2px;
  background: linear-gradient(180deg, var(--sf-brand), rgba(16, 179, 170, .1))
}

.page-id-1227 .sf-step:last-child::before {
  display: none
}

.page-id-1227 .sf-badge {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #0d3c3a;
  font-weight: 900;
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .24), rgba(16, 179, 170, .10));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .28)
}

.page-id-1227 .sf-body h3 {
  margin: 2px 0 6px;
  color: var(--sf-ink);
  font-weight: 900;
  letter-spacing: .02em;
  font-size: clamp(16px, 2vw, 18px)
}

.page-id-1227 .sf-body p {
  margin: 0;
  color: var(--sf-muted);
  line-height: 1.85;
  font-size: clamp(13.5px, 1.8vw, 14.5px)
}

.page-id-1227 .sf-body .sf-note {
  margin-top: 6px;
  font-size: 12.5px;
  color: #7a8893
}

.page-id-1227 .sf-media {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px
}

.page-id-1227 .sf-media-item {
  margin: 0;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.page-id-1227 .sf-media-item img {
  width: 100%;
  height: auto;
  display: block
}

.page-id-1227 .sf-media-item figcaption {
  padding: 12px;
  color: #506070;
  font-size: 13px;
  line-height: 1.6
}

.page-id-1227 .sf-media--lineqr {
  display: grid;
  grid-template-rows: auto 1fr
}

.page-id-1227 .sf-media--lineqr .sf-lineqr-wrap {
  display: grid;
  place-items: center;
  padding: 14px;
  background: #fff;
  border-bottom: 1px solid var(--sf-ring)
}

.page-id-1227 .sf-lineqr-link {
  display: block
}

.page-id-1227 .sf-lineqr-img {
  display: block;
  max-width: 300px;
  width: 70%;
  height: auto;
  margin: 8px auto 6px;
  border-radius: 8px
}

.page-id-1227 .sf-media--lineqr figcaption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap
}

.page-id-1227 .sf-media--lineqr .sf-caption-title {
  color: #506070
}

.page-id-1227 .sf-btn-line {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 800;
  text-decoration: none;
  background: #06c755;
  color: #fff;
  border: 2px solid #06c755;
  box-shadow: 0 2px 8px rgba(6, 199, 85, .25)
}

.page-id-1227 .sf-btn-line:focus-visible {
  outline: 3px solid #b1f2c8;
  outline-offset: 2px
}

@media(max-width:600px) {
  .page-id-1227 .sf-media--illustration {
    order: -1
  }
}

.page-id-1228 .whypro {
  --brand: #10b3aa;
  --ink: #0f1720;
  --muted: #5e6d79;
  --ring: #e6edf2;
  --card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 12px
}

.page-id-1228 .whypro-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr))
}

@media(max-width:980px) {
  .page-id-1228 .whypro-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }
}

@media(max-width:640px) {
  .page-id-1228 .whypro-grid {
    grid-template-columns: 1fr
  }
}

.page-id-1228 .whypro-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--ring);
  border-radius: 18px;
  padding: 18px 16px 16px;
  box-shadow: 0 16px 18px rgba(17, 24, 39, .08), 0 1px 2px rgba(17, 24, 39, .06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
  will-change: transform
}

.page-id-1228 .whypro-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(16, 179, 170, .6), rgba(16, 179, 170, 0))
}

.page-id-1228 .whypro-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(17, 24, 39, .12), 0 2px 6px rgba(17, 24, 39, .06);
  border-color: #dfe8ee
}

.page-id-1228 .whypro-icon {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  margin-bottom: 10px;
  color: var(--brand);
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .16), rgba(16, 179, 170, .06));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .16)
}

.page-id-1228 .whypro-icon svg {
  width: 28px;
  height: 28px
}

.page-id-1228 .whypro-card h3 {
  margin: 0 0 6px;
  color: var(--ink);
  font-weight: 900;
  font-size: clamp(16px, 1.9vw, 18px);
  letter-spacing: .02em
}

.page-id-1228 .whypro-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
  font-size: clamp(13.5px, 1.6vw, 14.5px)
}

.page-id-1228 .commitment-section {
  padding: 10px 0;
  background: transparent;
  position: relative
}

.page-id-1228 .commitment-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none
}

.page-id-1228 .commitment-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1
}

.page-id-1228 .commitment-section .section-header {
  text-align: center;
  margin-bottom: 70px
}

.page-id-1228 .commitment-section .section-title {
  font-size: 2.8rem;
  font-weight: 800;
  color: #10b3aa;
  margin-bottom: 15px;
  letter-spacing: -.02em;
  text-transform: uppercase
}

.page-id-1228 .commitment-section .section-subtitle {
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  padding: 12px 30px;
  border-radius: 25px;
  font-size: 1.2rem;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 25px;
  letter-spacing: .1em;
  box-shadow: 0 4px 15px rgba(16, 179, 170, .3)
}

.page-id-1228 .commitment-section .title-decoration {
  width: 100px;
  height: 4px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  margin: 0 auto;
  border-radius: 2px;
  position: relative
}

.page-id-1228 .commitment-section .title-decoration::after {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 10px;
  background: #10b3aa;
  border-radius: 5px
}

.page-id-1228 .commitment-section .commitment-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px
}

.page-id-1228 .commitment-section .commitment-item {
  background: #fff;
  border-radius: 25px;
  padding: 40px 35px;
  box-shadow: 0 10px 40px rgba(16, 179, 170, .08);
  border: 1px solid rgba(16, 179, 170, .1);
  position: relative;
  transition: all .4s cubic-bezier(.175, .885, .32, 1.275);
  overflow: hidden
}

.page-id-1228 .commitment-section .commitment-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb, #18d6cc)
}

.page-id-1228 .commitment-section .commitment-item::after {
  content: '';
  position: absolute;
  top: -50%;
  right: -50%;
  width: 100%;
  height: 200%;
  background: radial-gradient(circle, rgba(16, 179, 170, .02) 0%, transparent 70%);
  transition: all .6s ease;
  transform: scale(0)
}

.page-id-1228 .commitment-section .commitment-item:hover::after {
  transform: scale(1)
}

.page-id-1228 .commitment-section .commitment-item:hover {
  transform: translateY(-8px);
  box-shadow: 0 25px 50px rgba(16, 179, 170, .15);
  border-color: rgba(16, 179, 170, .2)
}

.page-id-1228 .commitment-section .commitment-number {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.2rem;
  font-weight: 800;
  margin-bottom: 25px;
  box-shadow: 0 6px 20px rgba(16, 179, 170, .3);
  position: relative;
  transition: all .3s ease
}

.page-id-1228 .commitment-section .commitment-number::before {
  content: '';
  position: absolute;
  top: -3px;
  left: -3px;
  width: calc(100% + 6px);
  height: calc(100% + 6px);
  border-radius: 50%;
  background: linear-gradient(135deg, #10b3aa, #14c4bb);
  opacity: 0;
  transition: opacity .3s ease;
  z-index: -1
}

.page-id-1228 .commitment-section .commitment-item:hover .commitment-number::before {
  opacity: .3
}

.page-id-1228 .commitment-section .commitment-item:hover .commitment-number {
  transform: scale(1.1);
  box-shadow: 0 8px 25px rgba(16, 179, 170, .4)
}

.page-id-1228 .commitment-section .commitment-content {
  position: relative;
  z-index: 2
}

.page-id-1228 .commitment-section .commitment-title {
  font-size: 2.6rem;
  font-weight: 700;
  color: #0f1720;
  margin-bottom: 18px;
  letter-spacing: -.01em;
  position: relative
}

.page-id-1228 .commitment-section .commitment-title::after {
  content: '';
  position: absolute;
  bottom: -8px;
  left: 0;
  width: 40px;
  height: 3px;
  background: linear-gradient(90deg, #10b3aa, #14c4bb);
  border-radius: 2px;
  transition: width .3s ease
}

.page-id-1228 .commitment-section .commitment-item:hover .commitment-title::after {
  width: 60px
}

.page-id-1228 .commitment-section .commitment-description {
  font-size: 1.6rem;
  color: #4a5568;
  line-height: 1.8;
  margin: 0;
  font-weight: 500
}

@media(max-width:1024px) {
  .page-id-1228 .commitment-section .commitment-grid {
    gap: 30px
  }

  .page-id-1228 .commitment-section .commitment-item {
    padding: 35px 30px
  }
}

@media(max-width:768px) {
  .page-id-1228 .commitment-section {
    padding: 8px 0
  }

  .page-id-1228 .commitment-section .section-title {
    font-size: 2.2rem
  }

  .page-id-1228 .commitment-section .section-subtitle {
    font-size: 1rem;
    padding: 10px 25px
  }

  .page-id-1228 .commitment-section .commitment-grid {
    grid-template-columns: 1fr;
    gap: 25px
  }

  .page-id-1228 .commitment-section .commitment-item {
    padding: 30px 25px
  }

  .page-id-1228 .commitment-section .commitment-number {
    width: 50px;
    height: 50px;
    font-size: 2.2rem;
    margin-bottom: 20px;
  }

  .page-id-1228 .commitment-section .commitment-title {
    font-size: 1.4rem;
    margin-bottom: 15px
  }

  .page-id-1228 .commitment-section .commitment-description {
    font-size: .95rem;
    line-height: 1.7
  }
}

@media(max-width:480px) {
  .page-id-1228 .commitment-section .container {
    padding: 0 15px
  }

  .page-id-1228 .commitment-section .section-title {
    font-size: 1.8rem
  }

  .page-id-1228 .commitment-section .section-subtitle {
    font-size: .9rem;
    padding: 8px 20px
  }

  .page-id-1228 .commitment-section .section-header {
    margin-bottom: 50px
  }

  .page-id-1228 .commitment-section .commitment-item {
    padding: 25px 20px
  }

  .page-id-1228 .commitment-section .commitment-title {
    font-size: 2.2rem;
  }

  .page-id-1228 .commitment-section .commitment-description {
    font-size: 1.4rem
  }
}

.page-id-1228 .service-flow {
  --sf-brand: #10b3aa;
  --sf-ink: #0f1720;
  --sf-muted: #5e6d79;
  --sf-ring: #e6edf2;
  --sf-panel: #f7fbfd;
  --sf-card: #fff;
  font-family: 'Noto Sans JP', system-ui, sans-serif;
  padding: 32px 14px;
  max-width: 1200px;
  margin: 0 auto
}

.page-id-1228 .sf-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) 420px
}

@media(max-width:1000px) {
  .page-id-1228 .sf-grid {
    grid-template-columns: 1fr
  }
}

.page-id-1228 .sf-steps {
  list-style: none;
  margin: 0;
  padding: 12px;
  background: var(--sf-panel);
  border: 1px solid var(--sf-ring);
  border-radius: 18px
}

.page-id-1228 .sf-step {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  position: relative;
  padding: 16px 12px;
  margin: 0 0 12px;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.page-id-1228 .sf-step:last-child {
  margin-bottom: 0
}

.page-id-1228 .sf-step::before {
  content: "";
  position: absolute;
  left: 34px;
  top: 58px;
  bottom: 16px;
  width: 2px;
  background: linear-gradient(180deg, var(--sf-brand), rgba(16, 179, 170, .1))
}

.page-id-1228 .sf-step:last-child::before {
  display: none
}

.page-id-1228 .sf-badge {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: #0d3c3a;
  font-weight: 900;
  background: radial-gradient(100% 100% at 50% 0%, rgba(16, 179, 170, .24), rgba(16, 179, 170, .10));
  box-shadow: inset 0 0 0 2px rgba(16, 179, 170, .28)
}

.page-id-1228 .sf-body h3 {
  margin: 2px 0 6px;
  color: var(--sf-ink);
  font-weight: 900;
  letter-spacing: .02em;
  font-size: clamp(16px, 2vw, 18px)
}

.page-id-1228 .sf-body p {
  margin: 0;
  color: var(--sf-muted);
  line-height: 1.85;
  font-size: clamp(13.5px, 1.8vw, 14.5px)
}

.page-id-1228 .sf-body .sf-note {
  margin-top: 6px;
  font-size: 12.5px;
  color: #7a8893
}

.page-id-1228 .sf-media {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px
}

.page-id-1228 .sf-media-item {
  margin: 0;
  background: var(--sf-card);
  border: 1px solid var(--sf-ring);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(2, 6, 12, .06)
}

.page-id-1228 .sf-media-item img {
  width: 100%;
  height: auto;
  display: block
}

.page-id-1228 .sf-media-item figcaption {
  padding: 12px;
  color: #506070;
  font-size: 13px;
  line-height: 1.6
}

.page-id-1228 .sf-media--lineqr {
  display: grid;
  grid-template-rows: auto 1fr
}

.page-id-1228 .sf-media--lineqr .sf-lineqr-wrap {
  display: grid;
  place-items: center;
  padding: 14px;
  background: #fff;
  border-bottom: 1px solid var(--sf-ring)
}

.page-id-1228 .sf-lineqr-link {
  display: block
}

.page-id-1228 .sf-lineqr-img {
  display: block;
  max-width: 300px;
  width: 70%;
  height: auto;
  margin: 8px auto 6px;
  border-radius: 8px
}

.page-id-1228 .sf-media--lineqr figcaption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap
}

.page-id-1228 .sf-media--lineqr .sf-caption-title {
  color: #506070
}

.page-id-1228 .sf-btn-line {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 800;
  text-decoration: none;
  background: #06c755;
  color: #fff;
  border: 2px solid #06c755;
  box-shadow: 0 2px 8px rgba(6, 199, 85, .25)
}

.page-id-1228 .sf-btn-line:focus-visible {
  outline: 3px solid #b1f2c8;
  outline-offset: 2px
}

@media (max-width:600px) {
  .page-id-1226 .sf-media--illustration {
    order: -1;
  }
}

/* ガラス交換ページ：ASV/エーミング解説ブロック */
section.breakdown-section {
  padding: 32px 0;
  background: transparent;
  position: relative
}

section.breakdown-section>.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 1;
  box-sizing: border-box
}

section.breakdown-section .breakdown-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 32px;
  align-items: stretch
}

section.breakdown-section .breakdown-item {
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid #e7eef3;
  box-shadow: 0 8px 24px rgba(15, 23, 32, .08);
  transition: transform .2s ease, box-shadow .2s ease;
  box-sizing: border-box
}

section.breakdown-section .breakdown-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 34px rgba(15, 23, 32, .12)
}

section.breakdown-section .breakdown-image {
  position: relative;
  height: 260px;
  overflow: hidden
}

section.breakdown-section .breakdown-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease
}

section.breakdown-section .breakdown-item:hover .breakdown-photo {
  transform: scale(1.04)
}

section.breakdown-section .breakdown-content {
  padding: 28px 26px
}

section.breakdown-section .breakdown-title {
  font-size: 1.9rem;
  font-weight: 800;
  letter-spacing: .01em;
  text-align: left;
  color: #173a8e;
  margin: 0 0 14px
}

section.breakdown-section .breakdown-description {
  font-size: 1rem;
  line-height: 1.9;
  color: #404b5a;
  margin: 0
}

@media(max-width:1024px) {
  section.breakdown-section .breakdown-grid {
    gap: 24px
  }

  section.breakdown-section .breakdown-image {
    height: 220px
  }

  section.breakdown-section .breakdown-title {
    font-size: 1.6rem
  }
}

@media(max-width:768px) {
  section.breakdown-section {
    padding: 24px 0
  }

  section.breakdown-section .breakdown-grid {
    grid-template-columns: 1fr;
    gap: 20px
  }

  section.breakdown-section .breakdown-image {
    height: 200px
  }

  section.breakdown-section .breakdown-content {
    padding: 22px 18px
  }

  section.breakdown-section .breakdown-title {
    font-size: 1.4rem
  }

  section.breakdown-section .breakdown-description {
    font-size: .95rem;
    line-height: 1.8
  }
}

@media(max-width:480px) {
  section.breakdown-section>.container {
    padding: 0 16px
  }

  section.breakdown-section .breakdown-image {
    height: 190px
  }
}

/* =====================================================
   1) service-flow コンポーネント用の共通カラー変数
   （Home・タイヤページなどのデフォルト配色）
   ===================================================== */
.service-flow {
  /* デフォルト：あなたが「正解」とした配色と同じトーン */
  --sf-brand: #10b3aa;

  /* brand から派生させるための追加変数（デフォルト値） */
  --sf-brand-soft: rgba(16, 179, 170, .10);
  --sf-brand-soft-strong: rgba(16, 179, 170, .24);
  --sf-brand-ring: rgba(16, 179, 170, .28);

  /* バッジ内テキスト＆キャプションの色 */
  --sf-badge-text: #0d3c3a;
  --sf-caption-text: #506070;
}
@media(max-width:1024px) {
  .service-flow {
  /* デフォルト：あなたが「正解」とした配色と同じトーン */
  --sf-brand: #10b3aa;

  /* brand から派生させるための追加変数（デフォルト値） */
  --sf-brand-soft: rgba(16, 179, 170, .10);
  --sf-brand-soft-strong: rgba(16, 179, 170, .24);
  --sf-brand-ring: rgba(16, 179, 170, .28);

  /* バッジ内テキスト＆キャプションの色 */
  --sf-badge-text: #0d3c3a;
  --sf-caption-text: #506070;
  margin-bottom: 0%;
}
}
@media (min-width:768px) and  (max-width:1024px) {
    .service-flow {
      margin-bottom: 0%;
}}
/* =====================================================
   2) 既存パーツを CSS 変数に紐づける「配線」部分
   （既存CSSとセレクタが被っても、こちらが後勝ちでOK）
   ===================================================== */

/* 縦のラインを brand 系変数に置き換え */
.service-flow .sf-step::before {
content: "";
  position: absolute;
  left: 29px;
  top: 68px;
  bottom: 10px;
  width: 2px;
  background: linear-gradient(180deg, #10b3aa, rgba(16,179,170,.10));
}

.service-flow .sf-step:last-child::before {
  display: none;
}

/* ステップ番号バッジ */
.service-flow .sf-badge {
    width: 36px;
    height: 36px;
    display: grid;
    color: #0d3c3a;
    font-weight: 900;
    box-shadow: inset 0 0 0 2px var(--sf-brand-ring);
    border-radius: 999px;
    place-items: center;
    background: radial-gradient(100% 100% at 50% 0%, rgba(16,179,170,.24), rgba(16,179,170,.10));
}

/* キャプションなどの説明テキスト */
.service-flow .sf-caption-title {
  color: var(--sf-caption-text);
}

/* =====================================================
   3) メーカー別 modifier クラス
   （メーカー専用ページの <section> にだけ付ける）
   例）<section class="service-flow service-flow--bmw">
   ===================================================== */

/* BMW */
.service-flow--bmw {
  --sf-brand: #0052A5;
  /* M ポルティマオ・ブルー */
  --sf-brand-soft-strong: rgba(0, 82, 165, .24);
  --sf-brand-soft: rgba(0, 82, 165, .10);
  --sf-brand-ring: rgba(0, 82, 165, .28);
}

/* MINI */
.service-flow--mini {
  --sf-brand: #C8102E;
  /* チリ・レッド II */
  --sf-brand-soft-strong: rgba(200, 16, 46, .24);
  --sf-brand-soft: rgba(200, 16, 46, .10);
  --sf-brand-ring: rgba(200, 16, 46, .28);
}

/* Audi */
.service-flow--audi {
  --sf-brand: #5A5A5A;
  /* デイトナグレー パールエフェクト */
  --sf-brand-soft-strong: rgba(90, 90, 90, .24);
  --sf-brand-soft: rgba(90, 90, 90, .10);
  --sf-brand-ring: rgba(90, 90, 90, .28);
}

/* Volkswagen */
.service-flow--vw {
  --sf-brand: #1A224C;
  /* ラピスブルー メタリック */
  --sf-brand-soft-strong: rgba(26, 34, 76, .24);
  --sf-brand-soft: rgba(26, 34, 76, .10);
  --sf-brand-ring: rgba(26, 34, 76, .28);
}

/* Mercedes-Benz */
.service-flow--mercedes {
  --sf-brand: #1E1E1E;
  /* MANUFAKTUR ナイトブラックマグノ */
  --sf-brand-soft-strong: rgba(30, 30, 30, .24);
  --sf-brand-soft: rgba(30, 30, 30, .10);
  --sf-brand-ring: rgba(30, 30, 30, .28);
}

/* Porsche */
.service-flow--porsche {
  /* Porsche は明るいホワイト系なので、テキストは濃いめに */
  --sf-brand: #F5F5F5;
  /* ホワイト */
  --sf-brand-soft-strong: rgba(245, 245, 245, .24);
  --sf-brand-soft: rgba(245, 245, 245, .10);
  --sf-brand-ring: rgba(0, 0, 0, .08);
  --sf-badge-text: #111111;
}

/* Volvo */
.service-flow--volvo {
  --sf-brand: #191C1F;
  /* オニキスブラック メタリック */
  --sf-brand-soft-strong: rgba(25, 28, 31, .24);
  --sf-brand-soft: rgba(25, 28, 31, .10);
  --sf-brand-ring: rgba(25, 28, 31, .28);
}

/* Land Rover */
.service-flow--landrover {
  --sf-brand: #A6A9AD;
  /* フラックスシルバー */
  --sf-brand-soft-strong: rgba(166, 169, 173, .24);
  --sf-brand-soft: rgba(166, 169, 173, .10);
  --sf-brand-ring: rgba(166, 169, 173, .28);
}

/* Jaguar */
.service-flow--jaguar {
  --sf-brand: #004225;
  /* ブリティッシュレーシンググリーン */
  --sf-brand-soft-strong: rgba(0, 66, 37, .24);
  --sf-brand-soft: rgba(0, 66, 37, .10);
  --sf-brand-ring: rgba(0, 66, 37, .28);
}

@media (max-width: 600px) {
  .margin-block {
    width: 22%;
  }
}

@media (min-width: 1025px) {
  .elementor-1229 .elementor-element.elementor-element-7f4e8ed .top-read-01 {
    text-align: center;
    font-size: 2.6em !important;
    font-weight: 700;
    color: #383838;
  }
}

.elementor-1229 .elementor-element.elementor-element-7f4e8ed {
  text-align: center;
  font-size: 1.6em;
  font-weight: 700;
  color: #383838;
}
@media (max-width: 600px) {
.article-body p {

}
}
