﻿@charset "UTF-8";

/* --- 共通設定 --- */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: min(100px, 9.09vw);
}

body {
  margin: 0;
}

h1,
h2,
h3,
h4,
a,
th,
td,
span,
li {
  font-family: "Zen Maru Gothic", sans-serif;
  color: #333;
}

p {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #333;
}

li {
  list-style: none;
}

a {
  color: #000;
  text-decoration: none;
}

a:hover {
  opacity: 0.8;
}

/* --- コンテナ設定 --- */
img {
  max-width: 100%;
  height: auto;
  border-style: none;
  display: block;
}

/* 消してる要素 */
.sp-header,
.sp,
.sp-fixed-bar {
  display: none;
}

/* アニメーションの動き */
.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition:
    opacity 0.8s ease-out,
    transform 0.8s ease-out;
}

/* 画面に入った時に付与するクラス */
.is-show {
  opacity: 1;
  transform: translateY(0);
}

/* --- ヘッダー --- */
#header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}

.header-container {
  width: 100%;
  margin: 0 auto;
  padding: 0 min(40px, 2.78vw);
}

.header-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: min(16px, 1.11vw) 0;
}

.header-logo img {
  height: min(80px, 5.56vw);
  width: auto;
}

.header-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: min(6px, 0.42vw);
}

.header-address {
  text-align: right;
  font-size: min(13px, 0.9vw);
  line-height: 1.7;
  color: #555;
}

.header-tel a {
  display: flex;
  align-items: center;
  gap: min(8px, 0.56vw);
  color: #333;
}

.header-tel a:hover {
  opacity: 0.7;
}

.header-tel-icon img {
  height: min(24px, 1.67vw);
  width: auto;
}

.header-tel-num {
  font-size: min(28px, 1.94vw);
  font-weight: bold;
  letter-spacing: 0.05em;
  color: #333;
}

/* --- メインビジュアル --- */
.main-v {
  width: 100%;
}

.main-v-container {
  position: relative;
  width: 100%;
  height: 65.63vw;
  background-image: url(../image/top-back1.png);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.main-v-cloud-wrap {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 6.94vw;
  width: 60.69vw;
  z-index: 2;
}

.main-v-cloud-img {
  width: 100%;
  height: auto;
}

.main-v-title {
  width: 52.08vw;
  position: absolute;
  top: 32%;
  left: 50%;
  transform: translateX(-45%);
  text-align: center;
}

.main-v-title h1 {
  font-size: 3.47vw;
  font-weight: bold;
  text-align: center;
}

.main-v-line {
  display: inline;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  background: linear-gradient(transparent 50%, #fff3b5 50%);
  padding-left: 1.39vw;
}

.main-v-line-text {
  font-size: 2.78vw;
}

.main-v-line--1 {
  color: #ff6606;
}

.main-v-line--2 {
  color: #ff8800;
}

.main-v-line--3 {
  color: #4cc2ff;
}

.main-v-line--1 span {
  color: #ff6606;
}

.main-v-line--2 span {
  color: #ff8800;
}

.main-v-line--3 span {
  color: #4cc2ff;
}

.main-v-points {
  position: absolute;
  bottom: 5.56vw;
  left: 50%;
  transform: translateX(-45%);
  display: flex;
  gap: 1.11vw;
  white-space: nowrap;
  z-index: 3;
}

.main-v-point {
  width: 13.4vw;
  height: 13.4vw;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 1.81vw;
  font-weight: bold;
  color: #fff;
  line-height: 1.4;
  white-space: normal;
}

.main-v-point:nth-of-type(1) {
  background-color: rgba(233, 84, 107, 0.9);
}

.main-v-point:nth-of-type(2) {
  background-color: rgba(193, 220, 129, 0.9);
}

.main-v-point:nth-of-type(3) {
  background-color: rgba(255, 136, 0, 0.9);
}

.main-v-photo {
  position: absolute;
  z-index: 2;
}

.main-v-photo--1 {
  right: 3.47vw;
  top: 15.69vw;
  width: 19.03vw;
}

.main-v-photo--2 {
  left: 5.42vw;
  top: 21.74vw;
  width: 18.4vw;
}

.main-v-photo--3 {
  left: 3.75vw;
  bottom: 13.89vw;
  width: 15.35vw;
}

.p1-a {
  position: relative;
  z-index: 5;
  margin-top: max(-50px, -3.47vw);
}

/* --- コンサルテーション --- */
.p1-b {
  padding-top: min(50px, 3.47vw);
}

.p1-b-box {
  text-align: center;
  padding: 0 min(60px, 4.17vw) min(30px, 2.08vw);
}

.p1-b-head {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: min(100px, 6.94vw);
}

.p1-b-hanabi:first-child {
  width: min(135px, 9.38vw);
  height: auto;
  margin-top: min(35px, 2.43vw);
}

.p1-b-hanabi:last-child {
  width: min(201px, 13.96vw);
  height: auto;
}

.p1-b-title {
  font-size: min(80px, 5.56vw);
  font-weight: bold;
  letter-spacing: 0.08em;

  background: linear-gradient(90deg, #ff8a00 0%, #ffb300 45%, #ffe45c 100%);

  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.p1-b-sub {
  text-align: center;
  font-size: min(30px, 2.08vw);
  font-weight: bold;
  color: #333;
  line-height: 1.8;
  margin-top: max(-50px, -3.47vw);
}

.p1-b-sub-em {
  color: #0071bc;
  font-weight: bold;
}

.p1-b-lower {
  background-image: url(../image/top-back3.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}

.p1-b-cards-wrap {
  padding: min(33px, 2.29vw) 0 min(120px, 8.33vw);
  margin-top: min(54px, 3.75vw);
}

.p1-b-cards {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: min(30px, 2.08vw);
}

.p1-b-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(313px, 21.74vw);
}

.p1-b-card-chara {
  height: auto;
  display: block;
  position: relative;
  z-index: 2;
  margin-bottom: min(-30px, -2.08vw);
}

.p1-b-card:nth-of-type(1) .p1-b-card-chara {
  width: min(140px, 9.72vw);
}

.p1-b-card:nth-of-type(2) .p1-b-card-chara {
  width: min(171px, 11.88vw);
}

.p1-b-card:nth-of-type(3) .p1-b-card-chara {
  width: min(156px, 10.83vw);
}

.p1-b-card:nth-of-type(4) .p1-b-card-chara {
  width: min(184px, 12.78vw);
}

.p1-b-card-bubble {
  position: relative;
  z-index: 1;
  width: 100%;
}

.p1-b-card-blob {
  width: 100%;
  height: auto;
  display: block;
}

.p1-b-card-text {
  position: absolute;
  transform: translate(-50%, -50%);
  font-size: min(18px, 1.25vw);
  line-height: 1.6;
  width: 74%;
}

.p1-b-card:nth-of-type(1) .p1-b-card-text {
  top: min(120px, 8.33vw);
  left: 50%;
}

.p1-b-card:nth-of-type(2) .p1-b-card-text {
  top: min(95px, 6.6vw);
  left: 50%;
}

.p1-b-card:nth-of-type(3) .p1-b-card-text {
  top: min(110px, 7.64vw);
  left: 55%;
}

.p1-b-card:nth-of-type(4) .p1-b-card-text {
  top: min(110px, 7.64vw);
  left: 55%;
}

/* --- 治療メニュー --- */
.p1-c {
  background-image: url(../image/top-back6.png), url(../image/top-back5.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position:
    top min(120px, 8.33vw) center,
    top center;
  margin-top: max(-17px, -1.18vw);
}

.p1-c-box {
  display: flex;
  justify-content: center;
}

.p1-c-head {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.p1-c-tooth {
  width: min(217px, 15.07vw);
  height: auto;
  position: absolute;
  top: max(-53px, -3.68vw);
  left: min(120px, 8.33vw);
  z-index: 2;
}

.p1-c-cloud {
  position: relative;
  width: min(812px, 56.39vw);
}

.p1-c-cloud-img {
  width: 100%;
  height: auto;
}

.p1-c-cloud-body {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -60%);
  width: 100%;
  text-align: center;
}

.p1-c-cloud-body p {
  font-size: min(40px, 2.78vw);
  font-family: "Zen Maru Gothic", sans-serif;
  line-height: 1.4;
  font-weight: bold;
}

.p1-c-em {
  color: #ff8800;
}

.p1-c-em2 {
  color: #d4572d;
}

.p1-c-lower {
  position: relative;
  padding-bottom: min(163px, 11.32vw);
}

.p1-c-wave {
  width: 100%;
  height: auto;
  display: block;
}

.p1-c-cards-wrap {
  padding: 0 min(60px, 4.17vw) 0;
}

.p1-c-cards {
  display: flex;
  justify-content: center;
  gap: min(20px, 1.39vw);
  margin-bottom: min(20px, 1.39vw);
}

.p1-c-card {
  width: min(306px, 21.25vw);
  border-radius: 0 0 min(20px, 1.39vw) min(20px, 1.39vw);
  display: flex;
  flex-direction: column;
  position: relative;
}

.p1-c-card--2,
.p1-c-card--4 {
  margin-top: min(60px, 4.17vw);
}

.p1-c-card--1 .p1-c-card-badge {
  background-color: #ff8800;
}

.p1-c-card--2 .p1-c-card-badge {
  background-color: #00b1a2;
}

.p1-c-card--3 .p1-c-card-badge {
  background-color: #fedc5e;
}

.p1-c-card--4 .p1-c-card-badge {
  background-color: #ee87b5;
}

.p1-c-card-badge {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: center;
  gap: min(10px, 0.69vw);
  clip-path: polygon(0 38%, 50% 0, 100% 38%, 100% 100%, 0 100%);
}

.p1-c-card-num {
  font-size: min(48px, 3.33vw);
  color: #fff;
  font-weight: bold;
  line-height: 1;
  padding-top: min(15px, 1.04vw);
}

.p1-c-card-sub {
  font-size: min(24px, 1.67vw);
  font-weight: bold;
  color: #fff;
  padding-bottom: min(15px, 1.04vw);
}

.p1-c-card-photo {
  height: min(207px, 14.38vw);
  position: relative;
  overflow: hidden;
}

.p1-c-card-animal {
  position: absolute;
  width: min(83px, 5.76vw);
  height: auto;
  z-index: 4;
}

.p1-c-card--1 .p1-c-card-animal {
  bottom: min(140px, 9.72vw);
  left: max(-10px, -0.69vw);
}

.p1-c-card--2 .p1-c-card-animal {
  bottom: min(80px, 5.56vw);
  left: max(-10px, -0.69vw);
}

.p1-c-card--3 .p1-c-card-animal {
  bottom: min(140px, 9.72vw);
  right: max(-10px, -0.69vw);
}

.p1-c-card--4 .p1-c-card-animal {
  bottom: min(80px, 5.56vw);
  right: max(-10px, -0.69vw);
}

.p1-c-card-footer {
  border-radius: 0 0 min(20px, 1.39vw) min(20px, 1.39vw);
  background-color: #fff;
}

.p1-c-card-footer a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(20px, 1.39vw);
  padding: min(30px, 2.08vw) 0;
}

.p1-c-card--1 .p1-c-card-footer {
  border: min(7px, 0.49vw) solid #ff8800;
}

.p1-c-card--2 .p1-c-card-footer {
  border: min(7px, 0.49vw) solid #00b1a2;
}

.p1-c-card--3 .p1-c-card-footer {
  border: min(7px, 0.49vw) solid #fedc5e;
}

.p1-c-card--4 .p1-c-card-footer {
  border: min(7px, 0.49vw) solid #ee87b5;
}

.p1-c-card-name {
  font-size: min(20px, 1.39vw);
  font-weight: bold;
  color: #333;
}

.p1-c-card-arrow {
  width: min(22px, 1.53vw);
  height: auto;
}

.p1-c-forest {
  width: min(1108px, 76.94vw);
  height: auto;
  display: block;
  position: absolute;
  left: 50%;
  bottom: max(-94px, -6.53vw);
  z-index: 4;
  transform: translateX(-50%);
}

/* --- 予約・問い合わせ --- */
.p1-d {
  background-color: #faf9f6;
  padding: min(170px, 11.81vw) 0;
}

.p1-d-container {
  width: min(996px, 69.17vw);
  background-color: #ff8800;
  padding: min(10px, 0.69vw);
  border-radius: min(30px, 2.08vw);
  margin: 0 auto;
}

.p1-d-box {
  border-radius: min(20px, 1.39vw);
  display: flex;
  align-items: center;
  position: relative;
  padding: min(36px, 2.5vw) 0;
  overflow: visible;
  border: min(1px, 0.07vw) solid #fff;
}

.p1-d-tooth {
  position: absolute;
  left: min(68px, 4.72vw);
  bottom: max(-15px, -1.04vw);
  width: min(156px, 10.83vw);
  height: auto;
  z-index: 4;
}

.p1-d-content {
  flex: 1;
  text-align: center;
}

.p1-d-catch {
  font-size: min(26px, 1.81vw);
  color: #fff;
  margin-bottom: min(8px, 0.56vw);
}

.p1-d-label {
  font-size: min(32px, 2.22vw);
  color: #fff;
  margin-bottom: min(4px, 0.28vw);
}

.p1-d-tel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(10px, 0.69vw);
}

.p1-d-tel-icon {
  height: min(50px, 3.47vw);
  width: auto;
}

.p1-d-tel-num {
  font-size: min(64px, 4.44vw);
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.02em;
}

.p1-d-tel-num:hover {
  opacity: 0.8;
}

/* --- 院長ご挨拶 --- */
.p1-e {
  background-image: url(../image/part3.png), url(../image/top-back7.png);
  background-repeat: no-repeat;
  background-size:
    100% min(5px, 0.35vw),
    cover;
  background-position:
    bottom,
    top center;
  padding-bottom: min(70px, 4.86vw);
}

.p1-e-box {
  max-width: min(1300px, 90.28vw);
  margin: 0 auto;
}

.p1-e-head {
  display: flex;
  align-items: center;
  gap: min(12px, 0.83vw);
  margin-bottom: min(30px, 2.08vw);
}

.p1-e-head.sp {
  display: none;
}

.p1-e-title {
  font-size: min(40px, 2.78vw);
  font-weight: bold;
  color: #333;
}

.p1-e-animal {
  width: min(137px, 9.51vw);
  height: auto;
}

.p1-e-main {
  display: flex;
  gap: min(40px, 2.78vw);
  align-items: flex-start;
}

.p1-e-left {
  width: min(588px, 40.83vw);
}

.p1-e-right-wrap {
  display: flex;
  flex-direction: column;
  gap: min(20px, 1.39vw);
}

.p1-e-greeting {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-size: min(100px, 6.94vw);
  font-weight: bold;
  color: #8fc320;
  letter-spacing: 0.1em;
  flex-shrink: 0;
  line-height: 1;
}

.p1-e-g {
  color: #25aa37;
}

.p1-e-text {
  flex: 1;
}

.p1-e-text-title {
  font-size: min(26px, 1.81vw);
  font-weight: bold;
  color: #ff8800;
  margin-bottom: min(30px, 2.08vw);
  margin-top: min(10px, 0.69vw);
}

.p1-e-text-title:first-child {
  margin-top: 0;
}

.p1-e-text p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
}

.p1-e-right {
  width: min(688px, 47.78vw);
  display: flex;
  gap: min(40px, 2.78vw);
  flex-shrink: 0;
  position: relative;
  margin-top: min(75px, 5.21vw);
}

.p1-e-photo {
  width: min(564px, 39.17vw);
  border-radius: min(10px, 0.69vw);
  position: relative;
}

.p1-e-photo img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.p1-e-name-box {
  position: absolute;
  bottom: min(75px, 5.21vw);
  left: max(-40px, -2.78vw);
  width: min(226px, 15.69vw);
  height: min(226px, 15.69vw);
  border-radius: 50%;
  background-color: #8fc320;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.p1-e-name-title {
  font-size: min(30px, 2.08vw);
  color: #fff;
}

.p1-e-name-ja {
  font-size: min(40px, 2.78vw);
  color: #fff;
}

.p1-e-name-en {
  font-size: min(24px, 1.67vw);
  color: #fff;
}

.p1-e-deco {
  position: absolute;
  bottom: min(54px, 3.75vw);
  right: min(18px, 1.25vw);
}

.p1-e-right .p1-e-deco {
  width: min(119px, 8.26vw);
  height: auto;
}

.p1-e-welcome {
  width: min(404px, 28.06vw);
  margin: min(40px, 2.78vw) auto 0;
}

/* --- フィーチャー --- */
.p1-f-container {
  padding-top: min(66px, 4.58vw);
}

.p1-f-head {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: min(80px, 5.56vw);
}

.p1-f-garland--l {
  width: min(400px, 27.78vw);
  flex-shrink: 0;
}

.p1-f-garland--r {
  width: min(400px, 27.78vw);
  flex-shrink: 0;
}

.p1-f-head-inner {
  text-align: center;
  padding: min(40px, 2.78vw) 0 min(30px, 2.08vw);
}

.p1-f-title {
  font-size: min(80px, 5.56vw);
  font-weight: bold;
  background: linear-gradient(90deg, #ff8a00 0%, #ffb300 50%, #ffe45c 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: 0.05em;
}

.p1-f-sub {
  font-size: min(32px, 2.22vw);
  margin-top: min(10px, 0.69vw);
  letter-spacing: 0.15em;
}

.p1-f-lower {
  position: relative;
  padding-top: min(60px, 4.17vw);
}

.p1-f-cards-wrap {
  background-image: url(../image/top-back9.png), url(../image/top-back8.png);
  background-repeat: no-repeat;
  background-size:
    100% auto,
    cover;
  background-position: top, center;
  padding-top: min(83px, 5.76vw);
  padding-bottom: min(200px, 13.89vw);
}

.p1-f-card-row {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.p1-f-card-body {
  width: min(616px, 42.78vw);
  flex-shrink: 0;
  background: white;
  border: min(10px, 0.69vw) solid #ff8800;
  border-radius: min(16px, 1.11vw);
  padding: min(75px, 5.21vw) min(42px, 2.92vw) min(27px, 1.88vw);
  position: relative;
  z-index: 2;
  margin-top: min(130px, 9.03vw);
}

.p1-f-card-badge {
  position: absolute;
  top: max(-70px, -4.86vw);
  left: 50%;
  transform: translateX(-50%);
  width: min(138px, 9.58vw);
  height: min(138px, 9.58vw);
  border-radius: 50%;
  background: #ff8800;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
}

.p1-f-card-badge::before {
  content: "";
  position: absolute;
  top: min(5px, 0.35vw);
  right: min(5px, 0.35vw);
  bottom: min(5px, 0.35vw);
  left: min(5px, 0.35vw);
  border-radius: 50%;
  border: min(2px, 0.14vw) dashed white;
}

.p1-f-card-num {
  font-size: min(64px, 4.44vw);
  font-weight: bold;
  color: white;
  margin-bottom: min(5px, 0.35vw);
}

.p1-f-card-title {
  text-align: center;
  font-size: min(32px, 2.22vw);
  line-height: 1.5;
  padding-bottom: min(25px, 1.74vw);
  border-bottom: min(1px, 0.07vw) dashed #ff8800;
}

.p1-f-card-text {
  font-size: min(16px, 1.11vw);
  line-height: 2;
  padding-top: min(17px, 1.18vw);
}

.p1-f-card-right {
  flex-shrink: 0;
  width: min(622px, 43.19vw);
  margin-left: max(-33px, -2.29vw);
  position: relative;
  z-index: 1;
}

.p1-f-card-photo {
  width: 100%;
  height: auto;
}

.p1-f-card-animal {
  position: absolute;
  bottom: min(-35px, -2.43vw);
  right: max(-14px, -0.97vw);
  width: min(250px, 17.36vw);
}

.p1-f-forest {
  width: min(1050px, 72.92vw);
  height: auto;
  position: absolute;
  left: 50%;
  bottom: max(-50px, -3.47vw);
  z-index: 4;
  transform: translateX(-50%);
  display: block;
}

.p1-f-lower2 .p1-f-cards-wrap {
  background-image: url(../image/top-back9.png), url(../image/top-back10.png);
  background-repeat: no-repeat;
  background-size:
    100% auto,
    cover;
  background-position: top, center;
}

.p1-f-lower2 .p1-f-card-row {
  flex-direction: row-reverse;
}

.p1-f-lower2 .p1-f-card-right {
  margin-left: 0;
  margin-right: max(-33px, -2.29vw);
}

.p1-f-lower2 .p1-f-card-animal {
  bottom: max(-85px, -5.9vw);
  left: min(20px, 1.39vw);
  right: auto;
  width: min(256px, 17.78vw);
}

.p1-f-lower2 .p1-f-card-badge {
  background: #00afec;
}

.p1-f-lower2 .p1-f-card-body {
  padding-bottom: min(66px, 4.58vw);
  border: min(10px, 0.69vw) solid #30bef0;
}

.p1-f-lower2 .p1-f-card-title {
  border-bottom: min(1px, 0.07vw) dashed #00afec;
}

.p1-f-lower3 .p1-f-cards-wrap {
  background-image: url(../image/top-back9.png), url(../image/top-back11.png);
  background-repeat: no-repeat;
  background-size:
    100% auto,
    cover;
  background-position: top, center;
}

.p1-f-lower3 .p1-f-card-animal {
  bottom: 0;
  left: auto;
  right: max(-12px, -0.83vw);
  width: min(270px, 18.75vw);
}

.p1-f-lower3 .p1-f-card-badge {
  background: #e9546b;
}

.p1-f-lower3 .p1-f-card-body {
  padding-bottom: min(66px, 4.58vw);
  border: min(10px, 0.69vw) solid #e9546b;
}

.p1-f-lower3 .p1-f-card-title {
  border-bottom: min(1px, 0.07vw) dashed #e9546b;
}

.p1-f-box2 {
  background-image: url(../image/top-back12.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top min(90px, 6.25vw) center;
  position: relative;
  padding-bottom: min(150px, 10.42vw);
  margin-top: min(180px, 12.5vw);
  margin-bottom: min(185px, 12.85vw);
}

.p1-f-cards-v {
  display: flex;
  gap: min(90px, 6.25vw);
  justify-content: center;
}

.p1-f-card-v {
  width: min(572px, 39.72vw);
}

.p1-f-card-v-photo {
  border-radius: min(36px, 2.5vw);
}

.p1-f-card-v-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p1-f-card-v-body {
  width: min(520px, 36.11vw);
  height: min(432px, 30vw);
  background: white;
  border: min(10px, 0.69vw) solid #ff8800;
  border-radius: min(16px, 1.11vw);
  padding: min(77px, 5.35vw) min(30px, 2.08vw) 0;
  position: relative;
  margin: max(-80px, -5.56vw) auto 0;
}

.p1-f-card-v:last-child .p1-f-card-v-body {
  border: min(10px, 0.69vw) solid #00b1a2;
}

.p1-f-card-v:last-child .p1-f-card-badge {
  background: #00b1a2;
}

.p1-f-card-v:last-child .p1-f-card-title {
  border-bottom: min(1px, 0.07vw) dashed #00b1a2;
}

.p1-f-box2 .p1-f-forest {
  width: min(1050px, 72.92vw);
  height: auto;
  position: absolute;
  left: 50%;
  bottom: max(-95px, -6.6vw);
  z-index: 4;
  transform: translateX(-50%);
  display: block;
}

/* こどもの予防歯科・治療 */
.p2-a-container {
  padding-top: min(77px, 5.35vw);
}

.p2-a-box {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  background-image: url(../image/p2-back1.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding-top: min(100px, 6.94vw);
  padding-bottom: min(120px, 8.33vw);
}

.p2-a-text {
  width: min(664px, 46.11vw);
  height: min(370px, 25.69vw);
  background-color: #fff;
  position: relative;
  z-index: 2;
  padding: min(45px, 3.13vw) min(34px, 2.36vw);
  border: min(10px, 0.69vw) solid #ff8800;
  border-radius: min(30px, 2.08vw);
  margin-top: min(82px, 5.69vw);
  margin-right: max(-30px, -2.08vw);
}

.p2-a-text p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
}

.p2-a-img {
  width: min(610px, 42.36vw);
  position: relative;
}

.p2-a-img img:last-child {
  width: min(120px, 8.33vw);
  height: auto;
  position: absolute;
  left: max(-30px, -2.08vw);
  bottom: max(-85px, -5.9vw);
  z-index: 4;
}

.p2-b {
  margin-top: min(64px, 4.44vw);
}

.p2-b-container {
  background-color: #ecf4db;
  padding: min(50px, 3.47vw) 0;
}

.p2-b-title {
  width: min(1280px, 88.89vw);
  text-align: center;
  position: relative;
  background-color: #fff;
  padding: min(30px, 2.08vw) 0;
  border-radius: min(20px, 1.39vw);
  margin: 0 auto;
}

.p2-b-title h2 {
  font-size: min(24px, 1.67vw);
  letter-spacing: 0.05em;
}

.p2-b-title img {
  width: min(127px, 8.82vw);
  height: auto;
  position: absolute;
  left: min(8px, 0.56vw);
  bottom: 0;
  z-index: 4;
}

.p2-b-box {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url(../image/p2-back5.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center center;
  gap: min(40px, 2.78vw);
  margin-top: min(20px, 1.39vw);
}

.p2-b-item {
  width: min(280px, 19.44vw);
  height: min(280px, 19.44vw);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  border-radius: 50%;
  border: min(9px, 0.63vw) solid #ff8800;
}

.p2-b-item:nth-of-type(2) {
  border: min(9px, 0.63vw) solid #f5dd4d;
}

.p2-b-item p {
  font-size: min(24px, 1.67vw);
  font-weight: bold;
  font-family: "Zen Maru Gothic", sans-serif;
  letter-spacing: 0.05em;
}

.p2-c-container {
  background-image: url(../image/p2-back2.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding-bottom: min(40px, 2.78vw);
}

.p2-c-box {
  position: relative;
  display: flex;
  justify-content: center;
}

.p2-c-text {
  width: 60%;
}

.p2-c-text p {
  width: min(674px, 46.81vw);
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
  padding-top: min(75px, 5.21vw);
  margin: 0 auto;
}

.p2-c-img {
  width: 40%;
}

.p2-c-img2 {
  width: min(260px, 18.06vw);
  position: absolute;
  right: 50%;
  bottom: max(-64px, -4.44vw);
  z-index: 4;
}

.p2-c-title {
  width: min(1280px, 88.89vw);
  text-align: center;
  background-color: #ff8800;
  padding: min(22px, 1.53vw) 0;
  margin: min(64px, 4.44vw) auto 0;
}

.p2-c-title h2 {
  font-size: min(24px, 1.67vw);
  color: #fff;
  letter-spacing: 0.05em;
}

.p2-c-box2 {
  width: min(1280px, 88.89vw);
  display: flex;
  margin: min(16px, 1.11vw) auto 0;
}

.p2-c-img3 {
  flex: 1;
}

.p2-c-img3 img {
  width: min(539px, 37.43vw);
  margin: min(40px, 2.78vw) auto 0;
}

.p2-c-text2 {
  flex: 1;
}

.p2-c-text2 p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
}

.p2-c-list {
  width: 100%;
  background-color: #fff;
  padding: min(27px, 1.88vw);
  margin-top: min(18px, 1.25vw);
}

.p2-c-list h3 {
  display: inline-block;
  font-size: min(24px, 1.67vw);
  font-weight: 400;
  color: #fff;
  letter-spacing: 0.05em;
  background-color: #ff8800;
  padding: min(4px, 0.28vw) min(10px, 0.69vw);
}

.p2-c-list ul li {
  font-size: min(16px, 1.11vw);
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: min(10px, 0.69vw);
  padding-top: min(20px, 1.39vw);
}

.p2-c-list ul li img {
  width: min(18px, 1.25vw);
}

/* p2-d 子どもの予防歯科 */
.p2-d {
  padding-top: min(95px, 6.6vw);
}

.p2-d-container {
  background-image: url(../image/p2-back3.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding: min(157px, 10.9vw) 0 min(182px, 12.64vw);
}

.p2-d-box {
  width: min(1166px, 80.97vw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: min(28px, 1.94vw);
}

.p2-d-card {
  background-color: #fff;
  border-radius: min(28px, 1.94vw);
  padding: min(17px, 1.18vw) min(40px, 2.78vw) min(40px, 2.78vw);
  position: relative;
  overflow: visible;
}

.p2-d-card-inner {
  display: flex;
  justify-content: space-between;
  gap: min(50px, 3.47vw);
}

.p2-d-card-text {
  width: min(664px, 46.11vw);
}

.p2-d-card-text h3 {
  font-size: min(20px, 1.39vw);
  font-weight: 400;
  padding: min(20px, 1.39vw) 0;
  line-height: 1.4;
  border-bottom: min(1px, 0.07vw) dashed #4cc2ff;
}

.p2-d-card-text p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
  padding-top: min(26px, 1.81vw);
}

.p2-d-card-img {
  width: min(388px, 26.94vw);
  flex-shrink: 0;
}

.p2-d-card-img img {
  width: 100%;
  height: auto;
}

.p2-d-deco {
  position: absolute;
  height: auto;
}

.p2-d-deco--1 {
  width: min(160px, 11.11vw);
  left: 50%;
  bottom: min(5px, 0.35vw);
}

.p2-d-deco--2 {
  width: min(80px, 5.56vw);
  left: max(-30px, -2.08vw);
  bottom: max(-10px, -0.69vw);
}

.p2-d-deco--3 {
  width: min(142px, 9.86vw);
  right: min(340px, 23.61vw);
  bottom: max(-73px, -5.07vw);
}

/* p2-e あいうべ体操 */
.p2-e {
  margin-top: min(89px, 6.18vw);
}

.p2-e .h2-title.h2-title1 {
  border-top: min(10px, 0.69vw) solid #ff8800;
  border-bottom: min(10px, 0.69vw) solid #ff8800;
}

.p2-e-box {
  background-image: url(../image/p2-back4.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding: min(122px, 8.47vw) 0 min(633px, 43.96vw);
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: min(20px, 1.39vw);
}

.p2-e-logo2 {
  width: min(587px, 40.76vw);
  margin: 0 auto;
}

.p2-e-logo {
  width: min(790px, 54.86vw);
  height: auto;
  margin-bottom: min(96px, 6.67vw);
}

.p2-e-intro {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(57px, 3.96vw);
  margin-bottom: min(60px, 4.17vw);
}

.p2-e-intro-text {
  width: min(618px, 42.92vw);
}

.p2-e-intro-text h3 {
  font-size: min(24px, 1.67vw);
  font-weight: bold;
  color: #ff8800;
  padding-bottom: min(14px, 0.97vw);
  border-bottom: min(1px, 0.07vw) dashed #ff8800;
}

.p2-e-intro-text span {
  font-size: min(20px, 1.39vw);
  color: #ff8800;
}

.p2-e-intro-text p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
  margin-top: min(26px, 1.81vw);
}

.p2-e-intro-img {
  width: min(460px, 31.94vw);
  flex-shrink: 0;
}

.p2-e-banner {
  width: min(674px, 46.81vw);
  background-image: url(../image/p2-back6.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding: min(27px, 1.88vw) 0 min(50px, 3.47vw);
  margin: 0 auto min(56px, 3.89vw);
  text-align: center;
}

.p2-e-banner p {
  color: #fff;
  font-size: min(32px, 2.22vw);
  font-family: "Zen Maru Gothic", sans-serif;
  letter-spacing: 0.05em;
}

.p2-e-list {
  width: min(992px, 68.89vw);
  background-color: #fff;
  border-radius: min(28px, 1.94vw);
  padding: min(42px, 2.92vw) min(74px, 5.14vw) min(18px, 1.25vw);
  margin-bottom: min(170px, 11.81vw);
}

.p2-e-item {
  display: flex;
  align-items: center;
  gap: min(120px, 8.33vw);
  padding: min(38px, 2.64vw) 0;
  border-bottom: min(1px, 0.07vw) dashed #ff8800;
}

.p2-e-item:last-child {
  border-bottom: none;
}

.p2-e-item img {
  width: min(307px, 21.32vw);
  height: auto;
  flex-shrink: 0;
}

.p2-e-item p {
  font-size: min(20px, 1.39vw);
  font-weight: bold;
  font-family: "Zen Maru Gothic", sans-serif;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.p2-e-outro {
  font-size: min(24px, 1.67vw);
  text-align: center;
  position: relative;
  line-height: 1.9;
  margin-bottom: min(45px, 3.13vw);
}

/* 左画像 */
.p2-e-outro::before {
  content: "";
  position: absolute;
  top: 50%;
  left: max(-60px, -4.17vw);
  transform: translateY(-50%);
  width: min(42px, 2.92vw);
  height: min(42px, 2.92vw);
  background-image: url(../image/part21.png);
  background-repeat: no-repeat;
  background-size: contain;
}

/* 右画像 */
.p2-e-outro::after {
  content: "";
  position: absolute;
  top: 50%;
  right: max(-60px, -4.17vw);
  transform: translateY(-50%);
  width: min(42px, 2.92vw);
  height: min(42px, 2.92vw);
  background-image: url(../image/part22.png);
  background-repeat: no-repeat;
  background-size: contain;
}

.p2-e-effects {
  text-align: center;
}

.p2-e-effects h3 {
  display: inline-block;
  color: #fff;
  font-size: min(24px, 1.67vw);
  font-weight: 400;
  text-align: center;
  background-color: #ff8800;
  padding: min(10px, 0.69vw) min(25px, 1.74vw);
  border-radius: min(30px, 2.08vw) min(30px, 2.08vw) 0 0;
}

.p2-e-effects ul {
  width: min(784px, 54.44vw);
  list-style: none;
  padding: min(62px, 4.31vw) min(109px, 7.57vw);
  border: min(5px, 0.35vw) solid #ff8800;
  border-radius: min(27px, 1.88vw);
  margin: 0;
}

.p2-e-effects li {
  display: flex;
  align-items: center;
  gap: min(10px, 0.69vw);
  padding: min(10px, 0.69vw) 0;
  font-size: min(16px, 1.11vw);
  line-height: 1.6;
}

.p2-e-effects li img {
  width: min(18px, 1.25vw);
}

/* p3-a 子供の歯並び治療 */
.p3-a {
  padding-top: min(77px, 5.35vw);
}

.p3-a-container {
  background-image: url(../image/p2-back1.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding: min(96px, 6.67vw) 0 min(70px, 4.86vw);
}

.p3-a-box {
  width: min(1280px, 88.89vw);
  margin: 0 auto;
}

.p3-a-content {
  display: flex;
  align-items: flex-start;
  gap: min(55px, 3.82vw);
}

.p3-a-text {
  width: min(640px, 44.44vw);
}

.p3-a-catch {
  font-size: min(32px, 2.22vw);
  font-weight: bold;
  line-height: 1.6;
  color: #6f5545;
  padding-bottom: min(10px, 0.69vw);
  border-bottom: min(3px, 0.21vw) dashed #ff8800;
  margin-bottom: min(20px, 1.39vw);
}

.p3-a-lead {
  font-size: min(16px, 1.11vw);
  font-weight: bold;
  line-height: 2;
  letter-spacing: 0.05em;
  margin-bottom: min(30px, 2.08vw);
}

.p3-a-section {
  margin-bottom: min(24px, 1.67vw);
}

.p3-a-section h3 {
  font-size: min(26px, 1.81vw);
  font-weight: bold;
  color: #0080c2;
  margin-bottom: min(25px, 1.74vw);
}

.p3-a-section p {
  font-size: min(16px, 1.11vw);
  font-weight: bold;
  line-height: 2;
  letter-spacing: 0.05em;
}

.p3-a-img {
  width: min(585px, 40.63vw);
  flex-shrink: 0;
  position: relative;
  margin-top: min(50px, 3.47vw);
}

.p3-a-img img {
  width: 100%;
  height: auto;
}

.p3-a-img .p3-a-deco {
  width: min(367px, 25.49vw);
  display: block;
  position: absolute;
  left: max(-37px, -2.57vw);
  bottom: min(-46px, -3.19vw);
  z-index: 4;
}

/* p3-b 相談ボックス */
.p3-b {
  padding-top: min(50px, 3.47vw);
}

.p3-b-container {
  background: linear-gradient(
    to bottom,
    #fff 0,
    #fff min(130px, 9.03vw),
    #ffe599 min(130px, 9.03vw),
    #ffe599 100%
  );
  position: relative;
  padding-bottom: min(80px, 5.56vw);
}

.p3-b-box {
  width: min(1280px, 88.89vw);
  border: min(11px, 0.76vw) solid #ff8800;
  border-radius: min(46px, 3.19vw);
  padding: min(24px, 1.67vw) min(30px, 2.08vw) min(64px, 4.44vw);
  background-color: #fff;
  position: relative;
  margin: 0 auto;
}

.p3-b-en {
  font-size: min(70px, 4.86vw);
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.1em;
  margin-bottom: min(10px, 0.69vw);
  background: linear-gradient(90deg, #ff8a00 0%, #ffb300 45%, #ffe45c 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.p3-b-title {
  background-color: #ff8800;
  border-radius: min(50px, 3.47vw);
  padding: min(14px, 0.97vw) min(40px, 2.78vw);
  text-align: center;
  margin-bottom: min(30px, 2.08vw);
}

.p3-b-title p {
  color: #fff;
  font-size: min(32px, 2.22vw);
  font-weight: bold;
}

.p3-b-list {
  width: min(1056px, 73.33vw);
  display: flex;
  gap: min(130px, 9.03vw);
  margin: 0 auto;
}

.p3-b-col {
  flex: 1;
}

.p3-b-item {
  display: flex;
  align-items: center;
  gap: min(12px, 0.83vw);
  padding: min(20px, 1.39vw) 0;
  border-bottom: min(1px, 0.07vw) dashed #e0e0e0;
}

.p3-b-item p {
  font-size: min(22px, 1.53vw);
}

.p3-b-item img {
  width: min(18px, 1.25vw);
}

.p3-b-flowers {
  width: min(852px, 59.17vw);
  height: auto;
  position: absolute;
  left: 50%;
  bottom: max(-54px, -3.75vw);
  z-index: 4;
  transform: translateX(-50%);
  display: block;
}

/* p3-c 治療の進め方 */
.p3-c {
  padding: min(140px, 9.72vw) 0 0;
}

.p3-c-container {
  background-image: url(../image/top-back5.png);
  background-repeat: no-repeat;
  background-size: cover;
  padding: min(62px, 4.31vw) 0 min(100px, 6.94vw);
}

.p3-c-box {
  width: min(1280px, 88.89vw);
  margin: 0 auto;
}

.p3-c-title {
  text-align: center;
  background-color: #ff8800;
  padding: min(15px, 1.04vw) 0;
  margin-bottom: min(50px, 3.47vw);
}

.p3-c-title h2 {
  color: #fff;
  font-size: min(32px, 2.22vw);
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.1em;
}

.p3-c-text {
  width: min(1158px, 80.42vw);
  margin: 0 auto;
}

.p3-c-text p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
}

/* p3-d 小児矯正のメリット */
.p3-d {
  padding-top: min(80px, 5.56vw);
  padding-bottom: min(330px, 22.92vw);
}

.p3-d-container {
  background-image: url(../image/p2-back3.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding: min(148px, 10.28vw) 0 min(130px, 9.03vw);
  margin-top: min(30px, 2.08vw);
}

.p3-d-box {
  width: min(1200px, 83.33vw);
  margin: 0 auto;
}

.p3-d-points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(45px, 3.13vw) min(60px, 4.17vw);
  margin-bottom: min(150px, 10.42vw);
}

.p3-d-point {
  background-color: #fff;
  position: relative;
  border-radius: min(28px, 1.94vw);
  padding: min(40px, 2.78vw) min(25px, 1.74vw);
}

.p3-d-point-label {
  font-size: min(32px, 2.22vw);
  font-weight: bold;
  color: #ff8800;
  position: absolute;
  left: min(10px, 0.69vw);
  top: max(-38px, -2.64vw);
  z-index: 4;
}

.p3-d-point:nth-of-type(even) .p3-d-point-label {
  color: #0098e5;
}

.p3-d-point-label span {
  font-size: min(40px, 2.78vw);
  color: #ff8800;
}

.p3-d-point:nth-of-type(even) .p3-d-point-label span {
  color: #0098e5;
}

.p3-d-point p:not(.p3-d-point-label) {
  font-size: min(16px, 1.11vw);
  font-weight: bold;
  line-height: 1.8;
}

.p3-d-info {
  display: flex;
  justify-content: center;
  gap: min(112px, 7.78vw);
}

.p3-d-info-card {
  width: min(539px, 37.43vw);
  background-color: #fff;
  padding: min(60px, 4.17vw) min(38px, 2.64vw) min(30px, 2.08vw);
  position: relative;
  border: min(10px, 0.69vw) solid #4cc2ff;
}

.p3-d-info-card.p3-d-info-card--blue {
  border: min(10px, 0.69vw) solid #009ded;
}

.p3-d-info-head {
  width: min(276px, 19.17vw);
  display: inline-block;
  color: #fff;
  font-size: min(24px, 1.67vw);
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: bold;
  letter-spacing: 0.05em;
  text-align: center;
  position: absolute;
  top: min(-38px, -2.64vw);
  left: 50%;
  z-index: 4;
  transform: translateX(-50%);
  padding: min(15px, 1.04vw) 0;
}

.p3-d-info-card--orange .p3-d-info-head {
  background-color: #4cc2ff;
}

.p3-d-info-card--blue .p3-d-info-head {
  background-color: #009ded;
}

.p3-d-info-body {
  background-color: #fff;
  padding: min(20px, 1.39vw) min(24px, 1.67vw) min(24px, 1.67vw);
}

.p3-d-info-body h3 {
  font-size: min(20px, 1.39vw);
  color: #ff8800;
  margin-bottom: min(10px, 0.69vw);
}

.p3-d-info-body p {
  font-size: min(16px, 1.11vw);
  line-height: 1.8;
  letter-spacing: 0.05em;
}

/* p4-a 料金表 */
.p4-a {
  padding-top: min(77px, 5.35vw);
  padding-bottom: min(390px, 27.08vw);
}

.p4-a-container {
  background-image: url(../image/p4-back1.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  position: relative;
  padding: min(87px, 6.04vw) 0 min(200px, 13.89vw);
}

.p4-a-box {
  width: min(1080px, 75vw);
  margin: 0 auto;
}

.p4-a-lead {
  text-align: center;
  font-size: min(24px, 1.67vw);
  font-weight: bold;
  color: #6f5545;
  letter-spacing: 0.05em;
  margin-top: min(42px, 2.92vw);
}

.p4-a-tables {
  display: flex;
  gap: min(40px, 2.78vw);
  margin-bottom: min(50px, 3.47vw);
}

.p4-a-table {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.p4-a-row {
  display: flex;
  border: min(2px, 0.14vw) solid #ff8800;
  overflow: hidden;
}

.p4-a-row:first-child {
  border-bottom: none;
}

.p4-a-name {
  width: min(214px, 14.86vw);
  padding: min(30px, 2.08vw) 0 min(25px, 1.74vw) min(45px, 3.13vw);
  font-size: min(16px, 1.11vw);
  border-right: min(2px, 0.14vw) solid #ff8800;
  background-color: #fff3b5;
}

.p4-a-price {
  width: min(327px, 22.71vw);
  padding: min(30px, 2.08vw) 0;
  font-size: min(16px, 1.11vw);
  text-align: center;
  background-color: #fff;
}

.p4-a-medical {
  width: min(1134px, 78.75vw);
  border: min(5px, 0.35vw) solid #ff8800;
  border-radius: min(28px, 1.94vw);
  background-color: #fff;
  padding: min(25px, 1.74vw) min(40px, 2.78vw);
  margin: 0 auto;
}

.p4-a-medical-head {
  background-color: #ff8800;
  color: #fff;
  font-size: min(20px, 1.39vw);
  font-weight: bold;
  text-align: center;
  padding: min(12px, 0.83vw) min(20px, 1.39vw);
}

.p4-a-medical-body {
  padding-top: min(25px, 1.74vw);
}

.p4-a-medical-body p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
}

.p4-a-nature {
  width: min(1050px, 72.92vw);
  position: absolute;
  left: 50%;
  bottom: max(-60px, -4.17vw);
  z-index: 4;
  transform: translateX(-50%);
}

/* p5-a よくあるご質問 */
.p5-a {
  padding-top: min(77px, 5.35vw);
  padding-bottom: min(150px, 10.42vw);
}

.p5-a-container {
  background-image: url(../image/p5-back1.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding: min(85px, 5.9vw) 0 min(235px, 16.32vw);
  margin-top: min(58px, 4.03vw);
}

.p5-a-box {
  width: min(1280px, 88.89vw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: min(60px, 4.17vw);
}

.p5-a-item {
  border-radius: min(27px, 1.88vw);
  overflow: hidden;
  background-color: #fff;
}

.p5-a-q {
  display: flex;
  align-items: stretch;
  background-color: #ff8800;
}

.p5-a-label--q {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(83px, 5.76vw);
  background-color: #76ac33;
  color: #fff;
  font-size: min(40px, 2.78vw);
  font-weight: bold;
  flex-shrink: 0;
}

.p5-a-q p {
  padding: min(20px, 1.39vw) min(36px, 2.5vw);
  font-size: min(24px, 1.67vw);
  line-height: 1.6;
  color: #fff;
  border-left: min(2px, 0.14vw) solid #fff;
}

.p5-a-a {
  border: min(2px, 0.14vw) solid #ff8800;
  border-top: none;
  border-radius: 0 0 min(27px, 1.88vw) min(27px, 1.88vw);
  padding: min(30px, 2.08vw) min(36px, 2.5vw);
}

.p5-a-a p {
  font-size: min(16px, 1.11vw);
  font-weight: bold;
  line-height: 2;
}

.p5-a-a p + p {
  margin-top: min(30px, 2.08vw);
}

/* p6-a 院長紹介 */
.p6-a {
  padding-top: min(77px, 5.35vw);
  padding-bottom: min(100px, 6.94vw);
}

.p6-a-container {
  background-image: url(../image/p6-back1.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: top min(130px, 9.03vw) center;
  padding: min(85px, 5.9vw) 0 min(80px, 5.56vw);
}

.p6-a-box {
  width: min(1300px, 90.28vw);
  margin: 0 auto;
}

.p6-a-main {
  display: flex;
  justify-content: space-between;
  gap: min(30px, 2.08vw);
  align-items: flex-start;
}

.p6-a-left {
  width: min(604px, 41.94vw);
}

.p6-a-title {
  font-size: min(40px, 2.78vw);
  font-weight: bold;
  color: #333;
  margin-bottom: min(150px, 10.42vw);
}

.p6-a-subtitle {
  font-size: min(26px, 1.81vw);
  font-weight: bold;
  color: #ff8800;
  margin-bottom: min(30px, 2.08vw);
}

.p6-a-text p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
}

.p6-a-name {
  display: flex;
  align-items: center;
  gap: min(16px, 1.11vw);
  padding-bottom: min(15px, 1.04vw);
  padding-left: min(60px, 4.17vw);
  border-bottom: min(4px, 0.28vw) dashed #25aa37;
  margin-top: min(90px, 6.25vw);
}

.p6-a-name img {
  width: min(53px, 3.68vw);
  height: auto;
}

.p6-a-name-text {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(30px, 2.08vw);
}

.p6-a-name-role {
  font-size: min(30px, 2.08vw);
  font-weight: bold;
}

.p6-a-name-ja {
  font-size: min(40px, 2.78vw);
  font-weight: bold;
  line-height: 1.2;
}

.p6-a-name-en {
  font-size: min(24px, 1.67vw);
  font-weight: bold;
  color: #25aa37;
  letter-spacing: 0.05em;
}

.p6-a-right {
  width: min(564px, 39.17vw);
  position: relative;
  flex-shrink: 0;
  margin-top: min(47px, 3.26vw);
}

.p6-a-photo {
  border-radius: min(42px, 2.92vw);
}

.p6-a-photo img {
  width: 100%;
  height: auto;
  display: block;
}

.p6-a-welcome {
  width: min(404px, 28.06vw);
  margin: min(40px, 2.78vw) auto 0;
}

.p6-a-welcome img {
  width: 100%;
  height: auto;
}

.p6-a-img {
  width: min(119px, 8.26vw);
  position: absolute;
  right: min(20px, 1.39vw);
  bottom: min(60px, 4.17vw);
  z-index: 4;
}

/* p6-b 経歴・写真 */
.p6-b {
  padding: min(83px, 5.76vw) 0 min(320px, 22.22vw);
}

.p6-b-box {
  width: min(1270px, 88.19vw);
  margin: 0 auto;
}

.p6-b-cards {
  display: flex;
  justify-content: space-between;
  margin-bottom: min(117px, 8.13vw);
}

.p6-b-card {
  width: min(376px, 26.11vw);
  border: min(2px, 0.14vw) solid #ff8800;
  border-radius: min(25px, 1.74vw);
  background-color: #fff;
  padding: 0 min(20px, 1.39vw) min(40px, 2.78vw);
  overflow: visible;
  position: relative;
}

.p6-b-card-head {
  text-align: center;
  position: relative;
  padding: min(20px, 1.39vw) 0;
  border-bottom: min(4px, 0.28vw) dashed #ff8800;
}

.p6-b-card-head p {
  font-size: min(24px, 1.67vw);
  line-height: 1.4;
  letter-spacing: 0.05em;
}

.p6-b-card-animal1 {
  position: absolute;
  top: max(-45px, -3.13vw);
  right: max(-45px, -3.13vw);
  width: min(155px, 10.76vw);
  height: auto;
}

.p6-b-card-animal2 {
  position: absolute;
  bottom: max(-16px, -1.11vw);
  right: max(-28px, -1.94vw);
  width: min(132px, 9.17vw);
  height: auto;
}

.p6-b-card-animal3 {
  position: absolute;
  top: max(-24px, -1.67vw);
  left: max(-20px, -1.39vw);
  width: min(79px, 5.49vw);
  height: auto;
}

.p6-b-card-animal4 {
  position: absolute;
  top: max(-24px, -1.67vw);
  right: max(-20px, -1.39vw);
  width: min(79px, 5.49vw);
  height: auto;
}

.p6-b-card-body {
  padding-top: min(20px, 1.39vw);
}

.p6-b-card-list {
  list-style: none;
  display: flex;
  flex-direction: column;
}

.p6-b-card-list li {
  font-size: min(16px, 1.11vw);
  font-weight: bold;
  line-height: 1.6;
  color: #444;
  padding-left: min(25px, 1.74vw);
  padding-top: min(15px, 1.04vw);
}

.p6-b-photos {
  display: flex;
  gap: min(65px, 4.51vw);
  align-items: center;
  justify-content: center;
}

.p6-b-photo {
  width: min(622px, 43.19vw);
}

.p6-b-photo img {
  width: 100%;
  height: auto;
  display: block;
}

/* p7-a 医院案内 */
.p7-a {
  padding-top: min(90px, 6.25vw);
}

.p7-a-container {
  background-image: url(../image/p7-back1.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding-top: min(145px, 10.07vw);
  padding-bottom: min(525px, 36.46vw);
  margin: min(40px, 2.78vw) auto 0;
}

.p7-a-box {
  width: min(1200px, 83.33vw);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin: 0 auto min(100px, 6.94vw);
}

.p7-a-info {
  display: flex;
  flex-direction: column;
}

.p7-a-info-row {
  display: flex;
  align-items: baseline;
  gap: min(90px, 6.25vw);
  padding: min(25px, 1.74vw) 0 min(25px, 1.74vw) min(10px, 0.69vw);
  border-bottom: min(1px, 0.07vw) solid #909090;
}

.p7-a-info dt {
  width: min(80px, 5.56vw);
  font-size: min(16px, 1.11vw);
  flex-shrink: 0;
}

.p7-a-info dd {
  font-size: min(16px, 1.11vw);
  line-height: 1.7;
}

.p7-a-table2 {
  width: min(476px, 33.06vw);
  padding: min(16px, 1.11vw) min(23px, 1.6vw);
  background-color: #fff;
}

.p7-a-table2 .footer-hours-notes {
  padding-left: min(10px, 0.69vw);
  margin-bottom: 0;
}

.p7-a-box2 {
  width: min(1000px, 69.44vw);
  margin: 0 auto;
}

.p7-a-credit {
  background-color: #fff;
  padding: min(30px, 2.08vw) min(35px, 2.43vw);
  border: min(5px, 0.35vw) solid #ff8800;
  border-radius: min(28px, 1.94vw);
}

.p7-a-credit-head {
  width: 100%;
  background-color: #ff8800;
  color: #fff;
  font-size: min(20px, 1.39vw);
  font-weight: bold;
  text-align: center;
  padding: min(10px, 0.69vw) 0;
}

.p7-a-credit-body {
  padding: min(30px, 2.08vw) 0 min(50px, 3.47vw);
  text-align: center;
}

.p7-a-credit-body p {
  font-size: min(16px, 1.11vw);
  font-weight: bold;
}

.p7-a-credit-body img {
  width: min(765px, 53.13vw);
  height: auto;
  margin: min(30px, 2.08vw) auto 0;
}

.p7-b {
  margin-top: max(-380px, -26.39vw);
}

.p7-b-box {
  width: min(1200px, 83.33vw);
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
}

.p7-b-item {
  width: min(534px, 37.08vw);
  text-align: center;
}

.p7-b-item:last-child {
  width: min(587px, 40.76vw);
}

.p7-b-item h3 {
  display: inline-block;
  font-size: min(24px, 1.67vw);
  font-weight: 400;
  color: #fff;
  padding: min(15px, 1.04vw) min(75px, 5.21vw);
  margin-bottom: min(26px, 1.81vw);
}

.p7-b-item:first-child h3 {
  background-color: #4cc2ff;
}

.p7-b-item:last-child h3 {
  background-color: #009ded;
}

.p7-b-box2 {
  width: min(1200px, 83.33vw);
  display: flex;
  align-items: flex-start;
  gap: min(47px, 3.26vw);
  margin: min(38px, 2.64vw) auto min(176px, 12.22vw);
}

.p7-b-item2 {
  width: min(534px, 37.08vw);
}

.p7-b-item3 {
  width: min(602px, 41.81vw);
  position: relative;
  margin-top: min(43px, 2.99vw);
}

.p7-b-item3 p {
  width: min(532px, 36.94vw);
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
  color: #fff;
  background-image: url(../image/part23.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  padding: min(23px, 1.6vw) 0 min(23px, 1.6vw) min(105px, 7.29vw);
}

.p7-b-item3 img {
  width: min(296px, 20.56vw);
  position: absolute;
  bottom: max(-154px, -10.69vw);
  right: 0;
  z-index: 4;
}

.p7-c-container {
  background-image: url(../image/p7-back2.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding-bottom: min(50px, 3.47vw);
  margin-top: min(60px, 4.17vw);
}

.p7-c-box {
  width: min(1280px, 88.89vw);
  display: grid;
  grid-template-columns: repeat(2, min(600px, 41.67vw));
  gap: min(34px, 2.36vw) min(80px, 5.56vw);
  padding-top: min(95px, 6.6vw);
  margin: 0 auto;
}

.p7-c-item {
  display: flex;
  flex-direction: column;
}

.p7-c-text {
  flex: 1;
  background-color: #fff;
  padding: min(14px, 0.97vw) min(66px, 4.58vw) min(30px, 2.08vw)
    min(48px, 3.33vw);
}

.p7-c-text h3 {
  font-size: min(20px, 1.39vw);
  font-weight: 400;
  color: #ff8800;
  letter-spacing: 0.05em;
}

.p7-c-text p {
  font-size: min(16px, 1.11vw);
  line-height: 2;
  letter-spacing: 0.05em;
  padding-top: min(5px, 0.35vw);
}

.p7-c-box2 {
  width: min(1130px, 78.47vw);
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  padding-top: min(75px, 5.21vw);
  margin: 0 auto;
}

.p7-c-item2 {
  width: min(315px, 21.88vw);
  display: flex;
  flex-direction: column;
}

.p7-c-item2 .p7-c-text {
  flex: 1;
  padding: min(20px, 1.39vw) min(20px, 1.39vw) min(10px, 0.69vw);
}

.p7-d-container {
  position: relative;
  background-image: url(../image/p7-back3.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding-bottom: min(345px, 23.96vw);
  margin-bottom: min(165px, 11.46vw);
}

.p7-d-img {
  width: min(1050px, 72.92vw);
  position: absolute;
  left: 50%;
  bottom: max(-25px, -1.74vw);
  z-index: 4;
  transform: translateX(-50%);
}

/* 下層共通メイン */
.sub-v {
  height: 36.11vw;
  background-image: url(../image/sub-back.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: relative;
}

.sub-v-container {
  width: 100%;
  height: 100%;
}

.sub-v-box {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.sub-v-title {
  font-size: min(40px, 2.78vw);
  font-weight: bold;
  color: #000;
  text-shadow:
    0 0 min(2px, 0.14vw) #fff,
    0 0 min(4px, 0.28vw) #fff,
    0 0 min(6px, 0.42vw) #fff,
    0 0 min(9px, 0.63vw) rgba(255, 255, 255, 0.99),
    min(2px, 0.14vw) min(2px, 0.14vw) min(4px, 0.28vw) #fff,
    max(-2px, -0.14vw) max(-2px, -0.14vw) min(4px, 0.28vw) #fff,
    max(-2px, -0.14vw) max(2px, 0.14vw) min(4px, 0.28vw) #fff,
    min(2px, 0.14vw) max(-2px, -0.14vw) min(4px, 0.28vw) #fff;
  line-height: 1.4;
  letter-spacing: 0.05em;
}

.sub-nav {
  position: relative;
  z-index: 5;
  margin-top: max(-32px, -2.22vw);
}

/* 共通タイトル */
.h2-title {
  text-align: center;
  position: relative;
}

.h2-title h2 {
  font-size: min(50px, 3.47vw);
  background: linear-gradient(90deg, #ff8a00 0%, #ffb300 45%, #ffe45c 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.h2-title p {
  font-size: min(20px, 1.39vw);
  font-weight: bold;
  font-family: "Zen Maru Gothic", sans-serif;
  color: #ff8800;
  letter-spacing: 0.05em;
}

.h2-title img:first-child {
  height: auto;
  position: absolute;
  bottom: max(-10px, -0.69vw);
  z-index: 4;
}

.h2-title img:last-child {
  width: min(106px, 7.36vw);
  height: auto;
  position: absolute;
  bottom: max(-10px, -0.69vw);
  z-index: 4;
}

.h2-title.h2-title1 {
  border-top: min(10px, 0.69vw) solid #c6ecff;
  border-bottom: min(10px, 0.69vw) solid #c6ecff;
}

.h2-title1 img:first-child {
  width: min(66px, 4.58vw);
  left: calc(335 / 1440 * 100vw);
}

.h2-title1 img:last-child {
  width: min(106px, 7.36vw);
  right: calc(306 / 1440 * 100vw);
}

.h2-title.h2-title2 {
  border-top: min(10px, 0.69vw) solid #cfdfbb;
  border-bottom: min(10px, 0.69vw) solid #cfdfbb;
}

.h2-title2 img:first-child {
  width: min(118px, 8.19vw);
  left: calc(335 / 1440 * 100vw);
}

.h2-title2 img:last-child {
  width: min(66px, 4.58vw);
  right: calc(306 / 1440 * 100vw);
}

/* --- ナビゲーション --- */
.nav {
  width: 100%;
  background-color: #fffbe0;
}

.nav-container {
  padding: min(28px, 1.94vw) min(60px, 4.17vw) min(20px, 1.39vw);
}

.nav-list {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.nav-item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(8px, 0.56vw);
  color: #555;
}

.nav-item a:hover {
  opacity: 0.8;
}

.nav-icon-wrap {
  width: min(49px, 3.4vw);
  height: min(49px, 3.4vw);
  border-radius: 50%;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.nav-icon-wrap img {
  height: auto;
  display: block;
}

.nav-item:nth-of-type(1) .nav-icon-wrap img {
  width: min(23px, 1.6vw);
}

.nav-item:nth-of-type(2) .nav-icon-wrap img {
  width: min(34px, 2.36vw);
}

.nav-item:nth-of-type(3) .nav-icon-wrap img {
  width: min(51px, 3.54vw);
}

.nav-item:nth-of-type(4) .nav-icon-wrap img {
  width: min(28px, 1.94vw);
}

.nav-item:nth-of-type(5) .nav-icon-wrap img {
  width: min(34px, 2.36vw);
}

.nav-item:nth-of-type(6) .nav-icon-wrap img {
  width: min(31px, 2.15vw);
}

.nav-item:nth-of-type(7) .nav-icon-wrap img {
  width: min(36px, 2.5vw);
}

.nav-label {
  font-size: min(20px, 1.39vw);
  font-weight: bold;
  color: #333;
  text-align: center;
  line-height: 1.4;
}

.nav-dot {
  width: min(10px, 0.69vw);
  height: auto;
  display: block;
  visibility: hidden;
}

.nav-item a:hover .nav-dot,
.nav-item.is-active .nav-dot {
  visibility: visible;
}

.nav-rainbow img {
  width: 100%;
  height: min(7px, 0.49vw);
  object-fit: cover;
  display: block;
}

.nav-contact {
  display: none;
  flex-direction: column;
  align-items: flex-end;
  gap: min(6px, 0.42vw);
}

.nav-contact-address {
  text-align: right;
  font-size: min(13px, 0.9vw);
  line-height: 1.7;
  color: #555;
}

.nav-contact-tel a {
  display: flex;
  align-items: center;
  gap: min(8px, 0.56vw);
  color: #333;
}

.nav-contact-tel a:hover {
  opacity: 0.7;
}

.nav-contact-tel-icon img {
  height: min(24px, 1.67vw);
  width: auto;
}

.nav-contact-tel-num {
  font-size: min(28px, 1.94vw);
  font-weight: bold;
  letter-spacing: 0.05em;
  color: #333;
}

.nav.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

.nav.is-fixed .nav-contact {
  display: flex;
}

.nav.is-fixed .nav-rainbow {
  display: none;
}

/* --- フッター --- */
footer {
  background-color: #fff9f0;
}

.footer-stripe {
  height: min(120px, 8.33vw);
  background-color: #ff8800;
}

.footer-main {
  background-image: url(../image/footer-back1.png);
  background-repeat: no-repeat;
  background-size: 100% min(75px, 5.21vw);
  background-position: top;
  padding: min(160px, 11.11vw) 0 min(137px, 9.51vw);
}

.footer-logo {
  width: min(480px, 33.33vw);
  height: auto;
  margin: 0 auto;
}

.footer-main-inner {
  display: flex;
  gap: min(190px, 13.19vw);
  justify-content: center;
  align-items: flex-start;
  margin-top: min(74px, 5.14vw);
}

.footer-left {
  width: min(417px, 28.96vw);
  flex-shrink: 0;
}

.footer-tel {
  display: flex;
  align-items: center;
  gap: min(10px, 0.69vw);
  margin-bottom: min(40px, 2.78vw);
}

.footer-tel-icon {
  width: min(50px, 3.47vw);
  height: auto;
}

.footer-tel-num {
  font-size: min(64px, 4.44vw);
  font-weight: bold;
  color: #ff8800;
}

.footer-cards {
  width: 100%;
  height: auto;
  margin-bottom: min(40px, 2.78vw);
}

.footer-address {
  font-size: min(16px, 1.11vw);
  line-height: 1.5;
  color: #555;
  font-style: normal;
}

.footer-right {
  width: min(506px, 35.14vw);
}

.footer-hours-table {
  width: min(414px, 28.75vw);
  border-collapse: collapse;
  margin: 0 auto;
  font-size: min(16px, 1.11vw);
  color: #6f5545;
}

.footer-hours-table th,
.footer-hours-table td {
  border: none;
  border-bottom: min(1px, 0.07vw) solid #6f5545;
  text-align: center;
  padding: min(10px, 0.69vw) min(6px, 0.42vw);
  font-weight: 400;
  color: #6f5545;
}

.footer-hours-table tr:last-child td {
  border-bottom: none;
}

.footer-hours-label {
  font-weight: normal;
  font-size: min(16px, 1.11vw);
  text-align: left;
  white-space: nowrap;
  padding-left: 0;
}

.footer-hours-time {
  font-size: min(16px, 1.11vw);
  color: #6f5545;
  text-align: left;
  padding-left: 0;
  white-space: nowrap;
}

.footer-hours-table .is-open {
  color: #ff4e00;
  font-size: min(16px, 1.11vw);
  line-height: 1;
}

.footer-hours-table .is-closed {
  font-size: min(16px, 1.11vw);
}

.footer-hours-table .is-limited {
  color: #00b1a2;
  font-size: min(16px, 1.11vw);
  font-weight: bold;
  line-height: 1;
}

.footer-hours-notes {
  font-size: min(16px, 1.11vw);
  color: #6f5545;
  line-height: 1.5;
  padding-left: min(60px, 4.17vw);
  margin-bottom: min(60px, 4.17vw);
}

.footer-hours-notes .is-limited {
  color: #00b1a2;
}

.footer-hours-notes .is-open {
  color: #c35144;
}

.footer-banner {
  display: block;
}

.footer-banner img {
  width: 100%;
  height: auto;
}

.footer-map {
  width: 100%;
  height: min(320px, 22.22vw);
}

.footer-map iframe {
  width: 100%;
  height: 100%;
}

.footer-nav {
  background-image: url(../image/footer-back2.png);
  background-repeat: no-repeat;
  background-size: cover;
  padding: min(130px, 9.03vw) 0;
}

.footer-nav ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(70px, 4.86vw);
}

.footer-nav ul li a {
  font-size: min(20px, 1.39vw);
  letter-spacing: 0.05em;
}

.copyright {
  text-align: center;
  background-color: #ff8800;
  padding: min(25px, 1.74vw) 0;
}

.copyright p {
  font-size: min(16px, 1.11vw);
  color: #fff;
}

.top-back {
  width: min(80px, 5.56vw);
  position: fixed;
  right: min(30px, 2.08vw);
  bottom: min(67px, 4.65vw);
  opacity: 0;
  visibility: hidden;
  transition: 0.4s;
  z-index: 999;
}

.top-back.is-show {
  opacity: 1;
  visibility: visible;
}

/* お知らせ内容 1100で可変 */
.single-container {
  width: 100%;
  padding: min(60px, 5.45vw) 0;
}

.single-box {
  width: min(1000px, 90.91vw);
  margin: 0 auto;
}

.single-title {
  font-size: min(32px, 2.91vw);
  font-weight: 600;
  margin-bottom: min(30px, 2.73vw);
  line-height: 1.4;
}

.single-img {
  width: 100%;
  max-width: min(600px, 54.55vw);
  margin-bottom: min(40px, 3.64vw);
}

.single-img img {
  width: 100%;
  height: auto;
  display: block;
}

.single-content {
  font-size: min(16px, 1.45vw);
  line-height: 1.8;
  color: #333;
}

.single-content img {
  max-width: 100%;
  height: auto;
}

@media screen and (max-width: 767px) {
  /* 全体 */
  #header,
  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

  /* ヘッダー */
  .sp-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(35 / 375 * 100vw);
    z-index: 9999;
    display: block;
  }

  .sp-header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    padding: 0 calc(6 / 375 * 100vw);
  }

  .sp-header-logo img {
    width: calc(177 / 375 * 100vw);
    height: auto;
  }

  /* ハンバーガーボタン */
  .sp-menu-btn {
    position: relative;
    width: calc(32 / 375 * 100vw);
    height: calc(32 / 375 * 100vw);
    background-color: #76ac33;
    border: none;
    border-radius: 50%;
    z-index: 1000;
  }

  /* 線 */
  .sp-menu-btn span {
    position: absolute;
    left: 50%;
    width: calc(18 / 375 * 100vw);
    height: calc(2 / 375 * 100vw);
    background-color: #fff;
    transform: translateX(-50%);
    transition: 0.3s;
  }

  .sp-menu-btn span:nth-child(1) {
    top: calc(9 / 375 * 100vw);
  }

  .sp-menu-btn span:nth-child(2) {
    top: calc(14 / 375 * 100vw);
  }

  .sp-menu-btn span:nth-child(3) {
    top: calc(19 / 375 * 100vw);
  }

  /* MENU文字 */
  .sp-menu-btn::after {
    content: "MENU";
    position: absolute;
    left: 50%;
    bottom: calc(3 / 375 * 100vw);
    transform: translateX(-50%);
    font-size: calc(7 / 375 * 100vw);
    font-weight: bold;
    color: #fff;
    line-height: 1;
    letter-spacing: 0.05em;
  }

  /* 開いた時 */
  .sp-menu-btn.is-active span:nth-child(1) {
    top: calc(14 / 375 * 100vw);
    transform: translateX(-50%) rotate(45deg);
  }

  .sp-menu-btn.is-active span:nth-child(2) {
    opacity: 0;
  }

  .sp-menu-btn.is-active span:nth-child(3) {
    top: calc(14 / 375 * 100vw);
    transform: translateX(-50%) rotate(-45deg);
  }

  /* 全画面メニュー */
  .sp-header-nav {
    position: fixed;
    top: 0;
    right: -255px;
    width: 255px;
    height: 100vh;
    background-color: #76ac33;
    transition: 0.4s;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 999;
  }

  .sp-header-nav.is-active {
    right: 0;
  }

  .sp-nav-list {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .sp-nav-list li {
    margin: 25px 0;
  }
  .sp-nav-list li a {
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #fff;
    text-decoration: none;
    font-size: 16px;
  }

  .sp-nav-list li a .first-span {
    font-size: 22px;
  }

  /* --- メインビジュアル --- */
  .main-v {
    width: 100%;
  }

  .main-v-container {
    position: relative;
    width: 100%;
    height: calc(730 / 375 * 100vw);
    background-image: url(../image/sp-top-back8.png);
    background-size: cover;
    background-position: top center;
    overflow: hidden;
  }

  .main-v-cloud-wrap {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: calc(262 / 375 * 100vw);
    width: calc(371 / 375 * 100vw);
    z-index: 2;
  }

  .main-v-cloud-img {
    width: 100%;
    height: auto;
  }

  .main-v-title {
    width: calc(352 / 375 * 100vw);
    position: absolute;
    top: calc(103 / 375 * 100vw);
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
  }

  .main-v-title h1 {
    font-size: calc(24 / 375 * 100vw);
    font-weight: bold;
    text-align: center;
  }

  .main-v-line {
    display: inline;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
    background: linear-gradient(transparent 70%, #fff3b5 70%);
    padding-left: calc(7 / 375 * 100vw);
  }

  .main-v-line-text {
    font-size: calc(20 / 375 * 100vw);
  }

  .main-v-line--1 {
    color: #ff6606;
  }

  .main-v-line--2 {
    color: #ff8800;
  }

  .main-v-line--3 {
    color: #4cc2ff;
  }

  .main-v-points {
    position: absolute;
    bottom: calc(25 / 375 * 100vw);
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: calc(10 / 375 * 100vw);
    white-space: nowrap;
    z-index: 3;
  }

  .main-v-point {
    width: calc(112 / 375 * 100vw);
    height: calc(112 / 375 * 100vw);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: calc(16 / 375 * 100vw);
    font-weight: bold;
    color: #fff;
    line-height: 1.4;
    white-space: normal;
  }

  .main-v-photo {
    position: absolute;
    z-index: 2;
  }

  .main-v-photo--1 {
    right: calc(18 / 375 * 100vw);
    top: calc(63 / 375 * 100vw);
    width: calc(169 / 375 * 100vw);
  }

  .main-v-photo--2 {
    left: 0;
    top: calc(58 / 375 * 100vw);
    width: calc(163 / 375 * 100vw);
  }

  .main-v-photo--3 {
    left: calc(74 / 375 * 100vw);
    top: calc(163 / 375 * 100vw);
    width: calc(129 / 375 * 100vw);
  }

  .p1-a {
    display: none;
  }

  /* --- コンサルテーション --- */
  .p1-b {
    padding-top: 0;
  }

  .p1-b-box {
    text-align: center;
    background-image: url(../image/part8.png), url(../image/part9.png);
    background-repeat: no-repeat;
    background-size:
      101px auto,
      96px auto;
    background-position:
      top 15px left -26px,
      bottom right -10px;
    padding: 74px 0 78px 0;
  }

  .p1-b-head {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 0;
  }

  .p1-b-hanabi:first-child {
    display: none;
  }

  .p1-b-hanabi:last-child {
    display: none;
  }

  .p1-b-title {
    font-size: 40px;
    font-weight: bold;
    letter-spacing: 0.08em;
    background: linear-gradient(90deg, #ff8a00 0%, #ffb300 45%, #ffe45c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }

  .p1-b-sub {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    color: #333;
    line-height: 1.8;
    margin-top: 16px;
  }

  .p1-b-sub-em {
    color: #0071bc;
    font-weight: bold;
  }

  .p1-b-lower {
    background-image: url(../image/sp-top-back1.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
  }

  .p1-b-cards-wrap {
    padding: 54px 0;
    margin-top: 0;
  }

  .p1-b-cards {
    display: grid;
    grid-template-columns: repeat(2, 171px);
    gap: 10px 5px;
  }

  .p1-b-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 171px;
  }

  .p1-b-card-chara {
    height: auto;
    display: block;
    position: relative;
    z-index: 2;
    margin-bottom: -20px;
  }

  .p1-b-card:nth-of-type(3) .p1-b-card-chara {
    margin-bottom: -30px;
  }

  .p1-b-card:nth-of-type(1) .p1-b-card-chara {
    width: 73px;
  }

  .p1-b-card:nth-of-type(2) .p1-b-card-chara {
    width: 90px;
  }

  .p1-b-card:nth-of-type(3) .p1-b-card-chara {
    width: 82px;
  }

  .p1-b-card:nth-of-type(4) .p1-b-card-chara {
    width: 96px;
  }

  .p1-b-card-bubble {
    position: relative;
    z-index: 1;
    width: 100%;
  }

  .p1-b-card-blob {
    width: 100%;
    height: auto;
    display: block;
  }

  .p1-b-card-text {
    position: absolute;
    transform: translate(-50%, -50%);
    font-size: 14px;
    line-height: 1.5;
    width: 82%;
  }

  .p1-b-card:nth-of-type(1) .p1-b-card-text {
    top: 60px;
    left: 50%;
  }

  .p1-b-card:nth-of-type(2) .p1-b-card-text {
    top: 58px;
    left: 50%;
  }

  .p1-b-card:nth-of-type(3) .p1-b-card-text {
    top: 65px;
    left: 55%;
  }

  .p1-b-card:nth-of-type(4) .p1-b-card-text {
    top: 50px;
    left: 50%;
  }

  /* --- 治療メニュー --- */
  .p1-c {
    background-image:
      url(../image/sp-top-back2.png), url(../image/top-back5.png);
    background-repeat: no-repeat, repeat-y;
    background-size:
      cover,
      100% auto;
    background-position:
      top 200px center,
      top center;
    margin-top: 0;
  }

  .p1-c-box {
    display: flex;
    justify-content: center;
  }

  .p1-c-head {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 36px;
  }

  .p1-c-tooth {
    width: 149px;
    height: auto;
    position: absolute;
    top: -36px;
    left: 26px;
    z-index: 2;
  }

  .p1-c-cloud {
    position: relative;
    width: 369px;
  }

  .p1-c-cloud-img {
    width: 100%;
    height: auto;
  }

  .p1-c-cloud-body {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -60%);
    width: 100%;
    text-align: center;
  }

  .p1-c-cloud-body p {
    font-size: 19px;
    font-family: "Zen Maru Gothic", sans-serif;
    line-height: 1.4;
    font-weight: bold;
  }

  .p1-c-em {
    color: #ff8800;
  }

  .p1-c-em2 {
    color: #d4572d;
  }

  .p1-c-lower {
    position: relative;
    margin-top: 44px;
    padding-bottom: 82px;
  }

  .p1-c-wave {
    width: 100%;
    height: auto;
    display: block;
  }

  .p1-c-cards-wrap {
    width: 92%;
    padding: 0;
    margin: 0 auto;
  }

  .p1-c-cards {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    gap: 37px;
    margin-bottom: 0;
  }

  .p1-c-card {
    width: 306px;
    border-radius: 0 0 20px 20px;
    display: flex;
    flex-direction: column;
    position: relative;
  }

  .p1-c-card--2,
  .p1-c-card--4 {
    margin-top: 60px;
  }

  .p1-c-card--1 .p1-c-card-badge {
    background-color: #ff8800;
  }

  .p1-c-card--2 .p1-c-card-badge {
    background-color: #00b1a2;
  }

  .p1-c-card--3 .p1-c-card-badge {
    background-color: #fedc5e;
  }

  .p1-c-card--4 .p1-c-card-badge {
    background-color: #ee87b5;
  }

  .p1-c-card-badge {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    text-align: center;
    gap: 10px;
    clip-path: polygon(0 38%, 50% 0, 100% 38%, 100% 100%, 0 100%);
  }

  .p1-c-card-num {
    font-size: 48px;
    color: #fff;
    font-weight: bold;
    line-height: 1;
    padding-top: 15px;
  }

  .p1-c-card-sub {
    font-size: 24px;
    font-weight: bold;
    color: #fff;
    padding-bottom: 15px;
  }

  .p1-c-card-photo {
    height: 207px;
    position: relative;
    overflow: hidden;
  }

  .p1-c-card-animal {
    position: absolute;
    width: 83px;
    height: auto;
    z-index: 4;
  }

  .p1-c-card--1 .p1-c-card-animal {
    bottom: 82px;
    left: -26px;
  }

  .p1-c-card--2 .p1-c-card-animal {
    bottom: 80px;
    left: -10px;
  }

  .p1-c-card--3 .p1-c-card-animal {
    bottom: 82px;
    right: -26px;
  }

  .p1-c-card--4 .p1-c-card-animal {
    bottom: 80px;
    right: -10px;
  }

  .p1-c-card-footer {
    border-radius: 0 0 20px 20px;
    background-color: #fff;
  }

  .p1-c-card-footer a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 30px 0;
  }

  .p1-c-card--1 .p1-c-card-footer {
    border: 7px solid #ff8800;
  }

  .p1-c-card--2 .p1-c-card-footer {
    border: 7px solid #00b1a2;
  }

  .p1-c-card--3 .p1-c-card-footer {
    border: 7px solid #fedc5e;
  }

  .p1-c-card--4 .p1-c-card-footer {
    border: 7px solid #ee87b5;
  }

  .p1-c-card-name {
    font-size: 20px;
    font-weight: bold;
    color: #333;
  }

  .p1-c-card-arrow {
    width: 22px;
    height: auto;
  }

  .p1-c-forest {
    width: 357px;
    height: auto;
    display: block;
    position: absolute;
    left: 50%;
    bottom: -17px;
    z-index: 4;
    transform: translateX(-50%);
  }

  /* --- 予約・問い合わせ --- */
  .p1-d {
    background-color: #faf9f6;
    padding: 63px 0 98px;
  }

  .p1-d-container {
    width: 335px;
    background-color: #ff8800;
    padding: 10px;
    border-radius: 30px;
    margin: 0 auto;
  }

  .p1-d-box {
    border-radius: 20px;
    display: flex;
    align-items: center;
    position: relative;
    padding: 20px 0;
    overflow: visible;
    border: 1px solid #fff;
  }

  .p1-d-tooth {
    position: absolute;
    left: -30px;
    bottom: 36px;
    width: 94px;
    height: auto;
    z-index: 4;
  }

  .p1-d-content {
    flex: 1;
    text-align: left;
  }

  .p1-d-catch {
    font-size: 19px;
    color: #fff;
    margin-bottom: 26px;
    padding-left: 5px;
  }

  .p1-d-label {
    text-align: right;
    font-size: 22px;
    color: #fff;
    margin-bottom: 0;
    padding-right: 10px;
  }

  .p1-d-tel {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 2px;
  }

  .p1-d-tel-icon {
    height: 36px;
    width: auto;
  }

  .p1-d-tel-num {
    font-size: 40px;
    font-weight: bold;
    color: #fff;
    letter-spacing: 0.02em;
  }

  .p1-d-tel-num:hover {
    opacity: 0.8;
  }

  /* --- 院長ご挨拶 --- */
  .p1-e {
    background-image: url(../image/sp-part1.png) url(../image/sp-top-back3.png);
    background-repeat: no-repeat;
    background-size:
      100% 7px,
      cover;
    background-position:
      bottom,
      top center;
    padding-bottom: min(70px, 4.86vw);
  }

  .p1-e-box {
    max-width: 92%;
    margin: 0 auto;
  }

  .p1-e-head.pc {
    display: none;
  }

  .p1-e-head.sp {
    display: flex;
  }

  .p1-e-head {
    display: flex;
    align-items: flex-start;
    gap: 15px;
    margin: 10px 0 23px 76px;
  }

  .p1-e-title {
    font-size: 24px;
    font-weight: bold;
    color: #333;
  }

  .p1-e-animal {
    width: 62px;
    height: auto;
    margin-top: 10px;
  }

  .p1-e-main {
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    gap: 80px;
  }

  .p1-e-left {
    width: 100%;
  }

  .p1-e-right-wrap {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .p1-e-greeting {
    writing-mode: horizontal-tb;
    text-orientation: initial;
    font-size: 50px;
    font-weight: bold;
    color: #8fc320;
    letter-spacing: 0.1em;
    flex-shrink: 0;
    line-height: 1;
  }

  .p1-e-g {
    color: #25aa37;
  }

  .p1-e-text {
    flex: 1;
  }

  .p1-e-text-title {
    font-size: 26px;
    font-weight: bold;
    color: #ff8800;
    margin: 20px 0;
  }

  .p1-e-text-title:first-child {
    margin-top: 0;
  }

  .p1-e-text p {
    font-size: 16px;
    line-height: 2;
  }

  .p1-e-right {
    max-width: 400px;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    flex-shrink: 0;
    position: relative;
    margin-top: 10px;
  }

  .p1-e-photo {
    width: 100%;
    border-radius: 10px;
    position: relative;
  }

  .p1-e-photo img {
    width: 100%;
    height: auto;
    object-fit: cover;
  }

  .p1-e-name-box {
    position: absolute;
    bottom: -46px;
    left: 20px;
    width: 149px;
    height: 149px;
    border-radius: 50%;
    background-color: #8fc320;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .p1-e-name-title {
    font-size: 20px;
    color: #fff;
  }

  .p1-e-name-ja {
    font-size: 32px;
    color: #fff;
  }

  .p1-e-name-en {
    font-size: 16px;
    color: #fff;
  }

  .p1-e-deco {
    position: absolute;
    bottom: -35px;
    right: 66px;
  }

  .p1-e-right .p1-e-deco {
    width: 101px;
    height: auto;
  }

  .p1-e-welcome {
    max-width: 400px;
    width: 100%;
    margin: 20px auto 0;
  }

  /* --- フィーチャー --- */
  .p1-f-container {
    padding-top: 43px;
  }

  .p1-f-head {
    background-image: url(../image/part16.png), url(../image/part17.png);
    background-repeat: no-repeat;
    background-size: 170px auto;
    background-position:
      top left 5px,
      top right 5px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 0;
    padding-top: 93px;
  }

  .p1-f-garland--l {
    display: none;
  }

  .p1-f-garland--r {
    display: none;
  }

  .p1-f-head-inner {
    text-align: center;
    padding: 0;
  }

  .p1-f-title {
    font-size: 50px;
    font-weight: bold;
    background: linear-gradient(90deg, #ff8a00 0%, #ffb300 50%, #ffe45c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: 0.05em;
  }

  .p1-f-sub {
    font-size: 24px;
    margin-top: 5px;
    letter-spacing: 0.15em;
  }

  .p1-f-lower {
    position: relative;
    padding-top: min(60px, 4.17vw);
  }

  .p1-f-cards-wrap {
    background-image: url(../image/sp-top-back4.png);
    background-repeat: no-repeat;
    background-size:
      100% auto,
      cover;
    background-position: top, center;
    padding: 50px 0;
  }

  .p1-f-card-row {
    width: 92%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column-reverse;
    gap: 80px;
    margin: 0 auto;
  }

  .p1-f-card-body {
    max-width: 400px;
    width: 100%;
    flex-shrink: 0;
    background: white;
    border: 8px solid #ff8800;
    border-radius: 27px;
    padding: 54px 23px 36px;
    position: relative;
    z-index: 2;
    margin-top: 0;
  }

  .p1-f-card-badge {
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: #ff8800;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 3;
  }

  .p1-f-card-badge::before {
    content: "";
    position: absolute;
    top: 5px;
    right: 5px;
    bottom: 5px;
    left: 5px;
    border-radius: 50%;
    border: 1px dashed white;
  }

  .p1-f-card-num {
    font-size: 48px;
    font-weight: bold;
    color: white;
    margin-bottom: 3px;
  }

  .p1-f-card-title {
    text-align: center;
    font-size: 24px;
    line-height: 1.5;
    padding-bottom: 26px;
    border-bottom: 1px dashed #ff8800;
  }

  .p1-f-card-text {
    font-size: 16px;
    line-height: 2;
    padding-top: 15px;
  }

  .p1-f-card-right {
    flex-shrink: 0;
    max-width: 400px;
    width: 100%;
    margin-left: 0;
    position: relative;
    z-index: 1;
  }

  .p1-f-card-photo {
    width: 100%;
    height: auto;
  }

  .p1-f-card-animal {
    position: absolute;
    bottom: -34px;
    right: -14px;
    width: 140px;
  }

  .p1-f-forest {
    width: 357px;
    height: auto;
    position: absolute;
    left: 50%;
    bottom: -24px;
    z-index: 4;
    transform: translateX(-50%);
    display: block;
  }

  .p1-f-lower2 .p1-f-cards-wrap {
    background-image: url(../image/sp-top-back5.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top, center;
    margin-top: 60px;
  }

  .p1-f-lower2 .p1-f-card-row {
    flex-direction: column-reverse;
    gap: 115px;
  }

  .p1-f-lower2 .p1-f-card-right {
    margin-left: 0;
    margin-right: 0;
  }

  .p1-f-lower2 .p1-f-card-animal {
    bottom: -63px;
    left: 0;
    right: auto;
    width: 145px;
  }

  .p1-f-lower2 .p1-f-card-badge {
    background: #00afec;
  }

  .p1-f-lower2 .p1-f-card-body {
    padding: 54px 23px 36px;
    border: 8px solid #30bef0;
  }

  .p1-f-lower2 .p1-f-card-title {
    border-bottom: min(1px, 0.07vw) dashed #00afec;
  }

  .p1-f-lower3 .p1-f-cards-wrap {
    background-image: url(../image/sp-top-back6.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top, center;
  }

  .p1-f-lower3 .p1-f-card-animal {
    bottom: -19px;
    left: auto;
    right: 0;
    width: 153px;
  }

  .p1-f-lower3 .p1-f-card-badge {
    background: #e9546b;
  }

  .p1-f-lower3 .p1-f-card-body {
    padding: 54px 23px 36px;
    border: 8px solid #e9546b;
  }

  .p1-f-lower3 .p1-f-card-title {
    border-bottom: min(1px, 0.07vw) dashed #e9546b;
  }

  .p1-f-box2 {
    background-image: url(../image/sp-top-back7.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
    position: relative;
    padding-bottom: 95px;
    margin-top: 60px;
    margin-bottom: 90px;
  }

  .p1-f-cards-v {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 66px;
    justify-content: center;
  }

  .p1-f-card-v {
    max-width: 400px;
    width: 92%;
    margin: 0 auto;
  }

  .p1-f-card-v-photo {
    border-radius: 36px;
  }

  .p1-f-card-v-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .p1-f-card-v-body {
    width: 90%;
    height: auto;
    background: white;
    border: 8px solid #ff8800;
    border-radius: 27px;
    padding: 54px 23px 36px;
    position: relative;
    margin: -30px auto 0;
  }

  .p1-f-card-v:last-child .p1-f-card-v-body {
    border: 8px solid #00b1a2;
  }

  .p1-f-card-v:last-child .p1-f-card-badge {
    background: #00b1a2;
  }

  .p1-f-card-v:last-child .p1-f-card-title {
    border-bottom: 1px dashed #00b1a2;
  }

  .p1-f-box2 .p1-f-forest {
    max-width: 400px;
    width: 100%;
    height: auto;
    position: absolute;
    left: 50%;
    bottom: -25px;
    z-index: 4;
    transform: translateX(-50%);
    display: block;
  }

  /* こどもの予防歯科・治療 */
  .p2-a-container {
    padding-top: 40px;
  }

  .p2-a-box {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column-reverse;
    gap: 20px;
    background-color: #fffbd2;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    padding-top: 75px;
    padding-bottom: 60px;
  }

  .p2-a-text {
    max-width: 400px;
    width: 92%;
    height: auto;
    background-color: #fff;
    position: relative;
    z-index: 2;
    padding: 10px 20px;
    border: 5px solid #ff8800;
    border-radius: 30px;
    margin-top: 0;
    margin-right: 0;
  }

  .p2-a-text p {
    font-size: 16px;
    line-height: 2;
    letter-spacing: 0.05em;
  }

  .p2-a-img {
    max-width: 400px;
    width: 92%;
    position: relative;
  }

  .p2-a-img img:last-child {
    width: 60px;
    height: auto;
    position: absolute;
    left: -6px;
    bottom: -15px;
    z-index: 4;
  }

  .p2-b {
    margin-top: 40px;
  }

  .p2-b-container {
    background-color: #ecf4db;
    padding: 30px 0;
  }

  .p2-b-title {
    width: 92%;
    text-align: center;
    position: relative;
    background-color: #fff;
    padding: 10px 0;
    border-radius: 10px;
    margin: 0 auto;
  }

  .p2-b-title h2 {
    font-size: 18px;
    letter-spacing: 0.05em;
  }

  .p2-b-title img {
    width: 40px;
    height: auto;
    position: absolute;
    left: 4px;
    bottom: 0;
    z-index: 4;
  }

  .p2-b-box {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    background-image: url(../image/p2-back5.png);
    background-repeat: no-repeat;
    background-size: 200% auto;
    background-position: center center;
    gap: 20px;
    margin-top: 20px;
  }

  .p2-b-item {
    width: 200px;
    height: 200px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #fff;
    border-radius: 50%;
    border: 5px solid #ff8800;
  }

  .p2-b-item:nth-of-type(2) {
    border: 5px solid #f5dd4d;
  }

  .p2-b-item p {
    font-size: 18px;
    font-weight: bold;
    font-family: "Zen Maru Gothic", sans-serif;
    letter-spacing: 0.05em;
  }

  .p2-c-container {
    position: relative;
    background-color: #fff7ce;
    background-image: none;
    z-index: 1;
    padding-bottom: 20px;
  }

  .p2-c-box {
    width: 92%;
    position: relative;
    display: flex;
    justify-content: center;
    flex-direction: column-reverse;
    align-items: center;
    gap: 20px;
    margin: 0 auto;
  }

  .p2-c-text {
    width: 100%;
  }

  .p2-c-text p {
    width: 100%;
    font-size: 16px;
    font-weight: bold;
    line-height: 2;
    letter-spacing: 0.05em;
    padding-top: 0;
    margin: 0 auto;
  }

  .p2-c-img {
    max-width: 400px;
    width: 100%;
  }

  .p2-c-img2 {
    width: 110px;
    position: absolute;
    right: 0;
    bottom: -40px;
    z-index: 4;
  }

  .p2-c-title {
    width: 92%;
    text-align: center;
    background-color: #ff8800;
    padding: 10px 0;
    margin: 40px auto 0;
  }

  .p2-c-title h2 {
    font-size: 18px;
    color: #fff;
    letter-spacing: 0.05em;
  }

  .p2-c-box2 {
    width: 92%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    margin: 20px auto 0;
  }

  .p2-c-img3 {
    max-width: 400px;
    width: 100%;
  }

  .p2-c-img3 img {
    width: 100%;
    margin: 20px auto 0;
  }

  .p2-c-text2 {
    width: 100%;
  }

  .p2-c-text2 p {
    font-size: 16px;
    font-weight: bold;
    line-height: 2;
    letter-spacing: 0.05em;
  }

  .p2-c-list {
    width: 100%;
    background-color: #fff;
    padding: 10px;
    margin-top: 20px;
  }

  .p2-c-list h3 {
    display: block;
    text-align: center;
    font-size: 18px;
    font-weight: 400;
    color: #fff;
    letter-spacing: 0.05em;
    background-color: #ff8800;
    padding: 10px 0;
  }

  .p2-c-list ul li {
    font-size: 14px;
    letter-spacing: 0.05em;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding-top: 10px;
  }

  .p2-c-list ul li img {
    width: 14px;
    margin-top: 4px;
  }

  /* p2-d 子どもの予防歯科 */
  .p2-d {
    padding-top: 40px;
  }

  .p2-d-container {
    background-color: #d0efff;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    padding: 50px 0;
  }

  .p2-d-box {
    width: 92%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  .p2-d-card {
    background-color: #fff;
    border-radius: 20px;
    padding: 20px 10px;
    position: relative;
    overflow: visible;
  }

  .p2-d-card-inner {
    display: flex;
    justify-content: space-between;
    flex-direction: column-reverse;
    align-items: center;
    gap: 20px;
  }

  .p2-d-card-text {
    width: 100%;
  }

  .p2-d-card-text h3 {
    font-size: 16px;
    font-weight: 400;
    padding: 10px 0;
    line-height: 1.4;
    border-bottom: 1px dashed #4cc2ff;
  }

  .p2-d-card-text p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.05em;
    padding-top: 20px;
  }

  .p2-d-card-img {
    max-width: 400px;
    width: 100%;
    flex-shrink: 0;
  }

  .p2-d-card-img img {
    width: 100%;
    height: auto;
  }

  .p2-d-deco {
    position: absolute;
    height: auto;
  }

  .p2-d-deco--1 {
    width: 80px;
    left: auto;
    right: 0;
    bottom: -20px;
  }

  .p2-d-deco--2 {
    width: 30px;
    left: auto;
    right: -2%;
    bottom: -10px;
  }

  .p2-d-deco--3 {
    width: 60px;
    right: -2%;
    bottom: -20px;
  }

  /* p2-e あいうべ体操 */
  .p2-e {
    margin-top: 40px;
  }

  .p2-e .h2-title.h2-title1 {
    border-top: 5px solid #ff8800;
    border-bottom: 5px solid #ff8800;
  }

  .p2-e-box {
    background-image: url(../image/p2-back4.png);
    background-repeat: no-repeat;
    background-size: 250% 100%;
    padding: 60px 0 150px;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 20px;
  }

  .p2-e-logo2 {
    width: 350px;
    margin: 0 auto;
  }

  .p2-e-logo {
    width: 300px;
    height: auto;
    margin-bottom: 40px;
  }

  .p2-e-intro {
    width: 92%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column-reverse;
    gap: 20px;
    margin: 0 auto 30px;
  }

  .p2-e-intro-text {
    width: 100%;
  }

  .p2-e-intro-text h3 {
    font-size: 18px;
    font-weight: bold;
    color: #ff8800;
    padding-bottom: 8px;
    border-bottom: 1px dashed #ff8800;
  }

  .p2-e-intro-text span {
    font-size: 16px;
    color: #ff8800;
  }

  .p2-e-intro-text p {
    font-size: 16px;
    line-height: 2;
    letter-spacing: 0.05em;
    margin-top: 15px;
  }

  .p2-e-intro-img {
    max-width: 400px;
    width: 100%;
    flex-shrink: 0;
  }

  .p2-e-banner {
    width: 325px;
    background-image: url(../image/p2-back6.png);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    padding: 10px 10px 30px;
    margin: 0 auto 10px;
    text-align: center;
  }

  .p2-e-banner p {
    color: #fff;
    font-size: 16px;
    font-family: "Zen Maru Gothic", sans-serif;
    letter-spacing: 0.05em;
  }

  .p2-e-list {
    width: 92%;
    background-color: #fff;
    border-radius: 20px;
    padding: 20px;
    margin: 0 auto 30px;
  }

  .p2-e-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 20px 0;
    border-bottom: 1px dashed #ff8800;
  }

  .p2-e-item:last-child {
    border-bottom: none;
  }

  .p2-e-item img {
    width: 200px;
    height: auto;
    flex-shrink: 0;
  }

  .p2-e-item p {
    font-size: 14px;
    font-weight: bold;
    font-family: "Zen Maru Gothic", sans-serif;
    letter-spacing: 0.03em;
    white-space: wrap;
  }

  .p2-e-outro {
    font-size: 14px;
    text-align: center;
    position: relative;
    line-height: 1.9;
    margin-bottom: 20px;
  }

  /* 左画像 */
  .p2-e-outro::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -27px;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    background-image: url(../image/part21.png);
    background-repeat: no-repeat;
    background-size: contain;
  }

  /* 右画像 */
  .p2-e-outro::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -27px;
    transform: translateY(-50%);
    width: 22px;
    height: 22px;
    background-image: url(../image/part22.png);
    background-repeat: no-repeat;
    background-size: contain;
  }

  .p2-e-effects {
    width: 92%;
    text-align: center;
    margin: 0 auto;
  }

  .p2-e-effects h3 {
    display: inline-block;
    color: #fff;
    font-size: 18px;
    font-weight: 400;
    text-align: center;
    background-color: #ff8800;
    padding: 10px 20px;
    border-radius: 20px 20px 0 0;
  }

  .p2-e-effects ul {
    width: 100%;
    list-style: none;
    padding: 20px 10px;
    border: 3px solid #ff8800;
    border-radius: 10px;
    margin: 0 auto;
  }

  .p2-e-effects li {
    text-align: left;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 5px 0;
    font-size: 14px;
    line-height: 1.6;
  }

  .p2-e-effects li img {
    width: 14px;
    margin-top: 5px;
  }

  /* p3-a 子供の歯並び治療 */
  .p3-a {
    padding-top: 40px;
  }

  .p3-a-container {
    background-color: #fffbd2;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    padding: 60px 0 40px;
  }

  .p3-a-box {
    width: 92%;
    margin: 0 auto;
  }

  .p3-a-content {
    display: flex;
    align-items: center;
    flex-direction: column-reverse;
    gap: 20px;
  }

  .p3-a-text {
    width: 100%;
  }

  .p3-a-catch {
    font-size: 24px;
    font-weight: bold;
    line-height: 1.6;
    color: #6f5545;
    padding-bottom: 10px;
    border-bottom: 2px dashed #ff8800;
    margin-bottom: 20px;
  }

  .p3-a-lead {
    font-size: 14px;
    font-weight: bold;
    line-height: 2;
    letter-spacing: 0.05em;
    margin-bottom: 20px;
  }

  .p3-a-section {
    margin-bottom: 16px;
  }

  .p3-a-section h3 {
    font-size: 16px;
    font-weight: bold;
    color: #0080c2;
    margin-bottom: 20px;
  }

  .p3-a-section p {
    font-size: 14px;
    font-weight: bold;
    line-height: 2;
    letter-spacing: 0.05em;
  }

  .p3-a-img {
    max-width: 400px;
    width: 100%;
    flex-shrink: 0;
    position: relative;
    margin-top: 30px;
  }

  .p3-a-img img {
    width: 100%;
    height: auto;
  }

  .p3-a-img .p3-a-deco {
    width: 150px;
    display: block;
    position: absolute;
    left: -10px;
    bottom: -10px;
    z-index: 4;
  }

  /* p3-b 相談ボックス */
  .p3-b {
    padding-top: 40px;
  }

  .p3-b-container {
    background: linear-gradient(
      to bottom,
      #fff 0,
      #fff 60px,
      #ffe599 60px,
      #ffe599 100%
    );
    position: relative;
    padding-bottom: 40px;
  }

  .p3-b-box {
    width: 92%;
    border: 5px solid #ff8800;
    border-radius: 20px;
    padding: 20px 10px;
    background-color: #fff;
    position: relative;
    margin: 0 auto;
  }

  .p3-b-en {
    font-size: 34px;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
    background: linear-gradient(90deg, #ff8a00 0%, #ffb300 45%, #ffe45c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }

  .p3-b-title {
    background-color: #ff8800;
    border-radius: 50px;
    padding: 10px 0;
    text-align: center;
    margin-bottom: 20px;
  }

  .p3-b-title p {
    color: #fff;
    font-size: 16px;
    font-weight: bold;
  }

  .p3-b-list {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 0 auto;
  }

  .p3-b-col {
    flex: 1;
  }

  .p3-b-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px dashed #e0e0e0;
  }

  .p3-b-item p {
    font-size: 16px;
  }

  .p3-b-item img {
    width: 14px;
  }

  .p3-b-flowers {
    max-width: 400px;
    width: 92%;
    height: auto;
    position: absolute;
    left: 50%;
    bottom: -20px;
    z-index: 4;
    transform: translateX(-50%);
    display: block;
  }

  /* p3-c 治療の進め方 */
  .p3-c {
    padding: 40px 0 0;
  }

  .p3-c-container {
    background-image: url(../image/top-back5.png);
    background-repeat: no-repeat;
    background-size: cover;
    padding: 30px 0 50px;
  }

  .p3-c-box {
    width: 92%;
    margin: 0 auto;
  }

  .p3-c-title {
    text-align: center;
    background-color: #ff8800;
    padding: 10px 0;
    margin-bottom: 30px;
  }

  .p3-c-title h2 {
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.1em;
  }

  .p3-c-text {
    width: 100%;
    margin: 0 auto;
  }

  .p3-c-text p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.05em;
  }

  /* p3-d 小児矯正のメリット */
  .p3-d {
    padding-top: 40px;
    padding-bottom: 160px;
  }

  .p3-d-container {
    background-color: #d0efff;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    padding: 40px 0 40px;
    margin-top: 20px;
  }

  .p3-d-box {
    width: 92%;
    margin: 0 auto;
  }

  .p3-d-points {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    margin-bottom: 40px;
  }

  .p3-d-point {
    max-width: 400px;
    width: 100%;
    background-color: #fff;
    position: relative;
    border-radius: 20px;
    padding: 40px 20px;
  }

  .p3-d-point-label {
    font-size: 20px;
    font-weight: bold;
    color: #ff8800;
    position: absolute;
    left: 10px;
    top: -20px;
    z-index: 4;
  }

  .p3-d-point:nth-of-type(even) .p3-d-point-label {
    color: #0098e5;
  }

  .p3-d-point-label span {
    font-size: 24px;
    color: #ff8800;
  }

  .p3-d-point:nth-of-type(even) .p3-d-point-label span {
    color: #0098e5;
  }

  .p3-d-point p:not(.p3-d-point-label) {
    font-size: 14px;
    font-weight: bold;
    line-height: 1.8;
  }

  .p3-d-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }

  .p3-d-info-card {
    width: 100%;
    background-color: #fff;
    padding: 30px 10px 20px;
    position: relative;
    border: 5px solid #4cc2ff;
  }

  .p3-d-info-card.p3-d-info-card--blue {
    border: 5px solid #009ded;
  }

  .p3-d-info-head {
    width: 200px;
    display: inline-block;
    color: #fff;
    font-size: 18px;
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: bold;
    letter-spacing: 0.05em;
    text-align: center;
    position: absolute;
    top: -20px;
    left: 50%;
    z-index: 4;
    transform: translateX(-50%);
    padding: 5px 0;
  }

  .p3-d-info-card--orange .p3-d-info-head {
    background-color: #4cc2ff;
  }

  .p3-d-info-card--blue .p3-d-info-head {
    background-color: #009ded;
  }

  .p3-d-info-body {
    background-color: #fff;
    padding: 0;
  }

  .p3-d-info-body h3 {
    font-size: 18px;
    color: #ff8800;
    margin-bottom: 10px;
  }

  .p3-d-info-body p {
    font-size: 14px;
    line-height: 1.8;
    letter-spacing: 0.05em;
  }

  /* p4-a 料金表 */
  .p4-a {
    padding-top: 40px;
    padding-bottom: 180px;
  }

  .p4-a-container {
    background-color: #fffbd2;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    position: relative;
    padding: 80px 0 50px;
  }

  .p4-a-box {
    width: 92%;
    margin: 0 auto;
  }

  .p4-a-lead {
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    color: #6f5545;
    letter-spacing: 0.05em;
    margin-top: 30px;
  }

  .p4-a-tables {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 30px;
    margin-bottom: 30px;
  }

  .p4-a-table {
    width: 100%;
    display: flex;
    flex-direction: column;
  }

  .p4-a-row {
    display: flex;
    border: 2px solid #ff8800;
    overflow: hidden;
  }

  .p4-a-name {
    width: 40%;
    text-align: center;
    padding: 20px 0;
    font-size: 14px;
    border-right: 2px solid #ff8800;
    background-color: #fff3b5;
  }

  .p4-a-price {
    width: 60%;
    padding: 20px 0;
    font-size: 14px;
    text-align: center;
    background-color: #fff;
  }

  .p4-a-medical {
    width: 100%;
    border: 3px solid #ff8800;
    border-radius: 20px;
    background-color: #fff;
    padding: 20px 10px;
    margin: 0 auto;
  }

  .p4-a-medical-head {
    background-color: #ff8800;
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    padding: 10px 0;
  }

  .p4-a-medical-body {
    padding-top: 20px;
  }

  .p4-a-medical-body p {
    font-size: 14px;
    line-height: 2;
  }

  .p4-a-nature {
    max-width: 400px;
    width: 92%;
    position: absolute;
    left: 50%;
    bottom: max(-60px, -4.17vw);
    z-index: 4;
    transform: translateX(-50%);
  }

  /* p5-a よくあるご質問 */
  .p5-a {
    padding-top: 40px;
    padding-bottom: 100px;
  }

  .p5-a-container {
    background-image: url(../image/p5-back1.png);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    padding: 40px 0 50px;
    margin-top: min(58px, 4.03vw);
  }

  .p5-a-box {
    width: 92%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 30px;
  }

  .p5-a-item {
    border-radius: 10px;
    overflow: hidden;
    background-color: #fff;
  }

  .p5-a-q {
    display: flex;
    align-items: stretch;
    background-color: #ff8800;
  }

  .p5-a-label--q {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    background-color: #76ac33;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    flex-shrink: 0;
  }

  .p5-a-q p {
    padding: 10px;
    font-size: 16px;
    line-height: 1.6;
    color: #fff;
    border-left: 2px solid #fff;
  }

  .p5-a-a {
    border: 2px solid #ff8800;
    border-top: none;
    border-radius: 0 0 10px 10px;
    padding: 15px;
  }

  .p5-a-a p {
    font-size: 14px;
    font-weight: bold;
    line-height: 2;
  }

  .p5-a-a p + p {
    margin-top: 15px;
  }

  /* p6-a 院長紹介 */
  .p6-a {
    padding-top: 40px;
    padding-bottom: 50px;
  }

  .p6-a-container {
    background-color: #ecf4db;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    padding: 80px 0;
  }

  .p6-a-box {
    width: 92%;
    margin: 0 auto;
  }

  .p6-a-main {
    display: flex;
    justify-content: space-between;
    flex-direction: column-reverse;
    align-items: center;
    gap: 20px;
  }

  .p6-a-left {
    width: 100%;
  }

  .p6-a-title {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    color: #333;
    margin-bottom: 20px;
  }

  .p6-a-subtitle {
    font-size: 16px;
    font-weight: bold;
    color: #ff8800;
    margin-bottom: 20px;
  }

  .p6-a-text p {
    font-size: 14px;
    line-height: 2;
  }

  .p6-a-name {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: 10px;
    padding-left: 20px;
    border-bottom: 2px dashed #25aa37;
    margin-top: 30px;
  }

  .p6-a-name img {
    width: 30px;
    height: auto;
  }

  .p6-a-name-text {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
  }

  .p6-a-name-role {
    font-size: 20px;
    font-weight: bold;
  }

  .p6-a-name-ja {
    font-size: 24px;
    font-weight: bold;
    line-height: 1.2;
  }

  .p6-a-name-en {
    font-size: 16px;
    font-weight: bold;
    color: #25aa37;
    letter-spacing: 0.05em;
  }

  .p6-a-right {
    max-width: 400px;
    width: 100%;
    position: relative;
    flex-shrink: 0;
    margin-top: 30px;
  }

  .p6-a-photo {
    border-radius: 30px;
  }

  .p6-a-photo img {
    width: 100%;
    height: auto;
    display: block;
  }

  .p6-a-welcome {
    width: 200px;
    margin: 20px auto 0;
  }

  .p6-a-welcome img {
    width: 100%;
    height: auto;
  }

  .p6-a-img {
    width: 80px;
    position: absolute;
    right: 10px;
    bottom: 40px;
    z-index: 4;
  }

  /* p6-b 経歴・写真 */
  .p6-b {
    padding: 40px 0;
  }

  .p6-b-box {
    width: 92%;
    margin: 0 auto;
  }

  .p6-b-cards {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    margin-bottom: 50px;
  }

  .p6-b-card {
    width: 100%;
    border: 2px solid #ff8800;
    border-radius: 20px;
    background-color: #fff;
    padding: 0 10px 20px;
    overflow: visible;
    position: relative;
  }

  .p6-b-card-head {
    text-align: center;
    position: relative;
    padding: 10px 0;
    border-bottom: 3px dashed #ff8800;
  }

  .p6-b-card-head p {
    font-size: 20px;
    line-height: 1.4;
    letter-spacing: 0.05em;
  }

  .p6-b-card-animal1 {
    position: absolute;
    top: -20px;
    right: -2%;
    width: 80px;
    height: auto;
  }

  .p6-b-card-animal2 {
    position: absolute;
    bottom: -20px;
    right: -2%;
    width: 80px;
    height: auto;
  }

  .p6-b-card-animal3 {
    position: absolute;
    top: -20px;
    left: -2%;
    width: 50px;
    height: auto;
  }

  .p6-b-card-animal4 {
    position: absolute;
    top: -20px;
    right: -2%;
    width: 50px;
    height: auto;
  }

  .p6-b-card-body {
    padding-top: 10px;
  }

  .p6-b-card-list {
    list-style: none;
    display: flex;
    flex-direction: column;
  }

  .p6-b-card-list li {
    font-size: 14px;
    font-weight: bold;
    line-height: 1.6;
    color: #444;
    padding-left: 0;
    padding-top: 0;
  }

  .p6-b-photos {
    display: flex;
    gap: min(65px, 4.51vw);
    align-items: center;
    justify-content: center;
  }

  .p6-b-photo {
    width: min(622px, 43.19vw);
  }

  .p6-b-photo img {
    width: 100%;
    height: auto;
    display: block;
  }

  /* p7-a 医院案内 */
  .p7-a {
    padding-top: 40px;
  }

  .p7-a-container {
    background-color: #d0efff;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    padding-top: 80px;
    padding-bottom: 100px;
    margin: 0 auto;
  }

  .p7-a-box {
    width: 92%;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    margin: 0 auto 50px;
  }

  .p7-a-table {
    width: 100%;
  }

  .p7-a-info {
    display: flex;
    flex-direction: column;
  }

  .p7-a-info-row {
    display: flex;
    align-items: baseline;
    gap: 30px;
    padding: 10px 0;
    border-bottom: 1px solid #909090;
  }

  .p7-a-info dt {
    width: 60px;
    font-size: 14px;
    flex-shrink: 0;
  }

  .p7-a-info dd {
    font-size: 14px;
    line-height: 1.7;
  }

  .p7-a-table2 {
    width: 345px;
    padding: 10px;
    background-color: #fff;
  }

  .p7-a-table2 .footer-hours-notes {
    padding-left: 10px;
    margin-bottom: 0;
  }

  .p7-a-box2 {
    width: 92%;
    margin: 0 auto;
  }

  .p7-a-credit {
    background-color: #fff;
    padding: 10px;
    border: 3px solid #ff8800;
    border-radius: 20px;
  }

  .p7-a-credit-head {
    width: 100%;
    background-color: #ff8800;
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    padding: 10px 0;
  }

  .p7-a-credit-body {
    padding: 20px 0;
    text-align: center;
  }

  .p7-a-credit-body p {
    font-size: 14px;
    font-weight: bold;
  }

  .p7-a-credit-body img {
    max-width: 400px;
    width: 100%;
    height: auto;
    margin: 20px auto 0;
  }

  .p7-b {
    margin-top: -50px;
  }

  .p7-b-box {
    width: 92%;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    margin: 0 auto;
  }

  .p7-b-item {
    max-width: 400px;
    width: 100%;
    text-align: center;
  }

  .p7-b-item:last-child {
    max-width: 400px;
    width: 100%;
  }

  .p7-b-item h3 {
    display: inline-block;
    font-size: 18px;
    font-weight: 400;
    color: #fff;
    padding: 10px 30px;
    margin-bottom: 10px;
  }

  .p7-b-item:first-child h3 {
    background-color: #4cc2ff;
  }

  .p7-b-item:last-child h3 {
    background-color: #009ded;
  }

  .p7-b-box2 {
    width: 92%;
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    gap: 20px;
    margin: 20px auto 50px;
  }

  .p7-b-item2 {
    max-width: 400px;
    width: 100%;
  }

  .p7-b-item3 {
    width: auto;
    position: relative;
    margin-top: 30px;
  }

  .p7-b-item3 p {
    width: 325px;
    font-size: 14px;
    background-image: url(../image/p2-back6.png);
    background-repeat: no-repeat;
    background-size: 100% 100%;
    padding: 10px 10px 30px;
    margin: 0 auto 10px;
    text-align: center;
  }

  .p7-b-item3 img {
    width: 120px;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 4;
  }

  .p7-c-container {
    background-color: #fffbd2;
    background-image: url(../image/sp-sub-back.png);
    background-repeat: no-repeat;
    background-size: 1440px auto;
    background-position: top center;
    padding-top: 80px;
    padding-bottom: 20px;
    margin-top: 0;
  }

  .p7-c-box {
    width: 92%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding-top: 30px;
    margin: 0 auto;
  }

  .p7-c-item {
    max-width: 400px;
    width: 100%;
    display: flex;
    flex-direction: column;
  }

  .p7-c-text {
    flex: 1;
    background-color: #fff;
    padding: 10px;
  }

  .p7-c-text h3 {
    font-size: 16px;
    font-weight: 400;
    color: #ff8800;
    letter-spacing: 0.05em;
  }

  .p7-c-text p {
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.05em;
    padding-top: 5px;
  }

  .p7-c-box2 {
    width: 92%;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding-top: 30px;
    margin: 0 auto;
  }

  .p7-c-item2 {
    width: 200px;
    display: flex;
    flex-direction: column;
  }

  .p7-c-item2 .p7-c-text {
    flex: 1;
    padding: 10px;
  }

  .p7-d-container {
    position: relative;
    background-color: #edffd7;
    background-image: none;
    padding-bottom: 100px;
    margin-bottom: 80px;
  }

  .p7-d-img {
    max-width: 400px;
    width: 92%;
    position: absolute;
    left: 50%;
    bottom: -20px;
    z-index: 4;
    transform: translateX(-50%);
  }

  /* 下層共通メイン */
  .sub-v {
    height: 36.11vw;
    background-image: url(../image/sub-back.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
  }

  .sub-v-container {
    width: 100%;
    height: 100%;
  }

  .sub-v-box {
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .sub-v-title {
    font-size: 20px;
    font-weight: bold;
    color: #000;
    text-shadow:
      0 0 min(2px, 0.14vw) #fff,
      0 0 min(4px, 0.28vw) #fff,
      0 0 min(6px, 0.42vw) #fff,
      0 0 min(9px, 0.63vw) rgba(255, 255, 255, 0.99),
      min(2px, 0.14vw) min(2px, 0.14vw) min(4px, 0.28vw) #fff,
      max(-2px, -0.14vw) max(-2px, -0.14vw) min(4px, 0.28vw) #fff,
      max(-2px, -0.14vw) max(2px, 0.14vw) min(4px, 0.28vw) #fff,
      min(2px, 0.14vw) max(-2px, -0.14vw) min(4px, 0.28vw) #fff;
    line-height: 1.4;
    letter-spacing: 0.05em;
  }

  .sub-nav {
    display: none;
  }

  /* 共通タイトル */
  .h2-title {
    text-align: center;
    position: relative;
  }

  .h2-title h2 {
    font-size: 24px;
    background: linear-gradient(90deg, #ff8a00 0%, #ffb300 45%, #ffe45c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }

  .h2-title p {
    font-size: 14px;
    font-weight: bold;
    font-family: "Zen Maru Gothic", sans-serif;
    color: #ff8800;
    letter-spacing: 0.05em;
  }

  .h2-title img:first-child {
    height: auto;
    position: absolute;
    bottom: -5px;
    z-index: 4;
  }

  .h2-title img:last-child {
    width: 30px;
    height: auto;
    position: absolute;
    bottom: -5px;
    z-index: 4;
  }

  .h2-title.h2-title1 {
    border-top: 5px solid #c6ecff;
    border-bottom: 5px solid #c6ecff;
  }

  .h2-title1 img:first-child {
    width: 30px;
    left: calc(20 / 375 * 100vw);
  }

  .h2-title1 img:last-child {
    width: 40px;
    right: calc(20 / 375 * 100vw);
  }

  .h2-title.h2-title2 {
    border-top: 5px solid #cfdfbb;
    border-bottom: 5px solid #cfdfbb;
  }

  .h2-title2 img:first-child {
    width: 50px;
    left: calc(20 / 375 * 100vw);
  }

  .h2-title2 img:last-child {
    width: 35px;
    right: calc(20 / 375 * 100vw);
  }

  /* お知らせ内容 1100で可変 */
  .single-container {
    width: 100%;
    padding: 40px 0;
  }

  .single-box {
    width: 94%;
    margin: 0 auto;
  }

  .single-title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 20px;
    line-height: 1.4;
  }

  .single-img {
    width: 100%;
    max-width: 400px;
    margin-bottom: 30px;
  }

  .single-img img {
    width: 100%;
    height: auto;
    display: block;
  }

  .single-content {
    font-size: 16px;
    line-height: 1.8;
    color: #333;
  }

  .single-content img {
    max-width: 100%;
    height: auto;
  }

  /* --- フッター --- */
  footer {
    background-color: #fff9f0;
  }

  .footer-stripe {
    height: 88px;
    background-color: #ff8800;
  }

  .footer-main {
    background-image: url(../image/sp-part2.png);
    background-repeat: no-repeat;
    background-size: 100% 65px;
    background-position: top;
    padding: 154px 0 60px;
  }

  .footer-logo {
    width: 318px;
    height: auto;
    margin: 0 auto;
  }

  .footer-main-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 45px;
    justify-content: center;
    margin-top: 45px;
  }

  .footer-left {
    width: 311px;
    flex-shrink: 0;
  }

  .footer-tel {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 37px;
  }

  .footer-tel-icon {
    width: 40px;
    height: auto;
  }

  .footer-tel-num {
    font-size: 47px;
    font-weight: bold;
    color: #ff8800;
  }

  .footer-cards {
    width: 281px;
    height: auto;
    margin: 0 auto 37px;
  }

  .footer-address {
    font-size: 16px;
    line-height: 1.5;
    font-style: normal;
  }

  .footer-right {
    width: 352px;
  }

  .footer-hours-table {
    width: 100%;
    border-collapse: collapse;
    margin: 0 auto;
    font-size: 14px;
    color: #6f5545;
  }

  .footer-hours-table th,
  .footer-hours-table td {
    border: none;
    border-bottom: 1px solid #6f5545;
    text-align: center;
    padding: 10px 6px;
    font-weight: 400;
    color: #6f5545;
  }

  .footer-hours-table tr:last-child td {
    border-bottom: none;
  }

  .footer-hours-label {
    font-weight: normal;
    font-size: 14px;
    text-align: left;
    white-space: nowrap;
    padding-left: 0;
  }

  .footer-hours-time {
    font-size: 14px;
    color: #6f5545;
    text-align: left;
    padding-left: 0;
    white-space: nowrap;
  }

  .footer-hours-table .is-open {
    color: #ff4e00;
    font-size: 14px;
    line-height: 1;
  }

  .footer-hours-table .is-closed {
    font-size: 14px;
  }

  .footer-hours-table .is-limited {
    color: #00b1a2;
    font-size: 14px;
    font-weight: bold;
    line-height: 1;
  }

  .footer-hours-notes {
    font-size: 14px;
    color: #6f5545;
    line-height: 1.5;
    padding-left: 0;
    margin-bottom: 60px;
  }

  .footer-hours-notes .is-limited {
    color: #00b1a2;
  }

  .footer-hours-notes .is-open {
    color: #c35144;
  }

  .footer-banner {
    display: block;
  }

  .footer-banner img {
    width: 100%;
    height: auto;
  }

  .footer-map {
    width: 100%;
    height: 206px;
  }

  .footer-map iframe {
    width: 100%;
    height: 100%;
  }

  .footer-nav {
    background-image: url(../image/footer-back2.png);
    background-repeat: no-repeat;
    background-size: cover;
    padding: 50px 0;
  }

  .footer-nav ul {
    width: 85%;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-direction: column;
    gap: 30px;
    margin: 0 auto;
  }

  .footer-nav ul li a {
    font-size: 16px;
    letter-spacing: 0.05em;
  }

  .copyright {
    text-align: center;
    background-color: #ff8800;
    padding: 20px 0;
  }

  .copyright p {
    font-size: 16px;
    color: #fff;
  }

  .top-back {
    display: none;
  }

  .top-back.is-show {
    opacity: 1;
    visibility: visible;
  }

  /* スマホ固定フッター */
  body {
    padding-bottom: 72px;
  }

  .sp-fixed-bar {
    height: 72px;
    display: flex;
    align-items: flex-end;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
  }

  .sp-bar-tel {
    flex: 1;
    height: 72px;
    background-color: #5dc8e6;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
    text-decoration: none;
  }

  .sp-bar-tel img {
    width: 34px;
    height: auto;
  }

  .sp-bar-tel span {
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.05em;
  }

  .sp-bar-access {
    width: calc(72 / 375 * 100vw);
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    background-color: #c1dc81;
    flex-shrink: 0;
  }

  .sp-bar-access img {
    width: 28px;
    height: auto;
  }

  .sp-bar-access span {
    color: #fff;
    font-size: 16px;
    letter-spacing: 0.05em;
  }

  .sp-bar-top {
    width: calc(70 / 375 * 100vw);
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background-color: #fff;
  }

  .sp-bar-top img {
    width: 70px;
    height: auto;
  }
}
