@charset "UTF-8";
/* theme Name: s-mozart
 * Author: s-mozart
 * Description: original theme
 * version: 1.0.0
 */

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
	font-size: 100%;
	vertical-align: baseline;
}

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

q,
blockquote {
  quotes: none;
}
q:before,
q:after,
blockquote:before,
blockquote:after {
  content: "";
  content: none;
}

a img {
  border: none;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

/* Init
 */
.pc-only {
  display: block !important;
}

.tb-only {
  display: none !important;
}

.sp-only {
  display: none !important;
}

body {
  font-size: 14px;
  line-height: 1.7;
  text-align: left;
  color: #333333;
  word-wrap: break-word;
  word-break: break-all;
  box-sizing: border-box;
}

.font-italianno {
  font-family: "Italianno", cursive;
}

/* Base
 */
p {
  display: block;
  margin: 0 0 10px;
  box-sizing: border-box;
}
p:last-of-type {
  margin: 0;
}

.strong {
  font-weight: bold;
  color: #df5f95;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

a {
  color: #aa75b1;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}

img {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  box-sizing: border-box;
}

/* btn */
.btn-wrapper,
.wp-block-button {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}
.btn-wrapper::after,
.wp-block-button::after {
  content: "";
  clear: both;
  display: block;
}
.btn-wrapper .btn,
.btn-wrapper .wp-block-button__link,
.wp-block-button .btn,
.wp-block-button .wp-block-button__link {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 15px 0;
  font-size: 16px;
  text-align: center;
  color: #ffffff;
  line-height: 1;
  background-color: #aa75b1;
  border: none;
  cursor: pointer;
  box-sizing: border-box;
}
.btn-wrapper .btn::after,
.btn-wrapper .wp-block-button__link::after,
.wp-block-button .btn::after,
.wp-block-button .wp-block-button__link::after {
  content: "";
  display: block;
  position: absolute;
  top: 45%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 20px;
  margin: 0;
  padding: 0;
  width: 6px;
  height: 6px;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.btn-wrapper .btn:hover,
.btn-wrapper .wp-block-button__link:hover,
.wp-block-button .btn:hover,
.wp-block-button .wp-block-button__link:hover {
  cursor: pointer;
  opacity: 0.8;
  text-decoration: none;
}
.btn-wrapper .btn.gray,
.btn-wrapper .wp-block-button__link.gray,
.wp-block-button .btn.gray,
.wp-block-button .wp-block-button__link.gray {
  color: #666666;
  background-color: #f6f6f6;
  border: #dedede 1px solid;
}
.btn-wrapper .btn.gray::after,
.btn-wrapper .wp-block-button__link.gray::after,
.wp-block-button .btn.gray::after,
.wp-block-button .wp-block-button__link.gray::after {
  border-top: solid 2px #666666;
  border-right: solid 2px #666666;
}
.btn-wrapper .btn.main,
.btn-wrapper .wp-block-button__link.main,
.wp-block-button .btn.main,
.wp-block-button .wp-block-button__link.main {
  color: #aa75b1;
  background: none;
  border: #aa75b1 1px solid;
}
.btn-wrapper .btn.main::after,
.btn-wrapper .wp-block-button__link.main::after,
.wp-block-button .btn.main::after,
.wp-block-button .wp-block-button__link.main::after {
  border-top: solid 2px #aa75b1;
  border-right: solid 2px #aa75b1;
}

.link-text {
  padding: 0 0 3px;
  color: #aa75b1;
  border-bottom: #aa75b1 1px solid;
}
.link-text:hover {
  text-decoration: none;
}

.link-arrow {
  text-align: right;
}
.link-arrow a {
  padding: 0 0 5px;
  font-size: 13px;
  color: #aa75b1;
  border-bottom: #aa75b1 1px solid;
}
.link-arrow a:before {
  content: "";
  display: inline-block;
  margin: 0 5px 0 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 0 5px 6px;
  border-color: transparent transparent transparent #aa75b1;
}
.link-arrow a:hover {
  text-decoration: none;
}

/* layout
 */
.inner-wrapper {
  display: block;
  position: relative;
  max-width: 960px;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}

article {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

aside {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

#container {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  background: url(images/common/bg_offwhite.png.webp) repeat 0 0;
  box-sizing: border-box;
}

#header {
  display: block;
  position: relative;
  max-width: 1080px;
  margin: 0 auto;
  padding: 8px 20px 15px;
}

#footer {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

#mv-wrapper {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

#breadcrumb-wrapper {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 0 10px;
  padding: 0;
  box-sizing: border-box;
}
#breadcrumb-wrapper .breadcrumb {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 10px 0 0;
  box-sizing: border-box;
}

#contents-wrapper {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
#contents-wrapper.side-wrapper .inner-wrapper::after {
  content: "";
  clear: both;
  display: block;
}
#contents-wrapper.side-wrapper .inner-wrapper article {
  float: left;
  width: calc((100% - 20px) * 0.78);
}
#contents-wrapper.side-wrapper .inner-wrapper aside {
  float: right;
  width: calc((100% - 20px) * 0.22);
}

section {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 60px 0;
  box-sizing: border-box;
}
section.bg-color {
  background: #f5f3f1;
}

article section:first-child {
  padding: 40px 0 60px;
}

.home section {
  padding: 30px 0;
}
.home section:first-child {
  padding: 30px 0;
}

/* Design
 */
/* header */
#header .header-top-nav-wrapper {
  margin: 0 0 8px;
  overflow: hidden;
}
#header .header-top-nav-wrapper .catch {
  float: left;
  font-size: 13px;
}
#header .header-top-nav-wrapper a {
  color: #333333;
}
#header .header-top-nav-wrapper .header-top-nav {
  float: right;
  display: flex;
}
#header .header-top-nav-wrapper .header-top-nav > li {
  padding: 0 0 0 20px;
}
#header .header-top-nav-wrapper .header-top-nav > li a {
  position: relative;
  display: block;
  padding: 0 0 0 24px;
  font-size: 13px;
}
#header .header-top-nav-wrapper .header-top-nav > li a::before {
  position: absolute;
  left: 0;
  top: 50%;
  display: block;
  width: 22px;
  height: 18px;
  content: "";
  transform: translateY(-50%);
}
#header .header-top-nav-wrapper .header-top-nav > li a.home::before {
  background: url(images/common/ico_header_home.png.webp) no-repeat 50% 50% /
    contain;
}
#header .header-top-nav-wrapper .header-top-nav > li a.news::before {
  background: url(images/common/ico_header_news.png.webp) no-repeat 50% 50% /
    contain;
}
#header .header-top-nav-wrapper .header-top-nav > li a.company::before {
  background: url(images/common/ico_header_company.png.webp) no-repeat 50% 50% /
    contain;
}
#header .header-top-nav-wrapper .header-top-nav > li a.access::before {
  background: url(images/common/ico_header_access.png.webp) no-repeat 50% 50% /
    contain;
}
#header .header-middle-wrapper {
  display: flex;
  justify-content: space-between;
  width: 100%;
  margin: 0 0 16px;
  padding: 0;
}
#header .header-middle-wrapper .header-logo-wrapper {
  display: flex;
  justify-content: space-between;
  width: 33.3%;
}
#header .header-middle-wrapper .header-logo-wrapper .logo {
  display: block;
  width: 61.2%;
}
#header .header-middle-wrapper .header-logo-wrapper .logo img {
  width: 100%;
  height: auto;
}
#header .header-middle-wrapper .header-logo-wrapper .access {
  display: block;
  width: 35%;
}
#header .header-middle-wrapper .header-logo-wrapper .access img {
  width: 100%;
  height: auto;
}
#header .header-middle-wrapper .header-contact-wrapper {
  display: flex;
  justify-content: space-between;
  width: 61.5%;
}
#header .header-middle-wrapper .header-contact-wrapper .tel {
  width: 55.6%;
}
#header .header-middle-wrapper .header-contact-wrapper .contact {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 21.7%;
  padding: 8px 10px;
  background: #c8a2cd;
  color: #fff;
  font-weight: bold;
  font-size: 13px;
  border-radius: 4px;
  box-shadow: 0 -2px 0 0 #aa75b1 inset;
  box-sizing: border-box;
}
#header .header-middle-wrapper .header-contact-wrapper .contact span {
  position: relative;
  display: inline-block;
  padding: 0 0 0 22px;
}
#header .header-middle-wrapper .header-contact-wrapper .contact span::before {
  position: absolute;
  left: 0;
  top: 50%;
  width: 16px;
  height: 14px;
  background: url(images/common/ico_header_contact.png.webp) no-repeat 50% 50% /
    contain;
  transform: translateY(-50%);
  content: "";
}
#header .header-middle-wrapper .header-contact-wrapper .contact:hover {
  text-decoration: none;
  opacity: 0.7;
}
#header .header-middle-wrapper .header-contact-wrapper .reservation {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 19.3%;
  padding: 8px 10px;
  background: #df5f95;
  color: #fff;
  font-weight: bold;
  font-size: 13px;
  border-radius: 4px;
  box-shadow: 0 -2px 0 0 #d23d7c inset;
  box-sizing: border-box;
}
#header .header-middle-wrapper .header-contact-wrapper .reservation span {
  position: relative;
  display: inline-block;
  padding: 0 0 0 22px;
}
#header
  .header-middle-wrapper
  .header-contact-wrapper
  .reservation
  span::before {
  position: absolute;
  left: 0;
  top: 50%;
  width: 16px;
  height: 14px;
  background: url(images/common/ico_header_reservation.png.webp) no-repeat 50%
    50% / contain;
  transform: translateY(-50%);
  content: "";
}
#header .header-middle-wrapper .header-contact-wrapper .reservation:hover {
  text-decoration: none;
  opacity: 0.7;
}
#header .header-middle-wrapper .header-menu-btn-sp {
  display: none;
}
#header .header-gnavi {
  display: flex;
  width: 100%;
  justify-content: space-between;
}
#header .header-gnavi > li {
  padding: 0 10px 0 0;
  font-size: 12px;
}
#header .header-gnavi > li:last-child {
  padding: 0;
}
#header .header-gnavi > li a.about {
  position: relative;
  display: inline-block;
  padding: 0 0 0 18px;
}
#header .header-gnavi > li a.about::before {
  position: absolute;
  left: 0;
  top: 3px;
  display: block;
  width: 14px;
  height: 18px;
  background: url(images/common/ico_header_about.png.webp) no-repeat 50% 50% /
    contain;
  content: "";
}
#header .header-gnavi a {
  color: #333333;
}

#breadcrumb-wrapper .breadcrumb ol {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
#breadcrumb-wrapper .breadcrumb ol li {
  display: inline-block;
  position: relative;
  margin: 0 10px 0 0;
  padding: 0;
  color: #333333;
  font-size: 15px;
  box-sizing: border-box;
}
#breadcrumb-wrapper .breadcrumb ol li + li:before {
  content: "";
  display: inline-block;
  position: relative;
  top: -1px;
  margin: 0 10px 0 0;
  vertical-align: middle;
  width: 6px;
  height: 6px;
  border-top: solid 1px #333333;
  border-right: solid 1px #333333;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#breadcrumb-wrapper .breadcrumb ol li a {
  color: #333333;
}
#breadcrumb-wrapper .breadcrumb ol li .icon {
  display: inline-block;
  width: 20px;
  margin: 0 5px -2px 0;
  box-sizing: border-box;
}
#breadcrumb-wrapper .breadcrumb.single ol li {
  color: #aa75b1;
}
#breadcrumb-wrapper .breadcrumb.single ol li + li:before {
  border-top: solid 1px #aa75b1;
  border-right: solid 1px #aa75b1;
}
#breadcrumb-wrapper .breadcrumb.single ol li a {
  color: #aa75b1;
}

/* mv */
#mv-wrapper .page {
  display: block;
  position: relative;
  width: 100%;
  height: 240px;
  margin: 0;
  padding: 0;
  background: #454545;
  overflow: hidden;
  box-sizing: border-box;
}
#mv-wrapper .page.gradient {
  background: linear-gradient(90deg, #454545 45%, #6a6a6a 55%);
}
#mv-wrapper .page .page-mv-img {
  width: auto;
  height: 100%;
  margin: 0 auto;
}
#mv-wrapper .page .page-title {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100%;
  margin: 0 auto;
  padding: 0;
  z-index: 2;
  box-sizing: border-box;
}
#mv-wrapper .page .page-title h1 {
  color: #ffffff;
  font-size: 36px;
  font-weight: 500;
  text-align: center;
}
#mv-wrapper .page .page-title p {
  color: #ffffff;
  font-size: 30px;
  text-align: center;
}
#mv-wrapper .page.nude {
  height: 480px;
  background: #000;
}
#mv-wrapper .page.nude .page-title-nude {
  position: relative;
  display: inline-block;
  width: auto;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
#mv-wrapper .page.nude .page-title h1 {
  position: relative;
  display: inline-block;
  font-size: 42px;
  line-height: 1.5;
}
#mv-wrapper .page.nude .page-title h1::after {
  content: "";
  position: relative;
  bottom: -40px;
  display: block;
  width: 32px;
  height: 1px;
  margin: 0 auto;
  background: #ffffff;
  box-sizing: border-box;
}
#mv-wrapper .page.nude .page-title p {
  display: block;
  margin: 0 auto;
  font-size: 16px;
}
#mv-wrapper .page.nude .page-title p.font-italianno {
  position: relative;
  top: -39px;
  font-size: 42px;
  opacity: 0.16;
}
#mv-wrapper .page #breadcrumb-wrapper {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
}
#mv-wrapper .page #breadcrumb-wrapper .breadcrumb ol li {
  color: #ffffff;
}
#mv-wrapper .page #breadcrumb-wrapper .breadcrumb ol li + li:before {
  border-top: solid 1px #ffffff;
  border-right: solid 1px #ffffff;
}
#mv-wrapper .page #breadcrumb-wrapper .breadcrumb ol li a {
  color: #ffffff;
}

#mv-wrapper .home {
  background-image: url(images/mv/bg_mv_home_sp.png.webp);
  background-repeat: repeat-y;
  background-position: center top;
  background-size: 100% auto;
  background-color: #3b3b3b;
  transition: opacity 0.3s ease-out;
}


@media screen and (min-width: 768px) {
  #mv-wrapper .home {
    background-image: url(images/mv/bg_mv_home_pc.png.webp);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    height: 920px;
    min-height: 920px;
    background-color: #454545;
  }
}

#mv-wrapper .home .inner-wrapper {
  min-height: 920px;	
  position: relative; /* 背景画像の上に重ねるためにrelativeを指定 */
  padding: 50px 0;
}

#mv-wrapper .home .slider-box {
  display: block;
  position: relative;
  width: 576px;
  margin: 0 34px 0 0;
  padding: 0;
  box-sizing: border-box;
}
#mv-wrapper .home .slider-box .top-slider {
  margin: 0 0 10px;
  box-sizing: border-box;
}
#mv-wrapper .home .slider-box .top-slider .slide-item {
  padding: 29px;
  background: no-repeat 50% 50% / cover;
}

#mv-wrapper .home .slider-box .top-slider .slide-item {
  background-image: url(images/common/img_photoframe.png.webp);
}

#mv-wrapper .home .slider-box .top-thumbnail {
  max-width: 100%;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: left;
}
#mv-wrapper .home .slider-box .top-thumbnail li {
  cursor: pointer;
  position: relative;
  width: 56px;
  height: 56px;
  margin: 0 0 0 9px;
  padding: 3px;
  background: no-repeat 50% 50% / cover;
  box-sizing: border-box;
}

#mv-wrapper .home .slider-box .top-thumbnail li {
  background-image: url(images/common/img_photoframe.png.webp);
}

#mv-wrapper .home .slider-box .top-thumbnail li:nth-child(9n + 1) {
  margin-left: 0;
}
#mv-wrapper .home .slider-box .top-thumbnail li.thumbnail-current::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: url(images/mv/img_thumbnail_current.png.webp) no-repeat 50% 50% /
    cover;
}
#mv-wrapper .home .heading-box {
  display: block;
  position: relative;
  width: 350px;
  margin: 0;
  padding: 28px 0 0;
  color: #ffffff;
  text-align: center;
  float: right;
  box-sizing: border-box;
}
#mv-wrapper .home .heading-box h1 {
  margin: 0 0 10px;
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  line-height: 1.3;
  letter-spacing: normal;
}
#mv-wrapper .home .heading-box p {
  width: 165px;
  margin: 0 auto;
}
#mv-wrapper .home .txt-box {
  display: block;
  position: absolute;
  top: 190px;
  right: 0;
  width: 350px;
  margin: 0;
  padding: 0;
  color: #ffffff;
  text-align: center;
  box-sizing: border-box;
}
#mv-wrapper .home .txt-box h2 {
  margin: 0 0 38px;
  font-size: 20px;
  font-weight: 500;
  text-align: center;
  line-height: 1.4;
  letter-spacing: normal;
  box-sizing: border-box;
}
#mv-wrapper .home .txt-box .btn-wrapper {
  margin: 0 0 15px;
  padding: 0 10px;
}
#mv-wrapper .home .txt-box .link {
  display: inline-block;
  margin: 0;
  padding: 0 0 4px;
  color: #ffffff;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  border-bottom: #ffffff 1px solid;
}
#mv-wrapper .home .txt-box .link:hover {
  text-decoration: none;
}
#mv-wrapper .home .txt-box .about-us {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 20px 10px 30px;
  color: #333333;
  font-size: 13px;
  background-color: #ffffff;
  box-sizing: border-box;
}
#mv-wrapper .home .txt-box .about-us h3 {
  position: relative;
  margin: 0 0 26px;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  line-height: 1.4;
  letter-spacing: normal;
  box-sizing: border-box;
}
#mv-wrapper .home .txt-box .about-us h3 img {
  position: relative;
  display: inline-block;
  width: 56px;
  margin: 0 -17px 15px -39px;
}
#mv-wrapper .home .txt-box .about-us p {
  position: relative;
  line-height: 1.5;
}

/* section */
section .heading {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto 40px;
  padding: 0;
  box-sizing: border-box;
}
section h2 {
  display: block;
  margin: 0 auto;
  font-size: 28px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
section h3 {
  display: block;
  margin: 0 auto;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
section h4 {
  display: block;
  margin: 0 auto;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
section h4::after {
  content: "";
  display: block;
  position: relative;
  width: 40px;
  height: 2px;
  margin: 15px auto -15px;
  padding: 0;
  background: #aa75b1;
  box-sizing: border-box;
}
section h5 {
  display: block;
  margin: 20px auto 10px;
  padding: 0 0 0 0.5em;
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  border-left: #aa75b1 2px solid;
}
section .catch {
  display: block;
  margin: 0 auto;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
section .title-sub {
  display: block;
  margin: 0 auto;
  font-size: 24px;
  text-align: center;
  color: #aa75b1;
}
section .column-1 {
  display: block;
  position: relative;
  width: 656px;
  margin: 0 auto 30px;
  padding: 0;
  font-size: 16px;
  box-sizing: border-box;
}
section .column-2 {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto 30px;
  padding: 0;
  font-size: 16px;
  box-sizing: border-box;
}
section .column-2::after {
  content: "";
  clear: both;
  display: block;
}
section .column-2 .column-child {
  display: block;
  position: relative;
  width: calc(50% - 7.5px);
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}
section .column-2 .column-child .btn-wrapper {
  width: 360px;
  margin: 15px auto 0;
}
section .column-2 .column-child .btn-wrapper.full {
  width: 100%;
}
section .column-2 .column-child.padding-left {
  padding-left: 10px;
}
section .column-2 .column-child.padding-right {
  padding-right: 10px;
}
section .column-2 .column-child:nth-child(even) {
  float: right;
}
section .column-2 .column-child:nth-child(odd) {
  float: left;
}
section .column-flex {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  width: 100%;
  margin: 0 auto 30px;
  padding: 0;
  font-size: 16px;
  box-sizing: border-box;
}
section .column-flex li {
  display: block;
  position: relative;
  width: 50%;
  margin: 0 0 40px;
  padding: 0;
  box-sizing: border-box;
}
section .column-flex li.heightLine {
  padding-bottom: 65px;
}
section .column-flex li.heightLine .btn-wrapper {
  position: absolute;
  bottom: 0;
  left: 56.25px;
}
section .column-flex li:nth-child(even) {
  padding-left: 15px;
}
section .column-flex li:nth-child(odd) {
  padding-right: 15px;
}
section .column-flex li img {
  margin: 0 auto 15px;
}
section .column-flex li .title {
  display: block;
  margin: 0 auto 10px;
  color: #aa75b1;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
section .column-flex li .title span {
  display: block;
  font-size: 18px;
}
section .column-flex li .btn-wrapper {
  width: 360px;
  margin: 15px auto 0;
}
section .column-flex.dress-list li .title {
  color: #333333;
  text-align: left;
}
section .column-flex.dress-list li .title span {
  display: inline;
  font-size: 22px;
  color: #aa75b1;
}
section .column-1 .align-center,
section .column-2 .align-center,
section .column-flex .align-center {
  text-align: center;
}
section .column-1 .align-left,
section .column-2 .align-left,
section .column-flex .align-left {
  text-align: left;
}
section .column-1 .align-right,
section .column-2 .align-right,
section .column-flex .align-right {
  text-align: right;
}
section .column-1 .margin-bottom,
section .column-2 .margin-bottom,
section .column-flex .margin-bottom {
  margin-bottom: 15px;
}
section .youtube-wrap {
  position: relative;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
}
section .youtube-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
section .caption {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 15px;
  color: #ffffff;
  font-size: 16px;
  text-align: center;
  background: rgba(0, 0, 0, 0.8);
  box-sizing: border-box;
}
section .caption span {
  color: #df5f95;
}
section .caption.align-left {
  text-align: left;
}
section .img-caption {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section .img-caption .caption {
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
section .memo-list {
  position: relative;
  width: 100%;
  margin: 0;
  padding: 27px;
  list-style-type: decimal;
  background: #ffffff;
  border: #dedede 4px solid;
  border-radius: 8px;
  box-sizing: border-box;
}
section .memo-list li {
  margin: 0 0 27px 1em;
}
section .memo-list li:last-child {
  margin: 0 0 0 1em;
}
section .memo-block {
  position: relative;
  width: 100%;
  margin: 0;
  padding: 27px;
  background: #ffffff;
  border: #dedede 4px solid;
  border-radius: 8px;
  box-sizing: border-box;
}
section .memo-block h4 {
  margin: 0 auto 30px;
}
section .culcform-goodday-block {
  position: relative;
  width: 100%;
  margin: 0 auto 50px;
  padding: 50px 27px 27px;
  background: #ffffff;
  border: #dedede 4px solid;
  box-sizing: border-box;
}
section .culcform-goodday-block h4 {
  font-size: 20px;
}
section .culcform-goodday-block h4::after {
  display: none;
}
section .culcform-goodday-block #goodday h4 {
  margin: 0 auto 10px;
}
section .culcform-goodday-block .section-body {
  margin: 30px auto 0;
  font-weight: 500;
  text-align: center;
}
section .culcform-goodday-block .section-body.answer {
  padding: 20px;
  text-align: center;
  border-radius: 5px;
  background: #f6f1f7;
}
section .culcform-goodday-block .section-body input[type="text"] {
  padding: 10px 20px;
  font-size: 16px;
  border: #dedede 1px solid;
  border-radius: 5px;
  background: #ffffff;
  box-sizing: border-box;
}
section .culcform-goodday-block .section-body #calcButton {
  display: block;
  position: relative;
  width: 292px;
  margin: 15px auto 0;
  padding: 10px;
  text-align: center;
  color: #ffffff;
  font-size: 18px;
  border: none;
  background: #c8a2cd;
  cursor: pointer;
  box-sizing: border-box;
}
section .culcform-goodday-block .section-body #calcButton::after {
  content: "";
  display: block;
  position: absolute;
  left: 4px;
  top: 4px;
  width: 100%;
  height: 100%;
  border-right: #eee3ef 4px solid;
  border-bottom: #eee3ef 4px solid;
  box-sizing: border-box;
}
section .culcform-goodday-block #returnDate {
  color: #df5f95;
}
section .culcform-goodday-block .heading {
  position: absolute;
  top: -30px;
  left: 0;
  text-align: center;
}
section .culcform-goodday-block .balloon {
  position: relative;
  display: inline-block;
  margin: 0 auto;
  width: auto;
  margin: 0 auto 40px;
  padding: 10px 60px;
  color: #ffffff;
  font-size: 22px;
  font-weight: 500;
  background: #aa75b1;
  box-sizing: border-box;
}
section .culcform-goodday-block .balloon::before {
  content: "";
  position: absolute;
  bottom: -13px;
  left: 50%;
  margin-left: -14px;
  border-style: solid;
  border-width: 14px 11px 0 11px;
  border-color: #aa75b1 transparent transparent transparent;
}
section .note {
  position: relative;
  padding: 0 0 0 1.2em;
}
section .note span {
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  box-sizing: border-box;
}
section .note.small {
  font-size: 13px;
}

/* accordion */
.js__acPrtSp {
  pointer-events: none;
}

/* staff */
section.staff h3 {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  padding: 0 0 10px;
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  box-sizing: border-box;
}
section.staff h3::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: #dedede;
  box-sizing: border-box;
}
section.staff h3::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 200px;
  height: 2px;
  background: #aa75b1;
  box-sizing: border-box;
}
section.staff h4 {
  display: block;
  position: relative;
  margin: 0 auto 10px;
  padding: 0 0 0 10px;
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  border-left: #aa75b1 3px solid;
}
section.staff h4::after {
  display: none;
}
section.staff .staff-list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.staff .staff-list li {
  display: block;
  width: calc(33.33333% - 20px);
  margin: 0 30px 30px 0;
  padding: 0;
  box-sizing: border-box;
}
section.staff .staff-list li:nth-child(3n) {
  margin-right: 0;
}
section.staff .staff-list li:nth-last-child(-n + 3) {
  margin-bottom: 0;
}
section.staff .staff-list li img {
  margin: 0 0 15px;
}
section.staff .staff-list li .role {
  font-size: 14px;
  margin: 0;
  line-height: 1;
  color: #333333;
}
section.staff .staff-list li .name {
  font-size: 18px;
  color: #333333;
}
section.staff .staff-list li .name-en {
  font-size: 13px;
  color: #999999;
}
section.staff .side-scroll {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.staff .works-list {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.staff .works-list img {
  margin: 20px auto 0;
}
section.staff .works-list table {
  width: 100%;
  margin: 0;
  padding: 0;
  font-size: 14px;
  border-collapse: separate;
  border-spacing: 2px;
  box-sizing: border-box;
}
section.staff .works-list table tr th {
  padding: 15px 27px;
  text-align: center;
  white-space: nowrap;
  background: #d4cfd5;
}
section.staff .works-list table tr td {
  padding: 15px;
  text-align: center;
}
section.staff .works-list table tr:nth-child(odd) td {
  background: #e3e3e3;
}
section.staff .works-list table tr:nth-child(even) td {
  background: #fafafa;
}
section.staff .history-list {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.staff .history-list li {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto 30px;
  padding: 0;
  box-sizing: border-box;
}
section.staff .history-list li::after {
  content: "";
  clear: both;
  display: block;
}
section.staff .history-list li.left img {
  float: left;
}
section.staff .history-list li.left .text {
  float: right;
}
section.staff .history-list li.right img {
  float: right;
}
section.staff .history-list li.right .text {
  float: left;
}
section.staff .history-list li:last-child {
  margin-bottom: 0;
}
section.staff .history-list li img {
  width: 270px;
  margin: 0 auto;
}
section.staff .history-list li .text {
  display: block;
  position: relative;
  width: calc(100% - 285px);
  margin: 0;
  padding: 0;
}
section.staff .history-list li .text::after {
  content: "";
  clear: both;
  display: block;
}
section.staff .column-2.profile .column-child:first-child {
  width: 230px;
}
section.staff .column-2.profile .column-child:last-child {
  width: calc(100% - 245px);
}
section.staff .column-2.profile .staff-img {
  border: #ffffff 4px solid;
  box-shadow: 0 0 4px #bababa;
}
section.staff .column-2.profile .name {
  font-size: 24px;
  font-weight: 500;
}
section.staff .column-2.profile .name span {
  margin: 0 0 0 10px;
  font-size: 16px;
  color: #999999;
}
section.staff .column-2.profile .greeting {
  display: block;
  position: relative;
  width: 100%;
  margin: 20px auto 0;
  padding: 20px 15px;
  font-size: 14px;
  background: #ffffff;
  border: #dedede 4px solid;
  box-sizing: border-box;
}

/* ========================================
   フォーム
======================================== */

.grecaptcha-badge {
	margin-bottom: 100px;
}

.reserve__phone-inner, .contact__phone-inner {
  width: 100vw;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  background: url(//s-mozart.com/wp-content/themes/s-mozart/images/common/bg_woodgrain.png.webp) repeat 50% 50%/cover;
}

.reserve__phone-heading,
.reserve__mail-heading,
.contact__phone-heading,
.contact__mail-heading {
	text-align: center !important;
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}
.reserve__phone-heading::before,
.reserve__phone-heading::after,
.reserve__mail-heading::before,
.reserve__mail-heading::after,
.contact__phone-heading::before,
.contact__phone-heading::after,
.contact__mail-heading::before,
.contact__mail-heading::after {
  content: none !important;
  display: none !important;
}
section .contact-text-wrapper {
  display: block;
  width: 656px;
  margin: 0 auto;
  padding: 30px 0 0;
  border-top: #999999 1px dotted;
  box-sizing: border-box;
}
section .contact-text-wrapper::after {
  content: "";
  clear: both;
  display: block;
}
section .contact-text-wrapper figure {
  width: 142px;
  margin: 0 0 0 20px;
  float: right;
}
section .form-table {
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section .form-table th {
  width: 200px;
  margin: 0;
  padding: 30px 0;
  vertical-align: baseline;
  box-sizing: border-box;
}
section .form-table td {
  margin: 0;
  padding: 30px 0 30px 15px;
  vertical-align: baseline;
  box-sizing: border-box;
}
section .form-table .vertical-align-top {
  vertical-align: top;
}
section .form-table .label {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0 3em 0 0;
  box-sizing: border-box;
}
section .form-table .label .required,
section .form-table .label .option {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  padding: 1px 5px;
  font-size: 15px;
  color: #ffffff;
  border-radius: 3px;
  box-sizing: border-box;
}
section .form-table .label .required {
  background: #df5f95;
}
section .form-table .label .option {
  background: #999999;
}
section .form-table td .label {
  display: inline-block;
  width: auto;
}
section .form-table .form-group {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section .form-table .form-group::after {
  content: "";
  clear: both;
  display: block;
}
section .form-table .form-group p {
  margin: 0 0 10px;
}
section .form-table input[type="text"],
section .form-table input[type="email"],
section .form-table textarea {
  width: 100%;
  padding: 10px;
  font-size: 16px;
  border: #dedede 1px solid;
  border-radius: 5px;
  background: #ffffff;
  box-sizing: border-box;
}
section .form-table input[type="text"]::placeholder,
section .form-table input[type="email"]::placeholder,
section .form-table textarea::placeholder {
  color: #bfbfbf;
}
section .form-table input[type="text"].hasDatepicker,
section .form-table input[type="email"].hasDatepicker,
section .form-table textarea.hasDatepicker {
  background-color: #ffffff;
  background-image: url(images/common/ico_calendar.png.webp);
  background-repeat: no-repeat;
  background-size: 22px 22px;
  background-position: right 10px center;
}
section .form-table .select-wrap {
  position: relative;
  box-sizing: border-box;
}
section .form-table .select-wrap::before {
  content: "";
  display: block;
  position: absolute;
  top: 45%;
  transform: translateY(-50%);
  right: 15px;
  margin: 0;
  padding: 0;
  z-index: 1;
  width: 6px;
  height: 6px;
  border-top: solid 2px #333333;
  border-right: solid 2px #333333;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}
section .form-table .select-wrap select {
  width: 100%;
  padding: 7.2px 10px;
  font-size: 16px;
  vertical-align: middle;
  border: #dedede 1px solid;
  border-radius: 5px;
  background: #ffffff;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  box-sizing: border-box;
}
section .form-table .select-wrap select option:first-child {
  display: none;
}
section .form-table .form-group .hasDatepicker,
section .form-table .form-group .select-wrap {
  width: calc(50% - 7.5px);
  float: left;
}
section .form-table .form-group .hasDatepicker {
  margin: 0 7.5px 30px 0 !important;
}
section .form-table .form-group .select-wrap {
  margin: 0 0 30px 7.5px !important;
}
section.form .btn-wrapper .btn {
  width: 352px;
}
section.form .btn-wrapper .btn::before {
  content: "";
  display: block;
  position: absolute;
  left: 4px;
  top: 4px;
  width: 100%;
  height: 100%;
  border-right: #eee3ef 4px solid;
  border-bottom: #eee3ef 4px solid;
  box-sizing: border-box;
}
section.form-tel-box {
  padding: 60px 0;
  text-align: center;
  background: url(images/common/bg_woodgrain.png.webp) repeat 50% 50% / cover;
}
section.form-tel-box .heading {
  margin: 0 auto 10px;
}
section.form-tel-box .btn-wrapper {
  margin: 0 auto 15px;
}
section.form-tel-box .form-top-txt {
  width: 427px;
  margin: 0 auto;
  text-align: left;
}
section.form-tel-box .tel {
  display: inline-block;
  position: relative;
  margin: 0 auto;
  padding: 10px 40px;
  text-align: center;
  color: #ffffff;
  font-size: 18px;
  border: none;
  background: #aa75b1;
  cursor: pointer;
  box-sizing: border-box;
}
section.form-tel-box .tel::after {
  content: "";
  display: block;
  position: absolute;
  left: 4px;
  top: 4px;
  width: 100%;
  height: 100%;
  border-right: #eee3ef 4px solid;
  border-bottom: #eee3ef 4px solid;
  box-sizing: border-box;
}
section.form-tel-box .tel .num {
  display: inline-block;
  position: relative;
  margin: 0 20px 0 0;
  padding: 0 0 0 1em;
  font-size: 32px;
  font-weight: bold;
}
section.form-tel-box .tel .num::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 26px;
  height: 35px;
  background: url(images/common/ico_cv_tel.png.webp) no-repeat 0 0 / contain;
  transform: translateY(-50%);
}
section.form-tel-box .tel .time {
  display: inline-block;
  position: relative;
  font-size: 15px;
  line-height: 1.2;
}

section .photoframe {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 5%;
  background: url(images/common/img_photoframe.png.webp) no-repeat 50% 50% /
    cover;
  box-shadow: 0 0 4px #bababa;
  box-sizing: border-box;
}
section .photoframe.photoframe-2 {
  background: url(images/common/img_photoframe_2.png.webp) no-repeat 50% 50% /
    cover;
}
section .photoframe img {
  margin: 0 auto !important;
}
section .faq-cat-list {
  display: flex;
  justify-content: space-between;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 10px;
  background: #dedede;
  box-sizing: border-box;
}
section .faq-cat-list li {
  display: block;
  position: relative;
  width: calc(33.3% - 5px);
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section .faq-cat-list li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 15px 0;
  text-align: center;
  color: #aa75b1;
  background: #ffffff;
  cursor: pointer;
  box-sizing: border-box;
}
section .faq-cat-list li:hover span,
section .faq-cat-list li.current span {
  color: #ffffff;
  background: #aa75b1;
  text-decoration: none;
}
section .basic-pagination {
  position: relative;
  text-align: center;
}
section .basic-pagination .page-numbers,
section .basic-pagination .dots {
  display: inline-flex;
  min-width: 36px;
  height: 40px;
  margin: 5px;
  padding: 0 5px;
  font-size: 16px;
  color: #333333;
  vertical-align: middle;
  align-items: center;
  justify-content: center;
  background: #f6f6f6;
  border: #dedede 1px solid;
  border-radius: 5px;
  box-sizing: border-box;
}
section .basic-pagination .page-numbers.dots,
section .basic-pagination .dots.dots {
  vertical-align: text-top;
  background: none;
  border: none;
}
section .basic-pagination .page-numbers.current,
section .basic-pagination .dots.current {
  background: #dedede;
}
section .basic-pagination .page-numbers.prev,
section .basic-pagination .dots.prev {
  padding: 0 10px;
}
section .basic-pagination .page-numbers.prev::before,
section .basic-pagination .dots.prev::before {
  content: "";
  display: inline-block;
  position: relative;
  top: 0;
  margin: 0 5px 0 0;
  padding: 0;
  width: 6px;
  height: 6px;
  border-top: solid 2px #333333;
  border-right: solid 2px #333333;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}
section .basic-pagination .page-numbers.next,
section .basic-pagination .dots.next {
  padding: 0 10px;
}
section .basic-pagination .page-numbers.next::after,
section .basic-pagination .dots.next::after {
  content: "";
  display: inline-block;
  position: relative;
  top: 0;
  margin: 0 0 0 5px;
  padding: 0;
  width: 6px;
  height: 6px;
  border-top: solid 2px #333333;
  border-right: solid 2px #333333;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
section .archive-gallery-list {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section .archive-gallery-list li {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto 30px;
  padding: 30px;
  background: #ffffff;
  box-shadow: 0 0 4px #bababa;
  box-sizing: border-box;
}
section .archive-gallery-list li .column-2 {
  margin-bottom: 0;
}
section .archive-gallery-list li .num {
  margin: 0 auto 5px;
  font-size: 16px;
  box-sizing: border-box;
}
section .archive-gallery-list li .num .cat {
  display: inline-block;
  width: auto;
  margin: 0 0 0 10px;
  padding: 1px 10px;
  font-size: 14px;
  color: #ffffff;
  background: #df5f95;
  box-sizing: border-box;
}
section .archive-gallery-list li .num .cat.cat-2 {
  background: #71aec0;
}
section .archive-gallery-list li .title {
  display: block;
  margin: 0 auto 5px;
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
}
section .archive-gallery-list li .text {
  font-size: 13px;
}
section .archive-gallery-list li .sub-text {
  display: block;
  margin: 0 auto;
  padding: 0;
  font-size: 14px;
  color: #999999;
  text-align: left;
  line-height: 1.2;
}
section .archive-gallery-list li .btn-wrapper {
  width: 100% !important;
}
section .archive-gallery-list li .btn-wrapper .btn {
  padding: 10px 0;
}
section.page-main img {
  margin: 0 auto 20px;
}
section.page-main p {
  width: 640px;
  margin: 0 auto;
  font-size: 16px;
}
section.gallery-single h1 {
  display: block;
  margin: 0 auto;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
section.gallery-single .guest {
  display: block;
  margin: 0 auto;
  color: #999999;
  text-align: center;
}
section.gallery-single .column-flex.gallery p {
  margin-top: 15px;
}
section.gallery-single .point-text {
  display: block;
  position: relative;
  margin: 0;
  padding: 25px;
  background: #ededed;
  box-sizing: border-box;
}
section.gallery-single .summary-wrapper {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.gallery-single .summary-wrapper::after {
  content: "";
  clear: both;
  display: block;
}
section.gallery-single .summary-wrapper .summary-image {
  display: block;
  position: relative;
  width: 595px;
  margin: 0;
  padding: 0 5px 0 0;
  float: left;
  box-sizing: border-box;
}
section.gallery-single .summary-wrapper .summary-text {
  display: block;
  position: relative;
  width: 350px;
  margin: 0;
  padding: 0;
  float: right;
  box-sizing: border-box;
}
section.gallery-single .summary-wrapper .summary-text .photoframe {
  margin: 0 auto 15px;
}
section.gallery-single .summary-wrapper .summary-text .data {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 20px;
  background: #ffffff;
  box-shadow: 0 0 4px #bababa;
  box-sizing: border-box;
}
section.gallery-single .summary-wrapper .summary-text .data table {
  width: 100%;
  margin: 0;
  padding: 0;
  font-size: 16px;
  box-sizing: border-box;
}
section.gallery-single .summary-wrapper .summary-text .data table tr {
  width: 100%;
  border-bottom: #9f9f9f 1px dotted;
}
section.gallery-single .summary-wrapper .summary-text .data table th {
  width: 100px;
  padding: 15px 0 15px 10px;
  font-weight: 500;
  vertical-align: top;
  box-sizing: border-box;
}
section.gallery-single .summary-wrapper .summary-text .data table td {
  padding: 15px 10px 15px 0;
  vertical-align: top;
  box-sizing: border-box;
}
section.gallery-single
  .summary-wrapper
  .summary-text
  .data
  table
  tr:first-child
  th,
section.gallery-single
  .summary-wrapper
  .summary-text
  .data
  table
  tr:first-child
  td {
  padding-top: 0;
}
section.gallery-single
  .summary-wrapper
  .summary-text
  .data
  table
  tr:last-child {
  border-bottom: none;
}
section.gallery-single
  .summary-wrapper
  .summary-text
  .data
  table
  tr:last-child
  th,
section.gallery-single
  .summary-wrapper
  .summary-text
  .data
  table
  tr:last-child
  td {
  padding-bottom: 0;
}
section.gallery-single.re-staff .column-1 {
  padding: 0 0 30px;
  border-bottom: #999999 1px dotted;
}
section.gallery-single.re-staff .column-1:last-child {
  padding: 0;
  border-bottom: none;
}
section.gallery-single.voice .voice-image {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
  border: #dedede 4px solid;
  box-sizing: border-box;
}
section.gallery-single.voice .voice-image .zoom {
  display: block;
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 26px;
  box-sizing: border-box;
}
section.gallery-single.voice-pickup .pickup-image {
  border: #dedede 4px solid;
  box-sizing: border-box;
}
section.gallery-single.voice-pickup p {
  margin: 0 0 30px;
}
section.gallery-single.voice-pickup .pickup-title {
  position: relative;
  width: 100%;
  margin: 0 auto 15px;
  padding: 0 0 10px;
  font-size: 20px;
  text-align: left;
}
section.gallery-single.voice-pickup .pickup-title::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: #dedede;
  box-sizing: border-box;
}
section.gallery-single.voice-pickup .pickup-title::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 200px;
  height: 2px;
  margin: 0;
  padding: 0;
  background: #aa75b1;
}
section.gallery-single.feature .staff-list li {
  width: 100%;
  margin: 0;
  padding: 30px 0;
  float: none;
  border-top: none;
  border-bottom: #999999 1px dotted;
}
section.gallery-single.feature .staff-list li:first-child {
  padding: 0 0 30px;
}
section.gallery-single.feature .staff-list li:nth-child(odd) {
  margin: 0;
}
section.gallery-single.feature .staff-list li p {
  font-size: 14px;
}
section.contents-list h2 {
  font-size: 28px;
  margin: 0 auto 30px;
}
section.contents-list .toc {
  display: block;
  position: relative;
  width: 596px;
  margin: 0 auto;
  padding: 40px 60px;
  border-left: #999999 2px solid;
  border-right: #999999 2px solid;
  border-bottom: #999999 2px solid;
  box-sizing: border-box;
}
section.contents-list .toc p {
  display: flex;
  align-items: center;
  position: absolute;
  width: 100%;
  left: 0;
  top: -20px;
  margin: 0;
  padding: 0;
  color: #aa75b1;
  font-size: 24px;
}
section.contents-list .toc p::before,
section.contents-list .toc p::after {
  content: "";
  display: block;
  flex-grow: 1;
  height: 2px;
  background: #999999;
}
section.contents-list .toc p::before {
  margin-right: 1.5em;
}
section.contents-list .toc p::after {
  margin-left: 1.5em;
}
section.contents-list .toc ul {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.contents-list .toc ul li {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 20px;
  font-size: 18px;
  border-bottom: #999999 1px dashed;
  box-sizing: border-box;
}
section.contents-list .toc ul li:first-child {
  padding: 0 20px 20px;
}
section.contents-list .toc ul li:last-child {
  padding: 20px 20px 0;
  border-bottom: none;
}
section.contents-list .toc ul li a {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0 0 0 1.7em;
  color: #333333;
  box-sizing: border-box;
}
section.contents-list .toc ul li a::before {
  content: "●";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  font-size: 18px;
  color: #aa75b1;
}

section.page-nude.voice .slider-box {
  padding: 0 0 30px;
}
section.page-nude.voice .slider-box .btn-wrapper {
  width: 100%;
}
section.page-nude.gallery-single.voice-pickup h3 {
  text-align: left;
  margin-bottom: 15px;
}
section.page-nude.gallery-single.voice-pickup h3 span {
  color: #aa75b1;
}
section.page-nude.gallery-single.voice-pickup .pickup-image {
  margin-bottom: 15px;
}
section.page-nude.gallery-single.voice-pickup p {
  font-size: 14px;
  margin-bottom: 10px;
}
section.page-nude .btn-wrapper {
  width: 60%;
}

section.company.access {
  padding: 60px 0;
}
section.company.access p {
  width: 100%;
}
section.company.access .access-data img {
  width: 194px;
}
section.company.access .access-data table {
  width: 436px;
}
section.company h3 {
  display: block;
  position: relative;
  margin: 0 auto 15px;
  padding: 0 0 10px;
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
}
section.company h3::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: #dedede;
  box-sizing: border-box;
}
section.company h3::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 200px;
  height: 2px;
  background: #aa75b1;
  box-sizing: border-box;
}
section.company h4 {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  padding: 0 0 0 15px;
  font-size: 22px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  border-left: #aa75b1 3px solid;
  box-sizing: border-box;
}
section.company h4::after {
  display: none;
}
section.company .access-list {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.company .column-flex {
  justify-content: flex-start;
}
section.company .column-flex li {
  display: inline-flex;
  flex-wrap: wrap;
  align-content: space-between;
  width: calc(50% - 7.5px);
  margin: 0 15px 30px 0;
}
section.company .column-flex li:nth-child(2n) {
  margin-right: 0;
}
section.company .column-flex li:nth-child(odd) {
  padding-right: 0;
}
section.company .column-flex li:nth-child(even) {
  padding-left: 0;
}
section.company .column-flex li .step {
  font-size: 18px;
  font-weight: 500;
  color: #aa75b1;
}
section.company .company-data table {
  width: 100%;
  margin: 0;
  padding: 0;
  font-size: 16px;
  box-sizing: border-box;
}
section.company .company-data table tr {
  border-bottom: #999999 1px dotted;
  box-sizing: border-box;
}
section.company .company-data table th {
  width: 200px;
  margin: 0;
  padding: 15px 0;
  font-weight: 500;
  vertical-align: top;
  box-sizing: border-box;
}
section.company .company-data table td {
  padding: 15px 0 15px 15px;
  vertical-align: top;
  box-sizing: border-box;
}

section.price .price-list {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.price .price-list::after {
  content: "";
  clear: both;
  display: block;
}
section.price .price-list li {
  display: block;
  width: calc(50% - 7.5px);
  margin: 0 15px 15px 0;
  padding: 0;
  background: #aa75b1;
  float: left;
  box-sizing: border-box;
}
section.price .price-list li:nth-child(2n) {
  margin: 0 0 15px 0;
}
section.price .price-list li a {
  position: relative;
  display: block;
  width: 100%;
  margin: 0;
  padding: 12px 12px 12px 55px;
  color: #ffffff;
  font-size: 16px;
  font-weight: 500;
  box-sizing: border-box;
}
section.price .price-list li a::after {
  content: "";
  display: block;
  position: absolute;
  top: 45%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 15px;
  margin: 0;
  padding: 0;
  width: 6px;
  height: 6px;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}
section.price .price-list li a img {
  display: inline-block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 12px;
  width: auto;
  height: auto;
  max-width: 32px;
  max-height: 28px;
  margin: 0 5px 0 0;
}
section.price h3 {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  padding: 0 0 10px;
  font-size: 26px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
}
section.price h3::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: #dedede;
  box-sizing: border-box;
}
section.price h3::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 200px;
  height: 2px;
  background: #aa75b1;
  box-sizing: border-box;
}
section.price .img-orign-size {
  width: auto;
  margin: 10px 0;
}
section.price .memo {
  display: block;
  position: relative;
  width: 100%;
  margin: 20px auto 0;
  padding: 20px;
  font-size: 16px;
  background: #ffffff;
  border: #dedede 4px solid;
  border-radius: 5px;
  box-sizing: border-box;
}
section.price .column-flex {
  justify-content: flex-start;
}
section.price .column-flex li {
  display: inline-flex;
  align-items: flex-start;
  width: calc(50% - 22.5px);
  margin: 0 30px 30px 0;
}
section.price .column-flex li:nth-child(2n) {
  margin-right: 0;
}
section.price .column-flex li:nth-child(odd) {
  padding-right: 0;
}
section.price .column-flex li:nth-child(even) {
  padding-left: 0;
}
section.price .column-flex li .option-list {
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.price .column-flex li .option-list .option-image {
  display: inline-flex;
  align-items: flex-end;
  width: 100%;
  height: 230px;
  box-sizing: border-box;
}
section.price .column-flex li .option-list .option-image img {
  width: auto;
  box-shadow: 0 0 4px #bababa;
}
section.price .column-flex li .option-list .option-text {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.price .column-flex li .option-list .option-text .name {
  font-size: 18px;
  font-weight: 500;
  text-align: center;
  margin: 0 auto 10px;
  padding: 0;
  border-left: #333333 2px solid;
  border-right: #333333 2px solid;
  box-sizing: border-box;
}
section.price .column-flex li .option-list .option-text .text {
  padding: 10px;
  font-size: 13px;
  background: #ededed;
}
section.price .column-flex li .option-list .option-text table {
  width: 100%;
  margin: 0 auto 15px;
  padding: 0;
  box-sizing: border-box;
}
section.price .column-flex li .option-list .option-text table tr {
  border-bottom: #999999 1px dotted;
}
section.price .column-flex li .option-list .option-text table th {
  padding: 10px 15px 10px 0;
  white-space: nowrap;
  color: #aa75b1;
  box-sizing: border-box;
}
section.price .column-flex li .option-list .option-text table td {
  padding: 10px 0;
}
section.price.contents-list .toc {
  margin-top: 50px;
  margin-bottom: 30px;
}
section.price.contents-list .toc ul li span {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0 0 0 1.7em;
  box-sizing: border-box;
}
section.price.contents-list .toc ul li span::before {
  content: "●";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  font-size: 18px;
  color: #aa75b1;
}
section.price.contents-list .toc ul li span.note::before {
  display: none;
}

section.single-all h1 {
  display: block;
  margin: 0 auto 30px;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
}
section.single-all .link-overlay {
  position: relative;
  display: block;
}
section.single-all .link-overlay::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  background: rgba(170, 117, 177, 0.8);
  z-index: 1;
  opacity: 0;
  box-sizing: border-box;
}
section.single-all .link-overlay::after {
  content: "この記事を読む";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 70%;
  padding: 10px 0;
  font-size: 16px;
  color: #ffffff;
  text-align: center;
  border: #ffffff 1px solid;
  z-index: 2;
  opacity: 0;
  box-sizing: border-box;
}
section.single-all .link-overlay:hover::before,
section.single-all .link-overlay:hover::after {
  opacity: 1;
}
section.single-all .post-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}
section.single-all .post-list li {
  display: block;
  position: relative;
  margin: 0 0 30px;
  padding: 0;
  width: calc(50% - 1.5px);
  background-color: #ffffff;
  box-sizing: border-box;
}
section.single-all .post-list li .photoframe {
  margin: 0 auto 0;
  box-shadow: none;
  border-bottom: #f6f5f0 3px solid;
}
section.single-all .post-list li .post-lis-item-text {
  display: block;
  width: 100%;
  margin: 0;
  padding: 20px;
  background: #ffffff;
  box-sizing: border-box;
}
section.single-all .post-list li .post-lis-item-text .title {
  display: block;
  margin: 0 auto 10px;
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
}
section.single-all .post-list li .post-lis-item-text .title a {
  color: #333333;
}
section.single-all .post-list li .post-lis-item-text .sub-text {
  display: block;
  margin: 0 auto;
  padding: 0;
  font-size: 14px;
  color: #999999;
  text-align: right;
  line-height: 1.2;
}
section.single-all .post-list li .post-lis-item-text .date {
  display: block;
  margin: 0 auto 5px;
  padding: 0;
  font-size: 14px;
  text-align: left;
  line-height: 1.2;
}
section.single-all .post-list li .post-lis-item-text .cat-link {
  display: block;
  margin: 0 auto;
  padding: 0;
  text-align: left;
  line-height: 1.2;
}
section.single-all .post-list li .post-lis-item-text .cat-link a {
  display: inline-block;
  margin: 0 5px 0 0;
  font-size: 14px;
  font-weight: 500;
  color: #aa75b1;
}
section.single-all .post-list.archive {
  justify-content: flex-start;
}
section.single-all .post-list.archive li {
  width: calc(33.3333% - 1.5px);
  margin-right: 2px;
}
section.single-all .post-list.archive li:nth-child(3n) {
  margin-right: 0;
}
section.single-all .single-pagination {
  display: block;
  position: relative;
  margin: 0 auto;
  padding: 15px;
  width: 656px;
  border-top: #dedede 2px solid;
  border-bottom: #dedede 2px solid;
  box-sizing: border-box;
}
section.single-all .single-pagination .pagination-heading {
  display: block;
  position: relative;
  margin: 0 auto 10px;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}
section.single-all .single-pagination .pagination-heading::after {
  content: "";
  clear: both;
  display: block;
}
section.single-all .single-pagination .pagination-heading span {
  display: inline-block;
  position: relative;
  font-size: 18px;
  font-weight: 500;
  color: #333333;
  box-sizing: border-box;
}
section.single-all .single-pagination .pagination-heading span:first-child {
  float: left;
}
section.single-all
  .single-pagination
  .pagination-heading
  span:first-child::before {
  content: "";
  display: inline-block;
  position: relative;
  top: -2px;
  margin: 0 5px 0 0;
  padding: 0;
  width: 6px;
  height: 6px;
  border-top: solid 2px #333333;
  border-right: solid 2px #333333;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}
section.single-all .single-pagination .pagination-heading span:last-child {
  float: right;
}
section.single-all
  .single-pagination
  .pagination-heading
  span:last-child::after {
  content: "";
  display: inline-block;
  position: relative;
  top: -2px;
  margin: 0 0 0 5px;
  padding: 0;
  width: 6px;
  height: 6px;
  border-top: solid 2px #333333;
  border-right: solid 2px #333333;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
section.single-all .single-pagination .pagination-flex {
  display: flex;
  justify-content: space-between;
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}
section.single-all .single-pagination .pagination-flex:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  width: 2px;
  height: 100%;
  background: #dedede;
  box-sizing: border-box;
}
section.single-all .single-pagination .pagination-flex .pagination-item {
  display: block;
  margin: 0;
  padding: 0;
  width: calc(50% - 7.5px);
  font-size: 16px;
  box-sizing: border-box;
}
section.single-all
  .single-pagination
  .pagination-flex
  .pagination-item:first-child {
  padding: 0 15px 0 0;
}
section.single-all
  .single-pagination
  .pagination-flex
  .pagination-item:last-child {
  padding: 0 0 0 15px;
}
section.single-all .single-pagination .pagination-flex .pagination-item a {
  color: #aa75b1;
}

section.page-all .date {
  font-size: 14px;
  color: #999999;
  text-align: right;
}
section.page-all .single-mv {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  padding: 0;
  width: 656px;
  box-sizing: border-box;
}
section.page-all .author-wrapper {
  display: block;
  position: relative;
  width: 100%;
  margin: 0;
  padding: 20px;
  border-top: #999999 1px dotted;
  border-bottom: #999999 1px dotted;
  box-sizing: border-box;
}
section.page-all .author-wrapper::after {
  content: "";
  clear: both;
  display: block;
}
section.page-all .author-wrapper figure {
  display: block;
  position: relative;
  width: 100px;
  margin: 0;
  padding: 0;
  float: left;
  box-sizing: border-box;
}
section.page-all .author-wrapper figure img {
  border-radius: 50%;
}
section.page-all .author-wrapper .author-text {
  padding: 0 0 0 115px;
}
section.page-all .author-wrapper .author-text .name {
  font-size: 16px;
}
section.page-all .author-wrapper .author-text .name span {
  display: inline-block;
  margin: 0 10px 0 0;
  padding: 1px 10px;
  font-size: 15px;
  color: #ffffff;
  background: #aa75b1;
}
section.page-all h1 {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  font-size: 30px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
}
section.page-all h2 {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  padding: 0 0 10px;
  font-size: 26px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
}
section.page-all h2::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: #dedede;
  box-sizing: border-box;
}
section.page-all h2::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 200px;
  height: 2px;
  background: #aa75b1;
  box-sizing: border-box;
}
section.page-all h3 {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  padding: 0 0 0 15px;
  font-size: 22px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
  border-left: #aa75b1 3px solid;
}
section.page-all h4 {
  display: block;
  position: relative;
  margin: 0 auto 20px;
  padding: 0 0 10px;
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  line-height: 1.5;
}
section.page-all h4::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 19px;
  height: 3px;
  background: #aa75b1;
  box-sizing: border-box;
}
section.page-all h4::after {
  display: none;
}
section.page-all ul li {
  position: relative;
  margin: 0 0 10px;
  padding: 0 0 0 20px;
}
section.page-all ul li::before {
  content: "●";
  position: absolute;
  color: #aa75b1;
  left: 0;
  top: 0;
}
section.page-all ol {
  list-style-type: decimal;
  list-style-position: outside;
  padding: 0 0 0 20px;
}
section.page-all ol li {
  margin: 0 0 10px;
}
section.page-all blockquote {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto 10px;
  padding: 50px 30px;
  background: #eaeaea;
  box-sizing: border-box;
}
section.page-all blockquote::before,
section.page-all blockquote::after {
  content: "";
  display: block;
  position: absolute;
  width: 28px;
  height: 21px;
  box-sizing: border-box;
}
section.page-all blockquote::before {
  left: 30px;
  top: 25px;
  background: url(images/common/ico_blockquote_top.png.webp) no-repeat 50% 50% /
    cover;
}
section.page-all blockquote::after {
  right: 30px;
  bottom: 25px;
  background: url(images/common/ico_blockquote_bottom.png.webp) no-repeat 50%
    50% / cover;
}
section.page-all blockquote pre {
  display: block;
  margin: 10px 0 0;
  font-size: 13px;
  color: #999999;
}

section .about-step {
  margin: 0 auto 50px;
}
section .about-step h4 {
  position: relative;
  width: 100%;
  margin: 0 auto 30px;
  padding: 0 0 10px;
  font-size: 20px;
  text-align: left;
}
section .about-step h4::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: #dedede;
  box-sizing: border-box;
}
section .about-step h4::after {
  position: absolute;
  width: 200px;
  height: 2px;
  margin: 0;
  left: 0;
  bottom: 0;
}
section .about-step .title-step {
  margin: 0 auto 10px;
}
section .about-step .title-step img {
  width: auto;
  height: 39px;
  margin: 0 auto;
}
section .about-point {
  padding: 30px 0;
}
section .about-point *:last-child {
  margin-bottom: 0;
}
section .about-point .column-point {
  margin: 0 auto 60px;
}
section .about-point .title-point {
  margin: 0 auto 10px;
}
section .about-point .title-point img {
  width: auto;
  height: 28px;
  margin: 0 auto;
}

section.news {
  text-align: center;
  background-color: #ffffff;
}
section.news .inner-wrapper {
  max-width: 615px;
}
section.message {
  padding: 50px 0 0;
}
section.message .message-box {
  width: 715px;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}
section.message .message-box::after {
  content: "";
  clear: both;
  display: block;
}
section.message .message-box img {
  width: 218px;
  float: left;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.message .message-box .message-txt {
  width: 470px;
  float: right;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.message .message-box .message-txt h2 {
  margin: 15px 0;
  text-align: center;
}
section.message .message-box .message-txt h2 img {
  width: 104px;
  float: none;
  margin: 0 auto;
}
section.message .message-box .message-txt h3 {
  margin: 0 0 20px;
  font-size: 24px;
  font-weight: bold;
}
section.message .message-box .message-txt p {
  font-size: 16px;
}
section.access {
  padding: 1px 0 50px;
}
section.access .btn-wrapper {
  width: 360px;
}
section.access p {
  width: 656px;
  margin: 0 auto 10px;
}
section.access .gmap {
  width: 656px;
  height: 230px;
  margin: 0 auto 30px;
  overflow: hidden;
  position: relative;
}
section.access .gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
section.access .access-data {
  width: 656px;
  margin: 20px auto 30px;
  padding: 0;
  box-sizing: border-box;
}
section.access .access-data::after {
  content: "";
  clear: both;
  display: block;
}
section.access .access-data img {
  width: 310px;
  float: left;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
section.access .access-data table {
  width: 320px;
  float: right;
  margin: 0;
  padding: 0;
  font-size: 16px;
  line-height: 1.3;
  border-collapse: separate;
  border-spacing: 0px 15px;
  box-sizing: border-box;
}
section.access .access-data table th {
  width: 90px;
  padding: 0 5px 0 0;
  vertical-align: middle;
  border-right: #333333 2px dotted;
  box-sizing: border-box;
}
section.access .access-data table td {
  padding: 0 0 0 15px;
  vertical-align: middle;
  box-sizing: border-box;
}
section.about {
  padding: 1px 0 50px;
}
section.about .about-txt-wrapper {
  position: relative;
  width: 638px;
  margin: 0 auto;
}
section.about .text {
  height: 180px;
  overflow: hidden;
}
section.about .btn-wrapper {
  position: absolute;
  bottom: 0;
  left: 0;
  padding-top: 50px;
  background: linear-gradient(180deg, rgba(244, 243, 238, 0) 0%, #f4f3ee 48%);
  transition: bottom 0.2s;
}
section.about .btn-wrapper .btn {
  width: 360px;
}
section.about .btn-wrapper .btn::after {
  display: inline-block;
  position: relative;
  top: auto;
  right: auto;
  margin: 0 0 0 10px;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}
section.faq {
  padding: 30px 0 50px;
}
section.faq .link-arrow {
  width: 635px;
  margin: 0 auto !important;
}
section.faq .faq-list {
  display: none;
  width: 635px;
  margin: 0 auto 20px;
  padding: 0;
  box-sizing: border-box;
}
section.faq .faq-list.is-show {
  display: block;
}
section.faq .faq-list li {
  width: 100%;
  padding: 20px 0;
  border-bottom: #999999 1px dashed;
}
section.faq .faq-list li:first-child {
  padding: 0 0 20px;
}
section.faq .faq-list li h3 {
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  margin: 0 0 15px;
  box-sizing: border-box;
}
section.faq .faq-list li p {
  font-size: 16px;
  box-sizing: border-box;
}
section.faq .faq-list li p span {
  color: #aa75b1;
}
section.faq .faq-list li h3,
section.faq .faq-list li p {
  position: relative;
  padding: 0 0 0 30px !important;
}
section.faq .faq-list li h3 span.icon,
section.faq .faq-list li p span.icon {
  display: inline-block;
  position: absolute;
  top: -13px;
  left: 0;
  font-size: 26px;
  font-weight: bold;
  box-sizing: border-box;
}
section.flow .flow-top-txt {
  width: 655px;
  margin: 0 auto 50px;
  padding: 0;
  font-size: 16px;
}
section.flow .flow-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 900px;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}
section.flow .flow-list li {
  width: 430px;
  margin: 0 0 40px;
  box-sizing: border-box;
}
section.flow .flow-list li::after {
  content: "";
  clear: both;
  display: block;
}
section.flow .flow-list li .flow-img {
  width: 198px;
  float: left;
}
section.flow .flow-list li .flow-txt {
  width: 217px;
  float: right;
}
section.flow .flow-list li .flow-txt img {
  width: auto;
  height: 21px;
  margin: 0 0 15px;
}
section.plan .plan-top-text {
  width: 655px;
  margin: 0 auto;
  padding: 0;
  font-size: 16px;
  box-sizing: border-box;
}
section.plan .plan-top-text .graph {
  width: 100%;
  margin: 30px 0;
  padding: 0;
  box-sizing: border-box;
}
section.plan .plan-top-text .graph::after {
  content: "";
  clear: both;
  display: block;
}
section.plan .plan-top-text .graph img {
  width: 330px;
  float: left;
}
section.plan .plan-top-text .graph .graph-txt {
  width: 305px;
  float: right;
  box-sizing: border-box;
}
section.plan .plan-top-text .graph .graph-txt .strong {
  color: #333333;
  font-weight: 500;
  background: #ffed59;
}
section.plan .note {
  position: relative;
  width: 684px;
  margin: 0 auto 10px;
  padding: 0 0 0 2.5em;
  font-size: 13px;
  box-sizing: border-box;
}
section.plan .note span {
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  box-sizing: border-box;
}
section.plan table {
  width: 900px;
  margin: 0 auto 15px;
}
section.plan table th,
section.plan table td {
  padding: 15px 0;
  vertical-align: middle;
  border: #dedede 1px solid;
}
section.plan table th {
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}
section.plan table td {
  padding: 15px 22px;
  font-size: 18px;
  text-align: center;
  background: #ffffff;
}
section.plan table td.recommend {
  background: #fff2fa;
}
section.plan table td.small-text {
  font-size: 16px;
  text-align: left;
  vertical-align: top;
}
section.plan table td.img-cell {
  vertical-align: bottom;
}
section.plan table td.img-cell a {
  font-size: 16px;
  color: #aa75b1;
  font-weight: 500;
}
section.plan table td.img-cell a img {
  width: auto;
  max-width: 100%;
  margin: 0 auto;
}
section.plan table td .plice1,
section.plan table td .plice3 {
  width: 105px;
  margin: 0 auto;
}
section.plan table .th-top {
  width: 246px;
  color: #ffffff;
  background: #aa75b1;
}
section.plan table .th-top.recommend {
  width: 274px;
  background: #df5f95;
}
section.plan table .th-top.recommend span {
  display: inline-block;
  margin: 0 10px 0 0;
  padding: 1px 8px;
  border-radius: 2px;
  color: #df5f95;
  background: #ffffff;
}
section.plan table .th-side {
  width: 134px;
  background: #ededed;
}
section.comparison .comparison-table,
section.comparison-home .comparison-table {
  display: block;
  position: relative;
  width: 910px;
  margin: 0 auto;
  padding: 12px;
  background: #ffffff;
  box-sizing: border-box;
}
section.comparison .comparison-table .table,
section.comparison-home .comparison-table .table {
  margin: 0 0 24px;
}
section.comparison .comparison-table .table img,
section.comparison-home .comparison-table .table img {
  margin: 0 0 2px;
}
section.comparison .comparison-table .table img:last-child,
section.comparison-home .comparison-table .table img:last-child {
  margin: 0;
}
section.comparison .comparison-table p,
section.comparison-home .comparison-table p {
  width: 715px;
  margin: 0 auto 10px;
}
section.comparison .comparison-table .btn-wrapper,
section.comparison-home .comparison-table .btn-wrapper {
  width: 365px;
}
section.comparison-home {
  padding: 30px 0 0;
  background: #e6e6e6;
}
section.comparison-home .comparison-table {
  padding: 12px 12px 40px;
}
section.comparison-home .comparison-table p {
  margin: 0 auto 24px;
}
section.feature .link-arrow {
  margin-bottom: 30px;
}
section.feature .btn-wrapper {
  width: 360px;
}
section.feature .staff-list {
  width: 100%;
  margin: 0 0 10px;
  padding: 0;
  box-sizing: border-box;
}
section.feature .staff-list::after {
  content: "";
  clear: both;
  display: block;
}
section.feature .staff-list li {
  display: block;
  width: 470px;
  margin: 40px 0 0 20px;
  padding: 40px 0 0;
  float: left;
  border-top: #999999 1px dotted;
  box-sizing: border-box;
}
section.feature .staff-list li::after {
  content: "";
  clear: both;
  display: block;
}
section.feature .staff-list li:nth-child(odd) {
  margin: 40px 0 0 0;
}
section.feature .staff-list li .staff-img {
  width: 144px;
  float: left;
}
section.feature .staff-list li .staff-txt {
  width: 314px;
  float: right;
}
section.feature .staff-list li .staff-txt .name {
  font-size: 20px;
  font-weight: 500;
  text-align: initial;
}
section.feature .staff-list li .staff-txt .name span {
  display: inline-block;
  margin: 0 10px 0 0;
  padding: 1px 10px;
  color: #ffffff;
  font-size: 16px;
  font-weight: normal;
  background: #aa75b1;
  box-sizing: border-box;
}
section.feature .feature-box {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin: 60px 0 0;
  padding: 0;
  box-sizing: border-box;
}
section.feature .feature-content {
  display: block;
  position: relative;
  width: 462px;
  margin: 0 0 0 36px;
  padding: 0;
  box-sizing: border-box;
}
section.feature .feature-content:first-child {
  margin: 0;
}
section.feature .feature-content:nth-child(odd) {
  margin: 0;
}
section.feature .feature-content.no1 {
  width: 100%;
  margin: 0;
  float: none;
}
section.feature .feature-content.no1::after {
  content: "";
  clear: both;
  display: block;
}
section.feature .feature-content.no1 .heading-img-feature {
  width: 472px !important;
  float: left;
}
section.feature .feature-content.no1 .feature-txt {
  width: 445px !important;
  float: right;
}
section.feature .feature-content.no1 .feature-txt .catch {
  margin: 0 0 12px;
}
section.feature .feature-content .heading-img-feature {
  display: block;
  width: 100%;
  margin: 0 0 30px;
  padding: 0;
}
section.feature .feature-content .btn-wrapper {
  margin: 20px auto 60px;
}
section.feature .feature-content .feature-txt {
  display: block;
  width: 100%;
  margin: 0;
  padding: 10px 0 0 0;
}
section.feature .feature-content .feature-txt .feature-no {
  margin: 0 0 28px;
  height: 38px;
}
section.feature .feature-content .feature-txt .feature-no img {
  width: auto;
  height: 100%;
  margin: 0 auto;
}
section.feature .feature-content .feature-txt .feature-no .no1 {
  height: 41px;
}
section.feature .feature-content .feature-txt .catch {
  margin: 0 0 6px;
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.5;
}
section.feature .feature-content .feature-txt h3 {
  margin: 0 0 30px;
  text-align: center;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.5;
}
section.feature .feature-content .feature-txt p {
  font-size: 18px;
}
section.voice {
  text-align: center;
  overflow: hidden;
}
section.voice .balloon {
  position: relative;
  display: inline-block;
  margin: 0 auto;
  width: auto;
  margin: 0 auto 30px;
  padding: 10px 60px;
  color: #ffffff;
  font-size: 22px;
  font-weight: 500;
  background: #aa75b1;
  box-sizing: border-box;
}
section.voice .balloon::before {
  content: "";
  position: absolute;
  bottom: -13px;
  left: 50%;
  margin-left: -14px;
  border-style: solid;
  border-width: 14px 11px 0 11px;
  border-color: #aa75b1 transparent transparent transparent;
}
section.voice .voice-for-img {
  width: 714px;
  margin: 0 auto;
}
section.voice .slider-box {
  display: block;
  width: 100%;
  padding: 30px 0;
  box-sizing: border-box;
}
section.voice .slider-box .voice-slider {
  width: 758px;
  margin: 0 auto;
  box-sizing: border-box;
}
section.voice .slider-box .voice-slider .slick-list {
  overflow: visible;
}
section.voice .slider-box .voice-slider .slick-prev,
section.voice .slider-box .voice-slider .slick-next {
  display: block;
  position: absolute;
  top: 50%;
  width: 56px;
  height: 56px;
  cursor: pointer;
  color: transparent;
  font-size: 0;
  line-height: 0;
  border-radius: none;
  outline: none;
  background: #aa75b1;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  z-index: 1;
}
section.voice .slider-box .voice-slider .slick-prev::before,
section.voice .slider-box .voice-slider .slick-next::before {
  content: "";
  opacity: 1;
  display: block;
  position: absolute;
  top: 45%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
section.voice .slider-box .voice-slider .slick-prev {
  left: -40px;
}
section.voice .slider-box .voice-slider .slick-prev::before {
  left: 45%;
  width: 6px;
  height: 6px;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}
section.voice .slider-box .voice-slider .slick-next {
  right: -40px;
}
section.voice .slider-box .voice-slider .slick-next::before {
  right: 45%;
  width: 6px;
  height: 6px;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
section.voice .slider-box .voice-slider .voice-slide-item {
  display: block;
  width: 718px;
  margin: 0 20px;
  padding: 24px;
  background: #ffffff;
  box-shadow: 0 0 5px #e6e6e6;
  box-sizing: border-box;
}
section.voice .slider-box .voice-slider .voice-slide-item::after {
  content: "";
  clear: both;
  display: block;
}
section.voice .slider-box .voice-slider .voice-slide-item .voice-text-box,
section.voice .slider-box .voice-slider .voice-slide-item .voice-link-box {
  display: block;
  position: relative;
  width: calc(100% - 340px);
  margin: 0;
  padding: 0;
  float: right;
  box-sizing: border-box;
}
section.voice .slider-box .voice-slider .voice-slide-item .voice-text-box {
  height: 311px;
  margin: 0 0 10px;
  font-size: 13px;
  text-align: left;
  overflow: hidden;
  box-sizing: border-box;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-text-box
  .voice-no {
  font-size: 14px;
  margin: 0;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-text-box
  .voice-no
  span {
  display: inline-block;
  margin: 0 0 0 10px;
  padding: 1px 8px;
  color: #ffffff;
  background: #df5f95;
  box-sizing: border-box;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-text-box
  .voice-no.cat-2
  span {
  background: #71aec0;
}
section.voice .slider-box .voice-slider .voice-slide-item .voice-text-box h3 {
  margin: 0 0 10px;
  font-size: 18px;
  text-align: left;
  font-weight: bold;
  line-height: 1.5;
}
section.voice .slider-box .voice-slider .voice-slide-item .voice-link-box {
  box-sizing: border-box;
}
section.voice .slider-box .voice-slider .voice-slide-item .voice-link-box p {
  display: flex;
  align-items: center;
  margin: 0 0 10px;
  color: #666666;
  font-weight: bold;
  text-align: center;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-link-box
  p::before,
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-link-box
  p::after {
  content: "";
  display: block;
  flex-grow: 1;
  border-top: 4px dotted #666666;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-link-box
  p::before {
  margin-right: 0.4em;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-link-box
  p::after {
  margin-left: 0.4em;
}
section.voice .slider-box .voice-slider .voice-slide-item .voice-photo-box {
  display: block;
  position: relative;
  width: 330px;
  margin: 0 0 0 0;
  padding: 0;
  float: left;
  box-sizing: border-box;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-photo-box
  .voice-photo-main {
  width: 100%;
  margin: 0 0 10px;
  padding: 15px;
  background: url(images/common/img_photoframe.png.webp) no-repeat 50% 50% /
    cover;
  box-shadow: 0 0 4px #e6e6e6;
  box-sizing: border-box;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-photo-box
  .voice-photo-main.cat-2 {
  background: url(images/common/img_photoframe_2.png.webp) no-repeat 50% 50% /
    cover;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-photo-box
  .voice-photo-main
  img {
  position: absolute;
  width: 300px;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-photo-box
  .voice-photo-thumbnail {
  max-width: 100%;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: left;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-photo-box
  .voice-photo-thumbnail
  li {
  cursor: pointer;
  position: relative;
  width: 60px;
  height: 60px;
  margin: 0 0 0 7.5px;
  padding: 3px;
  background: url(images/common/img_photoframe.png.webp) no-repeat 50% 50% /
    cover;
  box-sizing: border-box;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-photo-box
  .voice-photo-thumbnail
  li:nth-child(5n + 1) {
  margin-left: 0;
}
section.voice
  .slider-box
  .voice-slider
  .voice-slide-item
  .voice-photo-box
  .voice-photo-thumbnail
  li.current::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: url(images/mv/img_thumbnail_current.png.webp) no-repeat 50% 50% /
    cover;
}

h2 .heading-txt-img {
  position: relative;
  display: inline-block;
}
h2 .heading-txt-img.voice {
  width: 68px;
  margin: 0 -40px 26px -28px;
}
h2 .heading-txt-img.feature {
  width: 47px;
  margin: 0 -20px 26px -27px;
}
h2 .heading-txt-img.comparison {
  width: 73px;
  margin: 0 -20px 26px -53px;
}
h2 .heading-txt-img.plan {
  width: 61px;
  margin: 0 -30px 26px -31px;
}
h2 .heading-txt-img.flow {
  width: 31px;
  margin: 0 -3px 26px -28px;
}
h2 .heading-txt-img.faq {
  width: 34px;
  margin: 0 -7px 26px -27px;
}
h2 .heading-txt-img.about {
  width: 71px;
  margin: 0 -43px 26px -28px;
}
h2 .heading-txt-img.access {
  width: 38px;
  margin: 0 -8px 26px -30px;
}

.home section h2 {
  display: block;
  margin: 30px 0;
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
  letter-spacing: 0.1em;
}

/* .news .bnr-list {
  display: block;
  width: 100%;
  margin: 0 0 15px;
  padding: 0;
  box-sizing: border-box;
}
.news .bnr-list::after {
  content: "";
  clear: both;
  display: block;
}
.news .bnr-list .bnr {
  display: block;
  width: 300px;
  margin: 0;
  padding: 0;
  float: left;
  box-sizing: border-box;
}
.news .bnr-list .bnr:last-child {
  float: right;
} */

.bnr-list-pc {
@media screen and (max-width: 768px) {
display:none;
}
@media not screen and (max-width: 768px) {
	ul {
		display: flex;
		justify-content: space-between;
		flex-wrap: nowrap;
	}
	li {
		flex: 1;
		&:not(:first-child) {
			margin-left: 1px;
		}
	}
}
}

.news-list li {
  display: block;
  width: 100%;
  margin: 0 0 20px;
  padding: 0 0 20px;
  text-align: left;
  border-bottom: #dedede 1px solid;
  box-sizing: border-box;
}
.news-list li::after {
  content: "";
  clear: both;
  display: block;
}
.news-list li .date {
  display: block;
  width: 80px;
  margin: 0;
  padding: 0;
  color: #999999;
  float: left;
  box-sizing: border-box;
}
.news-list li .cat {
  display: block;
  width: 90px;
  margin: 0 20px 0 5px;
  padding: 1px;
  text-align: center;
  font-size: 13px;
  color: #ffffff;
  background-color: #aa75b1;
  float: left;
  box-sizing: border-box;
}
.news-list li .txt {
  display: block;
  width: calc(100% - 195px);
  margin: 0;
  padding: 0;
  color: #333333;
  float: left;
  box-sizing: border-box;
}

/* footer */
.footer-message-wrapper {
  width: auto;
  margin: 0 auto;
  padding: 60px 20px;
  max-width: 676px;
  box-sizing: content-box;
}
.footer-message-wrapper .footer-message-box {
  position: relative;
  border-top: 2px solid #000;
  border-bottom: 2px solid #000;
  padding: 2px 0;
}
.footer-message-wrapper .footer-message-box .footer-message-box-inner {
  padding: 55px 0;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
.footer-message-wrapper .footer-message-box .footer-message-box-inner::before {
  position: absolute;
  left: -20px;
  top: -30px;
  width: 228px;
  height: 103px;
  background: url(images/common/img_footer_message_top.png.webp) no-repeat 0 0 /
    contain;
  content: "";
}
.footer-message-wrapper .footer-message-box .footer-message-box-inner::after {
  position: absolute;
  right: -20px;
  bottom: -40px;
  width: 226px;
  height: 104px;
  background: url(images/common/img_footer_message_bottom.png.webp) no-repeat 0
    0 / contain;
  content: "";
}
.footer-message-wrapper .footer-message-box .footer-message-box-inner .heading {
  position: relative;
  margin: 0 0 24px;
  padding: 0 0 24px;
  line-height: 1.5;
  text-align: center;
  font-size: 24px;
}
.footer-message-wrapper
  .footer-message-box
  .footer-message-box-inner
  .heading::before {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 22px;
  height: 2px;
  background: #000;
  content: "";
  transform: translateX(-50%);
}
.footer-message-wrapper
  .footer-message-box
  .footer-message-box-inner
  .heading
  span {
  display: block;
  font-size: 26px;
  color: #aa75b1;
}
.footer-message-wrapper
  .footer-message-box
  .footer-message-box-inner
  .text-wrapper {
  padding: 0 0 0 30px;
}
.footer-message-wrapper
  .footer-message-box
  .footer-message-box-inner
  .text-wrapper::after {
  display: block;
  clear: both;
  content: "";
}
.footer-message-wrapper
  .footer-message-box
  .footer-message-box-inner
  .text-wrapper
  .image {
  float: right;
  margin: 0 0 0 20px;
  width: 155px;
}
.footer-message-wrapper
  .footer-message-box
  .footer-message-box-inner
  .text-wrapper
  .text {
  font-size: 16px;
  overflow: hidden;
}

.footer-cv-wrapper {
  padding: 60px 0;
  /*   background: url(images/common/bg_woodgrain.png.webp) repeat 50% 50%/cover; */
}
.footer-cv-wrapper .footer-cv-section {
  width: auto;
  margin: 0 auto;
  padding: 0 20px;
  max-width: 960px;
  box-sizing: content-box;
}
.footer-cv-wrapper .footer-cv-section .balloon-heading {
  position: relative;
  display: block;
  max-width: 716px;
  box-sizing: border-box;
  margin: 0 auto 20px;
  padding: 8px 8px 10px;
  border: 2px solid #aa75b1;
  border-bottom: none;
  font-size: 26px;
  font-weight: bold;
  color: #aa75b1;
}
.footer-cv-wrapper .footer-cv-section .balloon-heading::before,
.footer-cv-wrapper .footer-cv-section .balloon-heading::after {
  position: absolute;
  left: 0;
  bottom: 0;
  display: block;
  width: 50%;
  height: 2px;
  background: #aa75b1;
  content: "";
}
.footer-cv-wrapper .footer-cv-section .balloon-heading::after {
  left: auto;
  right: 0;
  width: calc(50% - 8px);
}
.footer-cv-wrapper .footer-cv-section .balloon-heading .inner::before {
  position: absolute;
  right: calc(50% - 5px);
  bottom: -13px;
  width: 2px;
  height: 16px;
  display: block;
  background: #aa75b1;
  content: "";
  transform: rotate(38deg);
}
.footer-cv-wrapper .footer-cv-section .footer-cv-content {
  display: flex;
  justify-content: space-between;
}
.footer-cv-image {
  width: 35.4%;
}
.footer-cv-wrapper .footer-cv-section .footer-cv-content .pc-image {
  width: 100%;
  height: auto;
  box-shadow: 0 0 10px 2px #e7e6e8;
}
.footer-cv-wrapper .footer-cv-section .footer-cv-content .text-wrapper {
  padding: 0;
  width: calc(100% - 35.4% - 25px);
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .text-wrapper
  .heading {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin: 0 0 25px;
  padding: 0 20px 18px;
  border-bottom: 2px solid #736652;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .text-wrapper
  .heading
  .sp-image {
  display: none;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .text-wrapper
  .heading
  .text {
  padding: 0 10px 0 0;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.5;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .text-wrapper
  .heading
  .logo {
  max-width: 48%;
}
.footer-cv-wrapper .footer-cv-section .footer-cv-content .list-wrapper {
  position: relative;
  margin: 0 0 25px;
  padding: 0 0 0 134px;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .circle-text {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
  align-items: baseline;
  position: absolute;
  left: 0;
  top: 50%;
  width: 117px;
  height: 117px;
  line-height: 1.2;
  background: #aa75b1;
  color: #fff;
  font-size: 12px;
  border-radius: 50%;
  font-weight: bold;
  transform: translateY(-50%);
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .circle-text
  .term {
  font-size: 20px;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .circle-text
  .term
  em {
  font-size: 25px;
  font-style: normal;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .circle-text
  .limit {
  display: block;
  font-size: 17px;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .circle-text
  .limit
  em {
  font-size: 25px;
  font-style: normal;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .list
  > li {
  position: relative;
  padding: 0 0 0 30px;
  margin: 0 0 10px;
  font-size: 16px;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .list
  > li::before {
  position: absolute;
  left: 0;
  top: 3px;
  width: 23px;
  height: 20px;
  background: url(images/common/ico_check.png.webp) no-repeat 0 0 / contain;
  content: "";
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .list-wrapper
  .list
  > li:last-child {
  margin: 0;
}
.footer-cv-wrapper .footer-cv-section .footer-cv-content .contact-wrapper {
  padding: 14px 20px 20px;
  background: #fff;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .contact-heading {
  margin: 0 0 10px;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .contact-heading::after {
  display: none;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper {
  display: flex;
  justify-content: space-between;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .tel,
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .mail {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  align-content: center;
  justify-content: center;
  padding: 10px 5px;
  text-align: center;
  line-height: 1.2;
  color: #fff;
  box-shadow: 4px 4px 0 #eee3ef;
  box-sizing: border-box;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .tel:hover,
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .mail:hover {
  text-decoration: none;
  opacity: 0.7;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .tel {
  pointer-events: none;
  width: 46.8%;
  background: #aa75b1;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .tel
  .time {
  font-size: 16px;
  width: 100%;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .tel
  .time
  br {
  display: none;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .tel
  .num {
  position: relative;
  display: inline-block;
  padding: 0 0 0 22px;
  font-weight: bold;
  font-size: 28px;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .tel
  .num::before {
  position: absolute;
  left: 0;
  top: 50%;
  width: 16px;
  height: 22px;
  background: url(images/common/ico_cv_tel.png.webp) no-repeat 0 0 / contain;
  content: "";
  transform: translateY(-50%);
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .mail {
  width: calc(100% - 46.8% - 16px);
  background: #c8a2cd;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .mail
  .time {
  font-size: 16px;
  font-weight: bold;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .mail
  .time
  br {
  display: none;
}
.footer-cv-wrapper
  .footer-cv-section
  .footer-cv-content
  .contact-wrapper
  .btn-wrapper
  .mail
  .text {
  font-size: 22px;
  font-weight: bold;
}

.footer-check-bnr-wrapper {
  width: auto;
  margin: 0 auto;
  padding: 50px 20px 40px;
  max-width: 960px;
  box-sizing: content-box;
}
.footer-check-bnr-wrapper .heading {
  margin: 0 0 25px;
  text-align: center;
  font-weight: bold;
  color: #df5f95;
  font-size: 26px;
}
.footer-check-bnr-wrapper .bnr-wrapper {
  display: flex;
  justify-content: space-between;
}
.footer-check-bnr-wrapper .bnr-wrapper a {
  display: block;
  width: calc((100% - 16px) / 2);
}
.footer-check-bnr-wrapper .bnr-wrapper a:hover img {
  opacity: 0.7;
}

.footer-ig-wrapper {
  max-width: 716px;
  width: auto;
  margin: 0 auto;
  padding: 40px 20px 60px;
  box-sizing: content-box;
}
.footer-ig-wrapper .heading {
  margin: 0 0 30px;
}
.footer-ig-wrapper .heading img {
  height: 52px;
  width: auto;
  margin: 0 auto;
}

.footer-nav-wrapper {
  padding: 60px 0;
  background: #eeeae3;
}
.footer-nav-wrapper .footer-nav-inner {
  display: flex;
  margin: 0 auto;
  padding: 0 20px;
  max-width: 960px;
}
.footer-nav-wrapper .footer-nav-inner .footer-access-wrapper {
  width: 57.2%;
  padding: 0 24px 0 0;
  box-sizing: border-box;
  border-right: 2px solid #d5d0c6;
}
.footer-nav-wrapper .footer-nav-inner .footer-access-wrapper::after {
  content: "";
  clear: both;
  display: block;
}
.footer-nav-wrapper .footer-nav-inner .footer-access-wrapper .image {
  float: left;
  width: 56.4%;
  height: auto;
  margin: 0 24px 0 0;
  box-shadow: 0 0 10px 2px #dad6d1;
}
.footer-nav-wrapper .footer-nav-inner .footer-access-wrapper .text-wrapper {
  overflow: hidden;
  width: auto;
  margin: 0;
  padding: 0;
  font-size: 13px;
  color: #736652;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .text-wrapper
  .logo {
  width: 200px;
  max-width: 100%;
  margin: 0 0 8px;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .text-wrapper
  .name,
.footer-nav-wrapper .footer-nav-inner .footer-access-wrapper .text-wrapper .tel,
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .text-wrapper
  .address {
  margin: 0 0 10px;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .text-wrapper
  .distance
  .sp-text {
  display: none;
}
.footer-nav-wrapper .footer-nav-inner .footer-access-wrapper .footer-sns-pc {
  display: flex;
  margin: 20px 0;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-sns-pc
  > li {
  margin: 0 14.7% 0 0;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-sns-pc
  > li:last-child {
  margin: 0;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-sns-pc
  > li
  a {
  display: block;
  width: 30px;
  height: 30px;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-sns-pc
  > li
  a.tw {
  background: url(images/common/ico_footer_tw.png.webp) no-repeat 50% 50% /
    contain;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-sns-pc
  > li
  a.fb {
  background: url(images/common/ico_footer_fb.png.webp) no-repeat 50% 50% /
    contain;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-sns-pc
  > li
  a.ig {
  background: url(images/common/ico_footer_ig.png.webp) no-repeat 50% 50% /
    contain;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-btn-wrapper {
  display: flex;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-btn-wrapper
  > li {
  margin: 0 6px 0 0;
  padding: 0 0 2px;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-btn-wrapper
  > li:last-child {
  margin: 0;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-btn-wrapper
  > li
  a {
  display: flex;
  padding: 6px 12px;
  background: #c8a2cd;
  color: #fff;
  font-weight: bold;
  box-shadow: 0 2px 0 0 #aa75b1;
  border-radius: 5px;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-btn-wrapper
  > li
  a.reservation {
  background: #df5f95;
  box-shadow: 0 2px 0 0 #d23d7c;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-access-wrapper
  .footer-btn-wrapper
  > li
  a:hover {
  text-decoration: none;
  opacity: 0.7;
}
.footer-nav-wrapper .footer-nav-inner .footer-sitemap-wrapper {
  width: 42.8%;
  padding: 0 0 0 24px;
  box-sizing: border-box;
  font-size: 13px;
}
.footer-nav-wrapper .footer-nav-inner .footer-sitemap-wrapper .heading {
  margin: 0 0 10px;
  text-align: left;
  font-size: 24px;
  font-weight: bold;
  color: #736652;
}
.footer-nav-wrapper .footer-nav-inner .footer-sitemap-wrapper .footer-nav-area {
  display: flex;
  justify-content: space-between;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-sitemap-wrapper
  .footer-nav-area
  .nav-left {
  width: 48.7%;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-sitemap-wrapper
  .footer-nav-area
  .nav-left
  > li:not(:last-child) {
  margin: 0 0 10px;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-sitemap-wrapper
  .footer-nav-area
  .nav-left
  a {
  color: #736652;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-sitemap-wrapper
  .footer-nav-area
  .nav-right
  a {
  color: #736652;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-sitemap-wrapper
  .footer-nav-area
  .nav-right
  dt:not(:first-child) {
  margin: 40px 0 0;
}
.footer-nav-wrapper
  .footer-nav-inner
  .footer-sitemap-wrapper
  .footer-nav-area
  .nav-right
  dd {
  margin: 10px 0 0 1em;
}
.footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp {
  display: none;
}

.top_column {
background: #fff;
width: -webkit-fill-available;
margin: auto;
padding: 10px;
margin-bottom: 24px;
height: 260px;
overflow-y: scroll;
}

.top_column .column-item {
	margin-bottom: 2rem;
}

.copyright {
  margin: 0;
  padding: 20px;
  font-size: 14px;
  text-align: center;
  background: #333;
  color: #fff;
}

#pagetop {
  display: block;
  position: fixed;
  overflow: hidden;
  right: 20px;
  bottom: 20px;
  width: 72px;
  height: 72px;
  margin: 0;
  text-indent: 100%;
  white-space: nowrap;
  background: #aa75b1;
}
#pagetop::before {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10px;
  height: 10px;
  margin: 3px 0 0;
  border-left: 3px solid #fff;
  border-top: 3px solid #fff;
  content: "";
  transform: translate(-50%, -50%) rotate(45deg);
}

.footer-floating-sp {
  display: none;
}

/* テキストレスポンシブ折り返し */
.txt-br {
  display: inline-block;
}

/* トップページ 助産師さん推薦 */
section.reccomend {
  padding-top: 0;
  padding-bottom: 60px;
}
.recommend-content {
  max-width: 960px;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  padding-top: 20px;
}
.recommend-img {
  width: 100%;
  max-width: 400px;
  margin-right: 2rem;
  text-align: center;
}
.recommend-img figcaption {
  font-size: 13px;
}
.recommend-heading {
  position: relative;
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝",
    "Yu Mincho", "游明朝体", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}
.recommend-sentence {
  color: #996699;
}
.recommend-person {
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝",
    "Yu Mincho", "游明朝体", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-size: 16px;
  font-weight: bold;
  color: #000;
  text-align: right;
}

/* メディア紹介 */
.media-info-text {
  margin-bottom: 2rem;
}

/* PC Only
 */
@media only screen and (min-width: 769px) {
  #sp-nav {
    display: none !important;
  }
}
/* Tablet Smartphone
 */
@media only screen and (max-width: 768px) {
  /* Base
   */
  .pc-only {
    display: none !important;
  }

  .tb-only {
    display: none !important;
  }

  .sp-only {
    display: block !important;
  }

  body {
    font-size: 12px;
  }

  /* btn */
  .btn-wrapper .btn,
  .btn-wrapper .wp-block-button__link,
  .wp-block-button .btn,
  .wp-block-button .wp-block-button__link {
    font-size: 12px;
  }

  /* Design
   */
  .inner-wrapper {
    max-width: auto;
    width: 100%;
  }

  /* header */
  #header {
    padding: 4px 0 10px 10px;
  }
  #header .header-top-nav-wrapper {
    margin: 0 0 3px;
  }
  #header .header-top-nav-wrapper .catch {
    float: none;
    font-size: 10px;
    text-align: center;
  }
  #header .header-top-nav-wrapper .header-top-nav {
    display: none;
  }
  #header .header-middle-wrapper {
    margin: 0;
  }
  #header .header-middle-wrapper .header-logo-wrapper {
    display: flex;
    justify-content: space-between;
    width: 247px;
  }
  #header .header-middle-wrapper .header-logo-wrapper .logo {
    width: 150px;
  }
  #header .header-middle-wrapper .header-logo-wrapper .access {
    width: 87px;
  }
  #header .header-middle-wrapper .header-contact-wrapper {
    display: none;
  }
  #header .header-middle-wrapper .header-menu-btn-sp {
    position: fixed;
    z-index: 10;
    right: 0;
    top: 20px;
    display: block;
    padding: 22px 6px 2px;
    background: url(images/common/bg_offwhite.png.webp) repeat 0 0;
    font-size: 10px;
    color: #aa75b1;
    border:none;	  
  }
  #header .header-middle-wrapper .header-menu-btn-sp::before {
    display: block;
    position: absolute;
    left: 50%;
    top: 11px;
    width: 18px;
    height: 2px;
    background: #aa75b1;
    content: "";
    transform: translateX(-50%);
  }
  #header .header-middle-wrapper .header-menu-btn-sp:hover {
    text-decoration: none;
  }
  #header .header-middle-wrapper .header-menu-btn-sp span::before,
  #header .header-middle-wrapper .header-menu-btn-sp span::after {
    display: block;
    position: absolute;
    left: 50%;
    top: 6px;
    width: 18px;
    height: 2px;
    background: #aa75b1;
    content: "";
    transform: translateX(-50%);
  }
  #header .header-middle-wrapper .header-menu-btn-sp span::after {
    top: 16px;
  }
  #header .header-gnavi {
    display: none;
    width: 100%;
    justify-content: space-between;
  }
  #header .header-gnavi > li {
    padding: 0 10px 0 0;
    font-size: 15px;
  }
  #header .header-gnavi > li:last-child {
    padding: 0;
  }
  #header .header-gnavi > li a.about {
    position: relative;
    display: inline-block;
    padding: 0 0 0 18px;
  }
  #header .header-gnavi > li a.about::before {
    position: absolute;
    left: 0;
    top: 3px;
    display: block;
    width: 14px;
    height: 18px;
    background: url(images/common/ico_header_about.png.webp) no-repeat 50% 50% /
      contain;
    content: "";
  }

  .overlay {
    content: "";
    display: block;
    position: fixed;
    visibility: hidden;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: transparent;
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
    z-index: 11;
    box-sizing: border-box;
  }

  #sp-nav {
    display: block;
    position: fixed;
    width: 240px;
    height: 100%;
    overflow: auto;
    top: 0;
    right: 0;
    z-index: 12;
    background: #eeeae3;
    transform: translate(240px);
    transition: transform 0.3s;
    box-sizing: border-box;
  }
  #sp-nav .inner {
    padding: 15px 15px 20px;
    width: 100%;
    height: auto;
    box-sizing: border-box;
  }
  #sp-nav .inner .sp-close-top {
    position: relative;
    float: right;
    width: 18px;
    height: 18px;
  }
  #sp-nav .inner .sp-close-top::before,
  #sp-nav .inner .sp-close-top::after {
    display: block;
    position: absolute;
    left: 0;
    top: 50%;
    width: 18px;
    height: 2px;
    margin: -1px 0 0;
    background: #aa75b1;
    transform: rotate(45deg);
    content: "";
  }
  #sp-nav .inner .sp-close-top::after {
    transform: rotate(135deg);
  }
  #sp-nav .inner .sp-nav-sns {
    display: flex;
    float: left;
    margin: 0 0 12px 12px;
  }
  #sp-nav .inner .sp-nav-sns > li {
    margin: 0 18px 0 0;
  }
  #sp-nav .inner .sp-nav-sns > li a {
    display: block;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    height: 22px;
    width: 22px;
  }
  #sp-nav .inner .sp-nav-sns > li a.tw {
    background: url(images/common/ico_tw_sp.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-sns > li a.fb {
    background: url(images/common/ico_fb_sp.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-sns > li a.ig {
    background: url(images/common/ico_ig_sp.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list {
    clear: both;
    margin: 0 0 20px;
    border-top: 1px solid #d5d0c6;
  }
  #sp-nav .inner .sp-nav-list > li {
    border-bottom: 1px solid #d5d0c6;
  }
  #sp-nav .inner .sp-nav-list > li a {
    position: relative;
    display: block;
    padding: 12px 12px 12px 45px;
    color: #736652;
    font-size: 13px;
  }
  #sp-nav .inner .sp-nav-list > li a::before {
    display: block;
    position: absolute;
    left: 10px;
    top: 50%;
    width: 24px;
    height: 24px;
    transform: translateY(-50%);
    content: "";
  }
  #sp-nav .inner .sp-nav-list > li a.top::before {
    background: url(images/common/ico_nav_top.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.news::before {
    background: url(images/common/ico_nav_news.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.about::before {
    background: url(images/common/ico_nav_about.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.gallery::before {
    background: url(images/common/ico_nav_gallery.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.make::before {
    background: url(images/common/ico_nav_make.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.costume::before {
    background: url(images/common/ico_nav_costume.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.staff::before {
    background: url(images/common/ico_nav_staff.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.price::before {
    background: url(images/common/ico_nav_price.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.qa::before {
    background: url(images/common/ico_nav_qa.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.studio::before {
    background: url(images/common/ico_nav_studio.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.access::before {
    background: url(images/common/ico_nav_access.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.reservation::before {
    background: url(images/common/ico_nav_reservation.png.webp) no-repeat 50%
      50% / contain;
  }
  #sp-nav .inner .sp-nav-list > li a.baby::before {
    background: url(images/common/ico_nav_baby.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.family::before {
    background: url(images/common/ico_nav_family.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.nude::before {
    background: url(images/common/ico_nav_nude.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-nav-list > li a.contact::before {
    background: url(images/common/ico_nav_contact.png.webp) no-repeat 50% 50% /
      contain;
  }
  #sp-nav .inner .sp-close-bottom {
    position: relative;
    display: block;
    margin: 20px 0 0;
    padding: 12px 25px;
    text-align: center;
    background: #aa75b1;
    color: #fff;
    font-size: 13px;
  }
  #sp-nav .inner .sp-close-bottom::before {
    display: block;
    position: absolute;
    top: 50%;
    right: 15px;
    width: 6px;
    height: 6px;
    border-right: 1px solid #fff;
    border-top: 1px solid #fff;
    transform: translateY(-50%) rotate(45deg);
    content: "";
  }
#sp-nav .inner .sp-close-top,
#sp-nav .inner .sp-close-bottom {
  outline: none !important;
  -webkit-tap-highlight-color: transparent;
  -webkit-focus-ring-color: transparent;
  box-shadow: none;
  border: none;
}

#sp-nav .inner .sp-close-top:focus,
#sp-nav .inner .sp-close-bottom:focus {
  outline: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-focus-ring-color: transparent;
  box-shadow: none;
  border: none;
}
  .side-open .overlay {
    visibility: visible;
    cursor: pointer;
    background-color: rgba(0, 0, 0, 0.3);
  }
  .side-open #sp-nav {
    -webkit-transform: translate(0);
    transform: translate(0);
  }
  .side-open #cv-area-sp {
    -webkit-transform: translate(-240px);
    transform: translate(-240px);
  }

  #breadcrumb-wrapper {
    padding: 0 15px;
  }
  #breadcrumb-wrapper .breadcrumb ol li {
    font-size: 11px;
  }
  #breadcrumb-wrapper .breadcrumb ol li .icon {
    width: 11px;
    margin: 0 5px 0 0;
  }

  /* mv */
  #mv-wrapper .page {
    height: auto;
    overflow: auto;
  }
  #mv-wrapper .page .page-mv-img {
    width: 100%;
    height: auto;
  }
  #mv-wrapper .page .page-title h1 {
    font-size: 20px;
  }
  #mv-wrapper .page .page-title p {
    font-size: 15px;
  }
  #mv-wrapper .page.nude {
    height: auto;
    overflow: auto;
    background: #000000;
  }
  #mv-wrapper .page.nude .inner-wrapper {
    text-align: center;
  }
  #mv-wrapper .page.nude #breadcrumb-wrapper .inner-wrapper {
    text-align: left;
  }
  #mv-wrapper .page.nude .page-title-nude {
    margin: 0 auto;
  }
  #mv-wrapper .page.nude .page-title h1 {
    font-size: 21px;
  }
  #mv-wrapper .page.nude .page-title h1::after {
    bottom: -20px;
    width: 16px;
    height: 1.5px;
  }
  #mv-wrapper .page.nude .page-title p {
    font-size: 11px;
  }
  #mv-wrapper .page.nude .page-title p.font-italianno {
    top: -19px;
    font-size: 21px;
  }
  #mv-wrapper .home .inner-wrapper {
    padding: 20px 0 50px;
  }
  #mv-wrapper .home .slider-box {
    width: 100%;
    margin: 0 0 35px;
    padding: 0 30px 0;
  }
  #mv-wrapper .home .slider-box .slick-dots li {
    width: 7px !important;
    height: 7px !important;
  }
  #mv-wrapper .home .slider-box .slick-dots li button {
    width: 7px !important;
    height: 7px !important;
  }
  #mv-wrapper .home .slider-box .slick-dots li button:before {
    content: "" !important;
    opacity: 1 !important;
    width: 5px !important;
    height: 5px !important;
    top: 1px;
    left: 1px;
    color: #ffffff !important;
    border-radius: 50% !important;
    background: none;
    border: 1px #ffffff solid;
    box-sizing: border-box;
  }
  #mv-wrapper .home .slider-box .slick-dots li.slick-active button:before {
    content: "" !important;
    opacity: 1 !important;
    width: 7px !important;
    height: 7px !important;
    top: 0;
    left: 0;
    color: #ffffff !important;
    background: #ffffff;
  }
  #mv-wrapper .home .slider-box .top-thumbnail {
    display: none;
  }
  #mv-wrapper .home .heading-box {
    float: none;
    width: 100%;
    margin: 0 0 10px;
    padding: 0;
  }
  #mv-wrapper .home .heading-box h1 {
    font-size: 20px;
    line-height: 1.5;
  }
  #mv-wrapper .home .txt-box {
    position: relative;
    top: 0;
    width: 100%;
  }
  #mv-wrapper .home .txt-box h2 {
    font-size: 14px;
    line-height: 1.8;
    margin: 0 0 20px;
  }
  #mv-wrapper .home .txt-box .link {
    font-size: 13px;
    color: #aa75b1;
    border-bottom: #aa75b1 1px solid;
  }
  #mv-wrapper .home .txt-box .text-attention {
	padding: 15px 0;
}
  #mv-wrapper .home .txt-box .about-us {
    padding: 15px 15px 40px;
  }
  #mv-wrapper .home .txt-box .about-us::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 75%;
    height: 100%;
    background-color: #ffffff;
    box-sizing: border-box;
    opacity:0;
  }
  #mv-wrapper .home .txt-box .about-us .about-us-img {
    padding: 15px 10px 0;
  }

  /* section */
  section {
    padding: 40px 10px;
  }
  section h2 {
    margin: 0;
    font-size: 18px;
  }
  section h3 {
    font-size: 18px;
  }
  section h4 {
    font-size: 16px;
  }
  section h4::after {
    margin: 10px auto;
  }
  section h5 {
    font-size: 14px;
    margin: 15px auto 10px;
  }

  article section:first-child {
    padding: 20px 10px 40px;
  }

  .home section {
    padding: 1px 15px;
  }
  .home section:first-child {
    padding: 1px 15px;
  }
  .home section h2 {
    font-size: 22px;
  }

  section .heading {
    margin: 0 auto 13px;
  }
  section .catch {
    font-size: 14px;
  }
  section .title-sub {
    font-size: 20px;
  }
  section .column-1 {
    width: calc(100% - 10px);
    margin: 0 auto 20px;
    font-size: 13px;
  }
  section .column-2 {
    width: calc(100% - 10px);
    margin: 0 auto 20px;
    font-size: 13px;
  }
  section .column-2 .column-child {
    width: 100%;
    margin: 0 auto 20px;
  }
  section .column-2 .column-child .btn-wrapper {
    width: calc(100% - 40px);
  }
  section .column-2 .column-child.padding-left {
    padding-left: 0;
  }
  section .column-2 .column-child.padding-right {
    padding-right: 0;
  }
  section .column-2 .column-child:nth-child(even) {
    float: none;
  }
  section .column-2 .column-child:nth-child(odd) {
    float: none;
  }
  section .column-flex {
    display: block;
  }
  section .column-flex li {
    width: calc(100% - 10px);
    margin: 0 auto 20px;
    font-size: 13px;
  }
  section .column-flex li.heightLine {
    padding-bottom: 0;
  }
  section .column-flex li.heightLine .btn-wrapper {
    position: relative;
    bottom: 0;
    left: 0;
  }
  section .column-flex li:nth-child(even) {
    padding-left: inherit;
  }
  section .column-flex li:nth-child(odd) {
    padding-right: inherit;
  }
  section .column-flex li .title {
    font-size: 16px;
  }
  section .column-flex li .title span {
    font-size: 13px;
  }
  section .column-flex li .btn-wrapper {
    width: calc(100% - 40px);
  }
  section .column-flex.dress-list li .title span {
    font-size: 16px;
  }
  section .column-1 .sp-align-center,
  section .column-2 .sp-align-center,
  section .column-flex .sp-align-center {
    text-align: center !important;
  }
  section .column-1 .sp-align-left,
  section .column-2 .sp-align-left,
  section .column-flex .sp-align-left {
    text-align: left !important;
  }
  section .column-1 .sp-align-right,
  section .column-2 .sp-align-right,
  section .column-flex .sp-align-right {
    text-align: right !important;
  }
  section .column-1 .margin-bottom,
  section .column-2 .margin-bottom,
  section .column-flex .margin-bottom {
    margin-bottom: 15px;
  }
  section .memo-list {
    padding: 20px;
  }
  section .memo-list li {
    margin: 0 0 20px 1em;
  }
  section .memo-block {
    padding: 20px;
  }
  section .culcform-goodday-block {
    margin: 0 auto 20px;
    padding: 40px 20px 20px;
  }
  section .culcform-goodday-block h4 {
    font-size: 15px;
  }
  section .culcform-goodday-block .section-body {
    margin: 20px auto 0;
  }
  section .culcform-goodday-block .section-body.answer {
    padding: 10px;
  }
  section .culcform-goodday-block .section-body input[type="text"] {
    padding: 10px;
  }
  section .culcform-goodday-block .section-body #calcButton {
    width: calc(100% - 60px);
  }
  section .culcform-goodday-block .heading {
    top: -20px;
  }
  section .culcform-goodday-block .balloon {
    padding: 10px;
    font-size: 14px;
  }
  section .caption {
    padding: 10px;
    font-size: 11px;
  }
  section .note.small {
    font-size: 11px;
  }

  /* accordion */
  .js__acPrtSp {
    pointer-events: auto;
  }

  /* staff */
  section.staff.staff-top {
    padding: 20px 0 40px;
  }
  section.staff h3.js__acPrtSp {
    margin: 10px auto 0;
    padding: 10px;
    color: #ffffff;
    font-size: 14px;
    font-weight: 500;
    background: #aa75b1;
  }
  section.staff h3.js__acPrtSp::before {
    display: none;
  }
  section.staff h3.js__acPrtSp::after {
    content: "+";
    display: inline-block;
    width: 20px;
    height: 20px;
    top: 10px;
    right: 10px;
    left: auto;
    bottom: auto;
    font-size: 20px;
    text-align: center;
    line-height: 1;
    background: none;
  }
  section.staff h3.js__acPrtSp.js__acOpenSp::after {
    content: "-";
  }
  section.staff h4 {
    margin: 0 auto 30px;
    font-size: 15px;
  }
  section.staff .staff-list {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }
  section.staff .staff-list li {
    width: 50%;
    margin: 0;
    padding: 0 0 20px;
  }
  section.staff .staff-list li img {
    margin: 0 0 10px;
  }
  section.staff .staff-list li .role {
    font-size: 11px;
    padding: 0 10px;
  }
  section.staff .staff-list li .name {
    font-size: 13px;
    padding: 0 10px;
  }
  section.staff .staff-list li .name-en {
    font-size: 10px;
    padding: 0 10px;
  }
  section.staff .side-scroll {
    overflow-x: scroll;
  }
  section.staff .works-list {
    display: block;
    position: relative;
    width: 100%;
    margin: 0 0 10px;
    background: #ffffff;
    padding: 10px;
    box-sizing: border-box;
  }
  section.staff .works-list table {
    width: auto;
    font-size: 12px;
    box-sizing: border-box;
  }
  section.staff .works-list table tr th {
    padding: 5px 20px;
  }
  section.staff .works-list table tr th:nth-child(2) {
    padding: 5px 70px;
  }
  section.staff .works-list table tr td {
    padding: 15px;
  }
  section.staff .history-list,
  section.staff .works-list {
    display: none;
  }
  section.staff .history-list {
    margin: 0 0 10px;
    background: #ffffff;
  }
  section.staff .history-list li {
    margin: 0 auto 20px;
    padding: 10px;
  }
  section.staff .history-list li.left img,
  section.staff .history-list li.left .text,
  section.staff .history-list li.right img,
  section.staff .history-list li.right .text {
    float: none;
  }
  section.staff .history-list li img {
    width: calc(100% - 60px);
    margin: 0 auto 15px;
  }
  section.staff .history-list li .text {
    width: 100%;
  }
  section.staff .column-2.profile .column-child:first-child {
    width: 100%;
  }
  section.staff .column-2.profile .column-child:last-child {
    width: 100%;
  }
  section.staff .column-2.profile .staff-img {
    width: calc(100% - 50px);
    margin: 0 auto;
  }
  section.staff .column-2.profile .name {
    margin: 0 0 30px;
    font-size: 18px;
    text-align: center;
  }
  section.staff .column-2.profile .name span {
    display: block;
    font-size: 10px;
  }
  section.staff .column-2.profile .greeting {
    padding: 15px;
    font-size: 13px;
  }

  section .contact-text-wrapper {
    width: 100%;
    padding: 20px 75px 0 0;
  }
  section .contact-text-wrapper figure {
    position: absolute;
    right: 0;
    width: 71px;
    margin: 0;
  }
  section .form-table {
    display: block;
    margin: 0 0 30px;
    padding: 0 5px;
    border-bottom: #dedede 1px solid;
  }
  section .form-table tbody {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }
  section .form-table tr {
    display: block;
    width: 100%;
    padding: 25px 0 30px;
    border-bottom: #dedede 1px solid;
    box-sizing: border-box;
  }
  section .form-table th {
    display: block;
    width: 100%;
    padding: 0 0 15px;
  }
  section .form-table td {
    display: block;
    width: 100%;
    padding: 0;
  }
  section .form-table .label {
    font-size: 15px;
    font-weight: 500;
  }
  section .form-table .label .required,
  section .form-table .label .option {
    display: inline-block;
    position: relative;
    margin: 0 0 0 10px;
    font-size: 12px;
  }
  section .form-table .form-group .label {
    font-weight: normal;
  }
  section .form-table .form-group .hasDatepicker,
  section .form-table .form-group .select-wrap {
    width: 100%;
    float: none;
  }
  section .form-table .form-group .hasDatepicker {
    margin: 0 0 10px 0 !important;
  }
  section .form-table .form-group .select-wrap {
    margin: 0 0 20px 0 !important;
  }
  section.form .btn-wrapper .btn {
    width: 100%;
  }
  section.form-tel-box {
    padding: 30px 10px;
  }
  section.form-tel-box .inner-wrapper {
    padding: 0 5px;
  }
  section.form-tel-box .form-top-txt {
    width: 100%;
  }
  section.form-tel-box .tel {
    display: block;
    width: 100%;
    padding: 10px;
    font-size: 18px;
  }
  section.form-tel-box .tel .num {
    padding: 0 0 0 1.3em;
    font-size: 18px;
  }
  section.form-tel-box .tel .num::before {
    width: 20px;
    height: 27px;
  }
  section.form-tel-box .tel .time {
    font-size: 9px;
  }
  section .faq-cat-list li span {
    padding: 5px 0;
  }
  section .basic-pagination {
    padding: 0 0 50px;
  }
  section .basic-pagination .dots {
    height: auto;
    margin-bottom: 0;
  }
  section .basic-pagination .page-numbers.prev,
  section .basic-pagination .page-numbers.next {
    display: block;
    position: absolute;
    width: calc(50% - 10px);
    bottom: 0;
    line-height: 2.3;
  }
  section .basic-pagination .page-numbers.prev {
    left: 0;
  }
  section .basic-pagination .page-numbers.prev:before {
    display: block;
    position: absolute;
    margin: 0;
    top: 15px;
    left: 20px;
  }
  section .basic-pagination .page-numbers.next {
    right: 0;
  }
  section .basic-pagination .page-numbers.next:after {
    display: block;
    position: absolute;
    margin: 0;
    top: 15px;
    right: 20px;
  }
  section .archive-gallery-list li {
    padding: 15px;
  }
  section .archive-gallery-list li .column-2 {
    width: 100%;
  }
  section .archive-gallery-list li .column-2 .column-child:last-child {
    margin-bottom: 0;
  }
  section .archive-gallery-list li .num {
    margin: 0 auto 10px;
    text-align: center;
    font-size: 12px;
  }
  section .archive-gallery-list li .num .cat {
    font-size: 10px;
  }
  section .archive-gallery-list li .title {
    margin: 0 auto 10px;
    font-size: 14px;
    font-weight: normal;
  }
  section .archive-gallery-list li .text {
    display: none;
  }
  section .archive-gallery-list li .sub-text {
    font-size: 11px;
  }
  section.gallery-single {
    padding: 30px 10px !important;
  }
  section.gallery-single h1 {
    font-size: 18px;
    text-align: left;
  }
  section.gallery-single .guest {
    font-size: 11px;
    text-align: left;
  }
  section.gallery-single .point-text {
    padding: 20px;
  }
  section.gallery-single .summary-wrapper .summary-image {
    width: 100%;
    margin: 0 0 15px;
    padding: 0;
    float: none;
  }
  section.gallery-single .summary-wrapper .summary-text {
    width: 100%;
    float: none;
  }
  section.gallery-single .summary-wrapper .summary-text .photoframe {
    display: none;
  }
  section.gallery-single .summary-wrapper .summary-text .data table {
    font-size: 13px;
  }
  section.gallery-single.re-staff .column-1 {
    padding: 0 0 20px;
  }
  section.gallery-single.voice .voice-image {
    height: 200px;
    overflow: hidden;
  }
  section.gallery-single.voice-pickup p {
    margin: 0 0 20px;
  }
  section.gallery-single.voice-pickup .pickup-title {
    font-size: 16px;
    margin: 0 auto 10px;
  }
  section.gallery-single.feature .column-2:last-child .column-child:last-child {
    margin-bottom: 0;
  }
  section.gallery-single.feature .staff-list li {
    padding: 20px 0;
  }
  section.gallery-single.feature .staff-list li:first-child {
    padding: 0 0 20px;
  }
  section.gallery-single.feature .staff-list li p {
    font-size: 9px;
  }
  section.gallery-single.feature .staff-list li .name {
    font-size: 12px;
  }
  section.gallery-single.feature .staff-list li .name span {
    font-size: 10px;
  }
  section.page-main img {
    margin: 0 auto 15px;
  }
  section.page-main p {
    width: calc(100% - 10px);
    font-size: 13px;
  }
  section.contents-list h2 {
    font-size: 20px;
    margin: 0 auto;
  }
  section.contents-list .toc {
    width: calc(100% - 20px);
    margin: 0 auto;
    padding: 0;
    border: none;
  }
  section.contents-list .toc p {
    display: block;
    position: relative;
    top: 0;
    margin: 5px 0 10px;
    font-size: 20px;
    text-align: center;
  }
  section.contents-list .toc p::before,
  section.contents-list .toc p::after {
    display: none;
  }
  section.contents-list .toc ul li {
    padding: 12.5px 0;
    font-size: 13px;
  }
  section.contents-list .toc ul li:first-child {
    padding: 0 0 12.5px;
  }
  section.contents-list .toc ul li:last-child {
    padding: 12.5px 0 0;
  }
  section.contents-list .toc ul li a::before {
    font-size: 13px;
  }

  section.page-nude {
    padding: 30px 10px;
  }
  section.page-nude.faq {
    padding: 30px 15px;
  }
  section.page-nude.voice .slider-box {
    padding: 0;
  }
  section.page-nude .btn-wrapper {
    width: 95%;
  }

  section.company {
    padding: 30px 10px !important;
  }
  section.company.access .access-data table {
    width: 100%;
  }
  section.company h3 {
    font-size: 16px;
  }
  section.company h4.js__acPrtSp {
    position: relative;
    width: 100%;
    margin: 0 auto;
    padding: 10px 35px 10px 10px;
    color: #ffffff;
    text-align: left;
    line-height: 1.5;
    font-size: 16px;
    font-weight: 500;
    background: #aa75b1;
  }
  section.company h4.js__acPrtSp::after {
    content: "+";
    display: inline-block;
    position: absolute;
    width: 20px;
    height: 20px;
    top: 30%;
    right: 10px;
    left: auto;
    bottom: auto;
    margin: 0;
    font-size: 20px;
    text-align: center;
    line-height: 1;
    background: none;
  }
  section.company h4.js__acPrtSp.js__acOpenSp {
    width: calc(100% - 4px);
    margin-top: 2px;
  }
  section.company h4.js__acPrtSp.js__acOpenSp::after {
    content: "-";
  }
  section.company .access-list-wrapper {
    margin: 0 auto 2px;
    padding: 0;
    border: #aa75b1 1px solid;
  }
  section.company .access-list {
    display: none;
  }
  section.company .column-flex {
    margin: 0 auto;
    padding: 15px;
  }
  section.company .column-flex li {
    display: block;
    width: 100%;
    margin: 0 0 20px;
  }
  section.company .column-flex li:last-child {
    margin: 0;
  }
  section.company .column-flex li img {
    margin: 0 auto;
  }
  section.company .column-flex li .step {
    margin-bottom: 0;
    font-size: 15px;
  }
  section.company .company-data table {
    display: block;
    font-size: 13px;
  }
  section.company .company-data table tbody {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }
  section.company .company-data table tr {
    display: block;
    padding: 10px 0;
  }
  section.company .company-data table th {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
  }
  section.company .company-data table td {
    padding: 0;
  }

  section.price {
    padding: 30px 10px !important;
  }
  section.price .price-list li {
    float: none;
    width: 100%;
    margin: 0 0 10px;
  }
  section.price .price-list li:nth-child(2n) {
    margin: 0 0 10px;
  }
  section.price .price-list li a {
    padding: 10px 10px 10px 40px;
    font-size: 14px;
  }
  section.price .price-list li a img {
    max-width: 23px;
    max-height: 21px;
  }
  section.price h3 {
    font-size: 16px;
  }
  section.price .img-orign-size {
    width: 100%;
  }
  section.price .memo {
    padding: 15px;
    font-size: 13px;
  }
  section.price .column-flex li {
    display: block;
    width: 100%;
    margin: 0 auto 2px;
    padding: 0;
    border: #aa75b1 1px solid;
  }
  section.price .column-flex li .option-list {
    display: none;
    padding: 15px;
  }
  section.price .column-flex li .option-list .option-image {
    height: 170px;
  }
  section.price .column-flex li .option-list .option-image img {
    zoom: 0.7;
    max-width: 100%;
    max-height: 100%;
  }
  section.price .column-flex li .option-list .option-text .name {
    font-size: 16px;
  }
  section.price .column-flex li .option-list .option-text .text {
    font-size: 13px;
  }
  section.price .column-flex li .option-list table {
    font-size: 13px;
  }
  section.price .column-flex li h3.js__acPrtSp {
    position: relative;
    width: 100%;
    margin: 0 auto;
    padding: 10px;
    color: #ffffff;
    text-align: left;
    line-height: 1.5;
    font-size: 14px;
    font-weight: 500;
    background: #aa75b1;
    box-sizing: border-box;
  }
  section.price .column-flex li h3.js__acPrtSp::after {
    content: "+";
    display: inline-block;
    position: absolute;
    width: 20px;
    height: 20px;
    top: 10px;
    right: 10px;
    left: auto;
    bottom: auto;
    font-size: 20px;
    text-align: center;
    line-height: 1;
    background: none;
  }
  section.price .column-flex li h3.js__acPrtSp.js__acOpenSp {
    width: calc(100% - 4px);
    margin-top: 2px;
  }
  section.price .column-flex li h3.js__acPrtSp.js__acOpenSp::after {
    content: "-";
  }
  section.price.contents-list .toc {
    margin-top: 50px;
    margin-bottom: 30px;
    padding: 20px 20px;
    border-left: #999999 2px solid;
    border-right: #999999 2px solid;
    border-bottom: #999999 2px solid;
  }
  section.price.contents-list .toc p {
    display: flex;
    position: absolute;
    top: -20px;
    font-size: 17px;
  }
  section.price.contents-list .toc p::before,
  section.price.contents-list .toc p::after {
    display: block;
  }
  section.price.contents-list .toc ul li span::before {
    font-size: 13px;
  }
  section.price.voice .slider-box {
    margin-top: 0;
  }
  section.price.voice .slider-box .voice-slider .slick-prev,
  section.price.voice .slider-box .voice-slider .slick-next {
    top: 50%;
  }

  section.single-all h1 {
    font-size: 18px;
    text-align: left;
  }
  section.single-all .post-list li {
    margin: 0 0 20px;
    box-sizing: border-box;
  }
  section.single-all .post-list li .post-lis-item-text {
    padding: 10px;
  }
  section.single-all .post-list li .post-lis-item-text .title {
    font-size: 11px;
  }
  section.single-all .post-list li .post-lis-item-text .sub-text {
    font-size: 9px;
  }
  section.single-all .post-list li .post-lis-item-text .date {
    font-size: 9px;
  }
  section.single-all .post-list li .post-lis-item-text .cat-link a {
    font-size: 9px;
  }
  section.single-all .post-list.archive {
    justify-content: space-between;
  }
  section.single-all .post-list.archive li {
    width: calc(50% - 1.5px);
    margin-right: 0;
  }
  section.single-all .single-pagination {
    width: 100%;
  }
  section.single-all .single-pagination .pagination-heading span {
    font-size: 12px;
  }
  section.single-all .single-pagination .pagination-flex .pagination-item {
    font-size: 11px;
  }

  section.page-all {
    font-size: 13px;
  }
  section.page-all .date {
    font-size: 11px;
  }
  section.page-all .author-wrapper {
    padding: 15px;
  }
  section.page-all .author-wrapper figure {
    width: 70px;
  }
  section.page-all .author-wrapper .author-text {
    padding: 0 0 0 85px;
    font-size: 9px;
  }
  section.page-all .author-wrapper .author-text .name {
    font-size: 12px;
  }
  section.page-all .author-wrapper .author-text .name span {
    font-size: 10px;
  }
  section.page-all .single-mv {
    width: calc(100% + 20px);
    margin: 0 0 20px -10px;
  }
  section.page-all h1 {
    font-size: 18px;
  }
  section.page-all h2 {
    font-size: 16px;
  }
  section.page-all h3 {
    font-size: 15px;
  }
  section.page-all h4 {
    font-size: 14px;
  }
  section.page-all ul li {
    padding: 0 0 0 16px;
  }
  section.page-all ol {
    padding: 0 0 0 16px;
  }
  section.page-all blockquote {
    padding: 35px 15px;
  }
  section.page-all blockquote::before,
  section.page-all blockquote::after {
    width: 14px;
    height: 10.5px;
  }
  section.page-all blockquote::before {
    left: 15px;
    top: 20px;
  }
  section.page-all blockquote::after {
    right: 15px;
    bottom: 20px;
  }
  section.page-all blockquote pre {
    font-size: 11px;
  }

  section .about-step {
    margin: 0 auto 20px;
  }
  section .about-step h4 {
    width: 100%;
    margin: 0 auto 20px;
    font-size: 18px;
  }
  section .about-step h4::after {
    width: 100px;
  }
  section .about-step .title-step img {
    height: 29px;
  }
  section .about-point {
    padding: 20px 0;
  }
  section .about-point .column-point {
    margin: 0 auto 45px;
  }
  section .about-point .title-point img {
    height: 20.5px;
  }

  section.news .inner-wrapper {
    max-width: auto;
    padding: 20px 0 40px;
  }
  section.message {
    padding: 30px 15px 20px;
  }
  section.message .message-box {
    width: 100%;
  }
  section.message .message-box img {
    width: 100%;
    float: none;
  }
  section.message .message-box .message-txt {
    width: 100%;
    float: none;
  }
  section.message .message-box .message-txt h2 {
    margin: 30px 0 15px;
    text-align: center;
  }
  section.message .message-box .message-txt h2 img {
    width: 81px;
  }
  section.message .message-box .message-txt h3 {
    font-size: 18px;
  }
  section.message .message-box .message-txt p {
    font-size: 13px;
  }
  section.access {
    padding: 1px 15px 30px;
  }
  section.access .btn-wrapper {
    width: calc(100% - 60px);
  }
  section.access p {
    width: 100%;
  }
  section.access .gmap {
    width: auto;
    height: 0;
    margin: 0 auto 20px;
    padding-bottom: 56.25%;
  }
  section.access .access-data {
    width: 100%;
    margin: 20px 0 10px;
  }
  section.access .access-data img {
    width: 100%;
    float: none;
  }
  section.access .access-data table {
    width: 100%;
    float: none;
    font-size: 13px;
  }
  section.about {
    padding: 1px 15px 30px;
  }
  section.about .about-txt-wrapper {
    width: 100%;
  }
  section.about .btn-wrapper .btn {
    width: calc(100% - 60px);
  }
  section.faq {
    padding: 1px 15px 30px;
  }
  section.faq .link-arrow {
    width: 100%;
  }
  section.faq .faq-list {
    width: 100%;
  }
  section.faq .faq-list li h3 {
    font-size: 13px;
  }
  section.faq .faq-list li p {
    font-size: 12px;
  }
  section.faq .faq-list li h3,
  section.faq .faq-list li p {
    padding: 0 0 0 20px;
  }
  section.faq .faq-list li h3 span.icon,
  section.faq .faq-list li p span.icon {
    font-size: 15px;
    top: -7.5px;
  }
  section.flow .flow-list {
    width: 100%;
  }
  section.flow .flow-list li {
    width: calc(50% - 7px);
    margin: 0 0 14px;
  }
  section.flow .flow-list li .flow-img {
    width: 100%;
    float: none;
    margin: 0 0 14px;
  }
  section.flow .flow-list li .flow-txt {
    width: 100%;
    float: none;
    font-size: 11px;
  }
  section.flow .flow-list li .flow-txt img {
    height: 16px;
    margin: 0 0 10px;
  }
  section.plan {
    padding: 0;
  }
  section.plan .note {
    width: calc(100% - 20px);
    font-size: 11px;
  }
  section.plan .plan-top-text {
    width: 100%;
    padding: 0 15px;
  }
  section.plan .plan-top-text p {
    padding: 0 5px;
    font-size: 12px;
  }
  section.plan .plan-top-text .graph {
    margin: 20px 0;
  }
  section.plan .plan-top-text .graph img {
    width: 100%;
    margin: 0 0 20px;
    float: none;
  }
  section.plan .plan-top-text .graph .graph-txt {
    width: 100%;
    float: none;
    font-size: 14px;
  }
  section.plan table {
    width: calc(100% - 8px);
  }
  section.plan table th {
    padding: 10px 0;
    font-size: 11px;
  }
  section.plan table td {
    padding: 10px 5px;
    font-size: 9px;
  }
  section.plan table td.small-text {
    font-size: 9px;
  }
  section.plan table td.img-cell a {
    font-size: 9px;
  }
  section.plan table td.img-cell a img {
    width: auto;
    max-width: 85px;
  }
  section.plan table td .plice1,
  section.plan table td .plice3 {
    width: 49px;
  }
  section.plan table td .plice2 {
    width: 75px !important;
    margin: 0 auto;
  }
  section.plan table .th-side {
    width: 57px;
  }
  section.plan table .th-top {
    width: calc((100% - 57px) / 3);
  }
  section.plan table .th-top.recommend {
    width: calc((100% - 57px) / 3);
  }
  section.plan table .th-top.recommend span {
    margin: 0;
  }
  section.comparison,
  section.comparison-home {
    padding: 40px 5px;
  }
  section.comparison h2,
  section.comparison-home h2 {
    position: absolute;
    margin: 0;
    width: 100%;
    z-index: 2;
  }
  section.comparison .comparison-table,
  section.comparison-home .comparison-table {
    width: 100%;
    padding: 0;
    background: none;
  }
  section.comparison .comparison-table .table,
  section.comparison-home .comparison-table .table {
    margin: 0 0 15px;
    background: #ffffff;
    border: #ffffff 1px solid;
  }
  section.comparison .comparison-table p,
  section.comparison-home .comparison-table p {
    width: 100%;
    margin: 0 auto 15px;
    padding: 0 20px;
  }
  section.comparison .comparison-table .btn-wrapper,
  section.comparison-home .comparison-table .btn-wrapper {
    width: calc(100% - 60px);
  }
  section.comparison-home {
    padding: 30px 0 0;
  }
  section.comparison-home .comparison-table {
    padding: 0 5px 30px;
    background: #ffffff;
  }
  section.comparison-home .comparison-table .table {
    background: none;
    border: none;
  }
  section.comparison-home .comparison-table p {
    width: 100%;
    margin: 0 auto 15px;
  }
  section.feature .inner-wrapper {
    padding: 1px 0 0;
  }
  section.feature hr {
    display: block;
    width: 100%;
    height: 1px;
    margin: 0 0 20px;
    padding: 0;
    border-top: #999999 1px dotted;
  }
  section.feature .link-arrow {
    margin-bottom: 19px;
  }
  section.feature .btn-wrapper {
    width: calc(100% - 30px);
  }
  section.feature .btn-wrapper .btn {
    font-size: 12px;
  }
  section.feature .staff-list li {
    width: 100%;
    float: none;
    margin: 20px 0 0 0;
    padding: 20px 0 0;
  }
  section.feature .staff-list li:nth-child(odd) {
    margin: 20px 0 0 0;
  }
  section.feature .staff-list li .staff-img {
    width: 97.5px;
  }
  section.feature .staff-list li .staff-txt {
    width: calc(100% - 108px);
    font-size: 9px;
  }
  section.feature .staff-list li .staff-txt .name {
    font-size: 12px;
  }
  section.feature .staff-list li .staff-txt .name span {
    font-size: 10px;
  }
  section.feature .feature-box {
    display: block;
    margin: 0;
    padding: 40px 0;
  }
  section.feature .feature-content {
    width: 100%;
    margin: 0;
  }
  section.feature .feature-content:last-child .btn-wrapper {
    margin: 20px auto 0;
  }
  section.feature .feature-content.no1 .heading-img-feature {
    width: 100% !important;
    float: none;
  }
  section.feature .feature-content.no1 .feature-txt {
    width: 100% !important;
    float: none;
  }
  section.feature .feature-content.no1 .feature-txt .catch {
    margin: 0 0 10px;
  }
  section.feature .feature-content .heading-img-feature {
    margin: 0 0 18px;
  }
  section.feature .feature-content .feature-txt .feature-no {
    height: 21px !important;
    margin: 0 0 20px;
  }
  section.feature .feature-content .feature-txt .catch {
    font-size: 14px;
    margin: 0 0 10px;
  }
  section.feature .feature-content .feature-txt h3 {
    font-size: 18px;
    margin: 0 0 20px;
  }
  section.feature .feature-content .feature-txt p {
    font-size: 14px;
  }
  section.voice {
    padding: 0;
  }
  section.voice .inner-wrapper {
    padding: 0 15px;
  }
  section.voice .balloon {
    margin: 30px auto 15px;
    padding: 10px 20px;
    font-size: 11px;
  }
  section.voice .balloon::before {
    bottom: -7px;
    margin-left: -7px;
    border-width: 7px 6px 0 6px;
  }
  section.voice .voice-for-img {
    width: 100%;
    max-width: 640px;
  }
  section.voice .slider-box {
    margin: 30px 0 50px;
  }
  section.voice .slider-box .slick-dots li {
    width: 7px !important;
    height: 7px !important;
  }
  section.voice .slider-box .slick-dots li button {
    width: 7px !important;
    height: 7px !important;
  }
  section.voice .slider-box .slick-dots li button:before {
    content: "" !important;
    opacity: 1 !important;
    width: 5px !important;
    height: 5px !important;
    top: 1px;
    left: 1px;
    color: #aa75b1 !important;
    border-radius: 50% !important;
    background: none;
    border: 1px #aa75b1 solid;
    box-sizing: border-box;
  }
  section.voice .slider-box .slick-dots li.slick-active button:before {
    content: "" !important;
    opacity: 1 !important;
    width: 7px !important;
    height: 7px !important;
    top: 0;
    left: 0;
    color: #aa75b1 !important;
    background: #aa75b1;
  }
  section.voice .slider-box .voice-slider {
    width: calc(100% - 50px);
  }
  section.voice .slider-box .voice-slider .slick-prev,
  section.voice .slider-box .voice-slider .slick-next {
    top: 25%;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    opacity: 0.8;
  }
  section.voice .slider-box .voice-slider .slick-prev::before,
  section.voice .slider-box .voice-slider .slick-next::before {
    top: 35%;
  }
  section.voice .slider-box .voice-slider .slick-prev {
    left: -15px;
  }
  section.voice .slider-box .voice-slider .slick-prev::before {
    left: 40%;
  }
  section.voice .slider-box .voice-slider .slick-next {
    right: -15px;
  }
  section.voice .slider-box .voice-slider .slick-next::before {
    right: 40%;
  }
  section.voice .slider-box .voice-slider .voice-slide-item {
    width: calc(100% - 50px);
    margin: 0 5px;
    padding: 0;
    background: none;
    box-shadow: none;
  }
  section.voice .slider-box .voice-slider .voice-slide-item .voice-text-box {
    width: 100%;
    float: none;
    height: auto;
    overflow: auto;
    margin: 0;
    padding: 16px;
    text-align: center;
    background: #ffffff;
    box-shadow: 0 0 5px #e6e6e6;
  }
  section.voice
    .slider-box
    .voice-slider
    .voice-slide-item
    .voice-text-box
    .voice-no {
    margin: 0 0 10px;
    font-size: 11px;
  }
  section.voice
    .slider-box
    .voice-slider
    .voice-slide-item
    .voice-text-box
    .voice-no
    span {
    font-size: 10px;
  }
  section.voice
    .slider-box
    .voice-slider
    .voice-slide-item
    .voice-text-box
    .voice-area {
    font-size: 11px;
  }
  section.voice
    .slider-box
    .voice-slider
    .voice-slide-item
    .voice-text-box
    .voice-area::after {
    content: "";
    display: block;
    position: relative;
    width: 15px;
    height: 1px;
    margin: 15px auto;
    background: #333333;
  }
  section.voice .slider-box .voice-slider .voice-slide-item .voice-text-box h3 {
    margin: 0 0 15px;
    font-size: 13px;
    font-weight: normal;
  }
  section.voice
    .slider-box
    .voice-slider
    .voice-slide-item
    .voice-text-box
    .btn-wrapper {
    padding: 0 16px;
  }
  section.voice .slider-box .voice-slider .voice-slide-item .voice-photo-box {
    width: 100%;
    box-shadow: 0 0 5px #e6e6e6;
    margin: 0 0 10px;
  }
  section.voice
    .slider-box
    .voice-slider
    .voice-slide-item
    .voice-photo-box
    .voice-photo-main {
    width: 100%;
    margin: 0;
  }
  section.voice
    .slider-box
    .voice-slider
    .voice-slide-item
    .voice-photo-box
    .voice-photo-main
    img {
    position: relative;
    width: 100%;
  }

  h2 {
    font-size: 19px;
  }
  h2 .heading-txt-img.recommend {
    width: 48px;
    margin: 0 -14px 19px -34px;
  }
  h2 .heading-txt-img.voice {
    width: 48px;
    margin: 0 -14px 19px -34px;
  }
  h2 .heading-txt-img.feature {
    width: 37px;
    margin: 0 -15px 19px -22px;
  }
  h2 .heading-txt-img.comparison {
    width: 56px;
    margin: 0 -30px 19px -26px;
  }
  h2 .heading-txt-img.plan {
    width: 48px;
    margin: 0 0 19px -48px;
  }
  h2 .heading-txt-img.flow {
    width: 24px;
    margin: 0 0 19px -24px;
  }
  h2 .heading-txt-img.faq {
    width: 27px;
    margin: 0 0 19px -27px;
  }
  h2 .heading-txt-img.about {
    width: 60px;
    margin: 0 -25px 19px -35px;
  }
  h2 .heading-txt-img.access {
    width: 30px;
    margin: 0 -3px 19px -27px;
  }

  .news .bnr-list .top-news-slider .slick-list {
    padding: 0 20px 0 0 !important;
  }
  .news .bnr-list .top-news-slider li {
    margin: 0 5px;
  }

  .news-list li .date {
    float: none;
    display: inline-block;
  }
  .news-list li .cat {
    float: none;
    display: inline-block;
  }
  .news-list li .txt {
    float: none;
    display: block;
    width: 100%;
    margin: 5px 0 0;
  }

  /* footer */
  .footer-message-wrapper {
    padding: 15px 15px 40px;
    max-width: none;
    overflow: hidden;
  }
  .footer-message-wrapper .footer-message-box {
    padding: 3px 0;
  }
  .footer-message-wrapper .footer-message-box .footer-message-box-inner {
    padding: 25px 0;
  }
  .footer-message-wrapper
    .footer-message-box
    .footer-message-box-inner::before {
    position: absolute;
    left: -37px;
    top: -22px;
    width: 155px;
    height: 103px;
    background: url(images/common/img_footer_message_top.png.webp) no-repeat 0 0 /
      contain;
    content: "";
  }
  .footer-message-wrapper .footer-message-box .footer-message-box-inner::after {
    position: absolute;
    right: -25px;
    bottom: -57px;
    width: 160px;
    height: 104px;
    background: url(images/common/img_footer_message_bottom.png.webp) no-repeat
      0 0 / contain;
    content: "";
  }
  .footer-message-wrapper
    .footer-message-box
    .footer-message-box-inner
    .heading {
    margin: 0 0 15px;
    padding: 0 0 15px;
    text-align: center;
    font-size: 12px;
  }
  .footer-message-wrapper
    .footer-message-box
    .footer-message-box-inner
    .heading::before {
    width: 11px;
    height: 1px;
  }
  .footer-message-wrapper
    .footer-message-box
    .footer-message-box-inner
    .heading
    span {
    font-size: 20px;
  }
  .footer-message-wrapper
    .footer-message-box
    .footer-message-box-inner
    .text-wrapper {
    position: relative;
    padding: 0 85px 0 0;
  }
  .footer-message-wrapper
    .footer-message-box
    .footer-message-box-inner
    .text-wrapper
    .image {
    position: absolute;
    right: -25px;
    top: 0;
    margin: 0;
    width: 100px;
  }
  .footer-message-wrapper
    .footer-message-box
    .footer-message-box-inner
    .text-wrapper
    .text {
    font-size: 12px;
  }

  .footer-cv-wrapper {
    padding: 30px 10px;
  }
  .footer-cv-wrapper .footer-cv-section {
    padding: 0;
  }
  .footer-cv-wrapper .footer-cv-section .balloon-heading {
    max-width: none;
    margin: 0 auto 14px;
    padding: 8px 8px 9px;
    border: 1px solid #aa75b1;
    border-bottom: none;
    font-size: 13px;
  }
  .footer-cv-wrapper .footer-cv-section .balloon-heading::before,
  .footer-cv-wrapper .footer-cv-section .balloon-heading::after {
    height: 1px;
  }
  .footer-cv-wrapper .footer-cv-section .balloon-heading::after {
    left: auto;
    right: 0;
    width: calc(50% - 4px);
  }
  .footer-cv-wrapper .footer-cv-section .balloon-heading .inner::before {
    right: calc(50% - 2px);
    bottom: -6px;
    width: 1px;
    height: 7px;
  }
  .footer-cv-wrapper .footer-cv-section .footer-cv-content {
    display: block;
  }
  .footer-cv-wrapper .footer-cv-section .footer-cv-content .pc-image {
    display: none;
  }
  .footer-cv-wrapper .footer-cv-section .footer-cv-content .text-wrapper {
    width: auto;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .text-wrapper
    .heading {
    position: relative;
    display: block;
    margin: 0 0 18px;
    padding: 0 0 15px 110px;
    border-bottom: 1px solid #736652;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .text-wrapper
    .heading
    .sp-image {
    display: block;
    position: absolute;
    left: 0;
    bottom: -8px;
    box-shadow: 0 0 10px 2px #e7e6e8;
    width: 100px;
    height: auto;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .text-wrapper
    .heading
    .text {
    display: block;
    margin: 0 0 5px;
    padding: 0;
    font-size: 12px;
    text-align: center;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .text-wrapper
    .heading
    .logo {
    max-width: 182px;
    margin: 0 auto;
  }
  .footer-cv-wrapper .footer-cv-section .footer-cv-content .list-wrapper {
    position: relative;
    margin: 0 0 15px;
    padding: 0 0 0 80px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .list-wrapper
    .circle-text {
    width: 73px;
    height: 73px;
    font-size: 10px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .list-wrapper
    .circle-text
    .term {
    font-size: 12px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .list-wrapper
    .circle-text
    .term
    em {
    font-size: 16px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .list-wrapper
    .circle-text
    .limit {
    font-size: 11px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .list-wrapper
    .circle-text
    .limit
    em {
    font-size: 16px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .list-wrapper
    .list
    > li {
    padding: 0 0 0 16px;
    font-size: 11px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .list-wrapper
    .list
    > li::before {
    top: 2px;
    width: 14px;
    height: 12px;
  }
  .footer-cv-wrapper .footer-cv-section .footer-cv-content .contact-wrapper {
    padding: 10px 10px 15px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .contact-heading {
    margin: 0 0 12px;
    font-size: 12px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper {
    display: block;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .tel,
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .mail {
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1.3;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .tel {
    pointer-events: auto;
    width: 100%;
    margin: 0 0 25px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .tel
    .time {
    order: 2;
    font-size: 10px;
    width: auto;
    padding: 0 0 0 10px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .tel
    .time
    br {
    display: block;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .tel
    .num {
    order: 1;
    position: relative;
    display: inline-block;
    padding: 0 0 0 25px;
    font-weight: bold;
    font-size: 18px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .tel
    .num::before {
    width: 20px;
    height: 27px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .mail {
    width: 100%;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .mail
    .time {
    padding: 0 10px 0 0;
    font-size: 10px;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .mail
    .time
    br {
    display: block;
  }
  .footer-cv-wrapper
    .footer-cv-section
    .footer-cv-content
    .contact-wrapper
    .btn-wrapper
    .mail
    .text {
    font-size: 14px;
  }

  .footer-check-bnr-wrapper {
    padding: 15px 10px 20px;
  }
  .footer-check-bnr-wrapper .heading {
    margin: 0 0 20px;
    font-size: 14px;
  }
  .footer-check-bnr-wrapper .bnr-wrapper {
    display: block;
  }
  .footer-check-bnr-wrapper .bnr-wrapper a {
    display: block;
    width: auto;
  }
  .footer-check-bnr-wrapper .bnr-wrapper a:not(:last-child) {
    margin: 0 0 25px;
  }

  .footer-ig-wrapper {
    max-width: none;
    padding: 20px 10px 40px;
  }
  .footer-ig-wrapper .heading {
    margin: 0 0 15px;
  }
  .footer-ig-wrapper .heading img {
    height: 30px;
  }

  .footer-nav-wrapper {
    padding: 0;
  }
  .footer-nav-wrapper .footer-nav-inner {
    display: block;
    padding: 0;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-access-wrapper {
    width: auto;
    padding: 30px 15px;
    border-right: none;
    background: #fff;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-access-wrapper .image {
    display: none;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-access-wrapper .text-wrapper {
    font-size: 11px;
    color: #736652;
  }
  .footer-nav-wrapper
    .footer-nav-inner
    .footer-access-wrapper
    .text-wrapper
    .name {
    margin: 0 0 15px;
    padding: 0 0 15px;
    border-bottom: 1px solid #e3e0dc;
  }
  .footer-nav-wrapper
    .footer-nav-inner
    .footer-access-wrapper
    .text-wrapper
    .tel,
  .footer-nav-wrapper
    .footer-nav-inner
    .footer-access-wrapper
    .text-wrapper
    .address {
    margin: 0 0 5px;
    color: #333;
  }
  .footer-nav-wrapper
    .footer-nav-inner
    .footer-access-wrapper
    .text-wrapper
    .distance {
    color: #333;
  }
  .footer-nav-wrapper
    .footer-nav-inner
    .footer-access-wrapper
    .text-wrapper
    .distance
    .sp-text {
    display: inline;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-access-wrapper .footer-sns-pc {
    display: none;
  }
  .footer-nav-wrapper
    .footer-nav-inner
    .footer-access-wrapper
    .footer-btn-wrapper {
    display: none;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-sitemap-wrapper {
    display: none;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp {
    display: block;
    padding: 0 15px 20px;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp .list > li {
    border-bottom: 1px solid #d5d0c6;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp .list > li a {
    position: relative;
    display: block;
    padding: 12px 20px 12px 6px;
    font-size: 14px;
    color: #736652;
  }
  .footer-nav-wrapper
    .footer-nav-inner
    .footer-nav-area-sp
    .list
    > li
    a::before {
    display: block;
    position: absolute;
    right: 6px;
    top: 50%;
    width: 5px;
    height: 5px;
    border-top: 2px solid #736652;
    border-right: 2px solid #736652;
    transform: translateY(-50%) rotate(45deg);
    content: "";
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp .sns {
    display: flex;
    justify-content: space-around;
    margin: 20px 0 0;
    padding: 0 10%;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp .sns > li a {
    display: block;
    width: 30px;
    height: 30px;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp .sns > li a.tw {
    background: url(images/common/ico_footer_tw.png.webp) no-repeat 50% 50% /
      contain;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp .sns > li a.fb {
    background: url(images/common/ico_footer_fb.png.webp) no-repeat 50% 50% /
      contain;
  }
  .footer-nav-wrapper .footer-nav-inner .footer-nav-area-sp .sns > li a.ig {
    background: url(images/common/ico_footer_ig.png.webp) no-repeat 50% 50% /
      contain;
  }

  .copyright {
    padding: 12px 12px 64px;
    font-size: 10px;
  }

  #pagetop {
    display: none;
  }

  .footer-floating-sp {
    position: fixed;
    left: 0;
    bottom: 0;
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 5px 10px;
    box-sizing: border-box;
    background: rgba(255, 255, 255, 0.9);
  }
  .footer-floating-sp a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: calc((100% - 2px) / 2);
    padding: 8px;
    box-sizing: border-box;
    box-shadow: 0 1px 0 0 rgba(255, 255, 255, 0.28) inset;
    font-size: 14px;
    color: #fff;
  }
  .footer-floating-sp a:hover {
    text-decoration: none;
  }
  .footer-floating-sp a .icon {
    position: relative;
    display: inline-block;
    padding: 0 0 0 25px;
  }
  .footer-floating-sp a .icon::before {
    position: absolute;
    left: 0;
    top: 50%;
    display: block;
    width: 18px;
    height: 21px;
    transform: translateY(-50%);
    content: "";
  }
  .footer-floating-sp a.reservation {
    border-radius: 3px 0 0 3px;
    border: 1px solid #aa75b1;
    background: linear-gradient(0deg, #aa75b1 0%, #c8a2cd 100%);
    text-shadow: 0 1px #9860a0;
  }
  .footer-floating-sp a.reservation .icon::before {
    background: url(images/common/ico_footer_floating_reservation.png.webp)
      no-repeat 50% 50% / contain;
  }
  .footer-floating-sp a.tel {
    border-radius: 0 3px 3px 0;
    border: 1px solid #9860a0;
    background: linear-gradient(0deg, #985fa0 0%, #aa75b1 100%);
    text-shadow: 0 1px #83468c;
  }
  .footer-floating-sp a.tel .icon::before {
    background: url(images/common/ico_footer_floating_tel.png.webp) no-repeat
      50% 50% / contain;
  }
  .footer-floating-sp a.tel .icon .column {
    display: flex;
    align-items: center;
  }
  .footer-floating-sp a.tel .icon .column .time {
    padding: 0 0 0 5px;
    font-size: 10px;
    text-align: center;
    line-height: 1.2;
  }
  /* トップページ 助産師さん推薦 */
  section.reccomend {
    padding-top: 0;
    padding-bottom: 30px;
  }
  .recommend-content {
    flex-wrap: wrap-reverse;
    padding-top: 0;
  }
  .recommend-img {
    margin: 0 auto;
  }
  .reccomend-txt {
    margin-top: 10px;
  }
}

h1,h2,h3:not(.feature-heading-h3) { font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝','Yu Mincho', '游明朝体', 'YuMincho','ＭＳ Ｐ明朝', 'MS PMincho', serif; }

section.faq .column-2 .column-child .btn-wrapper {
	width: 100%;
	padding-top: 2rem;
}

section.faq .faq-list li h3, section.faq .faq-list li p {
    padding: 0;
}
section.faq .faq-list li {
    display: block;
    position: relative;
    width: 100%;
    margin: 0 auto 30px;
    padding: 30px !important;
    background: #ffffff;
    box-shadow: 0 0 4px #bababa;
    box-sizing: border-box;
    border-bottom: none;
    }
    
section.faq .faq-list li .title {
	display: block;
	margin: 0 auto 5px;
	padding-bottom: 18px;
  font-size: 18px;
  font-weight: bold;
	color: #996699;
  text-align: left;
  line-height: 1.5;
}
    
section.faq .faq-list li p.text {
	font-size: 13px;
}

section.faq .faq-list li.faq-list-linkOnly {
    margin: 0 auto;
    background: transparent;
    box-shadow: none;
}

section.faq .faq-list li.faq-list-linkOnly:not(:last-child) {
	border-bottom: #999999 1px dashed;
}

section.faq .faq-list li.faq-list-linkOnly a {
    position: relative;
    display: block;
    padding: 0 0 0 1.7em;
    font-size: 17px;
    color: #333;
    transition: .3s ;
}

section.faq .faq-list li.faq-list-linkOnly a:hover {
    color:#aa75b1;
}

section.faq .faq-list li.faq-list-linkOnly a:before {
    position: absolute;
    left: 0;
    top: 0;
    content: "Q";
    display: block;
    font-family: "Italianno", cursive;
    font-size: 18px;
    font-weight: bold;
    color: #aa75b1;
}

.br-text {
	display: inline-block;
}

.related-posts li {
    font-weight: 700;
    margin-bottom: 1rem;
}

.answer-digest {
	color: #aa75b1;
	font-weight: 500;
	margin-bottom: 1rem;
}

p.gallery-table-of-contents {
	display: block;
	margin: 0 auto 30px;
	font-size: 28px;
	font-weight: 700;
	font-family: 'ヒラギノ明朝 Pro W3','Hiragino Mincho Pro','游明朝','Yu Mincho','游明朝体','YuMincho','ＭＳ Ｐ明朝','MS PMincho',serif;
	text-align: center;
	line-height: 1.5;
}

@media only screen and (max-width: 768px){
    p.gallery-table-of-contents {
        margin: 0;
        font-size: 18px;
    }
	.footer_line {
	border-radius: 3px 0 0 3px;
    border: 1px solid #999;
 /*   background: linear-gradient(0deg,#333 0%,#666 100%); */
    text-shadow: 0 1px #999;
	background:#3b3b3b;
}
	#mv-wrapper .home .slider-box {
	padding: 0;
	}
	#mv-wrapper .home .slider-box .top-slider .slide-item {
    padding: 16px;
}
	.item1{flex-basis: auto;height: 65px;}
	.item2{flex-basis: auto;height: 65px;}
	.item3{flex-basis: 20%;height: 65px;}
}

.youtube-container {
  width: 100%;
  aspect-ratio: 16 / 9;
  margin: 0 auto;
}
.youtube-container iframe {
  width: 100%;
  height: 100%;
}

.footer-widget-area {
	text-align: center;
	padding: 2rem 0 1rem;
}

/* ------------------------------------
 CF7
------------------------------------ */
.cf7-your-tel, .cf7-your-due-date, .cf7-your-desired-date, .cf7-your-desired-time {
  width: 100%;
  padding: 10px;
  font-size: 16px;
  border: #dedede 1px solid;
  border-radius: 5px;
  background: #fff;
  box-sizing: border-box;
}

@media not screen and (max-width: 768px) {
  .cf7-your-desired-date {
    width: 55%;
  }
  .cf7-your-desired-time {
    width: 40%;
    margin-left: 5%;
  }
}

.cf7-your-desired-date, .cf7-your-desired-time {
  margin-top: 10px;
}

.wpcf7 input[type="tel"]::placeholder,
input[type="date"]::placeholder {
  color: #bfbfbf;
}

.cf7-your-plan, .cf7-your-style {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cf7-your-plan .wpcf7-list-item, 
.cf7-your-style .wpcf7-list-item {
  display: flex;
  align-items: center;
}

.cf7-your-plan label, 
.cf7-your-style label {
  display: flex;
  align-items: center;
  gap: 0.5em;
  vertical-align: middle;
}

.cf7-your-plan .wpcf7-list-item:nth-of-type(2):after {
  content: "1番人気";
  background-color: #aa75b1;
  display: inline-block;
  margin-left: 10px;
  padding: 1px 10px;
  color: #fff;
  font-size: 15px;
  border-radius: 3px;
  box-sizing: border-box;
}

.cf7-your-plan .wpcf7-list-item:nth-of-type(3):after {
  content: "2番人気";
  background-color: #c8a2cd;
  display: inline-block;
  margin-left: 10px;
  padding: 1px 10px;
  color: #fff;
  font-size: 15px;
  border-radius: 3px;
  box-sizing: border-box;
}

.cf7-your-plan input[type="radio"],
.cf7-your-style input[type="radio"],
.cf7-your-together input[type="checkbox"],
.cf7-your-attendant input[type="checkbox"],
.cf7-your-parking input[type="checkbox"],
input[type="checkbox"].cf7-your-acceptance {
  width: 20px;
  height: 20px;
  transform: scale(1.3);
}

.wpcf7 input[type="radio"]:checked, .wpcf7 input[type="checkbox"]:checked {
  accent-color: #aa75b1;
}

.cf7-your-style {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1em;
}

.cf7-your-style .wpcf7-list-item {
  display: flex;
  align-items: center;
}

.cf7-your-together .wpcf7-list-item,
.cf7-your-attendant .wpcf7-list-item {
  width: 40%;
}

.cf7-your-together .wpcf7-list-item:not(:last-child),
.cf7-your-attendant .wpcf7-list-item,
.cf7-your-parking .wpcf7-list-item {
  margin-bottom: 16px;
}

.cf7-your-together input[type="checkbox"],
.cf7-your-attendant input[type="checkbox"],
.cf7-your-parking input[type="checkbox"],
input[type="checkbox"].cf7-your-acceptance {
  vertical-align: middle;
  margin: 0;
}

.cf7-your-together .wpcf7-list-item-label,
.cf7-your-attendant .wpcf7-list-item-label,
.cf7-your-parking .wpcf7-list-item-label,
input.cf7-your-acceptance + .wpcf7-list-item-label {
  vertical-align: middle;
  margin-left: 10px;
}

.cf7-btn input[type="submit"] {
  display: block;
  position: relative;
  width: 55%;
  margin: 0 auto 1rem;
  padding: 15px 0;
  font-size: 16px;
  text-align: center;
  color: #fff;
  line-height: 1;
  background-color: #aa75b1;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  box-sizing: border-box;
  transition: background-color 0.3s ease, opacity 0.3s ease;
}

.cf7-btn input[type="submit"]:hover:not(:disabled) {
  background-color: #91599e;
  opacity: 0.9;
}

.cf7-btn input[type="submit"]:active {
  background-color: #7b4485;
  opacity: 1;
}

.cf7-btn input[type="submit"]:disabled {
  cursor: not-allowed;
  background-color: #ddd;
  color: #aaa;
  opacity: 1;
}

.cf7-btn .wpcf7-spinner {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border: 2px solid #fff;
  border-top: 2px solid transparent;
  border-radius: 50%;
  animation: spinner-rotate 1s linear infinite;
}

@keyframes spinner-rotate {
  0% {
    transform: translateY(-50%) rotate(0deg);
  }
  100% {
    transform: translateY(-50%) rotate(360deg);
  }
}

/* ------------------------------------
 Gallery Page
------------------------------------ */
.single-gallery .point-title::after, .single-gallery .gallery-wife-title::after, .single-gallery .gallery-man-title::after {
  content: "";
  display: block;
  position: relative;
  width: 40px;
  height: 2px;
  margin: 15px auto 15px;
  padding: 0;
  background: #aa75b1;
  box-sizing: border-box;
}

.single-gallery .point-title, .single-gallery .gallery-wife-title, .single-gallery .gallery-man-title {
	font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
	font-size: 16px;
    font-weight: 700;
}

.single-gallery .gallery-wife-title, .single-gallery .gallery-man-title {
	color: #eb59ac;	
}

@media (min-width: 768px) {
	.single-gallery .point-title, .single-gallery .gallery-wife-title, .single-gallery .gallery-man-title {
	font-size: 24px;		
	}
}