@charset "utf-8";
/* CSS Document */

/*
Theme Name: AMATERASU
Description: Easy,SimpleDesign
Version: simple 1.1
Base Color: red
Author: AMATERASU
Author URI: http://www.seo-amaterasu.com/
*/

:root {
  --color-bk: #253047;
  --color-yellow: #F9DB00;
  --color-cream: #fffae5;
  --color-orange: #ff7b01;
  --color-green: #1bc18e;
  --color-blue: #19C4CE;
  --color-gray: #f6f6f6;


  --color-txt-bk: #253047;
  --color-txt-yellow: #F9DB00;
  --color-txt-orange: #f8b81d;
  --color-txt-blue: #19C4CE;

  --color-bg-cream: #F7F4ED;
  --color-bg-yellow1: #fff7c0;
  --color-bg-yellow2: #fffbe2;
  --color-bg-blue: #e5f9fa;

  --ff-normal: "Urbanist", "Noto Sans JP", sans-serif;
  --ff-noto: "Noto Sans JP", sans-serif;
  --ff-maru: "Zen Maru Gothic", sans-serif;
}

* {
  color: var(--color-bk);
}

@media screen and (min-width: 769px) {
  .sp {
    display: none;
  }

  /* ヘッダー エリア */
  #header_in {
    width: 90vw;
  }

  #header_in .inner_left {
    width: 25.42372881%;
    height: auto;
    margin: 0;
    padding: 0;
    float: left;
  }

  #header_in .inner_left ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #header_in .inner_left ul li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #header_in .inner_left ul li:first-child {
    /*  margin-bottom: 5px;*/
  }

  #header_in .inner_left ul li .description {
    font-family: var(--ff-normal);
    font-size: 14px;
    font-weight: 400;
    text-align: left;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: var(--color-bk);
    margin-bottom: 10px;
  }

  #header_in .inner_left ul li img {
    /*  width: 100%;*/
    width: 160px;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #header_in .inner_left ul li a:hover img {
    transition: 1.0s;
    opacity: 0.7;
  }

  #header_in .inner_right {
    width: 50.84745762%;
    height: auto;
    margin: 0;
    padding-top: 5px;
    float: right;
  }

  #header_in .inner_right ul {
    width: 100%;
    height: auto;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--color-bk);
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  #header_in .inner_right ul li {
    width: 33.33333333%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #header_in .inner_right ul li:first-child {
    width: 28.33333333%;
  }

  #header_in .inner_right ul li a {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    color: #ffffff;
    margin: 0;
    padding: 5px 0 7px 0;
    background-color: var(--color-orange);
    border-radius: 40px;
    display: block;
  }

  #header_in .inner_right ul li:last-child a {
    background-color: var(--color-green);
    border-radius: 40px;
  }

  #header_in .inner_right ul li a span {
    font-family: var(--ff-normal);
    font-size: 12px;
    font-weight: 400;
    text-align: center;
    line-height: 1.0em;
    color: #ffffff;
    margin-bottom: 5px;
    display: block;
  }

  #header_in .inner_right ul li:first-child a {
    font-size: 24px;
    letter-spacing: 0.04em;
    color: var(--color-bk);
    padding: 0;
    background: none;
  }

  #header_in .inner_right ul li:first-child a span {
    font-size: 16px;
    letter-spacing: 0;
    color: var(--color-bk);
    background: var(--color-yellow);
    padding: 5px 0;
  }

  #header_in .inner_right ul li a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  #header_in .inner_right p {
    font-family: var(--ff-normal);
    font-size: 14px;
    font-weight: 400;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: var(--color-bk);
  }

  #header_in .inner_nav {
    width: 100%;
    height: auto;
    margin: 0;
    padding-top: 10px;
    display: table;
  }

  #header_in .inner_nav ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  #header_in .inner_nav ul li {
    width: 20%;
    height: auto;
    margin: 0;
    padding: 0;
    border-right: 1px solid var(--color-bk);
    border-left: none;
  }

  #header_in .inner_nav ul li:first-child {
    border-right: 1px solid var(--color-bk);
    border-left: 1px solid var(--color-bk);
  }

  #header_in .inner_nav ul li a {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: var(--color-bk);
    margin: 0;
    padding: 5px 0;
    display: block;
  }

  #header_in .inner_nav ul li a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  /* メインヴィジュアル エリア */
  /*#main_visual img {
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
}*/

  #main_visual {
    width: 100%;
    height: auto;
    background: #fff url(../../uploads/2025/08/main-pic.jpg) center top / 100% auto no-repeat;
  }

  #main_visual * {
    font-family: var(--ff-normal);
  }

  #main_visual_in {
    width: 90vw !important;
    max-width: 1350px;
    margin: 0 auto;
  }

  .mv_toyou {
    padding: 5rem 0 1rem;
    font-size: clamp(1.25rem, 1.75vw, 2.25rem);
    font-weight: 700;
    width: fit-content;
    background: url(../../uploads/2025/09/wave-y.png) no-repeat left bottom / contain;
    margin-bottom: 1rem;
  }

  .mv_comment {}

  .mv_comment .mv_comment_txt1 {
    font-size: clamp(2rem, 2.5vw, 3rem);
    font-weight: 900;
    margin-bottom: 0.25rem;
  }

  .mv_comment .mv_comment_txt1 strong {
    color: var(--color-blue);
  }

  .mv_comment .mv_comment_txt1 strong span {
    color: var(--color-blue);
    font-size: clamp(4rem, 5vw, 6rem);
    position: relative;
  }

  .mv_comment .mv_comment_txt1 strong span:before {
    content: "";
    display: block;
    width: 0.9rem;
    height: 0.9rem;
    background: var(--color-blue);
    border-radius: 50%;
    position: absolute;
    top: -1rem;
    left: 50%;
    transform: translateX(-50%);
  }

  .mv_comment .mv_comment_txt2 {
    font-size: clamp(2rem, 2.5vw, 3rem);
    font-weight: 900;
    background-color: var(--color-blue);
    color: #fff;
    width: fit-content;
    line-height: 1.2;
    margin-bottom: 0.25rem;
  }

  .mv_comment .mv_comment_txt2 span {
    font-size: clamp(4rem, 5vw, 6rem);
    color: #fff;
  }

  .mv_comment .mv_comment_txt3 {
    font-size: clamp(2rem, 2.5vw, 3rem);
    font-weight: 900;
    margin-bottom: 4rem;
  }

  .mv_point {
    display: flex;
    justify-content: space-between;
  }

  .mv_point .mv_pt_item {
    flex-basis: 30%;
    background: #fff;
    border-radius: 2rem;
    padding: 3rem 2rem 2rem;
    margin-bottom: 2rem;
    position: relative;
    box-shadow: rgba(0, 0, 0, 0.16) 0px 10px 36px 0px, rgba(0, 0, 0, 0.06) 0px 0px 0px 1px;
  }

  .mv_point .mv_pt_item p {
    text-align: center;
    font-size: clamp(2rem, 2.5vw, 3rem);
    color: var(--color-orange);
    font-weight: 600;
  }

  .mv_point .mv_pt_item p span {
    font-size: 1rem;
    display: block;
    text-align: center;
  }

  .mv_point .mv_pt_item .mv_pt_c {
    position: absolute;
    top: -2.5rem;
    left: 50%;
    transform: translateX(-50%);
    width: 5rem;
    height: 5rem;
    background: var(--color-blue);
    border-radius: 50%;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    flex-direction: column;
    font-size: 0.7rem;
    line-height: 1;
  }

  .mv_point .mv_pt_item .mv_pt_c span {
    display: block;
    text-align: center;
    color: #fff;
    font-size: 2rem;
  }



  /* パンくずリスト エリア */
  #breadcrumb {
    width: 1180px;
    margin: 0 auto;
  }

  #breadcrumb div {
    font-size: 12px;
    display: inline-block;
  }

  .cases-template-default #breadcrumb,
  .page-template-default #breadcrumb {
    display: none;
  }

  /* コンテンツ エリア */
  #content h1 {
    font-family: var(--ff-normal);
    font-size: 40px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-blue);
    margin-bottom: 35px;
    padding: 1em 0.5em;
    border-radius: 5px;
    border: 2px solid;
  }

  #content h2 {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 600;
    line-height: 1.0em;
    color: #ffffff;
    margin-bottom: 30px;
    padding: 0.4em 0.4em 0.5em 1.5em;
    position: relative;
    background-color: var(--color-blue);
  }

  /*
#content h2::before {
  width: 0;
  height: 0;
  content: " ";
  position: absolute;
  top: 100%;
  left: 0;
  border-style: solid;
  border-width: 0 10px 10px 0;
  border-color: transparent;
  border-right-color: var(--color-bk);
}*/

  #content h3 {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: 600;
    line-height: 1.0em;
    color: #666666;
    margin-bottom: 20px;
    padding: 0.6em 0.4em 0.65em 0.8em;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    border-left: solid 8px var(--color-blue);
  }

  #content h4,
  #content h5,
  #content h6 {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 600;
    line-height: 1.0em;
    color: #666666;
    margin-bottom: 20px;
    padding-left: 1.5em;
    position: relative;
  }

  #content h4::before,
  #content h5::before,
  #content h6::before {
    width: 12px;
    height: 12px;
    content: '';
    position: absolute;
    left: 8px;
    bottom: 5px;
    border-radius: 50%;
    background-color: #596bb3;
    display: block;
  }

  #content h4::after,
  #content h5::after,
  #content h6::after {
    width: 7px;
    height: 7px;
    content: '';
    position: absolute;
    left: 0;
    bottom: 0px;
    border-radius: 50%;
    background-color: #596bb3;
    display: block;
  }

  #content .post {
    padding-bottom: 20px;
  }

  #content .eye_catch img {
    margin: 0 10px 20px 0;
    float: left;
  }

  /* 続きを読む エリア */
  a.more-link {
    font-size: 14px;
    text-align: right;
    margin-right: 10px;
    display: block;
  }

  a.more-link:hover {
    text-decoration: underline;
  }

  a.more-link:link,
  a.more-link:active,
  a.more-link:visited,
  a.more-link:hover {
    color: #dc143c;
  }

  /* ページトップ エリア */
  p.pagetop {
    display: none;
    position: fixed;
    bottom: 20px;
    right: 20px;
  }

  p.pagetop a {
    width: 40px;
    height: 40px;
    font-size: 15px;
    text-align: center;
    text-decoration: none;
    line-height: 40px;
    color: #ffffff;
    background-color: var(--color-bk);
    border: 1px solid #ffffff;
    display: block;
  }

  p.pagetop a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  /* フッター エリア */
  #footer_in {
    background: var(--color-cream);
  }

  #footer_in .footer_contact {
    max-width: 1100px;
    width: 90vw;
    height: auto;
    margin: 0 auto;
    padding: 50px 0 80px;
    display: table;
  }

  #footer_in .footer_contact .inner_top {
    width: 100%;
    height: auto;
    margin-top: 40px;
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  #footer_in .footer_contact .inner_top .right {
    width: 46.61016949%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #footer_in .footer_contact .inner_top .right img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #footer_in .footer_contact .inner_top .left {
    width: 50%;
    height: auto;
    margin: 0;
    padding: 0;
    float: left;
  }

  #footer_in .footer_contact .inner_top .left ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #footer_in .footer_contact .inner_top .left ul li {
    width: 100%;
    height: auto;
    margin-bottom: 30px;
    padding: 0;
  }

  #footer_in .footer_contact .inner_top .left ul li:first-child {
    margin-bottom: 20px;
  }

  #footer_in .footer_contact .inner_top .left ul li:last-child {
    margin: 0 0 20px 0;
  }

  #footer_in .footer_contact .inner_top .left ul li:first-child img {
    width: 225px;
    height: auto;
    margin: 0 auto;
    padding: 0;
  }

  #footer_in .footer_contact .inner_top .left ul li:first-child a:hover img {
    transition: 1.0s;
    opacity: 0.7;
  }

  #footer_in .footer_contact .inner_top .left ul li p {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: var(--color-bk);
  }

  #footer_in .footer_contact .time {
    background: #fff;
    border-radius: 30px;
    padding: 10px 40px 20px 30px;
  }

  #footer_in .footer_contact .time table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
    margin-bottom: 15px;
  }

  #footer_in .footer_contact .time table tr {
    height: 3.5rem;
    border-bottom: 1px solid var(--color-bk);
  }

  #footer_in .footer_contact .time table tr th,
  #footer_in .footer_contact .time table tr td {
    font-family: var(--ff-normal);
    text-align: center;
  }

  #footer_in .footer_contact .time table thead td {
    width: 8%;
    font-family: var(--ff-normal);
    text-align: center;
  }

  #footer_in .footer_contact .time table thead th {
    width: 20%;
  }

  #footer_in .footer_contact .time table thead td {
    font-weight: bold;
  }

  #footer_in .footer_contact .time table tbody th {
    font-weight: 600;
  }

  #footer_in .footer_contact .time table tbody td {
    color: var(--color-blue);
    font-size: 18px;
  }

  #footer_in .footer_contact .time table tbody td.none {
    color: var(--color-bk);
  }

  #footer_in .footer_contact .time .check {
    font-family: var(--ff-normal);
    font-size: 14px !important;
    text-align: left !important;
  }

  #footer_in .footer_contact .time .check span {
    color: var(--color-blue);
  }

  #footer_in .footer_contact .inner_middle {
    width: 100%;
    height: auto;
    margin-top: 40px;
    padding: 0;
    display: table;
  }

  #footer_in .footer_contact .inner_middle a {
    font-family: var(--ff-normal);
    font-size: 36px;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: var(--color-bk);
    padding: 15px 0;
    background-color: #ffffff;
    border: 1px solid var(--color-bk);
    border-radius: 10px;
    display: block;
  }

  #footer_in .footer_contact .inner_middle a span {
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    letter-spacing: 0.1em;
    color: var(--color-bk);
    margin-top: 7px;
    display: block;
  }

  #footer_in .footer_contact .inner_middle a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  #footer_in .footer_contact .inner_bottom {
    width: 100%;
    height: auto;
    margin-top: 30px;
    padding: 0;
    display: table;
  }

  #footer_in .footer_contact .inner_bottom ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  #footer_in .footer_contact .inner_bottom ul li {
    width: 49.15254237%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #footer_in .footer_contact .inner_bottom ul li a {
    font-family: var(--ff-normal);
    font-size: 32px;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    letter-spacing: 0;
    color: #ffffff;
    margin: 0;
    padding: 15px 0;
    background-color: var(--color-orange);
    border-radius: 10px;
    display: block;
  }

  #footer_in .footer_contact .inner_bottom ul li:last-child a {
    background-color: var(--color-green);
  }

  #footer_in .footer_contact .inner_bottom ul li a span {
    font-family: var(--ff-normal);
    font-size: 14px;
    font-weight: 400;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: #ffffff;
    margin-top: 10px;
    display: block;
  }

  #footer_in .footer_contact .inner_bottom ul li a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  #footer .footer_nav {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 50px 0;
    background-color: var(--color-blue);
    display: table;
  }

  #footer .footer_nav .inner {
    width: 90vw;
    max-width: 1300px;
    height: auto;
    margin: 0 auto;
    padding: 0;
    display: table;
  }

  #footer .footer_nav .inner .cover {
    width: 57.62711864%;
    height: auto;
    margin: 0 auto;
    padding: 0;
  }

  #footer .footer_nav .inner .cover img {
    width: 225px;
    height: auto;
    margin: 0 auto 20px auto;
    padding: 12px;
    background: #fff;
    border-radius: 2rem;
  }

  #footer .footer_nav .inner .cover a:hover img {
    transition: 1.0s;
    opacity: 0.7;
  }

  #footer .footer_nav .inner .cover p {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 400;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: #ffffff;
  }

  #footer .footer_nav .inner .cover ul {
    width: 100%;
    height: auto;
    margin-top: 25px;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
  }

  #footer .footer_nav .inner .cover ul li {
    width: auto;
    height: auto;
    margin-top: 15px;
    padding: 0;
    background-image: url("../../uploads/2025/07/footer_nav_icon.png");
    background-position: 0 center;
    background-repeat: no-repeat;
  }

  #footer .footer_nav .inner .cover ul li a {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 400;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    color: #ffffff;
    margin: 0;
    padding: 0 25px 0 17px;
    display: block;
  }

  #footer .footer_nav .inner .cover ul li a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  #footer .footer_nav .inner .copyright {
    width: 100%;
    height: auto;
    margin: 0;
    padding-top: 40px;
    display: table;
  }

  #footer .footer_nav .inner .copyright p {
    font-family: var(--ff-normal);
    font-size: 12px;
    font-weight: 400;
    text-align: center;
    line-height: 1.0em;
    color: #ffffff;
  }

  /* ウィジェット エリア */
  #sidebar #widget-area {
    width: 100%;
    height: auto;
    display: table;
  }

  #sidebar #widget-area .widget-container {
    width: 100%;
    height: auto;
    float: left;
    clear: both;
  }

  #sidebar #widget-area .widget-container img {
    width: 100%;
    height: auto;
    margin-bottom: 25px;
    padding: 0;
  }

  #sidebar #widget-area .widget-container a img:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  #sidebar #widget-area .widget-container .side_menu {
    margin-bottom: 25px;
  }

  #sidebar #widget-area .widget-container .side_menu p a {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    color: #ffffff;
    margin: 0;
    padding: 1.0em 0;
    transform: rotate(.03deg);
    text-transform: uppercase;
    border-radius: 5px;
    position: relative;
    overflow: hidden;
    display: block;
  }

  #sidebar #widget-area .widget-container .side_menu p a {
    background-color: var(--color-blue);
  }

  #sidebar #widget-area .widget-container .side_menu p a:hover {
    color: #ffffff;
  }

  #sidebar #widget-area .widget-container .side_menu p a::after {
    width: 100%;
    height: 0;
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    -o-transition: all 0.3s;
    transition: all 0.3s;
    z-index: -1;
  }

  #sidebar #widget-area .widget-container .side_menu p a::after {
    background-color: #18a3ab;
  }

  #sidebar #widget-area .widget-container .side_menu p a:hover:after {
    height: 100%;
  }

  #sidebar #widget-area .widget-container ul {
    width: 100%;
    height: auto;
    margin-bottom: 25px;
    padding: 0 10px;
    border: 1px solid #cccccc;
    border-top: none;
  }

  #sidebar #widget-area .widget-container ul li {
    width: 100%;
    height: auto;
    line-height: 1.2em;
    margin: 0;
    padding: 1.2em 0 1.0em 1.0em;
    border-bottom: 1px dotted #666666;
  }

  #sidebar #widget-area .widget-container ul li:last-child {
    border: none;
  }

  #sidebar #widget-area .widget-container ul li a {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 600;
    text-decoration: none;
    line-height: 1.0em;
    color: #666666;
    margin: 0;
    padding: 0;
    transform: rotate(.03deg);
    display: inline-block;
    position: relative;
    float: none;
  }

  #sidebar #widget-area .widget-container ul li a::after {
    width: 100%;
    height: 1px;
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    transform: scale(0, 1);
    transform-origin: center top;
    transition: transform .3s;
    background-color: var(--color-bk);
  }

  #sidebar #widget-area .widget-container ul li a:hover::after {
    transform: scale(1, 1);
  }

  #sidebar #widget-area .widget-container form#searchform {
    width: 100%;
    margin-bottom: 20px;
    padding: 10px 11px 0 11px;
    display: table;
    background-color: #f8f8f8;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
    border: 1px solid #eeeeee;
  }

  #sidebar #widget-area .widget-container form#searchform label.screen-reader-text {
    margin-top: -3px;
  }

  #sidebar #widget-area .widget-container form#searchform input[type=text] {
    width: 100%;
    border: 1px solid #cccccc;
  }

  #sidebar #widget-area .widget-container form#searchform input[type=submit] {
    width: auto;
    font-size: 12px;
    margin: 5px 0 10px 0;
    padding: 0 15px;
    float: right;
    color: #333333;
    background-color: #f5f5f5;
    border: 1px solid #cccccc;
  }

  #sidebar #widget-area .widget-container form#searchform input[type=submit]:hover {
    color: var(--color-orange);
  }

  #sidebar #widget-area .widget-container #calendar_wrap {
    width: auto;
    margin-bottom: 20px;
    padding: 0 15px 0 0;
    background-color: #f8f8f8;
    border: 1px solid #eeeeee;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
  }

  #sidebar #widget-area .widget-container #calendar_wrap table#wp-calendar {
    width: 100%;
    margin-top: 10px;
  }

  #sidebar #widget-area .widget-container #calendar_wrap table#wp-calendar th {
    font-weight: bold;
    text-align: right;
    color: #333333;
  }

  #sidebar #widget-area .widget-container #calendar_wrap table#wp-calendar td {
    text-align: right;
    color: #333333;
  }

  #sidebar #widget-area .widget-container #calendar_wrap table#wp-calendar td a {
    color: #dc143c;
  }

  #sidebar #widget-area .widget-container #calendar_wrap table#wp-calendar td a:hover {
    color: #999999;
  }

  #sidebar #widget-area .widget-container #calendar_wrap table#wp-calendar caption {
    font-size: 14px;
    font-weight: bold;
    margin: 0 0 10px 10px;
    color: #333333;
  }

  #sidebar #widget-area .widget-container h3 {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    line-height: 1.0em;
    color: #ffffff;
    margin: 0;
    padding: 1.0em 0;
    background-color: var(--color-blue);
    border-top-right-radius: 5px;
    border-top-left-radius: 5px;
  }

  #sidebar #widget-area .widget-container .tagcloud {
    margin-bottom: 20px;
  }

  #sidebar #widget-area .widget-container .rss-widget-icon {
    margin: 0 5px 20px -5px;
    float: left;
  }

  /* 店舗情報（カスタムHTML） エリア */
  .side_info {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    border: 1px solid #cccccc;
    border-top: none;
  }

  .side_info img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .side_info p {
    font-family: var(--ff-normal);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4em;
    color: #666666;
    margin-bottom: 15px;
    padding: 0 10px;
  }

  .side_info p span {
    font-family: var(--ff-normal);
    font-size: 15px;
    font-weight: 600;
    text-align: right;
    line-height: 1.4em;
    color: #666666;
    margin: 0;
    padding: 0;
    display: block;
  }

  .side_info p strong {
    font-family: var(--ff-normal);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.0em;
    color: var(--color-bk);
    margin-bottom: 5px;
    padding: 0;
    display: block;
  }

  /* コメント エリア */
  #comments {
    width: auto;
    height: auto;
    margin: 20px 0 10px 0;
  }

  #respond h3 a {
    color: #ffffff;
  }

  #respond h3 a:hover {
    color: #dc143c;
  }

  #respond {
    width: auto;
    height: auto;
    margin-top: 20px;
  }

  #respond a {
    font-weight: bold;
  }

  .commentlist {
    list-style-image: none;
    list-style-type: none;
  }

  .reply {
    margin-bottom: 20px;
  }

  #commentform textarea {
    width: 99%;
    height: auto;
    margin: 10px 0;
    border: 1px solid #cccccc;
  }

  #commentform input[type=text] {
    margin-bottom: 5px;
    border: 1px solid #cccccc;
  }

  #commentform input[type=submit] {
    margin-bottom: 20px;
    padding: 5px;
    color: #333333;
    background-color: #eeeeee;
    /* [if lt IE 9] */
    background: -webkit-gradient(linear,
        left top,
        left bottom,
        color-stop(0, #eeeeee),
        color-stop(1, #cccccc));
    background: -o-linear-gradient(bottom, #eeeeee 0%, #cccccc 100%);
    background: -moz-linear-gradient(bottom, #eeeeee 0%, #cccccc 100%);
    background: -webkit-linear-gradient(bottom, #eeeeee 0%, #cccccc 100%);
    background: -ms-linear-gradient(bottom, #eeeeee 0%, #cccccc 100%);
    background: linear-gradient(to bottom, #eeeeee 0%, #cccccc 100%);
    border: 1px solid #bbbbbb;
  }

  p.nocomments {
    display: none;
  }

  /* 検索結果 エリア */
  #content h4.not_found {
    font-size: 24px;
    padding-left: 25px;
    background-image: url("images/not_found.png") !important;
    background-position: 0 0 !important;
    background-repeat: no-repeat !important;
    background: none;
    border: none;
  }

  #content p.not_found {
    font-size: 14px;
    color: #dc143c;
  }

  #content dl.search_box {
    width: 100%;
    height: auto;
    padding: 15px;
    display: table;
    background-color: #f8f8f8;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
    border: 1px solid #eeeeee;
  }

  #content dl.search_box dt input[type=text] {
    width: 70%;
    height: 25px;
    float: left;
    border: 1px solid #cccccc;
  }

  #content dl.search_box dd input[type=submit] {
    width: 100px;
    height: auto;
    font-size: 14px;
    text-align: center;
    padding: 2px 0;
    float: right;
    color: #333333;
    background-color: #f5f5f5;
    border: 1px solid #cccccc;
  }

  #content dl.search_box dd input[type=submit]:hover {
    color: var(--color-orange);
  }

  #content h4.search_result_title {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 10px;
    padding-left: 30px;
    color: #333333;
    background: none;
    background-image: url("images/search_result.png");
    background-position: 0 0;
    background-repeat: no-repeat;
    border: none;
    border-bottom: 3px dotted #000000;
  }

  #content p.search_result {
    font-size: 16px;
    margin-bottom: 20px;
  }

  #content p.search_result_txt {
    font-size: 14px;
    color: #dc143c;
    margin-bottom: 20px;
  }

  /* ページャー エリア */
  #content .pager {
    text-align: center;
  }

  #content .pager a,
  #content .pager span {
    font-size: 14px;
    padding: 0 3px;
  }

  #content .pager span {
    color: #dc143c;
  }

  #content .pager a {
    color: #000000;
  }

  #content .pager a:hover {
    color: #dc143c;
  }

  /* 404 エリア */
  #content a.reverse_lnk {
    font-size: 16px;
    text-align: center;
    padding-top: 10px;
    text-decoration: underline;
  }

  /* トップページ エリア */
  .news {
    width: 90vw;
    max-width: 1300px;
    height: auto;
    margin: 0 auto;
    padding: 4.0em 0 5.0em 0;
    background-color: #ffffff;
    display: table;
  }

  .news section:nth-child(1) {
    width: 100%;
    max-width: 1200px;
    height: auto;
    margin: 0 auto;
    padding: 0 10px;
    display: flex;
    justify-content: space-between;
  }

  .news section ul:nth-child(1) {
    width: 30%;
    height: auto;
    margin: 0;
    padding-top: 1.0em;
  }

  .news section ul:nth-child(1) li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .news section ul li strong {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 65px;
    font-weight: 400;
    text-align: left;
    line-height: 1.0em;
    letter-spacing: 0.05em;
    color: var(--color-blue);
    position: relative;
    display: block;
  }

  .news section ul li strong::after {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    font-size: 16px;
    text-align: left;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: #000000;
    content: 'お知らせ';
    position: absolute;
    top: 75px;
    left: 0;
  }

  .news section ul:nth-child(2) {
    width: 70%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .news section ul:nth-child(2) li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 2.0em 0;
    border-bottom: 1px dotted #666666;
  }

  .news section ul li p {
    text-align: left;
    line-height: 1.0em;
    letter-spacing: 0.05em;
  }

  .news section ul li p span {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 15px;
    font-weight: 500;
    color: #000000;
    margin-right: 2.0rem;
  }

  .news section ul li p a {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 15px;
    font-weight: 400;
    text-decoration: none;
    color: #555555;
    float: none;
    display: inline-block;
  }

  .news section ul li p a::after {
    content: none;
  }

  .news section:nth-child(2) {
    width: 100%;
    max-width: 1200px;
    height: auto;
    margin: 2.5em auto 0 auto;
    padding: 0 10px;
  }

  .news section a {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 18px;
    font-weight: 400;
    text-decoration: none;
    color: #000000;
    float: right;
    display: inline-block;
  }

  .news section a .arrow {
    width: 1.5em;
    height: 0.1em;
    vertical-align: middle;
    line-height: 1;
    color: #555555;
    margin: -3px 0 0 0.7rem;
    position: relative;
    background: currentColor;
    display: inline-block;
  }

  .news section a .arrow::before {
    width: 0.55em;
    height: 0.55em;
    content: '';
    position: absolute;
    top: 50%;
    right: 0;
    transform: rotate(45deg);
    transform-origin: top right;
    border: 0.15em solid currentColor;
    border-left: 0;
    border-bottom: 0;
  }

  .top_contact {
    width: 90vw;
    max-width: 1300px;
    height: auto;
    margin: 0 auto;
    padding: 60px 0;
    background-color: var(--color-cream);
  }

  .top_contact2 {
    background-color: transparent;
  }

  .top_contact .txt {
    text-align: center;
    font-size: 1.75rem;
    font-weight: 500;
    letter-spacing: 0.2rem;
    margin-bottom: 2rem;
  }

  .top_contact .inner_top {
    width: 80%;
    height: auto;
    margin: 0 auto;
    padding: 0;
    display: table;
  }

  .top_contact .inner_top a {
    font-family: var(--ff-normal);
    font-size: 36px;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: #596bb3;
    padding: 15px 0;
    background-color: #ffffff;
    border: 1px solid #596bb3;
    border-radius: 10px;
    display: block;
  }

  .top_contact .inner_top a span {
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    letter-spacing: 0.1em;
    color: #596bb3;
    margin-top: 7px;
    display: block;
  }

  .top_contact .inner_top a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  .top_contact .inner_bottom {
    width: 80%;
    height: auto;
    margin: 0 auto;
    padding: 0;
    display: table;
  }

  .top_contact .inner_bottom ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .top_contact .inner_bottom ul li {
    width: 49.15254237%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_contact .inner_bottom ul li a {
    font-family: var(--ff-normal);
    font-size: 32px;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    letter-spacing: 0;
    color: #ffffff;
    margin: 0;
    padding: 15px 0;
    background-color: var(--color-orange);
    border-radius: 10px;
    display: block;
  }

  .top_contact .inner_bottom ul li:last-child a {
    background-color: var(--color-green);
  }

  .top_contact .inner_bottom ul li a span {
    font-family: var(--ff-normal);
    font-size: 14px;
    font-weight: 400;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.03em;
    color: #ffffff;
    margin-top: 10px;
    display: block;
  }

  .top_contact .inner_bottom ul li a:hover {
    transition: 1.0s;
    opacity: 0.7;
  }

  .top_concept {
    width: 100%;
    height: auto;
    margin: 100px 0 150px 0;
    padding: 0;
    display: table;
    margin-bottom: 0;
    background: linear-gradient(180deg, #fff 0%, #fff 50%, var(--color-gray) 50%, var(--color-gray) 100%);
  }

  .top_concept .inner {
    width: 90vw;
    max-width: 1200px;
    height: auto;
    margin: 0 auto;
    padding: 0;
    background-color: #fff;
    position: relative;
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    border-radius: 0 0 50px 50px;
  }

  .top_concept .inner::after {
    /*
  content: url("../../uploads/2025/06/arrow.png");
  position: absolute;
  bottom: -110px;
  left: calc(50% - 40px);
*/
  }

  .top_concept .inner .right {
    width: 43.965517242%;
    height: auto;
    margin: 0;
    padding: 0;
    background-image: url("../../uploads/2025/08/pic02.jpg");
    background-position: right top;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 0 0 50px 0;
  }

  .top_concept .inner .left {
    width: 56.034482758%;
    height: auto;
    margin: 0;
    padding: 50px 65px 70px;
  }

  .top_concept .inner .left ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_concept .inner .left ul li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_concept .inner .left ul li strong {
    font-family: var(--ff-normal);
    font-size: 46px;
    font-weight: 700;
    text-align: center;
    line-height: 1.2em;
    color: var(--color-bk);
    padding-bottom: 35px;
    /*  background-image: url("../../uploads/2025/06/title_border.png");*/
    background-position: center bottom;
    background-repeat: no-repeat;
    display: block;
  }

  .top_concept .inner .left ul li strong span {
    font-family: var(--ff-normal);
    font-size: 52px;
    font-weight: 700;
    color: var(--color-orange);
    position: relative;
  }

  .top_concept .inner .left ul li strong span::after {
    /*
  content: url("../../uploads/2025/06/concept_title_decorate.png");
  position: absolute;
  top: -18px;
  right: -12px;
*/
  }

  .top_concept .inner .left ul li p {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 400;
    text-align: justify;
    line-height: 1.6em;
    color: #333333;
    margin-top: 20px;
  }

  .top_appeal {
    width: 100%;
    height: auto;
    margin: 0;
    padding-top: 60px;
    padding-bottom: 80px;
    display: table;
    background: var(--color-gray);
  }

  .top_appeal .inner {
    width: 80vw;
    max-width: 1000px;
    height: auto;
    margin: 0 auto;
    padding: 0;
  }

  .top_appeal .inner ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_appeal .inner ul li {
    width: 100%;
    height: auto;
    margin-bottom: 40px;
    padding: 0;
  }

  .top_appeal .inner ul li strong {
    font-family: var(--ff-normal);
    font-size: 46px;
    font-weight: 700;
    text-align: center;
    /*  line-height: 1.0em;*/
    color: var(--ff-txt-bk);
    /*  padding-bottom: 35px;*/
    /*  background-image: url("../../uploads/2025/06/title_border02.png");*/
    background-position: center bottom;
    background-repeat: no-repeat;
    display: block;
  }

  .top_appeal .inner ul li strong span {
    color: var(--color-blue);
    font-family: var(--ff-normal);
    font-size: 52px;
    margin-right: 5px;
  }

  .top_appeal .inner ul li p {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 400;
    text-align: justify;
    line-height: 1.6em;
    color: #333333;
  }

  .top_appeal .inner ul li img {
    width: 100%;
    height: auto;
    margin: 0 auto;
    padding: 0;
    border-radius: 2rem;
  }


  .top_message {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 50px 30px 100px;
    background-color: var(--color-gray);
    display: table;
  }

  .top_message strong {
    font-family: var(--ff-normal);
    font-size: 48px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-bk);
    /*  padding-bottom: 35px;*/
    /*  background-image: url("../../uploads/2025/06/title_border03.png");
  background-position: center bottom;
  background-repeat: no-repeat;*/
    display: block;
  }

  .top_message strong span.incho {
    font-family: var(--ff-normal);
    color: var(--color-orange);
  }

  .top_message strong span.txt {
    font-family: var(--ff-normal);
    font-size: 36px;
    font-weight: 700;
  }

  .top_message_box {
    width: 90vw;
    max-width: 1300px;
    height: auto;
    margin: 40px auto 0 auto;
    padding: 80px 80px 40px;
    background-color: #ffffff;
    border-radius: 50px;
  }

  .top_message .inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  .top_message .inner:first-child {
    align-items: center;
    margin-bottom: 50px;
  }

  .top_message .inner .left {
    width: 39.215686274%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_message .inner .right {
    width: 54.901960784%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_message .inner .left img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_message .inner .left strong,
  .top_message .inner .right strong {
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 700;
    text-align: left;
    line-height: 1.8em;
    margin-bottom: 30px;
    padding: 0 0 0 20px;
    background: none;
    position: relative;
  }

  .top_message .inner .left strong:before,
  .top_message .inner .right strong:before {
    content: "";
    display: block;
    position: absolute;
    top: 2px;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-blue);
  }

  .top_message .inner .left p,
  .top_message .inner .right p {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 400;
    text-align: left;
    line-height: 1.8em;
    color: #333333;
    margin-bottom: 15px;
    padding: 0;
  }

  .top_message .inner .left em,
  .top_message .inner .right em {
    font-family: var(--ff-normal);
    background: var(--color-blue);
    padding: 5px 10px 5px 5px;
    display: inline-block;
    line-height: 1.2;
    font-weight: 500;
    font-style: normal;
    margin-bottom: 5px;
  }

  .top_message .inner .right .lead {
    font-weight: 600;
    margin-bottom: 30px;
    font-size: 20px;
  }

  .top_message .inner .right p span {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 600;
    color: #333333;
    background: linear-gradient(transparent 60%, var(--color-yellow) 60%);
  }

  /* 院長挨拶はこちらボタン */
  .greeting-btn {
    display: inline-block;
    background: #19c4ce;
    color: #fff;
    text-decoration: none;
    padding: 12px 24px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 16px;
    transition: all 0.3s ease;
  }

  .greeting-btn:hover {
    background: #17b2bb;
    transform: translateY(-3px);
  }

  .top_cases {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 100px 0;
    display: table;
    background: var(--color-blue);
  }

  .top_cases strong {
    font-family: var(--ff-normal);
    font-size: 46px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    color: #fff;
    padding-bottom: 35px;
    /*
  background-image: url("../../uploads/2025/06/title_border05.png");
  background-position: center bottom;
  background-repeat: no-repeat;
*/
    display: block;
  }

  .top_cases strong span {
    font-family: var(--ff-normal);
    color: var(--color-bk);
  }

  .top_cases .inner {
    max-width: 1300px;
    width: 85vw;
    height: auto;
    margin: 40px auto;
    padding: 0;
  }

  .top_cases .inner ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
  }

  .top_cases .inner ul li {
    width: auto;
    height: auto;
    margin: 0 15px 30px 15px;
    padding: 0;
  }

  .top_cases .inner ul li a {
    width: auto;
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    color: var(--color-bk);
    margin: 0;
    padding: 20px 40px;
    border-radius: 10px;
    background-color: #fff;
    display: block;
  }

  .top_cases a.link_btn {
    font-family: var(--ff-normal);
    display: block;
    width: 300px;
    padding: 25px 80px 25px 30px;
    position: relative;
    text-align: center;
    line-height: 1.3;
    margin: 0 auto;
    background-color: var(--color-yellow);
    color: var(--color-bk);
    border-radius: 60px;
    text-decoration: none;
    font-weight: 700;
    z-index: 1;
    letter-spacing: 0.05em;
    transition: all 0.2s;
  }

  .top_cases a.link_btn:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 15px;
    margin: auto;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #fff url(../images/ico_arrow.svg) no-repeat center center;
    background-size: 1.1em;
    transition: 0.2s;
  }


  .top_cases a.link_btn:after {
    content: "";
    width: 20px;
    height: 8px;
    position: absolute;
    top: calc(50% - 6px);
    right: 30px;
    border-bottom: 2px solid var(--color-orange);
    border-right: 2px solid var(--color-orange);
    transform: skew(45deg);
    display: inline-block;
    z-index: 2;
  }

  .top_cases .inner ul li a:hover,
  .top_cases a:hover {
    transition: 1.0s;
    transform: scale(1.1);
  }

  .top_reason {
    width: 90vw;
    max-width: 1100px;
    height: auto;
    margin: 0 auto;
    padding: 100px 0 50px;
    display: table;
  }

  .top_reason p.ttl_txt {
    font-family: var(--ff-normal);
    font-size: 38px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    padding-bottom: 35px;
    /*
  background-image: url("../../uploads/2025/06/title_border06.png");
  background-position: center bottom;
  background-repeat: no-repeat;
*/
  }

  .top_reason p strong {
    font-family: var(--ff-normal);
    font-size: 42px;
    font-weight: 700;
    color: var(--color-orange);
  }

  .top_reason p strong span {
    font-family: var(--ff-normal);
    font-size: 60px;
    font-weight: 700;
    color: var(--color-orange);
  }

  .top_reason .inner {
    width: 90vw;
    max-width: 1300px;
    height: auto;
    margin: 40px auto 0 auto;
    padding: 0;
  }

  .top_reason .inner .img_left,
  .top_reason .inner .img_right {
    width: 100%;
    height: auto;
    margin-bottom: 70px;
    padding: 0;
    display: table;
  }

  .top_reason .inner .img_left .img_box {
    width: 55.08474576%;
    height: auto;
    margin: 0;
    padding: 0;
    float: left;
  }

  .top_reason .inner .img_right .img_box {
    width: 55.08474576%;
    height: auto;
    margin: 0;
    padding: 0;
    float: right;
  }

  .top_reason .inner .img_left .img_box img,
  .top_reason .inner .img_right .img_box img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    position: relative;
    z-index: 2;
    border-radius: 2rem;
    aspect-ratio: 3 / 2;
    object-fit: cover;
  }

  .top_reason .inner .img_left ul {
    width: 44.91525423%;
    height: auto;
    margin: 0;
    padding: 100px 0 0 40px;
    float: right;
  }

  .top_reason .inner .img_right ul {
    width: 44.91525423%;
    height: auto;
    margin: 0;
    padding: 100px 40px 0 0;
    float: left;
  }

  .top_reason .inner .img_left ul li,
  .top_reason .inner .img_right ul li {
    width: 100%;
    height: auto;
    margin-bottom: 30px;
    padding: 0;
  }

  .top_reason .inner .img_left ul li:last-child,
  .top_reason .inner .img_right ul li:last-child {
    margin: 0;
  }

  .top_reason .inner .img_left ul li img,
  .top_reason .inner .img_right ul li img {
    width: 30.18867924%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_reason .inner .img_left ul li strong,
  .top_reason .inner .img_right ul li strong {
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 700;
    line-height: 1.2em;
    color: var(--color-bk);
    display: block;
    position: relative;
    z-index: 1;
  }

  .top_reason .inner .img_left ul li p,
  .top_reason .inner .img_right ul li p {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 400;
    text-align: justify;
    line-height: 1.8em;
    color: #333333;
    background: none;
  }

  .top_reason .inner ul li p.num {
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 400;
    color: var(--color-blue);
    position: relative;
    width: fit-content;
  }

  .top_reason .inner p.num span {
    font-family: var(--ff-normal);
    font-size: 50px;
    font-weight: 800;
    color: var(--color-blue);
    font-style: italic;
    margin-left: 5px;
  }

  .top_reason .inner p.num:after {
    content: "";
    position: absolute;
    display: block;
    width: 200px;
    height: 200px;
    left: -60%;
    top: 50%;
    transform: translateY(-50%);
    border: 1px solid var(--color-blue);
    border-radius: 50%;
    z-index: 0;
  }

  .top_recommend {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: table;
  }

  .top_recommend strong {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-bk);
    padding-bottom: 35px;
    background-image: url("../../uploads/2025/06/title_border07.png");
    background-position: center bottom;
    background-repeat: no-repeat;
    display: block;
  }

  .top_recommend strong span {
    font-family: var(--ff-normal);
    font-size: 34px;
    font-weight: 700;
    color: var(--color-orange);
  }

  .top_recommend .inner {
    width: 1300px;
    height: auto;
    margin: 40px auto 0 auto;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
  }

  .top_recommend .inner ul {
    width: 30.508474576%;
    height: auto;
    margin-bottom: 40px;
    padding: 0;
  }

  .top_recommend .inner ul li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_recommend .inner ul li img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_recommend .inner ul li:nth-child(2) {
    margin-top: 20px;
    padding: 20px 0 10px 0;
    background-color: var(--color-bk);
  }

  .top_recommend .inner ul li p {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 500;
    text-align: center;
    line-height: 2.2em;
    color: #ffffff;
  }

  .top_recommend .inner ul li p strong {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 900;
    text-align: center;
    line-height: 1.0em;
    color: #ffffff;
    margin: 0;
    padding: 0;
    display: block;
  }

  .top_theory {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 60px 0 100px 0;
    display: table;
  }

  .top_theory strong {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-bk);
    padding-bottom: 35px;
    background-image: url("../../uploads/2025/06/title_border08.png");
    background-position: center bottom;
    background-repeat: no-repeat;
    display: block;
  }

  .top_theory strong span {
    font-family: var(--ff-normal);
    font-size: 34px;
    font-weight: 700;
    color: var(--color-orange);
  }

  .top_theory .inner {
    width: 1300px;
    height: auto;
    margin: 40px auto 0 auto;
    padding: 0;
    display: flex;
    justify-content: space-between;
  }

  .top_theory .inner ul {
    width: 31.016949152%;
    height: auto;
    margin: 0;
    padding: 25px 35px;
    background-color: #bddcc0;
  }

  .top_theory .inner ul li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_theory .inner ul li:nth-child(2) {
    margin-top: 15px;
  }

  .top_theory .inner ul li img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .top_theory .inner ul li p {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: 700;
    text-align: justify;
    line-height: 1.6em;
    color: #000000;
  }

  /* ページタイトル */
  .beginner_title,
  .access_title {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    background-color: var(--color-blue);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
  }

  .beginner_title {
    /*  background-image: url("../../uploads/2025/02/beginner_title_bg.png");*/
  }

  .access_title {
    /*  background-image: url("../../uploads/2025/02/access_title_bg.png");*/
  }

  .beginner_title h1,
  .access_title h1 {
    font-family: var(--ff-normal);
    font-size: 40px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    color: #ffffff;
    margin: 0;
    padding: 80px 0;
    position: relative;
  }

  .beginner_title h1::after {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: normal;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.1em;
    color: #ffffff;
    margin-top: 14px;
    content: 'Beginner';
    display: block;
  }

  .access_title h1::after {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: normal;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.05em;
    color: #ffffff;
    margin-top: 15px;
    content: 'Price・Access';
    display: block;
  }

  /* 初めての方へページ エリア */
  .beginner {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .beginner .inner_top {
    width: 90vw;
    max-width: 1100px;
    height: auto;
    margin: 0 auto;
    padding: 80px 0 100px 0;
    display: table;
  }

  .beginner .inner_top .inner_first {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: table;
  }

  .beginner .inner_top .inner_first img {
    width: 50%;
    height: auto;
    margin: 0;
    padding: 0;
    z-index: 2;
    position: relative;
    float: left;
  }

  .beginner .inner_top .inner_first ul {
    width: 55%;
    height: auto;
    margin-left: -5%;
    padding: 0;
    float: right;
  }

  .beginner .inner_top .inner_first ul li:first-child {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 20px 0 0 90px;
  }

  .beginner .inner_top .inner_first ul li:first-child strong {
    font-family: var(--ff-normal);
    font-size: 22px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: #666666;
    display: block;
  }

  .beginner .inner_top .inner_first ul li:first-child strong span {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 700;
    color: var(--color-blue);
  }

  .beginner .inner_top .inner_first ul li:last-child {
    width: 100%;
    height: auto;
    margin-top: -15px;
    padding: 40px 90px 20px 90px;
    background-color: var(--color-cream);
  }

  .beginner .inner_top .inner_first ul li:last-child p {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 500;
    text-align: justify;
    line-height: 1.8em;
    color: #666666;
    margin-bottom: 20px;
  }

  .beginner .inner_top .inner_second {
    width: 100%;
    height: auto;
    margin-top: 60px;
    padding: 0;
    display: table;
  }

  .beginner .inner_top .inner_second img {
    width: 50%;
    height: auto;
    margin: 0;
    padding: 0;
    float: right;
  }

  .beginner .inner_top .inner_second ul {
    width: 50%;
    height: auto;
    margin: 0;
    padding-right: 25px;
    float: left;
  }

  .beginner .inner_top .inner_second ul li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .beginner .inner_top .inner_second ul li strong {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: #000000;
    display: block;
  }

  .beginner .inner_top .inner_second ul li p {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 500;
    text-align: justify;
    line-height: 1.8em;
    color: #000000;
    margin-top: 20px;
  }

  .beginner .inner_reason {
    width: 90vw;
    max-width: 1100px;
    height: auto;
    margin: 0 auto;
    padding: 0;
    display: table;
  }

  .beginner .inner_reason strong {
    font-family: var(--ff-normal);
    font-size: 60px;
    font-weight: bold;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-orange);
    margin: 0;
    padding: 0;
    position: relative;
    display: block;
  }

  .beginner .inner_reason strong::after {
    font-family: var(--ff-normal);
    font-size: 22px;
    font-weight: 600;
    text-align: center;
    line-height: 1.0em;
    color: #666666;
    margin-top: 10px;
    content: '選ばれる理由';
    display: block;
  }

  .beginner .inner_reason .inner {
    width: 100%;
    height: auto;
    margin-top: 60px;
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .beginner .inner_reason .inner img {
    width: 33%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .beginner .inner_reason .inner ul {
    width: 65%;
    height: auto;
    margin: 0;
    padding: 0;
    background-position: left top;
    background-repeat: no-repeat;
  }

  .beginner .inner_reason .inner ul.first {
    background-image: url("../../uploads/2025/02/first.png");
  }

  .beginner .inner_reason .inner ul.second {
    background-image: url("../../uploads/2025/02/second.png");
  }

  .beginner .inner_reason .inner ul.third {
    background-image: url("../../uploads/2025/02/third.png");
  }

  .beginner .inner_reason .inner ul.fourth {
    background-image: url("../../uploads/2025/02/fourth.png");
  }

  .beginner .inner_reason .inner ul.fifth {
    background-image: url("../../uploads/2025/02/fifth.png");
  }

  .beginner .inner_reason .inner ul li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .beginner .inner_reason .inner ul li:first-child {
    padding-top: 55px;
  }

  .beginner .inner_reason .inner ul li strong {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: var(--color-bk);
    display: block;
  }

  .beginner .inner_reason .inner ul li strong::after {
    content: none;
  }

  .beginner .inner_reason .inner ul li p {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 500;
    text-align: justify;
    line-height: 1.8em;
    color: #666666;
    margin-top: 20px;
  }

  .beginner .inner_flow {
    width: 1100px;
    height: auto;
    margin: 0 auto;
    padding: 100px 0 80px 0;
    display: table;
  }

  .beginner .inner_flow strong {
    font-family: var(--ff-normal);
    font-size: 60px;
    font-weight: bold;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-orange);
    margin: 0;
    padding: 0;
    position: relative;
    display: block;
  }

  .beginner .inner_flow strong::after {
    font-family: var(--ff-normal);
    font-size: 22px;
    font-weight: 600;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-bk);
    margin-top: 10px;
    content: '施術の流れ';
    display: block;
  }

  .beginner .inner_flow .inner {
    width: 100%;
    height: auto;
    margin-top: 60px;
    padding: 0;
    display: flex;
    justify-content: space-between;
  }

  .beginner .inner_flow .inner ul {
    width: 47.27272727%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .beginner .inner_flow .inner ul li {
    width: 100%;
    height: auto;
    margin-bottom: 20px;
    padding-left: 50px;
    position: relative;
  }

  .beginner .inner_flow .inner ul li::before {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 600;
    text-align: center;
    line-height: 1.4em;
    color: #ffffff;
    padding: 0 0.4em;
    position: absolute;
    top: 2px;
    left: 0;
    background: var(--color-blue);
  }

  .beginner .inner_flow .inner ul li.first::before {
    content: '1';
  }

  .beginner .inner_flow .inner ul li.second::before {
    content: '2';
  }

  .beginner .inner_flow .inner ul li.third::before {
    content: '3';
  }

  .beginner .inner_flow .inner ul li.fourth::before {
    content: '4';
  }

  .beginner .inner_flow .inner ul li.fifth::before {
    content: '5';
  }

  .beginner .inner_flow .inner ul li.first-child::before,
  .beginner .inner_flow .inner ul li.last-child::before {
    content: none;
  }

  .beginner .inner_flow .inner ul li:first-child {
    padding: 0;
  }

  .beginner .inner_flow .inner ul li:last-child {
    margin: 0;
    padding: 0;
  }

  .beginner .inner_flow .inner ul li:first-child img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .beginner .inner_flow .inner ul li strong {
    font-family: var(--ff-normal);
    font-size: 26px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: var(--color-bk);
    display: block;
  }

  .beginner .inner_flow .inner ul li strong::after {
    content: none;
  }

  .beginner .inner_flow .inner ul li:last-child p {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 500;
    text-align: justify;
    line-height: 1.8em;
    color: #666666;
    margin-top: 20px;
  }

  /* 料金・アクセスページ エリア */
  .price {
    width: 90vw;
    max-width: 1100px;
    height: auto;
    margin: 0 auto;
    padding: 0;
    display: table;
  }

  .price .price_title {
    width: 100%;
    height: auto;
    margin: 0;
    padding-top: 80px;
  }

  .price .price_title02 {
    width: 100%;
    height: auto;
    margin: 0;
    padding-top: 60px;
  }

  .price .price_title strong {
    font-family: var(--ff-normal);
    font-size: 30px;
    font-weight: 600;
    text-align: center;
    line-height: 1.0em;
    color: #666666;
    display: block;
  }

  .price .price_title strong span {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 400;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.1rem;
    color: var(--color-orange);
    margin-top: 10px;
    display: block;
  }

  .price .price_title img {
    width: 100%;
    height: auto;
    margin-top: 30px;
    padding: 0;
  }

  .price .inner {
    width: 100%;
    height: auto;
    margin-top: 40px;
    padding: 0;
  }

  .price .inner span {
    font-family: var(--ff-normal);
    font-size: 14px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: #dc143c;
    margin-top: 10px;
    display: block;
  }

  .price .inner table {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    border-collapse: collapse;
    border: 0;
  }

  .price .inner table.type02,
  .price .inner table.type04 {
    margin-bottom: 30px;
  }

  .price .inner table th {
    width: 40%;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 500;
    text-align: left;
    line-height: 1.0em;
    color: #ffffff;
    margin: 0;
    padding: 1.0em;
    border-top: 1px solid var(--color-bk);
    border-right: 1px solid var(--color-bk);
    border-bottom: 1px solid #ffffff;
    border-left: 1px solid var(--color-bk);
    background-color: var(--color-bk);
  }

  .price .inner table.type03 th,
  .price .inner table.type04 th {
    width: 30%;
  }

  .price .inner table th.type02 {
    border: 1px solid var(--color-bk);
  }

  .price .inner table th p {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 600;
    text-align: center;
    line-height: 1.4em;
    color: #ffffff;
  }

  .price .inner table td {
    width: 60%;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 500;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-bk);
    margin: 0;
    padding: 1.0em;
    border: 1px solid var(--color-bk);
  }

  .price .inner table.type03 td,
  .price .inner table.type04 td {
    width: 35%;
  }

  .price .inner table td strong {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: 500;
    text-align: center;
    line-height: 1.6em;
    color: var(--color-bk);
    display: block;
  }

  .price .inner table td span {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: #666666;
    margin-top: 10px;
    display: block;
  }

  .price .inner table td span.note {
    font-size: 14px;
    text-align: center;
    color: #dc143c;
  }

  .price .inner table td p {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: #666666;
  }

  .page_access {
    width: 90vw;
    max-width: 1100px;
    height: auto;
    margin: 0 auto;
    padding-bottom: 80px;
    display: table;
  }

  .page_access .page_access_title {
    width: 100%;
    height: auto;
    margin: 0;
    padding-top: 80px;
  }

  .page_access .page_access_title strong {
    font-family: var(--ff-normal);
    font-size: 30px;
    font-weight: 600;
    text-align: center;
    line-height: 1.0em;
    color: #666666;
    display: block;
  }

  .page_access .page_access_title strong span {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    letter-spacing: 0.1rem;
    color: var(--color-orange);
    margin-top: 10px;
    display: block;
  }

  .page_access .inner {
    width: 100%;
    height: auto;
    margin-top: 60px;
    padding: 0;
  }

  .page_access .inner .view {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .page_access .inner table {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    border-collapse: collapse;
    border: 0;
  }

  .page_access .inner table th {
    width: 40%;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 19px;
    font-weight: 600;
    text-align: center;
    line-height: 1.6em;
    color: #ffffff;
    margin: 0;
    padding: 1.0em;
    border-top: 1px solid var(--color-bk);
    border-right: 1px solid var(--color-bk);
    border-bottom: 1px solid #ffffff;
    border-left: 1px solid var(--color-bk);
    background-color: var(--color-bk);
  }

  .page_access .inner table th.type02 {
    border: 1px solid var(--color-bk);
  }

  .page_access .inner table td {
    width: 60%;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 19px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: #666666;
    margin: 0;
    padding: 1.0em;
    border: 1px solid var(--color-bk);
  }

  .page_access .inner table td span {
    font-family: var(--ff-normal);
    font-size: 19px;
    font-weight: 600;
    color: #666666;
  }

  /* コンタクトフォーム7 エリア */
  .wpcf7 label {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    line-height: 1.0em;
    color: #666666;
  }

  .wpcf7 p input[type="text"],
  .wpcf7 p input[type="email"],
  .wpcf7 p input[type="tel"],
  .wpcf7 p input[type="date"],
  select.wpcf7-form-control.wpcf7-select.wpcf7-validates-as-required {
    width: 100%;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    line-height: 1.0em;
    color: #666666;
    margin: 1.0em 0 3.0em 0;
    padding: 1.0em;
    border: 1px solid #8290ca;
    background-color: #fefefe;
  }

  .wpcf7 p textarea {
    width: 100%;
    height: auto;
    margin-top: 0.5em;
    padding: 1.0em;
    border: 1px solid #8290ca;
    background-color: #fefefe;
  }

  .wpcf7 p select {
    width: 100%;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    line-height: 1.0em;
    color: #666666;
    margin: 1.0em 0 3.0em 0;
    padding: 1.0em;
    border: 1px solid #8290ca;
  }

  .wpcf7 p select option {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    line-height: 1.0em;
    color: #666666;
  }

  .wpcf7 p span.required {
    font-family: var(--ff-normal);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.0em;
    color: #ffffff;
    padding: 1px 1.0em 3px 1.0em;
    background-color: #596bb3;
  }

  .wpcf7 p {
    width: 100%;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    line-height: 1.0em;
    color: #666666;
    padding: 0;
  }

  span.wpcf7-list-item-label {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 400;
    color: #666666;
    margin: 1.0em 0 3.0em 0.5em;
    display: inline-block;
  }

  .wpcf7 p span.accept {
    font-family: var(--ff-normal);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.0em;
    color: #596bb3;
  }

  .wpcf7 p input[type="submit"] {
    width: 30% !important;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 600;
    text-align: center;
    line-height: 1.0em;
    color: #ffffff;
    margin: 30px auto 0 auto;
    padding: 1.0em 0;
    background: linear-gradient(to bottom, #8290ca 0%, #596bb3 100%);
    border: 1px solid #596bb3;
    display: block;
  }

  .wpcf7 p input[type="submit"]:hover {
    background: linear-gradient(to bottom, #596bb3 0%, #8290ca 100%);
    border: 1px solid #596bb3;
  }

  ::-webkit-input-placeholder {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 200;
    line-height: 1.0em;
    color: #cccccc;
  }

  ::-moz-placeholder {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 200;
    line-height: 1.0em;
    color: #cccccc;
    opacity: 1;
  }

  :-ms-input-placeholder {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 200;
    line-height: 1.0em;
    color: #cccccc;
  }

  /* コンタクトフォーム7サンクスページ エリア */
  .page_thanks {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .page_thanks p {
    font-family: var(--ff-normal);
    font-size: 32px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    color: #666666;
  }

  /* お客様の声ページ エリア */
  .single_voice {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .single_voice strong {
    font-family: var(--ff-normal);
    font-size: 28px;
    font-weight: 600;
    text-align: left;
    line-height: 1.4em;
    color: #333333;
    margin-bottom: 20px;
    display: block;
  }

  .single_voice figure {
    width: 100%;
    height: auto;
    margin：0;
    padding: 0;
  }

  .single_voice figure img {
    width: 100%;
    height: 500px;
    margin-bottom: 20px;
    padding: 0;
    object-fit: cover;
  }

  .single_voice .inner {
    width: 100%;
    height: auto;
    margin：0;
    padding: 20px 20px 30px 20px;
    background-color: #f8f8f8;
    display: table;
  }

  .single_voice .top {
    width: 100%;
    height: auto;
    margin：0;
    padding: 0;
  }

  .single_voice .top p {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 17px;
    font-weight: 400;
    text-align: justify;
    line-height: 1.8em;
    color: #000000;
  }

  .single_voice .top p span {
    font-family: "arial", sans-serif;
    font-size: 20px;
    font-weight: 600;
    color: var(--color-orange);
  }

  .single_voice .bottom {
    width: 100%;
    height: auto;
    margin-top: 20px;
    padding: 0;
  }

  .single_voice .bottom ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
  }

  .single_voice .bottom ul li {
    width: auto;
    height: auto;
    margin-right: 15px;
    padding: 0;
  }

  .single_voice .bottom ul li p {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 17px;
    font-weight: 400;
    text-align: left;
    line-height: 1.0em;
    color: #000000;
  }

  /* お客様の声一覧ページ エリア */
  .voices_cats {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .voices_cats .voice_excerpt {
    width: 100%;
    height: auto;
    margin-bottom: 40px;
    padding: 20px 20px 30px 20px;
    background-color: #f8f8f8;
    display: table;
  }

  .voices_cats .voice_excerpt a {
    font-family: var(--ff-normal);
    font-size: 24px;
    font-weight: 600;
    text-align: left;
    text-decoration: none;
    line-height: 1.4em;
    color: #333333;
    display: block;
  }

  .voices_cats .voice_excerpt a:hover {
    transition: 1.0s;
    opacity: 0.3;
  }

  .voices_cats .voice_excerpt .inner {
    width: 100%;
    height: auto;
    margin-top: 20px;
    padding: 0;
  }

  .voices_cats .voice_excerpt .inner figure {
    width: 47.058823529%;
    height: auto;
    margin: 0 0 15px 15px;
    padding: 0;
    float: right;
  }

  .voices_cats .voice_excerpt .inner figure img {
    width: 400px;
    height: 250px;
    margin: 0;
    padding: 0;
    object-fit: cover;
  }

  .voices_cats .voice_excerpt .inner .top {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .voices_cats .voice_excerpt .inner .top p {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 17px;
    font-weight: 400;
    text-align: justify;
    line-height: 1.8em;
    color: #000000;
  }

  .voices_cats .voice_excerpt .inner .top p span {
    font-family: "arial", sans-serif;
    font-size: 20px;
    font-weight: 600;
    color: var(--color-orange);
  }

  .voices_cats .voice_excerpt .inner .bottom {
    width: 100%;
    height: auto;
    margin-top: 20px;
    padding: 0;
  }

  .voices_cats .voice_excerpt .inner .bottom ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
  }

  .voices_cats .voice_excerpt .inner .bottom ul li {
    width: auto;
    height: auto;
    margin-right: 15px;
    padding: 0;
  }

  .voices_cats .voice_excerpt .inner .bottom ul li p {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 17px;
    font-weight: 400;
    text-align: left;
    line-height: 1.0em;
    color: #000000;
  }

  /* 対応症状個別ページ エリア */
  .single_case {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .single_case .inner {
    width: 100%;
    height: auto;
    margin-bottom: 25px;
    padding: 0;
    display: table;
  }

  .single_case .type01 {
    margin-bottom: 45px;
  }

  .single_case .inner img {
    width: 100%;
    height: auto;
    margin-bottom: 25px;
    padding: 0;
  }

  .single_case .inner p {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 500;
    text-align: justify;
    line-height: 2.0em;
    color: #000000;
    margin: 20px 0;
    padding: 0;
  }

  .single_case .inner ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: block;
  }

  .single_case .inner ul li {
    width: 100%;
    min-height: 20px;
    margin: 0 0 10px 0;
    padding-left: 30px;
    background-image: url("../../uploads/2025/02/check_icon.png");
    background-position: left 6px;
    background-repeat: no-repeat;
    background-size: 20px;
  }

  .single_case .inner ul li:last-child {
    margin: 0;
  }

  .single_case .inner ul li p {
    font-family: var(--ff-normal);
    font-size: 19px;
    font-weight: 600;
    text-align: left;
    line-height: 1.6em;
    margin: 0;
    padding: 0;
  }

  .single_case .inner ul li p span {
    font-family: var(--ff-normal);
    font-size: 17px;
    font-weight: 500;
    text-align: left;
    line-height: 1.4em;
    margin: 0;
    padding: 0;
    display: block;
  }

  .cases_voice {
    width: 100%;
    height: auto;
    margin-top: 60px;
    padding: 0;
  }

  .cases_voice .inner:has(.title) {
    width: 100%;
    height: auto;
    margin-bottom: 50px;
    padding: 25px;
    border: 10px solid #d4fb82;
    display: table;
  }

  .cases_voice .inner {
    display: none;
  }

  .cases_voice .inner p {
    font-family: var(--ff-normal);
    font-size: 20px;
    font-weight: 700;
    text-align: left;
    line-height: 1.2em;
    letter-spacing: 0.03em;
    color: var(--color-bk);
    margin-bottom: 25px;
    padding: 0 0 10px 10px;
    border-bottom: 2px dotted var(--color-bk);
  }

  .cases_voice .inner ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: space-between;
  }

  .cases_voice .inner ul li {
    width: 48.192771084%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .cases_voice .inner ul li img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .cases_voice .inner ul li p {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 400;
    text-align: left;
    line-height: 1.8em;
    letter-spacing: 0;
    color: #000000;
    margin: 0;
    padding: 0;
    border: none;
  }

  /* 対応症状一覧ページ エリア */
  #cases_wrap .case-block span.case-title {
    font-family: var(--ff-normal);
    font-size: 28px;
    font-weight: 700;
    text-align: center;
    line-height: 1.0em;
    color: var(--color-bk);
    padding: 1.0em;
    display: block;
  }

  #cases_wrap .case-block span.case-title::before {
    color: var(--color-bk);
    margin-right: 1.0em;
    content: "-";
    transform: scaleX(4);
    display: inline-block;
  }

  #cases_wrap .case-block span.case-title::after {
    color: var(--color-bk);
    margin-left: 1.0em;
    content: "-";
    transform: scaleX(4);
    display: inline-block;
  }

  #cases_wrap .case-block ul {
    width: 100%;
    margin-bottom: 30px;
    overflow: hidden;
  }

  #cases_wrap .case-block li {
    width: calc(100% / 3);
    padding: 0.5em;
    float: left;
  }

  #cases_wrap .case-block a {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    line-height: 1.0em;
    color: #ffffff;
    padding: 1.0em;
    border-radius: 5px;
    background-color: #18a3ab;
    transition: 0.2s;
    overflow: hidden;
    position: relative;
    display: block;
  }

  #cases_wrap .case-block a span {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    color: #fff;
  }

  #cases_wrap .case-block a::after {
    content: " ";
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    border: 5px solid transparent;
    border-left-color: #ffffff;
    display: inline-block;
  }

  #cases_wrap .case-block a:hover {
    transform: scale(0.9);
    opacity: 0.5;
  }

  /* お問い合わせページ／投稿ページ下部 エリア */
  .single_reason {
    width: 100%;
    height: auto;
    margin: 80px 0;
    padding: 0;
    display: table;
  }

  .single_reason .ttl {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: block;
  }

  .single_reason .ttl li {
    width: 100%;
    height: auto;
    margin: 25px 0 20px 0;
    padding: 0;
  }

  .single_reason .ttl li:first-child,
  .single_reason .ttl li:last-child {
    margin: 0;
  }

  .single_reason .ttl li img {
    width: 23.529411764%;
    height: auto;
    margin: 0 auto;
    padding: 0;
  }

  .single_reason .ttl li p {
    font-family: var(--ff-normal);
    font-size: 28px;
    font-weight: 700;
    text-align: center;
    line-height: 1.4em;
    letter-spacing: 0.03em;
    color: var(--color-bk);
    margin: 0;
  }

  .single_reason .ttl li p span {
    font-family: var(--ff-normal);
    font-size: 28px;
    font-weight: 700;
    color: var(--color-orange);
  }

  .single_reason .inner {
    width: 100%;
    height: auto;
    margin-top: 50px;
    padding: 0;
  }

  .single_reason .inner ul {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .single_reason .inner ul li {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .single_reason .inner ul li:last-child {
    margin-top: 20px;
  }

  .single_reason .inner ul li img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .single_reason .inner ul li p {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    text-align: justify;
    line-height: 1.6em;
    color: #333333;
    margin: 0;
  }

  .page_contact,
  .single_contact {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    display: table;
  }

  .page_contact p {
    font-family: var(--ff-normal);
    font-size: 18px;
    font-weight: 500;
    text-align: justify;
    line-height: 1.8em;
    color: #333333;
    margin: 0 0 40px 0;
  }

  .page_contact ul,
  .single_contact ul {
    width: 100%;
    height: auto;
    margin-bottom: 50px;
    padding: 0;
  }

  .page_contact ul li,
  .single_contact ul li {
    width: 100%;
    height: auto;
    margin-top: 20px;
    padding: 0;
  }

  .page_contact ul li:first-child,
  .single_contact ul li:first-child {
    margin: 0;
  }

  .page_contact ul li p,
  .single_contact ul li p {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    text-align: justify;
    line-height: 1.6em;
    color: #333333;
    margin: 0;
  }

  .page_contact ul li img,
  .single_contact ul li img {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .page_contact ul li a:hover img,
  .single_contact ul li a:hover img {
    transition: 1.0s;
    opacity: 0.3;
  }

  .page_contact .view,
  .single_contact .view {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  /* カテゴリ・アーカイブ・検索結果ページ エリア */
  .post_inner {
    width: 100%;
    height: auto;
    margin-bottom: 30px;
    padding-bottom: 15px;
    float: left;
    border-bottom: 1px dotted var(--color-bk);
  }

  .post_inner .thum {
    width: 17.14285714%;
    height: auto;
    margin: 0;
    padding: 0;
    float: left;
  }

  .post_inner .show_post {
    width: 80%;
    height: auto;
    margin: 0;
    padding: 0;
    float: right;
  }

  .post_inner .show_post li {
    width: 100%;
    height: auto;
    margin-bottom: 10px;
    padding: 0;
    float: left;
  }

  .post_inner .show_post li.cat_mark_box p.cat_mark {
    width: auto;
    height: auto;
    line-height: 1.0em;
    margin: 0;
    padding: 2px 5px;
    float: left;
    background-color: var(--color-bk);
  }

  .post_inner .show_post li.cat_mark_box p.cat_mark a {
    font-family: var(--ff-normal);
    font-size: 12px;
    font-weight: 500;
    color: #ffffff;
    text-decoration: none;
  }

  .post_inner .show_post li.cat_mark_box p.cat_date {
    width: auto;
    height: auto;
    font-family: var(--ff-normal);
    font-size: 12px;
    font-weight: 500;
    color: #999999;
    line-height: 1.4em;
    float: right;
  }

  .post_inner .show_post li.cat_title_box p.cat_title {
    font-weight: bold;
    line-height: 1.2em;
  }

  .post_inner .show_post li.cat_title_box p.cat_title a {
    font-family: var(--ff-normal);
    font-size: 16px;
    font-weight: 500;
    color: #666666;
    text-decoration: none;
  }

  .post_inner .show_post li.cat_text_box {
    margin: 0;
  }

  .post_inner .show_post li.cat_text_box p.cat_text {
    line-height: 1.3em;
  }

  .post_inner .show_post li.cat_text_box p.cat_text a {
    font-family: var(--ff-normal);
    font-size: 15px;
    font-weight: 500;
    color: #999999;
    text-decoration: none;
  }

  .post_inner .show_post li.cat_title_box p.cat_title a:hover,
  .post_inner .show_post li.cat_text_box p.cat_text a:hover,
  .post_inner .show_post li.cat_mark_box p.cat_mark a:hover {
    transition: 1.0s;
    opacity: 0.3;
  }
}