.service-page { background: #fff; }
.service-hero { padding: 54px 0 42px; border-bottom: 1px solid var(--line); background: #f4f4f3; }
.service-hero-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr); gap: 48px; align-items: center; }
.service-breadcrumbs { margin-bottom: 22px; color: var(--muted); font-size: 12px; }
.service-hero h1 { margin: 0; font-size: clamp(34px, 4.2vw, 54px); line-height: 1.28; letter-spacing: -.045em; }
.service-hero h1 span { display: block; margin-bottom: 9px; color: var(--brand-dark); font-size: 14px; letter-spacing: .08em; }
.service-lead { margin: 22px 0 0; color: #55565a; font-size: 16px; line-height: 1.9; }
.service-points { display: flex; flex-wrap: wrap; gap: 8px; margin: 24px 0 0; padding: 0; list-style: none; }
.service-points li { padding: 8px 12px; border: 1px solid #d9d7d4; border-radius: 99px; background: #fff; font-size: 12px; font-weight: 800; }
.service-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.service-hero-actions .button { min-width: 220px; min-height: 50px; }
.service-visual { overflow: hidden; border: 1px solid #d9d7d4; border-radius: 10px; background: #fff; }
.service-visual img { display: block; width: 100%; height: auto; }
.service-visual-note { padding: 14px 18px; color: #5f6063; font-size: 12px; line-height: 1.7; }
.service-body { padding-block: 54px 100px; }
.service-layout { display: block; }              /* 右カラム廃止＝本文を全幅に */
.service-main { min-width: 0; max-width: 900px; margin-inline: auto; }
.service-sidebar { display: none; }              /* 右カラムは表示しない（ナビはヘッダー＋フッターサイトマップ） */
.service-sidebar nav { background: transparent; }
.service-sidebar-group {
  padding: 22px;
  border: 1px solid var(--line);
  background: #fff;
}
.service-sidebar-group + .service-sidebar-group { margin-top: 16px; }
.service-sidebar strong { display: block; margin-bottom: 10px; color: var(--ink); font-size: 14px; }
.service-sidebar h3 {
  margin: 18px 0 6px;
  color: var(--brand-dark);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
}
.service-sidebar h3:first-of-type { margin-top: 12px; }
.service-sidebar a {
  display: block;
  padding: 11px 0;
  border-bottom: 1px solid var(--line);
  color: #55565a;
  font-size: 12px;
  line-height: 1.55;
}
.service-sidebar a:last-child { border: 0; }
.service-sidebar-related a {
  position: relative;
  padding-left: 14px;
}
.service-sidebar-related a::before {
  content: "›";
  position: absolute;
  left: 0;
  color: var(--brand);
  font-weight: 900;
}
.service-answer { padding: 25px 28px; border-left: 5px solid var(--brand); background: #f7f7f6; }
.service-answer strong { display: block; margin-bottom: 8px; color: var(--brand-dark); font-size: 20px; }
.service-answer p { margin: 0; line-height: 1.9; }
.service-jump { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; padding: 18px; border: 1px solid var(--line); background: #fff; }
.service-jump strong { width: 100%; margin-bottom: 4px; font-size: 13px; }
.service-jump a { padding: 8px 11px; border-radius: 99px; color: var(--brand-dark); background: #f3eeee; font-size: 11px; font-weight: 800; }
.service-section { margin-top: 62px; }
.service-section > h2 { margin: 0 0 24px; padding: 0 0 14px; border-bottom: 2px solid #d8d7d4; font-size: 25px; line-height: 1.5; }
.service-section > h2::before { content: none; }
.service-section > p { line-height: 2; }
.price-summary { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.price-box { padding: 24px; border: 1px solid #d9d7d4; background: #fff; }
.price-box small, .price-box strong, .price-box span { display: block; }
.price-box small { color: var(--muted); font-weight: 800; }
.price-box strong { margin-top: 8px; color: var(--brand-dark); font-size: 30px; }
.price-box span { margin-top: 8px; color: var(--muted); font-size: 12px; line-height: 1.7; }
.promise-list { display: grid; gap: 0; margin: 20px 0 0; padding: 0; list-style: none; border-top: 1px solid var(--line); }
.promise-list li { position: relative; padding: 16px 10px 16px 38px; border-bottom: 1px solid var(--line); line-height: 1.8; }
.promise-list li::before { content: "✓"; position: absolute; left: 11px; color: var(--brand); font-weight: 900; }
.symptom-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.symptom-cards article { padding: 20px; border: 1px solid var(--line); background: #fafafa; }
.symptom-cards h3 { margin: 0 0 8px; font-size: 17px; }
.symptom-cards p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.8; }
.process-list { counter-reset: step; display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin: 0; padding: 0; list-style: none; }
.process-list li { counter-increment: step; padding: 18px 14px; border: 1px solid var(--line); background: #fff; font-size: 12px; line-height: 1.7; }
.process-list li::before { content: "0" counter(step); display: block; margin-bottom: 9px; color: var(--brand); font-weight: 900; }
.equipment-figure { margin: 26px 0 0; }
.equipment-figure img { display: block; width: 100%; height: auto; border-radius: 8px; }
.equipment-figure figcaption { margin-top: 8px; color: var(--muted); font-size: 12px; text-align: center; }
.quality-photo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 24px 0; }
.quality-photo-grid figure { margin: 0; overflow: hidden; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.quality-photo-grid img { display: block; width: 100%; height: auto; aspect-ratio: 3 / 2; object-fit: cover; }
.quality-photo-grid figcaption { padding: 10px 12px; color: var(--muted); font-size: 11px; line-height: 1.7; }
.model-switch { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 24px; }
.model-switch a { padding: 14px 8px; border: 1px solid #d9d7d4; border-radius: 6px; background: #fff; font-size: 13px; font-weight: 900; text-align: center; }
.model-switch a.active { border-color: var(--brand); color: #fff; background: var(--brand); }
.price-table-wrap { overflow-x: auto; border: 1px solid var(--line); }
.price-table { width: 100%; min-width: 680px; border-collapse: collapse; }
.price-table th, .price-table td { padding: 16px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: middle; }
.price-table th { color: #fff; background: #626367; font-size: 12px; }
.price-table td { font-size: 14px; }
.price-table td strong { color: var(--brand-dark); font-size: 19px; }
.price-table tr:last-child td { border-bottom: 0; }
.repair-card-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.repair-card { display: grid; grid-template-columns: 128px 1fr; overflow: hidden; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.repair-card img { width: 128px; height: 100%; min-height: 150px; padding: 12px; object-fit: contain; background: #f7f6f4; border-right: 1px solid var(--line); }
.repair-card div { padding: 18px; }
.repair-card h3 { margin: 0; font-size: 17px; }
.repair-card p { margin: 9px 0; color: var(--muted); font-size: 12px; line-height: 1.7; }
.repair-card strong { color: var(--brand-dark); }
.notice-box { margin-top: 22px; padding: 20px 24px; border: 1px solid #dfd7c5; border-left: 4px solid #b6853c; background: #fffaf0; line-height: 1.9; }
.service-inline-links { display: flex; flex-wrap: wrap; gap: 8px 22px; margin-top: 18px; }
.service-inline-links a { color: var(--brand-dark); font-size: 12px; font-weight: 800; text-decoration: underline; text-underline-offset: 4px; }
.accordion-section { scroll-margin-top: 18px; }
.content-accordion { border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.content-accordion summary { position: relative; display: flex; min-height: 74px; padding: 18px 58px 18px 24px; align-items: center; justify-content: space-between; gap: 18px; cursor: pointer; list-style: none; background: #f7f6f4; }
.content-accordion summary::-webkit-details-marker { display: none; }
.content-accordion summary::after { content: "+"; position: absolute; right: 24px; top: 50%; translate: 0 -50%; color: var(--brand); font-size: 25px; font-weight: 700; }
.content-accordion[open] summary::after { content: "−"; }
.content-accordion summary h2 { margin: 0; font-size: 23px; line-height: 1.5; }
.content-accordion summary h2::before { content: none; }
.content-accordion summary span { flex: 0 0 auto; color: var(--brand-dark); font-size: 14px; font-weight: 800; }
.accordion-body { padding: 26px; border-top: 1px solid var(--line); }
.accordion-body > p { margin: 0 0 18px; line-height: 2; }
.accordion-body > p:last-child { margin-bottom: 0; }
.policy-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.policy-grid article { padding: 19px; border: 1px solid var(--line); background: #fafafa; }
.policy-grid h3 { margin: 0 0 8px; font-size: 16px; }
.policy-grid p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.8; }
.comparison-table-wrap { overflow-x: auto; border: 1px solid var(--line); }
.comparison-table { width: 100%; min-width: 650px; border-collapse: collapse; }
.comparison-table th, .comparison-table td { padding: 14px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); font-size: 12px; line-height: 1.7; text-align: left; vertical-align: top; }
.comparison-table thead th { color: #fff; background: #656669; }
.comparison-table tbody th { white-space: nowrap; background: #f7f6f4; }
.comparison-table tr:last-child th, .comparison-table tr:last-child td { border-bottom: 0; }
.comparison-table th:last-child, .comparison-table td:last-child { border-right: 0; }
.comparison-table strong { color: var(--brand-dark); }
.sub-note { margin-top: 16px !important; padding: 15px 18px; border-left: 4px solid var(--brand); background: #f7f6f4; font-size: 12px; }
.evidence-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 22px; }
.evidence-list div { padding: 18px; border-top: 3px solid var(--brand); background: #f7f6f4; }
.evidence-list strong, .evidence-list span { display: block; }
.evidence-list strong { font-size: 14px; }
.evidence-list span { margin-top: 8px; color: var(--muted); font-size: 11px; line-height: 1.8; }
.equipment-spec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 22px 0; }
.equipment-spec-grid article { padding: 18px; border: 1px solid var(--line); background: #fff; }
.equipment-spec-grid strong, .equipment-spec-grid span { display: block; }
.equipment-spec-grid strong { color: var(--brand-dark); font-size: 17px; }
.equipment-spec-grid span { margin-top: 7px; color: var(--muted); font-size: 11px; line-height: 1.8; }
.case-sample-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.case-sample-grid article { padding: 19px; border: 1px solid var(--line); }
.case-sample-grid small { color: var(--brand-dark); font-weight: 800; }
.case-sample-grid h3 { margin: 8px 0; font-size: 16px; line-height: 1.55; }
.case-sample-grid p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.8; }
.expert-profile-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 26px; }
.expert-profile-grid strong { font-size: 17px; }
.expert-profile-grid p { margin: 8px 0 0; color: var(--muted); font-size: 12px; line-height: 1.9; }
.expert-profile dl { margin: 0; }
.expert-profile dl div { display: grid; grid-template-columns: 86px 1fr; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 11px; }
.expert-profile dt { color: var(--muted); }
.expert-profile dd { margin: 0; font-weight: 700; }
.related-resources { padding: 26px; border: 1px solid var(--line); background: #fafafa; }
.related-resources > h2 { margin: 0 0 18px; font-size: 22px; }
.related-accordion-list { display: grid; gap: 8px; }
.related-accordion { border: 1px solid var(--line); background: #fff; }
.related-accordion summary { position: relative; padding: 17px 52px 17px 18px; cursor: pointer; list-style: none; }
.related-accordion summary::-webkit-details-marker { display: none; }
.related-accordion summary::after { content: "+"; position: absolute; right: 19px; top: 50%; translate: 0 -50%; color: var(--brand); font-size: 22px; font-weight: 800; }
.related-accordion[open] summary::after { content: "−"; }
.related-accordion h3 { margin: 0; font-size: 16px; }
.related-accordion > div { padding: 0 18px 14px; border-top: 1px solid var(--line); }
.related-accordion a { display: block; padding: 10px 0; border-bottom: 1px solid var(--line); color: var(--brand-dark); font-size: 12px; font-weight: 700; line-height: 1.6; }
.related-accordion a:last-child { border-bottom: 0; }
.service-faq details { border-bottom: 1px solid var(--line); }
.service-faq summary { padding: 18px 44px 18px 4px; cursor: pointer; font-weight: 800; }
.service-faq p { margin: 0; padding: 0 4px 20px; color: #5d5e61; line-height: 1.9; }
.service-cta { display: grid; grid-template-columns: 1fr auto; gap: 28px; align-items: center; margin-top: 60px; padding: 30px; border: 1px solid #d8d6d3; border-left: 5px solid var(--brand); background: #f7f7f6; }
.service-cta h2 { margin: 0; font-size: 23px; }
.service-cta p { margin: 9px 0 0; color: var(--muted); }
.service-cta div:last-child { display: flex; gap: 9px; }

/* Full source-content restoration for major landing pages */
.legacy-restored-content {
  --legacy-space-sm: 12px;
  --legacy-space-md: 24px;
  --legacy-space-lg: 40px;
  margin-top: 32px;
  color: var(--ink);
}
.legacy-restored-content > * { max-width: 100%; }
.legacy-restored-content h2 {
  margin: var(--legacy-space-lg) 0 var(--legacy-space-md);
  padding: 0 0 14px;
  border-bottom: 2px solid #d8d7d4;
  font-size: 24px;
  line-height: 1.5;
}
.legacy-restored-content h2::before {
  content: none;
}
.legacy-restored-content h3 {
  margin: var(--legacy-space-md) 0 var(--legacy-space-sm);
  padding: 14px 18px;
  border-left: 4px solid var(--brand);
  background: #f7f6f4;
  font-size: 18px;
  line-height: 1.55;
}
.legacy-restored-content h4 { margin: var(--legacy-space-md) 0 10px; font-size: 18px; line-height: 1.65; }
.legacy-restored-content p,
.legacy-restored-content li,
.legacy-restored-content td,
.legacy-restored-content th { font-size: 15px; line-height: 1.95; }
.legacy-restored-content p { margin: 0 0 var(--legacy-space-md); }
.legacy-restored-content ul,
.legacy-restored-content ol { margin: var(--legacy-space-sm) 0 var(--legacy-space-md); padding-left: 1.5em; }
.legacy-restored-content a { color: var(--brand-dark); font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }
.legacy-restored-content img { display: block; max-width: 100%; height: auto; margin: 20px auto; border-radius: 7px; }
.legacy-restored-content .legacy-table-scroll { overflow-x: auto; margin: 18px 0 28px; border: 1px solid var(--line); }
.legacy-restored-content table { width: 100%; min-width: 640px; border-collapse: collapse; background: #fff; }
.legacy-restored-content th,
.legacy-restored-content td { padding: 13px 14px; border: 1px solid var(--line); text-align: left; vertical-align: top; }
.legacy-restored-content th { background: #f3f2f0; color: #333 !important; font-weight: bold; }
.legacy-restored-content .review_list,
.legacy-restored-content .review_sheet,
.legacy-restored-content .review_wrap { display: grid; gap: 12px; }
.legacy-restored-content .item {
  padding: var(--legacy-space-md);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.legacy-restored-content .item .label { color: var(--brand-dark); font-size: 12px; font-weight: 800; }
.legacy-restored-content .item h4 { margin-top: 10px; }
.legacy-restored-content .item ul { margin-bottom: 0; }
.legacy-restored-content .review_btn,
.legacy-restored-content label[for="review_toggle"] { display: none; }
.legacy-restored-content .promise_sheet { display: grid; gap: 14px; }
.legacy-restored-content .promise_sheet > section {
  padding: 22px;
  border: 1px solid var(--line);
  background: #fafafa;
}
.legacy-restored-content .promise_sheet h4 { margin-top: 0; }
.legacy-restored-content .bnr_mic img { width: auto; max-height: 90px; }
.legacy-restored-content [id] { scroll-margin-top: 18px; }
.legacy-section-accordion {
  margin: var(--legacy-space-md) 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.legacy-section-accordion > summary {
  position: relative;
  padding: 18px 58px 18px 22px;
  cursor: pointer;
  list-style: none;
  background: #f7f6f4;
}
.legacy-section-accordion > summary::-webkit-details-marker { display: none; }
.legacy-section-accordion > summary::after {
  content: "+";
  position: absolute;
  right: 22px;
  top: 50%;
  translate: 0 -50%;
  color: var(--brand);
  font-size: 24px;
  font-weight: 800;
}
.legacy-section-accordion[open] > summary::after { content: "−"; }
.legacy-section-accordion > summary h2,
.legacy-section-accordion > summary h3 {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 24px;
  line-height: 1.5;
}
.legacy-section-accordion > summary h2::before,
.legacy-section-accordion > summary h3::before {
  content: none;
}
.legacy-section-body { padding: var(--legacy-space-md); border-top: 1px solid var(--line); }
.legacy-section-body > :first-child { margin-top: 0; }
.legacy-section-body > :last-child { margin-bottom: 0; }
.legacy-restored-content .menu_list,
.legacy-restored-content .menu_thumbbtn { margin: 0; padding: 0; }
.legacy-restored-content .menu_list > ul,
.legacy-restored-content .menu_thumbbtn > ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin: 0;
  padding: 0;
}
.legacy-restored-content .menu_list li,
.legacy-restored-content .menu_thumbbtn li {
  min-width: 0;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  list-style: none;
  background: #fff;
  overflow: hidden;
}
.legacy-restored-content .menu_list img,
.legacy-restored-content .menu_thumbbtn img {
  grid-row: 1 / 3;
  width: 94px;
  height: auto;
  aspect-ratio: 1;
  margin: 0;
  padding: 9px;
  object-fit: contain;
  background: #f7f6f4;
  border-right: 1px solid var(--line);
}
.legacy-restored-content .menu_list a,
.legacy-restored-content .menu_thumbbtn a {
  display: grid;
  grid-template-columns: 94px 1fr;
  grid-template-rows: 1fr auto;
  column-gap: 12px;
  align-items: center;
  height: 100%;
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.55;
  text-decoration: none;
}
.legacy-restored-content .menu_list a:not(:has(img)),
.legacy-restored-content .menu_thumbbtn a:not(:has(img)) { padding: 14px; }
.legacy-restored-content .menu_list a:has(img),
.legacy-restored-content .menu_thumbbtn a:has(img) { padding: 0 12px 0 0; text-align: left; }
.legacy-restored-content .menu_list a:has(img)::after,
.legacy-restored-content .menu_thumbbtn a:has(img)::after { content: "詳しく見る →"; display: block; align-self: start; padding-bottom: 10px; color: var(--brand-dark); font-size: 10px; }
.legacy-restored-content .legacy-inline-cta {
  margin: var(--legacy-space-md) 0;
  padding: 18px 22px;
  border: 1px solid #ddd6d2;
  border-left: 4px solid var(--brand);
  border-radius: 7px;
  background: #faf8f7;
  text-align: center !important;
}
.legacy-restored-content .legacy-inline-cta p { margin-bottom: 10px; }
.legacy-restored-content .legacy-inline-cta p:last-child { margin-bottom: 0; }
.legacy-restored-content .legacy-inline-cta div {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
.legacy-restored-content .legacy-inline-cta a {
  display: inline-flex !important;
  width: min(100%, 310px) !important;
  min-height: 52px;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 9px 18px !important;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  border: 1px solid var(--brand) !important;
  border-radius: 5px !important;
  color: #fff !important;
  background: var(--brand) !important;
  box-shadow: none !important;
  font-size: 14px !important;
  font-weight: 800;
  line-height: 1.5;
  text-decoration: none;
}
.legacy-restored-content .legacy-inline-cta a[href*="recovery_offer"] {
  color: var(--brand-dark) !important;
  background: #fff !important;
}
.legacy-restored-content .legacy-inline-cta a > span,
.legacy-restored-content .legacy-inline-cta a > strong { display: block; }
.legacy-restored-content .legacy-inline-cta a > span {
  margin: 0 0 2px;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
}
.legacy-restored-content .legacy-inline-cta a > strong {
  font-size: 15px;
  line-height: 1.25;
  white-space: nowrap;
}
.legacy-conclusion-first {
  margin: 0 0 22px;
  padding: 28px 30px;
  border: 1px solid #d9d0ca;
  border-top: 4px solid var(--brand);
  border-radius: 10px;
  background: linear-gradient(180deg, #fff 0%, #faf6f4 100%);
  box-shadow: 0 10px 28px rgba(69, 57, 54, .07);
}
.legacy-conclusion-first p { margin: 0 0 14px; font-size: 16px; line-height: 1.9; }
.legacy-conclusion-first p:first-child { color: var(--brand-dark); font-size: 21px; font-weight: 800; line-height: 1.65; }
.legacy-conclusion-first p:last-child { margin-bottom: 0; }
.legacy-conclusion-first a { color: var(--brand-dark); font-weight: 800; text-decoration: underline; text-underline-offset: 3px; }
.legacy-conclusion-first > div { margin-top: 14px; padding: 14px 16px; border: 1px solid #dfd7c5; border-radius: 6px; background: #fffaf0; }
.legacy-emergency-summary {
  margin: 28px 0;
  padding: 24px 26px;
  border: 1px solid #d9d0ca;
  border-left: 5px solid var(--brand);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(69, 57, 54, .05);
}
.legacy-emergency-summary > p:first-child {
  margin-bottom: 16px;
  color: var(--ink);
  font-size: 20px;
  font-weight: 900;
  line-height: 1.65;
}
.legacy-emergency-summary > p:first-child span {
  color: var(--brand-dark);
}
.legacy-emergency-summary > ul {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 9px;
  margin: 0 0 18px;
  padding: 0;
}
.legacy-emergency-summary > ul li {
  margin: 0;
  padding: 10px 11px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #f7f6f4;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 900;
  text-align: center;
}
.legacy-emergency-summary > div {
  margin: 14px 0;
  padding: 14px 16px;
  border: 1px solid #dfd7c5;
  border-radius: 8px;
  background: #fffaf0;
  line-height: 1.85;
}
.legacy-emergency-summary > a {
  display: inline-flex;
  min-height: 48px;
  margin: 4px 8px 0 0;
  padding: 10px 18px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--brand);
  border-radius: 6px;
  color: #fff;
  background: var(--brand);
  font-weight: 900;
  text-decoration: none;
}
.legacy-emergency-summary > a[href*="recovery_offer"] {
  color: var(--brand-dark);
  background: #fff;
}
.legacy-pricing-section {
  margin: 34px 0;
  padding: 28px;
  border: 1px solid var(--line);
  border-top: 4px solid var(--brand);
  border-radius: 10px;
  background: linear-gradient(180deg, #fff 0%, #faf8f7 100%);
}
.legacy-pricing-section > h2 {
  margin-top: 0;
  padding-bottom: 16px;
}
.legacy-pricing-section > p:nth-of-type(1) {
  margin-bottom: 16px;
  padding: 18px 20px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--brand);
  border-radius: 8px;
  background: #fff;
}
.legacy-pricing-section > p:nth-of-type(2) {
  margin-bottom: 20px;
  padding: 16px 18px;
  border-radius: 8px;
  background: #f7f6f4;
}
.legacy-pricing-section > div {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 18px 0 18px;
}
.legacy-pricing-section > div > div {
  padding: 20px;
  border: 1px solid #d9d0ca;
  border-radius: 9px;
  background: #fff;
}
.legacy-pricing-section > div > div > div:first-child {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.legacy-pricing-section > div > div > div:nth-child(2) {
  margin-top: 7px;
  color: var(--brand-dark);
  font-size: 26px;
  font-weight: 900;
  line-height: 1.3;
}
.legacy-pricing-section > div > div > div:nth-child(3) {
  margin-top: 8px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.7;
}
.legacy-pricing-section > ul {
  display: grid;
  gap: 10px;
  margin: 18px 0;
  padding: 0;
}
.legacy-pricing-section > ul > li {
  position: relative;
  margin: 0;
  padding: 15px 16px 15px 44px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  list-style: none;
}
.legacy-pricing-section > ul > li::before {
  content: "✓";
  position: absolute;
  left: 16px;
  top: 16px;
  color: var(--brand);
  font-weight: 900;
}
.legacy-pricing-section > p:last-child {
  margin-bottom: 0;
  color: #5f6063;
  font-size: 14px;
}
.legacy-section-body p,
.legacy-section-body li,
.legacy-section-body td,
.legacy-section-body th,
.legacy-section-body dt,
.legacy-section-body dd { font-size: 16px; line-height: 1.9; }
.legacy-section-body .item p,
.legacy-section-body .item li { font-size: 15px; }
.legacy-open-section {
  margin: var(--legacy-space-md) 0;
  padding: 28px;
  border: 1px solid var(--line);
  border-top: 4px solid var(--brand);
  border-radius: 10px;
  background: #fff;
}
.legacy-open-section > h2:first-child,
.legacy-open-section > section > h2:first-child {
  margin-top: 0;
}
.legacy-link-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
}
.legacy-link-list li {
  margin: 0;
  padding: 0;
  list-style: none;
}
.legacy-link-list a {
  display: block;
  padding: 13px 16px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--brand);
  border-radius: 7px;
  color: var(--brand-dark);
  background: #fff;
  font-size: 15px;
  line-height: 1.65;
  text-decoration: none;
}
.legacy-link-list a::after {
  content: " →";
  font-weight: 900;
}
.legacy-faq-list {
  display: grid;
  gap: 12px;
  margin: 0;
}
.legacy-faq-list dt {
  margin: 0;
  padding: 15px 18px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--brand);
  border-radius: 8px 8px 0 0;
  color: var(--ink);
  background: #f7f6f4;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.65;
}
.legacy-faq-list dt::before {
  content: "Q";
  display: inline-flex;
  width: 24px;
  height: 24px;
  margin-right: 9px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #fff;
  background: var(--brand);
  font-size: 13px;
  font-weight: 900;
  vertical-align: 1px;
}
.legacy-faq-list dd {
  margin: -12px 0 12px;
  padding: 17px 18px 18px 51px;
  border: 1px solid var(--line);
  border-top: 0;
  border-radius: 0 0 8px 8px;
  background: #fff;
}
.legacy-faq-list dd::before {
  content: "A.";
  margin-left: -31px;
  margin-right: 8px;
  color: var(--brand-dark);
  font-weight: 900;
}
.legacy-glossary-list {
  display: grid;
  gap: 0;
  margin: 0;
}
.legacy-glossary-list dt {
  display: flex;
  gap: 10px;
  align-items: center;
  margin: 0;
  padding: 16px 18px 8px;
  border: 1px solid var(--line);
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  color: var(--brand-dark);
  background: #fff;
  font-size: 17px;
  font-weight: 900;
  line-height: 1.5;
}
.legacy-glossary-list dt::before {
  content: "TERM";
  display: inline-flex;
  min-width: 43px;
  height: 22px;
  align-items: center;
  justify-content: center;
  border-radius: 99px;
  color: #fff;
  background: var(--brand);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .06em;
}
.legacy-glossary-list dd {
  margin: 0 0 14px;
  padding: 0 18px 17px 71px;
  border: 1px solid var(--line);
  border-top: 0;
  border-radius: 0 0 8px 8px;
  background: #fff;
}
.legacy-glossary-list dd strong {
  color: var(--ink);
  background: linear-gradient(transparent 62%, rgba(163, 79, 77, .16) 0);
}

@media (max-width: 820px) {
  .service-hero { padding-top: 32px; }
  .service-hero-grid, .service-layout { grid-template-columns: 1fr; }
  .service-hero-grid { gap: 30px; }
  .service-sidebar { display: none; } /* 右カラムはバーガーに格納（global-ui.jsがメニューへ統合） */
  .process-list { grid-template-columns: 1fr 1fr; }
  .repair-card-grid { grid-template-columns: 1fr; }
  .service-cta { grid-template-columns: 1fr; }
  .service-cta div:last-child { display: grid; }
  .evidence-list, .case-sample-grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .service-hero h1 { font-size: 32px; }
  .service-hero-actions { display: grid; grid-template-columns: 1fr; }
  .service-hero-actions .button { width: 100%; min-width: 0; min-height: 52px; }
  .price-summary, .symptom-cards { grid-template-columns: 1fr; }
  .model-switch { grid-template-columns: 1fr 1fr; }
  .process-list { grid-template-columns: 1fr; }
  .repair-card { grid-template-columns: 100px 1fr; }
  .repair-card img { width: 100px; padding: 8px; }
  .service-jump { padding: 14px; }
  .content-accordion summary { min-height: 68px; padding: 15px 48px 15px 16px; }
  .content-accordion summary::after { right: 17px; }
  .content-accordion summary h2 { font-size: 20px; }
  .content-accordion summary span { display: none; }
  .accordion-body { padding: 18px 16px; }
  .policy-grid, .expert-profile-grid, .equipment-spec-grid { grid-template-columns: 1fr; }
  .quality-photo-grid { grid-template-columns: 1fr; }
  .legacy-restored-content h2 { margin-top: 44px; font-size: 22px; }
  .legacy-restored-content h3 { margin-top: 24px; padding: 12px 14px; font-size: 18px; }
  .legacy-restored-content h4 { font-size: 18px; }
  .legacy-restored-content p,
  .legacy-restored-content li,
  .legacy-restored-content td,
  .legacy-restored-content th { font-size: 15px; line-height: 1.9; }
  .legacy-restored-content .item,
  .legacy-restored-content .promise_sheet > section { padding: 17px; }
  .legacy-section-accordion > summary { padding: 15px 48px 15px 16px; }
  .legacy-section-accordion > summary::after { right: 16px; }
  .legacy-section-accordion > summary h2 { font-size: 20px; }
  .legacy-section-body { padding: 16px; }
  .legacy-restored-content .menu_list > ul,
  .legacy-restored-content .menu_thumbbtn > ul { grid-template-columns: 1fr; gap: 8px; }
  .legacy-restored-content .menu_list img,
  .legacy-restored-content .menu_thumbbtn img { width: 86px; padding: 8px; }
  .legacy-restored-content .menu_list a,
  .legacy-restored-content .menu_thumbbtn a { grid-template-columns: 86px 1fr; font-size: 13px; }
  .legacy-restored-content .legacy-inline-cta { padding: 15px 16px; }
  .legacy-restored-content .legacy-inline-cta div { display: grid; grid-template-columns: 1fr; }
  .legacy-restored-content .legacy-inline-cta a { display: flex !important; width: 100% !important; }
  .legacy-conclusion-first { padding: 20px 18px; }
  .legacy-conclusion-first p { font-size: 15px; }
  .legacy-conclusion-first p:first-child { font-size: 19px; }
  .legacy-emergency-summary { padding: 18px 16px; }
  .legacy-emergency-summary > p:first-child { font-size: 18px; }
  .legacy-emergency-summary > ul { grid-template-columns: 1fr 1fr; }
  .legacy-emergency-summary > a { display: flex; width: 100%; margin-right: 0; }
  .legacy-pricing-section { padding: 20px 16px; }
  .legacy-pricing-section > div { grid-template-columns: 1fr; }
  .legacy-pricing-section > div > div > div:nth-child(2) { font-size: 23px; }
  .legacy-section-body p,
  .legacy-section-body li,
  .legacy-section-body td,
  .legacy-section-body th,
  .legacy-section-body dt,
  .legacy-section-body dd { font-size: 15px; }
  .legacy-section-body .item p,
  .legacy-section-body .item li { font-size: 15px; }
  .legacy-open-section { padding: 20px 16px; }
  .legacy-link-list a { padding: 12px 13px; font-size: 14px; }
  .legacy-faq-list dt { padding: 14px 14px; font-size: 15px; }
  .legacy-faq-list dd { padding: 15px 14px 16px 43px; }
  .legacy-glossary-list dt { padding: 14px 14px 7px; font-size: 16px; }
  .legacy-glossary-list dd { padding: 0 14px 15px; }
}

/* === 心斎橋店舗ページ：スライダー以外のモダン表示 === */
body.sdp-shinsaibashi-modern {
  background: #f7f4f2;
  color: #302829;
}
body.sdp-shinsaibashi-modern .main-body,
body.sdp-shinsaibashi-modern .layout_shop.page_shop {
  background:
    linear-gradient(180deg, #fff 0, #f7f4f2 320px),
    #f7f4f2;
}
body.sdp-shinsaibashi-modern .main-body-in,
body.sdp-shinsaibashi-modern .layout_shop.page_shop .container {
  width: auto;
  max-width: 1180px;
  padding: 28px 24px 70px;
  margin: 0 auto;
}
body.sdp-shinsaibashi-modern main,
body.sdp-shinsaibashi-modern .main-conts,
body.sdp-shinsaibashi-modern .article-body {
  float: none;
  width: auto;
  max-width: none;
  padding: 0;
  margin: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}
body.sdp-shinsaibashi-modern #main_contents,
body.sdp-shinsaibashi-modern #shop_main {
  max-width: 1120px;
  margin: 0 auto;
  color: #302829;
}
body.sdp-shinsaibashi-modern .covid-19-taiou {
  display: block;
  margin: 0 auto 20px;
  overflow: hidden;
  border: 1px solid #e7dad6;
  border-radius: 8px;
  color: #302829;
  background: #fff;
  text-decoration: none;
  box-shadow: 0 12px 28px rgb(80 54 50 / 8%);
}
body.sdp-shinsaibashi-modern .covid-19-taiou .wrapper {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
}
body.sdp-shinsaibashi-modern .covid-19-taiou .read {
  flex: 0 0 auto;
  padding: 6px 10px;
  border-radius: 999px;
  color: #fff;
  background: #a34f4d;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}
body.sdp-shinsaibashi-modern .covid-19-taiou .cont {
  color: #302829;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.65;
}
body.sdp-shinsaibashi-modern .article-body .modi,
body.sdp-shinsaibashi-modern .article-body .modi-shop {
  display: flex;
  justify-content: flex-end;
  margin: 0 0 14px;
  color: #7c7472;
  font-size: 13px;
  font-weight: 700;
}
body.sdp-shinsaibashi-modern #main_contents > h1.heading_02 {
  position: relative;
  margin: 0 0 20px;
  padding: 34px 40px 36px;
  overflow: hidden;
  border: 1px solid #e2d5d0;
  border-radius: 8px;
  color: #fff;
  background:
    linear-gradient(135deg, rgb(48 40 41 / 94%), rgb(128 61 60 / 92%)),
    #302829;
  font-size: 30px;
  line-height: 1.72;
  font-weight: 900;
  letter-spacing: 0;
  box-shadow: 0 18px 42px rgb(48 38 41 / 14%);
}
body.sdp-shinsaibashi-modern #main_contents > h1.heading_02::after {
  content: "";
  position: absolute;
  right: 28px;
  bottom: 0;
  width: 140px;
  height: 4px;
  background: #a34f4d;
}
body.sdp-shinsaibashi-modern .shop_header {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
  gap: 22px;
  align-items: stretch;
  margin: 0 0 24px;
  padding: 30px;
  border: 1px solid #e2d5d0;
  border-radius: 8px;
  color: #fff;
  background:
    linear-gradient(135deg, rgb(48 40 41 / 96%), rgb(128 61 60 / 92%)),
    #302829;
  box-shadow: 0 18px 42px rgb(48 38 41 / 14%);
}
body.sdp-shinsaibashi-modern .shop_name {
  margin: 0;
  color: #fff;
  font-size: 30px;
  line-height: 1.55;
  font-weight: 900;
  letter-spacing: 0;
}
body.sdp-shinsaibashi-modern .shop_name span {
  display: block;
  margin-top: 12px;
  color: #f3ddda;
  font-size: 22px;
}
body.sdp-shinsaibashi-modern .shop_mic_number {
  display: inline-block;
  margin-top: 18px;
  padding: 12px 14px;
  border: 1px solid rgb(255 255 255 / 22%);
  border-radius: 8px;
  color: rgb(255 255 255 / 88%);
  background: rgb(255 255 255 / 8%);
  font-size: 13px;
  line-height: 1.8;
}
body.sdp-shinsaibashi-modern .shop_mic_number span {
  display: inline-block;
  margin-right: 8px;
  color: #fff;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .shop_meta_contact {
  align-self: stretch;
  padding: 22px;
  border: 1px solid #eadfdb;
  border-radius: 8px;
  color: #302829;
  background: #fff;
}
body.sdp-shinsaibashi-modern .shop_meta_contact p {
  margin: 0 0 8px;
  color: #803d3c;
  font-size: 14px;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .shop_meta_contact .telnum,
body.sdp-shinsaibashi-modern .tellink {
  color: #a34f4d;
  font-size: 30px;
  line-height: 1.2;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .shop_meta_contact ul {
  padding: 0;
  margin: 16px 0 0;
  list-style: none;
}
body.sdp-shinsaibashi-modern .shop_meta_contact li {
  padding: 10px 0;
  border-top: 1px solid #eee4df;
  color: #4b4242;
  font-size: 14px;
  line-height: 1.7;
}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-content-section,
body.sdp-shinsaibashi-modern #shop_main > section:not(#shop_hero) {
  position: relative;
  padding: 44px 0 6px;
  margin: 38px 0 0;
  border-top: 1px solid #e3d7d2;
}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-content-section::before,
body.sdp-shinsaibashi-modern #shop_main > section:not(#shop_hero)::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 92px;
  height: 3px;
  background: #a34f4d;
}
body.sdp-shinsaibashi-modern #main_contents h2.heading_02,
body.sdp-shinsaibashi-modern #main_contents h2.heading_03,
body.sdp-shinsaibashi-modern #shop_main h2.heading_02 {
  margin: 0 0 22px;
  padding: 0 0 0 18px;
  border: 0;
  border-left: 5px solid #a34f4d;
  color: #302829;
  background: transparent;
  font-size: 25px;
  line-height: 1.58;
  font-weight: 900;
  letter-spacing: 0;
}
body.sdp-shinsaibashi-modern #main_contents h2 span,
body.sdp-shinsaibashi-modern #shop_main h2 span {
  display: block;
  margin-bottom: 5px;
  color: #803d3c;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern #main_contents h3,
body.sdp-shinsaibashi-modern #shop_main h3 {
  margin: 30px 0 14px;
  color: #803d3c;
  font-size: 20px;
  line-height: 1.55;
  font-weight: 900;
  letter-spacing: 0;
}
body.sdp-shinsaibashi-modern #main_contents p,
body.sdp-shinsaibashi-modern #main_contents li,
body.sdp-shinsaibashi-modern #main_contents dd,
body.sdp-shinsaibashi-modern #shop_main p,
body.sdp-shinsaibashi-modern #shop_main li,
body.sdp-shinsaibashi-modern #shop_main dd {
  color: #413838;
  font-size: 16px;
  line-height: 1.95;
}
body.sdp-shinsaibashi-modern #main_contents .lead,
body.sdp-shinsaibashi-modern #main_contents .lead_left,
body.sdp-shinsaibashi-modern #shop_main .lead {
  color: #3b3232;
  font-size: 17px;
  line-height: 2;
}
body.sdp-shinsaibashi-modern #main_contents a,
body.sdp-shinsaibashi-modern #shop_main a {
  color: #803d3c;
  text-underline-offset: 3px;
}
body.sdp-shinsaibashi-modern #main_contents strong,
body.sdp-shinsaibashi-modern #shop_main strong,
body.sdp-shinsaibashi-modern #main_contents em.marker,
body.sdp-shinsaibashi-modern #shop_main em.marker {
  color: #803d3c;
}
body.sdp-shinsaibashi-modern #main_contents > p img,
body.sdp-shinsaibashi-modern #shop_main img {
  max-width: 100%;
  height: auto;
}
body.sdp-shinsaibashi-modern #main_contents > p:has(img) img,
body.sdp-shinsaibashi-modern .bnr_markset img,
body.sdp-shinsaibashi-modern .bnr_mic_model img,
body.sdp-shinsaibashi-modern .bnr_reassurance img {
  display: block;
  border-radius: 8px;
}
body.sdp-shinsaibashi-modern #main_contents table,
body.sdp-shinsaibashi-modern #shop_main table {
  width: 100%;
  overflow: hidden;
  border-collapse: separate !important;
  border-spacing: 0;
  border: 1px solid #e3d7d2 !important;
  border-radius: 8px;
  background: #fff;
}
body.sdp-shinsaibashi-modern #main_contents th,
body.sdp-shinsaibashi-modern #shop_main th {
  color: #fff !important;
  background: #803d3c !important;
  font-weight: 900 !important;
}
body.sdp-shinsaibashi-modern #main_contents td,
body.sdp-shinsaibashi-modern #main_contents th,
body.sdp-shinsaibashi-modern #shop_main td,
body.sdp-shinsaibashi-modern #shop_main th {
  padding: 14px 16px !important;
  border: 0 !important;
  border-bottom: 1px solid #eee4df !important;
  font-size: 15px;
  line-height: 1.75;
}
body.sdp-shinsaibashi-modern #main_contents tr:nth-child(even) td,
body.sdp-shinsaibashi-modern #shop_main tr:nth-child(even) td {
  background: #fbf8f6;
}
body.sdp-shinsaibashi-modern .shop_info_table {
  overflow: hidden;
  border: 1px solid #e3d7d2;
  border-radius: 8px;
  background: #fff;
}
body.sdp-shinsaibashi-modern .shop_info_table dl {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  margin: 0;
}
body.sdp-shinsaibashi-modern .shop_info_table dt,
body.sdp-shinsaibashi-modern .shop_info_table dd {
  min-height: 56px;
  padding: 16px 18px;
  margin: 0;
  border-bottom: 1px solid #eee4df;
}
body.sdp-shinsaibashi-modern .shop_info_table dt {
  color: #803d3c;
  background: #f7f1ee;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .shop_info_table dd {
  background: #fff;
}
body.sdp-shinsaibashi-modern .bnr_mic_number,
body.sdp-shinsaibashi-modern .bnr_markset,
body.sdp-shinsaibashi-modern .bnr_mic_model,
body.sdp-shinsaibashi-modern .bnr_reassurance {
  padding: 16px;
  margin: 22px 0;
  border: 1px solid #e3d7d2;
  border-radius: 8px;
  background: #fff;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof {
  position: relative;
  margin: 30px 0 10px;
  overflow: hidden;
  border: 1px solid #e2d5d0;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 38px rgb(80 54 50 / 8%);
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #a34f4d 0, #803d3c 42%, #302829 100%);
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__main {
  display: grid;
  grid-template-columns: 168px minmax(0, 1fr) minmax(230px, 300px);
  gap: 24px;
  align-items: center;
  padding: 30px;
  background: linear-gradient(135deg, #fff 0%, #fbf8f6 58%, #f4ece8 100%);
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__logo {
  display: flex;
  min-height: 128px;
  align-items: center;
  justify-content: center;
  padding: 20px;
  border: 1px solid #eadfdb;
  border-radius: 8px;
  background: #fff;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__logo img {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: 82px;
  object-fit: contain;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__eyebrow {
  display: inline-flex;
  margin: 0 0 10px !important;
  padding: 5px 10px;
  border-radius: 999px;
  color: #fff !important;
  background: #a34f4d;
  font-size: 12px !important;
  line-height: 1.4 !important;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-legal-proof__text h3 {
  margin: 0 0 10px;
  color: #302829;
  font-size: 26px;
  line-height: 1.45;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-legal-proof__text p:not(.sdp-shop-legal-proof__eyebrow) {
  margin: 0;
  color: #514847;
  font-size: 15px;
  line-height: 1.9;
  font-weight: 700;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 16px;
  border-radius: 8px;
  color: #fff;
  background: linear-gradient(135deg, #302829 0%, #513837 100%);
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid rgb(255 255 255 / 15%);
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers div:last-child {
  border-bottom: 0;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers dt,
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers dd {
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers dt {
  color: #eadfdb !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers dd {
  color: #fff !important;
  font-size: 19px !important;
  line-height: 1.2 !important;
  font-weight: 900;
  letter-spacing: .02em;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin: 0;
  padding: 0;
  border-top: 1px solid #e8ddd9;
  list-style: none;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges li {
  min-height: 92px;
  padding: 20px;
  border-right: 1px solid #e8ddd9;
  background: #fff;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges li:last-child {
  border-right: 0;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges span {
  display: block;
  margin: 0 0 6px;
  color: #a34f4d;
  font-size: 12px;
  line-height: 1.3;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges strong {
  display: block;
  color: #302829;
  font-size: 16px;
  line-height: 1.55;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs {
  border-top: 1px solid #e8ddd9;
  background: #fff;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs > summary {
  position: relative;
  padding: 18px 58px 18px 24px;
  cursor: pointer;
  list-style: none;
  color: #803d3c;
  background: #fbf8f6;
  font-size: 15px;
  line-height: 1.6;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs > summary::-webkit-details-marker {
  display: none;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs > summary::after {
  content: "+";
  position: absolute;
  top: 50%;
  right: 24px;
  color: #a34f4d;
  font-size: 24px;
  font-weight: 900;
  transform: translateY(-50%);
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs[open] > summary::after {
  content: "-";
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs-body {
  padding: 20px;
  border-top: 1px solid #e8ddd9;
}
body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs-body img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  border-radius: 8px;
  filter: saturate(.82);
}
body.sdp-shinsaibashi-modern .menu_list,
body.sdp-shinsaibashi-modern .shop_service_menu {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
body.sdp-shinsaibashi-modern .menu_list dl {
  overflow: hidden;
  margin: 0;
  border: 1px solid #e3d7d2;
  border-radius: 8px;
  background: #fff;
}
body.sdp-shinsaibashi-modern .menu_list dt {
  padding: 16px 18px;
  color: #fff;
  background: #302829;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.6;
}
body.sdp-shinsaibashi-modern .menu_list dd {
  padding: 16px 18px 18px;
  margin: 0;
}
body.sdp-shinsaibashi-modern .menu_list ul {
  display: grid;
  gap: 8px;
  padding: 0;
  margin: 0;
  list-style: none;
}
body.sdp-shinsaibashi-modern .menu_list li {
  position: relative;
  padding-left: 18px;
  font-size: 14px;
  line-height: 1.75;
}
body.sdp-shinsaibashi-modern .menu_list li::before {
  content: "";
  position: absolute;
  top: .75em;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #a34f4d;
}
body.sdp-shinsaibashi-modern .menu_list li.jump {
  padding-left: 0;
  margin-top: 8px;
}
body.sdp-shinsaibashi-modern .menu_list li.jump::before {
  display: none;
}
body.sdp-shinsaibashi-modern .menu_list li.jump a,
body.sdp-shinsaibashi-modern .txtbtn a,
body.sdp-shinsaibashi-modern .txtbtn_03 a,
body.sdp-shinsaibashi-modern .btn_shoplist_window_new2 a {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 12px 18px !important;
  border: 1px solid #a34f4d !important;
  border-radius: 8px !important;
  color: #fff !important;
  background: #a34f4d !important;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.4;
  text-decoration: none !important;
  box-shadow: 0 10px 22px rgb(163 79 77 / 18%);
}
body.sdp-shinsaibashi-modern .txtbtn a:hover,
body.sdp-shinsaibashi-modern .txtbtn_03 a:hover,
body.sdp-shinsaibashi-modern .btn_shoplist_window_new2 a:hover {
  background: #803d3c !important;
  border-color: #803d3c !important;
}
body.sdp-shinsaibashi-modern .shop_reasons {
  padding: 24px;
  border-radius: 8px;
  color: #fff;
  background: #302829;
}
body.sdp-shinsaibashi-modern .shop_resons_head div,
body.sdp-shinsaibashi-modern .shop_resons_head h3 {
  color: #fff;
}
body.sdp-shinsaibashi-modern .shop_resons_head .hilite {
  color: #f2d2ce;
}
body.sdp-shinsaibashi-modern .shop_reasons_index {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 22px;
}
body.sdp-shinsaibashi-modern .shop_reasons_index .item {
  padding: 18px;
  border: 1px solid rgb(255 255 255 / 12%);
  border-radius: 8px;
  background: rgb(255 255 255 / 8%);
}
body.sdp-shinsaibashi-modern .shop_reasons_index .item span {
  display: inline-block;
  margin-bottom: 10px;
  color: #f2d2ce;
  font-size: 13px;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .shop_reasons_index .item h4 {
  margin: 0 0 10px;
  color: #fff;
  font-size: 16px;
  line-height: 1.6;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .shop_reasons_index .item p {
  margin: 0;
  color: rgb(255 255 255 / 86%);
  font-size: 14px;
  line-height: 1.85;
}
body.sdp-shinsaibashi-modern .gmap,
body.sdp-shinsaibashi-modern .shop_map_01,
body.sdp-shinsaibashi-modern .shop_map_02 {
  overflow: hidden;
  border-radius: 8px;
}
body.sdp-shinsaibashi-modern .gmap iframe,
body.sdp-shinsaibashi-modern .shop_map_01 iframe,
body.sdp-shinsaibashi-modern .shop_map_02 iframe {
  display: block;
  width: 100% !important;
  min-height: 360px;
  border: 0 !important;
}
body.sdp-shinsaibashi-modern .shop_access_info {
  padding: 18px 20px;
  margin: 18px 0;
  border: 1px solid #e3d7d2;
  border-radius: 8px;
  background: #fff;
}
body.sdp-shinsaibashi-modern .shop_access_info dt {
  color: #803d3c;
  font-size: 16px;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern #shop_access_route_folder {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
body.sdp-shinsaibashi-modern #shop_access_route_folder .item,
body.sdp-shinsaibashi-modern #shop_jirei-voice .item,
body.sdp-shinsaibashi-modern .news_thumb_index .item,
body.sdp-shinsaibashi-modern .staff_sheet {
  overflow: hidden;
  border: 1px solid #e3d7d2;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 24px rgb(80 54 50 / 8%);
}
body.sdp-shinsaibashi-modern #shop_access_route_folder .item img,
body.sdp-shinsaibashi-modern #shop_jirei-voice .item img,
body.sdp-shinsaibashi-modern .news_thumb_index .item img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}
body.sdp-shinsaibashi-modern #shop_access_route_folder .item h4,
body.sdp-shinsaibashi-modern #shop_access_route_folder .item p,
body.sdp-shinsaibashi-modern #shop_jirei-voice .item h4,
body.sdp-shinsaibashi-modern .news_thumb_index .item h4 {
  padding-right: 18px;
  padding-left: 18px;
}
body.sdp-shinsaibashi-modern #shop_access_route_folder .item h4 {
  color: #803d3c;
  font-size: 13px;
  letter-spacing: 0;
}
body.sdp-shinsaibashi-modern #shop_jirei-voice .clearfix,
body.sdp-shinsaibashi-modern .news_thumb_index {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
body.sdp-shinsaibashi-modern #shop_jirei-voice .cate,
body.sdp-shinsaibashi-modern #shop_jirei-voice .date,
body.sdp-shinsaibashi-modern .news_thumb_index .cate,
body.sdp-shinsaibashi-modern .news_thumb_index .date {
  display: inline-block;
  margin: 14px 0 0 18px;
  color: #8b817f;
  font-size: 12px;
  font-weight: 800;
}
body.sdp-shinsaibashi-modern .staff_sheet header {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 24px;
  align-items: center;
  padding: 24px;
}
body.sdp-shinsaibashi-modern .staff_avater img {
  display: block;
  width: 100%;
  border-radius: 8px;
}
body.sdp-shinsaibashi-modern .staff_profile {
  color: #302829;
}
body.sdp-shinsaibashi-modern .staff_role_01 {
  display: inline-block;
  margin: 10px 0;
  padding: 5px 9px;
  border-radius: 999px;
  color: #fff;
  background: #803d3c;
  font-size: 12px;
  font-weight: 900;
}
body.sdp-shinsaibashi-modern .staff_name {
  color: #302829;
  font-size: 24px;
  font-weight: 900;
  line-height: 1.5;
}
body.sdp-shinsaibashi-modern #main_contents [style*="#e85e6a"],
body.sdp-shinsaibashi-modern #main_contents [style*="#E85E6A"],
body.sdp-shinsaibashi-modern #main_contents [style*="#0056b3"],
body.sdp-shinsaibashi-modern #main_contents [style*="#d32f2f"] {
  color: #803d3c !important;
  border-color: #a34f4d !important;
}
body.sdp-shinsaibashi-modern #main_contents [style*="background: #e85e6a"],
body.sdp-shinsaibashi-modern #main_contents [style*="background:#e85e6a"],
body.sdp-shinsaibashi-modern #main_contents [style*="background-color: #e85e6a"],
body.sdp-shinsaibashi-modern #main_contents [style*="background: #0056b3"],
body.sdp-shinsaibashi-modern #main_contents [style*="background-color: #0056b3"] {
  color: #fff !important;
  background: #a34f4d !important;
}
@media (max-width: 900px) {
  body.sdp-shinsaibashi-modern .shop_header,
  body.sdp-shinsaibashi-modern .shop_info_table dl,
  body.sdp-shinsaibashi-modern .menu_list,
	  body.sdp-shinsaibashi-modern .shop_service_menu,
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__main,
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges,
	  body.sdp-shinsaibashi-modern .shop_reasons_index,
	  body.sdp-shinsaibashi-modern #shop_access_route_folder,
  body.sdp-shinsaibashi-modern #shop_jirei-voice .clearfix,
  body.sdp-shinsaibashi-modern .news_thumb_index,
  body.sdp-shinsaibashi-modern .staff_sheet header {
    grid-template-columns: 1fr;
  }
  body.sdp-shinsaibashi-modern #main_contents > h1.heading_02 {
    padding: 26px 22px 30px;
    font-size: 24px;
  }
  body.sdp-shinsaibashi-modern .shop_name {
    font-size: 24px;
  }
  body.sdp-shinsaibashi-modern .shop_meta_contact .telnum,
  body.sdp-shinsaibashi-modern .tellink {
    font-size: 25px;
  }
  body.sdp-shinsaibashi-modern #main_contents h2.heading_02,
	  body.sdp-shinsaibashi-modern #main_contents h2.heading_03,
	  body.sdp-shinsaibashi-modern #shop_main h2.heading_02 {
	    font-size: 21px;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__logo {
	    min-height: 104px;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers {
	    grid-template-columns: repeat(2, minmax(0, 1fr));
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers div {
	    display: block;
	    border-bottom: 0;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers dd {
	    margin-top: 6px !important;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges li {
	    min-height: auto;
	    border-right: 0;
	    border-bottom: 1px solid #e8ddd9;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges li:last-child {
	    border-bottom: 0;
	  }
	}
@media (max-width: 767px) {
  body.sdp-shinsaibashi-modern .main-body-in,
  body.sdp-shinsaibashi-modern .layout_shop.page_shop .container {
    padding: 18px 14px 58px;
  }
  body.sdp-shinsaibashi-modern .covid-19-taiou .wrapper {
    align-items: flex-start;
  }
  body.sdp-shinsaibashi-modern #main_contents p,
  body.sdp-shinsaibashi-modern #main_contents li,
  body.sdp-shinsaibashi-modern #main_contents dd,
  body.sdp-shinsaibashi-modern #shop_main p,
  body.sdp-shinsaibashi-modern #shop_main li,
  body.sdp-shinsaibashi-modern #shop_main dd {
    font-size: 15px;
  }
  body.sdp-shinsaibashi-modern #main_contents .sdp-shop-content-section,
  body.sdp-shinsaibashi-modern #shop_main > section:not(#shop_hero) {
    padding-top: 34px;
    margin-top: 30px;
  }
	  body.sdp-shinsaibashi-modern .shop_header {
	    padding: 22px 18px;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__main {
	    gap: 16px;
	    padding: 22px 18px;
	  }
	  body.sdp-shinsaibashi-modern #main_contents .sdp-shop-legal-proof__text h3 {
	    font-size: 22px;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__numbers {
	    grid-template-columns: 1fr;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges li {
	    min-height: auto;
	    padding: 16px 18px;
	    border-right: 0;
	    border-bottom: 1px solid #e8ddd9;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__badges li:last-child {
	    border-bottom: 0;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs > summary {
	    padding: 16px 50px 16px 18px;
	  }
	  body.sdp-shinsaibashi-modern .sdp-shop-legal-proof__docs > summary::after {
	    right: 18px;
	  }
	  body.sdp-shinsaibashi-modern .gmap iframe,
  body.sdp-shinsaibashi-modern .shop_map_01 iframe,
  body.sdp-shinsaibashi-modern .shop_map_02 iframe {
    min-height: 300px;
  }
}

/* 心斎橋ページ：スクショ確認後の下層セクション補正 */
body.sdp-shinsaibashi-modern #main_contents {
  padding-bottom: 110px;
}

body.sdp-shinsaibashi-modern .shop_reasons {
  padding: 28px;
  border: 1px solid #eadfdb;
  border-radius: 8px;
  color: #302829;
  background: #fff;
  box-shadow: 0 14px 34px rgb(80 54 50 / 9%);
}

body.sdp-shinsaibashi-modern .shop_resons_head {
  margin: 0 0 22px;
  padding: 24px 28px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgb(48 40 41 / 96%), rgb(128 61 60 / 92%)),
    #302829;
}

body.sdp-shinsaibashi-modern #main_contents .shop_resons_head h3 {
  margin: 0;
  color: #fff !important;
  font-size: 26px !important;
  line-height: 1.55 !important;
  letter-spacing: 0;
}

body.sdp-shinsaibashi-modern .shop_resons_head .hilite {
  color: #fff !important;
}

body.sdp-shinsaibashi-modern .shop_resons_head em {
  color: #f4d9d6;
  font-style: normal;
}

body.sdp-shinsaibashi-modern .shop_reasons .note_sp {
  display: none !important;
}

body.sdp-shinsaibashi-modern .shop_reasons_index {
  gap: 16px;
  margin-top: 0;
}

body.sdp-shinsaibashi-modern .shop_reasons_index .item {
  display: flex;
  min-height: 0;
  padding: 22px;
  border: 1px solid #eadfdb;
  border-radius: 8px;
  background: #fbf8f6;
  box-shadow: none;
  flex-direction: column;
}

body.sdp-shinsaibashi-modern .shop_reasons_index .item span {
  display: inline-flex;
  width: 38px;
  height: 38px;
  align-items: center;
  justify-content: center;
  margin: 0 0 14px;
  border: 1px solid #e4cbc6;
  border-radius: 999px;
  color: #803d3c;
  background: #fff;
  font-size: 14px;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .shop_reasons_index .item h4 {
  margin: 0 0 12px;
  color: #302829 !important;
  font-size: 17px;
  line-height: 1.65;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern #main_contents .shop_reasons_index .item p,
body.sdp-shinsaibashi-modern #main_contents .shop_reasons_index .item em.marker {
  color: #504747 !important;
  font-size: 14px !important;
  line-height: 1.9 !important;
}

body.sdp-shinsaibashi-modern #main_contents .shop_reasons_index .item em.marker {
  font-style: normal;
  font-weight: 800;
}

body.sdp-shinsaibashi-modern #shop_faq .faq_list {
  display: grid;
  gap: 0;
  margin: 10px 0 0 !important;
}

body.sdp-shinsaibashi-modern #shop_faq .faq_list dt {
  position: relative;
  margin: 18px 0 0 !important;
  padding: 18px 20px 14px 54px;
  border: 1px solid #eadfdb;
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
  color: #803d3c !important;
  background: #fff;
  font-size: 17px;
  line-height: 1.65;
  font-weight: 900 !important;
}

body.sdp-shinsaibashi-modern #shop_faq .faq_list dt::before {
  content: "Q";
  position: absolute;
  top: 19px;
  left: 18px;
  display: inline-flex;
  width: 26px;
  height: 26px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: #fff;
  background: #a34f4d;
  font-size: 14px;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern #shop_faq .faq_list dd {
  position: relative;
  margin: 0 !important;
  padding: 0 20px 20px 54px;
  border: 1px solid #eadfdb;
  border-top: 0;
  border-radius: 0 0 8px 8px;
  color: #413838 !important;
  background: #fff;
  box-shadow: 0 10px 24px rgb(80 54 50 / 7%);
  font-size: 16px;
  line-height: 1.9;
}

body.sdp-shinsaibashi-modern #shop_faq .faq_list dd::before {
  content: "A";
  position: absolute;
  top: 1px;
  left: 18px;
  display: inline-flex;
  width: 26px;
  height: 26px;
  align-items: center;
  justify-content: center;
  border: 1px solid #e4cbc6;
  border-radius: 999px;
  color: #803d3c;
  background: #fbf8f6;
  font-size: 14px;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .rss-voice {
  padding: 28px;
  border: 1px solid #eadfdb;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgb(80 54 50 / 9%);
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice_main {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin: 22px 0 0;
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice {
  overflow: hidden;
  border: 1px solid #e3d7d2;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 24px rgb(80 54 50 / 8%);
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .media-wrap__con__list__item__img {
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: #f0ecea;
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .media-wrap__con__list__item__img img {
  display: block;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover;
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .media-wrap__con__list__item__txt {
  padding: 16px 18px 18px;
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .cate,
body.sdp-shinsaibashi-modern #shop_jirei-voice .date {
  display: inline-flex;
  margin: 0 10px 10px 0;
  color: #8b817f;
  font-size: 12px;
  font-weight: 800;
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice h4 {
  margin: 0;
  padding: 0;
  color: #302829;
  font-size: 16px;
  line-height: 1.65;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice h4 a {
  color: #803d3c;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}

@media (max-width: 900px) {
  body.sdp-shinsaibashi-modern .shop_reasons_index,
  body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice_main {
    grid-template-columns: 1fr;
  }

  body.sdp-shinsaibashi-modern #main_contents .shop_resons_head h3 {
    font-size: 22px !important;
  }
}

@media (max-width: 767px) {
  body.sdp-shinsaibashi-modern .shop_reasons,
  body.sdp-shinsaibashi-modern #shop_jirei-voice .rss-voice {
    padding: 18px;
  }

  body.sdp-shinsaibashi-modern #shop_faq .faq_list dt,
  body.sdp-shinsaibashi-modern #shop_faq .faq_list dd {
    padding-right: 14px;
  }
}

/* 心斎橋ページ：基板修理ページ型のアコーディオン */
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-content-section.sdp-shop-accordion {
  padding: 0;
  margin: 24px 0 0;
  overflow: hidden;
  border: 1px solid #e3d7d2;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgb(80 54 50 / 7%);
}

body.sdp-shinsaibashi-modern #main_contents .sdp-shop-content-section.sdp-shop-accordion::before {
  display: none;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion > summary {
  position: relative;
  display: flex;
  min-height: 76px;
  padding: 18px 62px 18px 24px;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  cursor: pointer;
  list-style: none;
  background: #f7f4f2;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion > summary::-webkit-details-marker {
  display: none;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion > summary::after {
  content: "+";
  position: absolute;
  top: 50%;
  right: 24px;
  color: #a34f4d;
  font-size: 28px;
  font-weight: 700;
  transform: translateY(-50%);
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion[open] > summary::after {
  content: "-";
}

body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion > summary h2,
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion > summary h2.heading_02,
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion > summary h2.heading_03 {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  color: #302829;
  background: transparent;
  font-size: 23px;
  line-height: 1.5;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion > summary h2 span {
  display: block;
  margin: 0 0 4px;
  color: #803d3c;
  font-size: 13px;
  line-height: 1.5;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion__hint {
  flex: 0 0 auto;
  color: #803d3c;
  font-size: 0;
  font-weight: 900;
  letter-spacing: 0;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion__hint::before {
  content: "詳しく見る";
  font-size: 11px;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion[open] .sdp-shop-accordion__hint::before {
  content: "閉じる";
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion__body {
  padding: 28px;
  border-top: 1px solid #e3d7d2;
  background: #fff;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion__body > :first-child {
  margin-top: 0;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion__body > :last-child {
  margin-bottom: 0;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion[open] > summary {
  background: #fff;
}

body.sdp-shinsaibashi-modern .sdp-shop-accordion[open] > summary h2 {
  color: #803d3c;
}

@media (max-width: 767px) {
  body.sdp-shinsaibashi-modern .sdp-shop-accordion > summary {
    min-height: 68px;
    padding: 15px 50px 15px 16px;
  }

  body.sdp-shinsaibashi-modern .sdp-shop-accordion > summary::after {
    right: 17px;
    font-size: 25px;
  }

  body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion > summary h2,
  body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion > summary h2.heading_02,
  body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion > summary h2.heading_03 {
    font-size: 20px;
  }

  body.sdp-shinsaibashi-modern .sdp-shop-accordion__hint {
    display: none;
  }

  body.sdp-shinsaibashi-modern .sdp-shop-accordion__body {
    padding: 18px 16px;
  }
}

/* === 店舗ページ shop_slide：新デザイン軽量ギャラリー（slick不要・vanilla JS） === */
.legacy-restored-content .shop_slide,
.article-body .shop_slide,
.main-conts .shop_slide {
  position: relative;
  width: 100% !important;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  margin: 18px 0 12px;
  border: 1px solid #ddd4d0;
  border-radius: 12px;
  background: #eee8e4;
  box-shadow: 0 18px 42px rgb(48 38 41 / 12%);
  isolation: isolate;
  touch-action: pan-y;
}
.shop_slide.sdp-shop-gallery::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgb(18 18 20 / 18%), transparent 28%),
    linear-gradient(0deg, rgb(18 18 20 / 62%), rgb(18 18 20 / 0%) 46%);
}
.shop_slide.sdp-shop-gallery .item {
  position: absolute !important;
  inset: 0;
  z-index: 1;
  display: block !important;
  width: 100% !important;
  height: 100%;
  padding: 0 !important;
  margin: 0 !important;
  opacity: 0;
  pointer-events: none;
  transform: scale(1.025);
  transition: opacity .56s ease, transform 4.8s ease;
}
.shop_slide.sdp-shop-gallery .item.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: scale(1);
}
.shop_slide.sdp-shop-gallery .item a,
.shop_slide.sdp-shop-gallery .item img {
  display: block;
  width: 100%;
  height: 100%;
}
.shop_slide.sdp-shop-gallery .item img {
  object-fit: cover;
}
.sdp-shop-gallery__meta {
  position: absolute;
  right: 22px;
  bottom: 22px;
  left: 22px;
  z-index: 4;
  display: grid;
  max-width: 680px;
  gap: 5px;
  color: #fff;
  text-shadow: 0 2px 14px rgb(0 0 0 / 42%);
  pointer-events: none;
}
.sdp-shop-gallery__eyebrow {
  color: #f0d9d6;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
}
.sdp-shop-gallery__title {
  font-size: 22px;
  line-height: 1.45;
  font-weight: 900;
}
.sdp-shop-gallery__detail {
  max-width: 560px;
  font-size: 13px;
  line-height: 1.65;
  color: rgb(255 255 255 / 88%);
}
.sdp-shop-gallery__counter {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 4;
  padding: 8px 10px;
  border: 1px solid rgb(255 255 255 / 34%);
  border-radius: 7px;
  color: #fff;
  background: rgb(32 29 31 / 54%);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .08em;
}
.sdp-shop-gallery__progress {
  position: absolute;
  right: 22px;
  bottom: 14px;
  left: 22px;
  z-index: 4;
  height: 3px;
  overflow: hidden;
  border-radius: 99px;
  background: rgb(255 255 255 / 28%);
}
.sdp-shop-gallery__progress span {
  display: block;
  width: 100%;
  height: 100%;
  background: #fff;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .34s ease;
}
.sdp-shop-gallery__controls {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 4;
  display: flex;
  gap: 8px;
}
.sdp-shop-gallery__arrow,
.sdp-shop-gallery__toggle {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  padding: 0;
  border: 1px solid rgb(255 255 255 / 38%);
  border-radius: 50%;
  color: #fff;
  background: rgb(32 29 31 / 52%);
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, transform .18s ease;
}
.sdp-shop-gallery__arrow:hover,
.sdp-shop-gallery__toggle:hover,
.sdp-shop-gallery__arrow:focus-visible,
.sdp-shop-gallery__toggle:focus-visible {
  border-color: #fff;
  background: rgb(128 61 60 / 82%);
  outline: none;
  transform: translateY(-1px);
}
.sdp-shop-gallery__arrow span,
.sdp-shop-gallery__toggle span {
  position: relative;
  display: block;
  width: 16px;
  height: 16px;
}
.sdp-shop-gallery__arrow--prev span::before,
.sdp-shop-gallery__arrow--next span::before {
  content: "";
  position: absolute;
  top: 3px;
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
}
.sdp-shop-gallery__arrow--prev span::before {
  left: 5px;
  border-left: 2px solid currentColor;
  transform: rotate(-45deg);
}
.sdp-shop-gallery__arrow--next span::before {
  right: 5px;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}
.sdp-shop-gallery__toggle span::before,
.sdp-shop-gallery__toggle span::after {
  content: "";
  position: absolute;
  top: 2px;
  width: 4px;
  height: 12px;
  border-radius: 1px;
  background: currentColor;
}
.sdp-shop-gallery__toggle span::before { left: 4px; }
.sdp-shop-gallery__toggle span::after { right: 4px; }
.sdp-shop-gallery__toggle[data-state="paused"] span::before {
  top: 1px;
  left: 5px;
  width: 0;
  height: 0;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
  border-left: 11px solid currentColor;
  border-radius: 0;
  background: transparent;
}
.sdp-shop-gallery__toggle[data-state="paused"] span::after {
  display: none;
}
.shop_slide_tab.sdp-shop-gallery__thumbs {
  display: grid !important;
  grid-auto-flow: column;
  grid-auto-columns: minmax(112px, 1fr);
  gap: 8px;
  overflow-x: auto;
  margin: 0 0 24px !important;
  padding: 4px 0 8px !important;
  list-style: none !important;
  scrollbar-width: thin;
}
.shop_slide_tab.sdp-shop-gallery__thumbs li {
  display: block !important;
  width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}
.sdp-shop-gallery__thumb {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 8px;
  background: #eee8e4;
  cursor: pointer;
  opacity: .72;
  transition: opacity .18s ease, border-color .18s ease, transform .18s ease;
}
.sdp-shop-gallery__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.sdp-shop-gallery__thumb.is-active,
.sdp-shop-gallery__thumb:hover,
.sdp-shop-gallery__thumb:focus-visible {
  border-color: #a34f4d;
  opacity: 1;
  outline: none;
  transform: translateY(-1px);
}
@media (max-width: 767px) {
  .legacy-restored-content .shop_slide,
  .article-body .shop_slide,
  .main-conts .shop_slide {
    aspect-ratio: 4 / 3;
    border-radius: 10px;
    margin-top: 12px;
  }
  .sdp-shop-gallery__meta {
    right: 14px;
    bottom: 18px;
    left: 14px;
    gap: 3px;
  }
  .sdp-shop-gallery__eyebrow { font-size: 10px; }
  .sdp-shop-gallery__title { font-size: 16px; }
  .sdp-shop-gallery__detail {
    display: none;
  }
  .sdp-shop-gallery__counter {
    top: 12px;
    right: 12px;
    padding: 7px 8px;
    font-size: 11px;
  }
  .sdp-shop-gallery__controls {
    top: 12px;
    left: 12px;
    gap: 6px;
  }
  .sdp-shop-gallery__arrow,
  .sdp-shop-gallery__toggle {
    width: 36px;
    height: 36px;
  }
  .sdp-shop-gallery__progress {
    right: 14px;
    bottom: 10px;
    left: 14px;
  }
  .shop_slide_tab.sdp-shop-gallery__thumbs {
    grid-auto-columns: 92px;
    gap: 7px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .shop_slide.sdp-shop-gallery .item,
  .sdp-shop-gallery__progress span,
  .sdp-shop-gallery__arrow,
  .sdp-shop-gallery__toggle,
  .sdp-shop-gallery__thumb {
    transition: none;
  }
}

/* === 2026-06-21 心斎橋：末尾ボタン(.txtbtn)がカード/アコーディオン縁に密着する問題の余白修正 === */
body.sdp-shinsaibashi-modern .txtbtn{margin:24px 0 12px !important;padding:0 !important;text-align:center}
body.sdp-shinsaibashi-modern .sdp-shop-accordion__body{padding-bottom:30px !important}
body.sdp-shinsaibashi-modern .sdp-shop-accordion__body > .txtbtn:last-child,
body.sdp-shinsaibashi-modern .sdp-shop-content-section > .txtbtn:last-child,
body.sdp-shinsaibashi-modern #shop_jirei-voice .txtbtn:last-child{margin-bottom:8px !important}

/* 心斎橋ページ：総務省登録修理業者バナーを新サイト色へ再構成 */
body.sdp-shinsaibashi-modern .sdp-legal-proof {
  margin: 26px 0 18px;
  overflow: hidden;
  border: 1px solid #e4d8d3;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgb(80 54 50 / 8%);
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, 330px);
  gap: 24px;
  padding: 30px;
  align-items: center;
  color: #fff;
  background: linear-gradient(135deg, #302829 0%, #4b3634 100%);
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__eyebrow {
  margin: 0 0 10px;
  color: #f2d7d1;
  font-size: 13px;
  line-height: 1.5;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__title {
  margin: 0;
  color: #fff;
  font-size: 30px;
  line-height: 1.45;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__copy {
  margin: 14px 0 0;
  color: #f3eeee;
  font-size: 16px;
  line-height: 1.9;
  font-weight: 700;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__registry {
  display: grid;
  gap: 10px;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__registry-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  padding: 13px 16px;
  align-items: center;
  border: 1px solid rgb(255 255 255 / 20%);
  border-radius: 8px;
  background: rgb(255 255 255 / 9%);
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__registry-row span {
  color: #eadfdc;
  font-size: 13px;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__registry-row strong {
  color: #fff;
  font-size: 20px;
  letter-spacing: .02em;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__points {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid #e8ddd9;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__points li {
  min-height: 108px;
  padding: 22px 20px;
  border-right: 1px solid #e8ddd9;
  background: #fff;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__points li:last-child {
  border-right: 0;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__points span {
  display: block;
  margin: 0 0 7px;
  color: #a34f4d;
  font-size: 12px;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof__points strong {
  display: block;
  color: #302829;
  font-size: 17px;
  line-height: 1.6;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion {
  margin: 16px 0 0;
  border: 1px solid #e4d8d3;
  border-radius: 8px;
  background: #fff;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion > summary {
  position: relative;
  padding: 17px 56px 17px 20px;
  cursor: pointer;
  list-style: none;
  color: #803d3c;
  background: #f8f5f3;
  font-size: 15px;
  line-height: 1.6;
  font-weight: 900;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion > summary::-webkit-details-marker {
  display: none;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion > summary::after {
  content: "+";
  position: absolute;
  top: 50%;
  right: 20px;
  color: #a34f4d;
  font-size: 24px;
  font-weight: 900;
  transform: translateY(-50%);
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion[open] > summary::after {
  content: "-";
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion__body {
  display: grid;
  gap: 18px;
  padding: 18px;
  border-top: 1px solid #e4d8d3;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion__body .bnr_markset,
body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion__body .bnr_mic_system {
  margin: 0 !important;
  padding: 16px !important;
  border: 1px solid #eadfdb;
  border-radius: 8px;
  background: #fff;
  box-shadow: none !important;
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion__body img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  filter: saturate(.78);
}

body.sdp-shinsaibashi-modern .sdp-legal-proof-accordion__body h4 {
  margin: 0 0 14px !important;
  color: #803d3c !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
}

@media (max-width: 900px) {
  body.sdp-shinsaibashi-modern .sdp-legal-proof__hero,
  body.sdp-shinsaibashi-modern .sdp-legal-proof__points {
    grid-template-columns: 1fr;
  }

  body.sdp-shinsaibashi-modern .sdp-legal-proof__points li {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid #e8ddd9;
  }

  body.sdp-shinsaibashi-modern .sdp-legal-proof__points li:last-child {
    border-bottom: 0;
  }
}

@media (max-width: 767px) {
  body.sdp-shinsaibashi-modern .sdp-legal-proof__hero {
    padding: 22px 18px;
  }

  body.sdp-shinsaibashi-modern .sdp-legal-proof__title {
    font-size: 23px;
  }
}
/* アクセス（電車/お車）末尾ボタン等にも同様の余白 */
body.sdp-shinsaibashi-modern .shop_free .txtbtn,
body.sdp-shinsaibashi-modern #shop_access .txtbtn{margin:20px 0 10px !important}

/* === 2026-06-21 心斎橋：カードの動き（ホバー持ち上げ＋画像ズーム＋スクロールでフェードイン） === */
body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice,
body.sdp-shinsaibashi-modern .news_thumb_index .item,
body.sdp-shinsaibashi-modern .staff_sheet,
body.sdp-shinsaibashi-modern .shop_reasons_index .item{
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice:hover,
body.sdp-shinsaibashi-modern .news_thumb_index .item:hover,
body.sdp-shinsaibashi-modern .staff_sheet:hover,
body.sdp-shinsaibashi-modern .shop_reasons_index .item:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 40px rgba(80,54,50,.18);
  border-color:#cdbdb8;
}
body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice:active,
body.sdp-shinsaibashi-modern .news_thumb_index .item:active{transform:translateY(-2px)}
/* カード内画像のズーム（カードは overflow:hidden 済み） */
body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice img,
body.sdp-shinsaibashi-modern .news_thumb_index .item img{transition:transform .55s ease}
body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice:hover img,
body.sdp-shinsaibashi-modern .news_thumb_index .item:hover img{transform:scale(1.05)}
/* スクロールでフェードイン（JS+IntersectionObserver時のみ opacity:0。失敗時は常に表示＝安全） */
body.sdp-shinsaibashi-modern.sdp-reveal-on .sdp-reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
body.sdp-shinsaibashi-modern.sdp-reveal-on .sdp-reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  body.sdp-shinsaibashi-modern.sdp-reveal-on .sdp-reveal{opacity:1;transform:none;transition:none}
  body.sdp-shinsaibashi-modern #shop_jirei-voice .item-voice,
  body.sdp-shinsaibashi-modern .news_thumb_index .item,
  body.sdp-shinsaibashi-modern .staff_sheet{transition:none}
}

/* === 2026-06-21 修理事例カード(.item-voice)の動きを全ページ共通化（/voice/ 等。shinsaibashiの装飾は別途スコープで維持） === */
.item-voice{transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease}
.item-voice:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(80,54,50,.16)}
.item-voice:active{transform:translateY(-2px)}
.item-voice .media-wrap__con__list__item__img,
.item-voice [class*="__img"]{overflow:hidden}
.item-voice img{transition:transform .55s ease}
.item-voice:hover img{transform:scale(1.05)}
body.sdp-reveal-on .item-voice.sdp-reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
body.sdp-reveal-on .item-voice.sdp-reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  body.sdp-reveal-on .item-voice.sdp-reveal{opacity:1;transform:none;transition:none}
  .item-voice,.item-voice img{transition:none}
}

/* === sdp-shop-hero-v2 (心斎橋FV統合ヒーロー 2026-06-23) === */
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:30px;align-items:center;margin:0 0 26px;padding:30px;border:1px solid #e4d8d3;border-radius:10px;background:linear-gradient(135deg,#fff 0%,#fbf8f6 58%,#f4ece8 100%);box-shadow:0 16px 40px rgba(80,54,50,.08)}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__eyebrow{margin:0 0 12px;color:#803d3c;font-size:13px;font-weight:900;letter-spacing:.04em}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-hero-v2__title{margin:0;padding:0;border:0;background:none;color:#302829;font-size:clamp(25px,3vw,36px);line-height:1.42;font-weight:900;letter-spacing:-.01em}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-hero-v2__title:before{content:none}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__lead{margin:16px 0 0;color:#514847;font-size:15px;line-height:1.95;font-weight:600}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__chips{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 0;padding:0;list-style:none}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__chips li{padding:7px 12px;border:1px solid #e0d3ce;border-radius:999px;background:#fff;color:#5a4b48;font-size:12px;font-weight:800}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__actions{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 0}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__button{display:inline-flex;min-height:50px;min-width:200px;padding:0 22px;align-items:center;justify-content:center;border-radius:8px;background:#a34f4d;color:#fff!important;font-weight:900;text-decoration:none!important}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__button--outline{background:#fff;color:#803d3c!important;border:1px solid #a34f4d}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__facts{display:grid;gap:0;margin:20px 0 0;border-top:1px solid #e8ddd9}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__facts div{display:grid;grid-template-columns:88px 1fr;gap:10px;padding:9px 0;border-bottom:1px solid #e8ddd9}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__facts span{color:#7a706d;font-size:12px;font-weight:800}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__facts strong{color:#302829;font-size:13px;font-weight:800}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__subnav{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 0}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__subnav a{padding:8px 13px;border-radius:999px;background:#f3eeee;color:#803d3c!important;font-size:12px;font-weight:800;text-decoration:none!important}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__media{min-width:0}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__media .shop_slide{margin:0;border:1px solid #e4d8d3;border-radius:10px;overflow:hidden}
body.sdp-shinsaibashi-modern .sdp-shop-hero-v2__media .shop_slide_tab{margin:8px 0 0}
@media(max-width:900px){body.sdp-shinsaibashi-modern .sdp-shop-hero-v2{grid-template-columns:1fr;gap:20px;padding:22px 16px}}
/* 心斎橋ヒーロースライダー: 画像上のキャプション文字・グラデ枠を除去（写真のみ表示） 2026-06-23 */
body.sdp-shinsaibashi-modern .sdp-shop-gallery__meta{display:none!important}
body.sdp-shinsaibashi-modern .shop_slide.sdp-shop-gallery::before{display:none!important}
/* スライダー画像の上部隙間を解消: a/imgを枠いっぱいにピン留め 2026-06-23 */
body.sdp-shinsaibashi-modern .shop_slide.sdp-shop-gallery .item a,
body.sdp-shinsaibashi-modern .shop_slide.sdp-shop-gallery .item img{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;margin:0!important}
body.sdp-shinsaibashi-modern .shop_slide.sdp-shop-gallery .item img{object-fit:cover!important}
/* サービスLP本文(折込旧コンテンツ含む)の画像をレスポンシブに（img.switch等のはみ出し防止） 2026-06-23 */
.service-main img{max-width:100%;height:auto}
.service-main .accordion-body img,.service-main img.switch{max-width:100%!important;height:auto!important}
/* 折込んだレガシーのバナー/フロート/テーブルを新デザイン内で幅内・縦積みに（はみ出し防止） 2026-06-23 */
.service-main .accordion-body{overflow-x:auto}
.service-main .accordion-body [class^="bnr_"],.service-main .accordion-body [class*=" bnr_"]{display:block!important;float:none!important;width:auto!important;max-width:100%!important;margin:14px auto!important;text-align:center}
.service-main .accordion-body [class^="bnr_"] img,.service-main .accordion-body [class*=" bnr_"] img{max-width:100%!important;height:auto!important}
.service-main .accordion-body table{max-width:100%}
/* レガシーbanner画像をスコープ非依存で幅内に（service-mainタグ不均衡対策） 2026-06-23 */
img.switch{max-width:100%!important;height:auto!important}
[class^="bnr_"] img,[class*=" bnr_"] img{max-width:100%!important;height:auto!important}
.bnr_markset,.bnr_warrantee,.bnr_repair_call,.bnr_repair_point{max-width:100%!important;overflow:hidden}
/* === アコーディオン内部(折込旧コンテンツ)の整形 2026-06-23 === */
.service-main .accordion-body{font-size:15px;line-height:1.95;color:#3a3230}
.service-main .accordion-body>:first-child{margin-top:0}
.service-main .accordion-body>:last-child{margin-bottom:0}
.service-main .accordion-body h3{margin:24px 0 10px;font-size:17px;line-height:1.6;font-weight:900;color:#302829}
.service-main .accordion-body h4{margin:18px 0 8px;font-size:15px;line-height:1.6;font-weight:800;color:#803d3c}
.service-main .accordion-body p{margin:0 0 14px;line-height:1.95}
.service-main .accordion-body ul,.service-main .accordion-body ol{margin:0 0 16px;padding-left:1.35em}
.service-main .accordion-body li{margin:5px 0;line-height:1.85}
.service-main .accordion-body strong{color:#803d3c}
.service-main .accordion-body a{color:#803d3c;font-weight:700;text-underline-offset:3px}
/* 表を新デザインに整える */
.service-main .accordion-body table{width:100%;border-collapse:collapse;margin:14px 0;font-size:13px;border:1px solid #e6ddd9}
.service-main .accordion-body th,.service-main .accordion-body td{padding:11px 12px;border:1px solid #ece3df;text-align:left;vertical-align:middle;line-height:1.7}
.service-main .accordion-body thead th,.service-main .accordion-body tr:first-child th{background:#5c5654;color:#fff!important;font-weight:800;font-size:12px}
.service-main .accordion-body tbody th{background:#f7f4f2;color:#302829!important;font-weight:800;white-space:nowrap}
/* レガシーの色付き情報ボックスを淡色・細ボーダー・左アクセントに統一 */
.service-main .accordion-body [style*="#fff5f5"],.service-main .accordion-body [style*="#fff8f0"],.service-main .accordion-body [style*="#fffaf0"],.service-main .accordion-body [style*="#fff8e6"],.service-main .accordion-body [style*="#fffbeb"],.service-main .accordion-body [style*="#fff5e6"],.service-main .accordion-body [style*="#fff5ff"],.service-main .accordion-body [style*="#f9f5ff"]{background:#faf7f5!important;border:1px solid #ece3df!important;border-left:3px solid #a34f4d!important;border-radius:8px!important;padding:16px 18px!important;margin:16px 0!important;box-shadow:none!important}
.service-main .accordion-body [style*="#fff5f5"] *,.service-main .accordion-body [style*="#fff8f0"] *{color:inherit}
/* === /faq/ 質問ごとアコーディオン 2026-06-23 === */
.faq-cat>h2{margin-top:46px}
.faq-list2{display:grid;gap:10px;margin-top:18px}
.faq-acc{border:1px solid #e6ddd9;border-radius:8px;background:#fff;overflow:hidden}
.faq-acc>summary{position:relative;display:flex;gap:12px;align-items:flex-start;padding:18px 52px 18px 18px;cursor:pointer;list-style:none}
.faq-acc>summary::-webkit-details-marker{display:none}
.faq-acc>summary::after{content:"+";position:absolute;right:20px;top:16px;color:#a34f4d;font-size:24px;font-weight:700;line-height:1}
.faq-acc[open]>summary::after{content:"\2212"}
.faq-acc[open]>summary{background:#faf7f5}
.faq-q{flex:0 0 auto;display:inline-flex;width:26px;height:26px;align-items:center;justify-content:center;border-radius:999px;background:#a34f4d;color:#fff!important;font-size:14px;font-weight:900;margin-top:1px}
.faq-qtext{font-size:16px;line-height:1.65;font-weight:800;color:#302829}
.faq-a{display:flex;gap:12px;align-items:flex-start;padding:18px;border-top:1px solid #efe7e3;background:#fbf9f8}
.faq-amark{flex:0 0 auto;display:inline-flex;width:26px;height:26px;align-items:center;justify-content:center;border-radius:999px;border:1px solid #d8c8c3;background:#fff;color:#803d3c;font-size:14px;font-weight:900;margin-top:1px}
.faq-atext{min-width:0;font-size:15px;line-height:1.95;color:#3a3230}
.faq-atext p{margin:0 0 12px}.faq-atext p:last-child{margin-bottom:0}
.faq-atext ul.link{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:7px}
.faq-atext ul.link a{display:inline-block;color:#803d3c;font-weight:700;text-decoration:underline;text-underline-offset:3px;font-size:13px;line-height:1.6}
.faq-hero-copy{max-width:760px}
@media(max-width:767px){.faq-acc>summary{padding:15px 42px 15px 14px}.faq-qtext{font-size:15px}.faq-a{padding:15px 14px}}

/* service-hero-actions: PCでボタン等幅・等高に統一 2026-06-24 */
@media (min-width:821px){
  .service-hero-actions{display:flex;flex-wrap:wrap;gap:10px}
  .service-hero-actions .button{flex:1 1 auto;min-width:max-content;min-height:52px;white-space:nowrap}
}

/* 心斎橋: wpautopで#main_contents外に出た節の幅制限＋スタイル補正 2026-06-24 */
body.sdp-shinsaibashi-modern .shop_reasons,
body.sdp-shinsaibashi-modern #shop_feature,
body.sdp-shinsaibashi-modern #shop_faq,
body.sdp-shinsaibashi-modern #shop_access{
  width:100%;margin-inline:0;box-sizing:border-box;
}
/* カード説明文の可読性（#main_contentsスコープ外でも適用） */
body.sdp-shinsaibashi-modern .shop_reasons_index .item p,
body.sdp-shinsaibashi-modern .shop_reasons_index .item em.marker{
  color:#504747 !important;font-size:14px !important;line-height:1.9 !important;font-style:normal;
}


/* 心斎橋: 手動アコーディオン(sdp-acc-content)をカード型に揃える(アクセス情報等 sdp-shop-content-section と統一) 2026-06-26 */
body.sdp-shinsaibashi-modern #main_contents .sdp-acc-content.sdp-shop-accordion{padding:0;margin:24px 0 0;overflow:hidden;border:1px solid #e3d7d2;border-radius:8px;background:#fff;box-shadow:0 10px 26px rgb(80 54 50 / 7%)}
body.sdp-shinsaibashi-modern #main_contents .sdp-acc-content.sdp-shop-accordion::before{display:none}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary .sdp-acc-ttl{border:0 !important;padding:0 !important;margin:0 !important;background:transparent !important;font-size:23px !important;line-height:1.5 !important;color:#302829 !important;font-weight:900}
body.sdp-shinsaibashi-modern .sdp-shop-accordion[open]>summary .sdp-acc-ttl{color:#803d3c !important}
@media(max-width:767px){body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary .sdp-acc-ttl{font-size:20px !important}}


/* 心斎橋アコーディオン: タイトル20px統一+前置きspan非表示で全summaryを単一行76pxに揃える 2026-06-26 */
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary h2,body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary h2.heading_02,body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary h2.heading_03,body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary .sdp-acc-ttl{font-size:20px !important;line-height:1.5 !important}
body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary h2 span{display:inline !important;font-size:14px !important;font-weight:800 !important;color:#803d3c !important;margin-right:6px !important}
@media(max-width:767px){body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary h2,body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary h2.heading_02,body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary h2.heading_03,body.sdp-shinsaibashi-modern #main_contents .sdp-shop-accordion>summary .sdp-acc-ttl{font-size:17px !important}}


/* 心斎橋: 閉じたアコーディオン本文を隠す(本文がdisplay:blockで閉でも表示され崩れる不具合の是正) 2026-06-26 */
body.sdp-shinsaibashi-modern .sdp-shop-accordion:not([open]) > .sdp-shop-accordion__body{display:none !important}


/* 心斎橋: 「詳しく見る」ヒントを全バー表示に統一(復元) 2026-06-26 */

/* #shop_feature/#shop_faq/#shop_access のアコーディオン幅を他バー(900px)と統一(860px狭小の是正) 2026-06-26 */
body.sdp-shinsaibashi-modern #shop_feature.sdp-shop-accordion,body.sdp-shinsaibashi-modern #shop_faq.sdp-shop-accordion,body.sdp-shinsaibashi-modern #shop_access.sdp-shop-accordion{width:100% !important;margin-inline:0 !important}


/* 修理事例カテゴリバッジ(.cate)を白抜き(赤背景に濃グレー文字で不可視だった是正) 2026-06-26 */
body.sdp-shinsaibashi-modern .item-voice .cate,body.sdp-shinsaibashi-modern .item-voice_main .cate,body.sdp-shinsaibashi-modern #shop_jirei-voice .cate{color:#fff !important;-webkit-text-fill-color:#fff !important}


/* /kiban/ データ取り出し誤解セクション (2026-06-28) */
#misunderstanding.kiban-data-section{border-color:#e3d4cf;background:#fff}
#misunderstanding .legacy-section-body{padding:clamp(18px,3vw,34px)}
.kiban-data-explain{display:grid;gap:22px}
.kiban-data-hero{border:1px solid #eadbd6;border-left:6px solid var(--brand,#a34f4d);border-radius:8px;background:linear-gradient(135deg,#fff 0%,#fbf6f3 100%);padding:clamp(22px,4vw,38px)}
.kiban-data-eyebrow{margin:0 0 10px;color:var(--brand-dark,#803b3a);font-size:13px;font-weight:900}
.kiban-data-hero h3,.kiban-data-alert h3,.kiban-data-card h3,.kiban-data-policy h3,.kiban-data-note h3,.kiban-data-cta h3{margin:0 0 12px;color:#24272b;font-size:clamp(20px,2.2vw,28px);line-height:1.45;letter-spacing:0}
.kiban-data-hero p,.kiban-data-card p,.kiban-data-policy p,.kiban-data-note p,.kiban-data-cta p{margin:0;color:#3e4146;line-height:1.95}
.kiban-data-hero p+p,.kiban-data-card p+p,.kiban-data-policy p+p{margin-top:12px}
.kiban-data-alert{border-radius:8px;background:#2f3237;color:#fff;padding:clamp(22px,4vw,34px)}
.kiban-data-alert h3{color:#fff}
.kiban-data-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:18px 0 0;padding:0;list-style:none}
.kiban-data-steps li{min-height:180px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:rgba(255,255,255,.08);padding:18px}
.kiban-data-steps span{display:inline-grid;place-items:center;width:38px;height:38px;margin-bottom:12px;border-radius:50%;background:var(--brand,#a34f4d);color:#fff;font-size:13px;font-weight:900}
.kiban-data-steps strong{display:block;color:#fff;font-size:17px;line-height:1.55}
.kiban-data-steps p{margin:8px 0 0;color:rgba(255,255,255,.86);font-size:14px;line-height:1.75}
.kiban-data-compare{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.kiban-data-card,.kiban-data-policy,.kiban-data-note{border:1px solid #e7dfdc;border-radius:8px;background:#fff;padding:clamp(20px,3vw,28px)}
.kiban-data-card--safe{border-top:4px solid #68746c}
.kiban-data-card--risk{border-top:4px solid var(--brand,#a34f4d);background:#fffaf8}
.kiban-data-card a{color:var(--brand-dark,#803b3a);font-weight:900;text-decoration:underline;text-underline-offset:3px}
.kiban-data-policy{border-left:6px solid #68746c;background:#f6f7f5}
.kiban-data-note-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.kiban-data-note h3{font-size:20px}
.kiban-data-cta{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;border-radius:8px;background:#2f3237;padding:clamp(22px,4vw,34px)}
.kiban-data-cta h3,.kiban-data-cta p{color:#fff}
.kiban-data-cta__actions{display:flex;flex-wrap:wrap;gap:10px}
.kiban-data-cta__actions a{display:inline-flex;align-items:center;justify-content:center;min-height:48px;min-width:150px;border:1px solid rgba(255,255,255,.35);border-radius:6px;color:#fff;font-weight:900;text-decoration:none}
.kiban-data-cta__actions a:first-child{border-color:var(--brand,#a34f4d);background:var(--brand,#a34f4d)}
@media(max-width:760px){#misunderstanding .legacy-section-body{padding:14px}.kiban-data-steps,.kiban-data-compare,.kiban-data-note-grid,.kiban-data-cta{grid-template-columns:1fr}.kiban-data-steps li{min-height:auto}.kiban-data-cta__actions a{width:100%}}

/* kiban-data h3 contrast fix: legacy .legacy-restored-content h3 の薄背景を打ち消す (2026-06-28) */
.kiban-data-explain h3{background:transparent !important;padding:0 !important;margin:0 0 12px !important;border-radius:0 !important}
.kiban-data-alert h3,.kiban-data-cta h3{color:#fff !important}

/* service-faq accordion polish: mac-faq-item風カード型に統一 (2026-06-28) */
.service-faq{display:grid;gap:10px;margin-top:6px}
.service-faq details{border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden}
.service-faq details[open]{border-color:var(--brand)}
.service-faq summary{position:relative;display:block;list-style:none;padding:17px 54px 17px 18px;cursor:pointer;font-weight:800;color:#24272b;line-height:1.6}
.service-faq summary::-webkit-details-marker{display:none}
.service-faq summary::after{content:"+";position:absolute;top:50%;right:20px;transform:translateY(-50%);font-size:22px;font-weight:700;color:var(--brand);line-height:1}
.service-faq details[open] summary::after{content:"-"}
.service-faq summary:hover{background:#faf7f6}
.service-faq p{margin:0;padding:2px 18px 18px;color:#5d5e61;line-height:1.9}
