@charset "UTF-8";
 *,
*::before,
*::after {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
font-size: clamp(14px, 1.1vw, 18px);
scroll-behavior: smooth;
}
body {
font-family: "Noto Sans JP", sans-serif;
letter-spacing: 0.1em;
line-height: 1.6;
font-feature-settings: "palt" 1;
text-align: center;
color: #000;
}
img,
picture,
video,
canvas,
svg {
display: block;
width: 100%;
max-width: 100%;
height: auto;
}
a {
color: inherit;
text-decoration: none;
transition: 0.3s;
}
a:hover {
opacity: 0.7;
}
ul,
ol {
list-style: none;
}
button,
input,
select,
textarea {
font: inherit;
color: inherit;
border: none;
background: none;
outline: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
} .wrap {
max-width: 80vw;
margin: 0 auto;
padding: 6rem 0;
}
.wrap_2 {
max-width: 65vw;
margin: 0 auto;
}
.wrap_3 {
max-width: 60vw;
margin: 0 auto;
padding: 6rem 0;
}
.wrap_4 {
max-width: 70vw;
margin: 0 auto;
padding: 6rem 0;
}
.wrap_5 {
max-width: 80vw;
margin: 0 auto;
padding: 2.5rem 0;
}
.wrap_6 {
max-width: 70vw;
margin: 0 auto;
padding: 5rem 0;
}
.wrap_7 {
max-width: 70vw;
margin: 0 auto;
}
.wrap_8 {
max-width: 60vw;
margin: 0 auto;
padding-top: 6rem;
}
.wrap_9 {
max-width: 60vw;
margin: 0 auto;
padding-bottom: 6rem;
}
.anchor-target {
scroll-margin-top: 7rem;
}
.min {
font-family: "Noto Serif JP", serif;
}
.barlow_regular {
font-family: "Barlow Condensed", sans-serif;
font-weight: 400;
font-style: normal;
}
.img_hover {
overflow: hidden;
}
.img_hover img {
transition: 0.4s ease-in-out;
}
.img_hover img:hover {
transform: scale(1.1);
}
.highlight {
color: #0099ff;
} .fade {
opacity: 0;
transition:
opacity 0.9s ease,
transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
transition-delay: var(--delay, 0s);
will-change: opacity, transform;
}
.fade.active {
opacity: 1;
transform: translate(0, 0);
}
.fade-up {
transform: translateY(2rem);
}
.fade-down {
transform: translateY(-2rem);
}
.fade-left {
transform: translateX(2.5rem);
}
.fade-right {
transform: translateX(-2.5rem);
}
.band-slide {
position: relative;
display: block;
overflow: hidden;
opacity: 0;
transform: translateY(1.5rem);
transition:
opacity 0.9s ease,
transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
transition-delay: var(--delay, 0s);
will-change: opacity, transform;
}
.band-slide img {
display: block;
width: 100%;
height: auto;
transform: scale(1.04);
transition: transform 1.2s ease;
}
.band-slide::before {
content: "";
position: absolute;
inset: 0;
z-index: 2;
pointer-events: none;
background: linear-gradient(110deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.78) 50%, rgba(255, 255, 255, 0) 100%);
transform: translateX(-130%);
}
.band-slide.active {
opacity: 1;
transform: translateY(0);
}
.band-slide.active img {
transform: scale(1);
}
.band-slide.active::before {
animation: band-slide-pass 1.2s ease forwards;
animation-delay: calc(var(--delay, 0s) + 0.1s);
}
@keyframes band-slide-pass {
0% {
transform: translateX(-130%);
}
100% {
transform: translateX(130%);
}
}
.text-split {
display: inline-block;
opacity: 1;
}
.text-split span {
display: inline-block;
opacity: 0;
transform: translateY(1rem);
transition:
opacity 0.55s ease,
transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
will-change: opacity, transform;
}
.text-split.active span {
opacity: 1;
transform: translateY(0);
}
.float {
animation: float-gentle 6s ease-in-out infinite;
}
@keyframes float-gentle {
0% {
transform: translateY(0);
}
50% {
transform: translateY(-0.75rem);
}
100% {
transform: translateY(0);
}
}
@media (prefers-reduced-motion: reduce) {
.fade,
.band-slide,
.text-split span,
.float {
animation: none !important;
transition: none !important;
transform: none !important;
}
.fade,
.band-slide,
.text-split,
.text-split span {
opacity: 1 !important;
}
.band-slide::before {
display: none !important;
}
} @media screen and (min-width: 769px) {
.br_sp,
.footer_nav_sp,
.nav_cta,
.footer_action {
display: none;
}
} @media screen and (max-width: 1024px) {
html {
font-size: clamp(14px, 1.6vw, 16px);
}
.wrap,
.wrap_5 {
max-width: 90vw;
}
.wrap_2,
.wrap_3,
.wrap_4,
.wrap_6,
.wrap_7,
.wrap_8,
.wrap_9 {
max-width: 85vw;
}
.wrap,
.wrap_3,
.wrap_4,
.wrap_6 {
padding: 5rem 0;
}
.wrap_5 {
padding: 2rem 0;
}
.wrap_8 {
padding-top: 5rem;
}
.wrap_9 {
padding-bottom: 3rem;
}
.br_pc {
display: none;
}
} @media screen and (max-width: 768px) {
html {
font-size: 16px;
}
body {
letter-spacing: 0.05em;
line-height: 1.7;
}
.wrap,
.wrap_2,
.wrap_3,
.wrap_4,
.wrap_5,
.wrap_6,
.wrap_7,
.wrap_8,
.wrap_9 {
max-width: calc(100% - 2rem);
margin-right: auto;
margin-left: auto;
}
.wrap,
.wrap_3,
.wrap_4,
.wrap_6 {
padding: 2rem 0;
}
.wrap_5 {
padding: 2.5rem 0;
}
.wrap_8 {
padding-top: 4rem;
}
.wrap_9 {
padding: 2rem 0;
}
.br_pc {
display: none;
}
.br_sp {
display: block;
}
.fade-left,
.fade-right {
transform: translateY(2rem);
}
.img_hover img:hover {
transform: none;
}
footer .footer_logo {
width: 70%;
margin: 0 auto 2rem;
}
} .site_header {
position: relative;
}
.site_nav {
position: fixed;
top: 0;
left: 0;
width: 100%;
z-index: 1000;
}
.site_nav .nav_wrap {
position: relative;
margin: 0 auto;
padding: 0.75rem 1.5rem;
background-color: rgba(179, 179, 179, 0.65);
display: flex;
justify-content: space-between;
align-items: center;
}
.site_nav .nav_wrap h1 {
margin: 0;
width: 20%;
flex: 0 1 15%;
box-sizing: border-box;
}
.site_nav .nav_wrap h1 a {
display: block;
}
.site_nav .nav_wrap h1 img {
display: block;
width: 100%;
height: auto;
}
.site_nav .nav_wrap nav {
flex: 1;
}
.site_nav .nav_wrap nav ul {
margin: 0;
padding: 0;
list-style: none;
display: flex;
justify-content: flex-end;
align-items: center;
}
.site_nav .nav_wrap nav ul li {
display: flex;
align-items: center;
}
.site_nav .nav_wrap nav ul li a {
color: #fff;
text-decoration: none;
transition: 0.3s;
}
.site_nav .nav_wrap nav ul li a:hover {
opacity: 0.7;
}
.site_nav .nav_wrap nav ul li + li::before {
content: "｜";
color: #fff;
margin: 0 1rem;
} .main_visual {
position: relative;
background-image: url(//waiwaiservice.com/wp-content/themes/waiwaiservice/img/main.jpg);
background-size: cover;
background-position: center;
background-repeat: no-repeat;
min-height: 75vh;
display: flex;
justify-content: center;
align-items: center;
overflow: hidden; transform: scale(1);
opacity: 0; animation: kvZoom 6s ease forwards;
}
@keyframes kvZoom {
0% {
transform: scale(1);
opacity: 0;
}
20% {
opacity: 1;
}
100% {
transform: scale(1.08);
opacity: 1;
}
}
.main_visual .wrap {
position: relative;
z-index: 1;
width: 100%;
padding: 0 1rem;
box-sizing: border-box;
}
.main_visual .wrap h2 {
margin: 0;
font-size: 300%;
line-height: 1.2;
text-align: center;
color: #fff;
letter-spacing: 0.5rem;
text-shadow:
0 2px 4px rgba(57, 57, 57, 0.6),
0 4px 12px rgba(57, 57, 57, 0.4);
opacity: 0;
transform: translateY(20px);
animation: fadeUp 1s ease 0.9s forwards;
}
@keyframes fadeUp {
to {
opacity: 1;
transform: translateY(0);
}
}
.main_visual .wrap h2 span {
display: block;
margin-bottom: 0.5rem;
font-size: 50%;
line-height: 1.2;
letter-spacing: 0.5rem;
font-weight: normal;
}
body:not(.home) .main_visual {
display: none;
}
body:not(.home) main {
padding-top: 80px;
} .nav-toggle {
display: none;
}
.hamburger {
display: none;
width: 52px;
height: 52px;
border: 1px solid #fff;
border-radius: 50%;
background-color: rgba(255, 255, 255, 0.15);
cursor: pointer;
position: relative;
z-index: 1002;
transition: 0.3s;
}
.hamburger span {
position: absolute;
left: 50%;
width: 20px;
height: 2px;
background: #fff;
border-radius: 2px;
transform: translateX(-50%);
transition: 0.3s;
}
.hamburger span:nth-child(1) {
top: 15px;
}
.hamburger span:nth-child(2) {
top: 21px;
}
.hamburger span:nth-child(3) {
top: 27px;
}
.hamburger::after {
content: "MENU";
position: absolute;
left: 50%;
bottom: 8px;
transform: translateX(-50%);
font-size: 0.5rem;
line-height: 1;
letter-spacing: 0.1em;
color: #fff;
}
.nav-toggle:checked + .hamburger {
background-color: #fff;
border-color: #999;
}
.nav-toggle:checked + .hamburger span {
background: #555;
}
.nav-toggle:checked + .hamburger::after {
content: "CLOSE";
color: #555;
}
.nav-toggle:checked + .hamburger span:nth-child(1) {
top: 21px;
transform: translateX(-50%) rotate(45deg);
}
.nav-toggle:checked + .hamburger span:nth-child(2) {
opacity: 0;
}
.nav-toggle:checked + .hamburger span:nth-child(3) {
top: 21px;
transform: translateX(-50%) rotate(-45deg);
} @media screen and (max-width: 1024px) {
.site_nav .nav_wrap h1 {
flex: 0 0 22%;
width: 22%;
}
.site_nav .nav_wrap nav ul li a {
font-size: 0.9rem;
}
.site_nav .nav_wrap nav ul li + li::before {
margin: 0 0.7rem;
}
.main_visual {
min-height: 72vh;
}
.main_visual .wrap h2 {
font-size: 250%;
}
} @media screen and (max-width: 768px) {
body:not(.home) main {
padding-top: 70px;
}
.site_nav .nav_wrap {
padding: 0.75rem 1rem;
}
.site_nav .nav_wrap h1 {
width: 45%;
flex: none;
position: relative;
z-index: 1002;
}
.site_nav .nav_wrap nav {
display: block;
width: 100%;
position: absolute;
top: 100%;
left: 0;
background-color: #eeeeee;
padding: 1.5rem 1.25rem 2rem;
box-sizing: border-box;
opacity: 0;
visibility: hidden;
pointer-events: none;
transition: 0.3s;
}
.site_nav .nav_wrap nav ul {
flex-direction: column;
justify-content: flex-start;
align-items: center;
width: 100%;
gap: 0.2rem;
}
.site_nav .nav_wrap nav ul li {
width: 100%;
border-top: 1px solid rgba(0, 0, 0, 0.06);
}
.site_nav .nav_wrap nav ul li:first-child {
border-top: none;
}
.site_nav .nav_wrap nav ul li + li::before {
content: none;
}
.site_nav .nav_wrap nav ul li a {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.25rem;
width: 100%;
padding: 1.1rem 0;
color: #333;
text-align: center;
transition:
background-color 0.3s ease,
transform 0.2s ease;
}
.site_nav .nav_wrap nav ul li a:hover {
background-color: rgba(42, 156, 255, 0.05);
}
.site_nav .nav_wrap nav ul li a:active {
transform: scale(0.97);
}
.site_nav .nav_wrap nav ul li .nav_en {
position: relative;
font-family: "Barlow Condensed", sans-serif;
font-size: 0.75rem;
line-height: 1;
letter-spacing: 0.18em;
color: #1e90ff;
}
.site_nav .nav_wrap nav ul li .nav_en::after {
content: "";
display: block;
width: 20px;
height: 1px;
background: #1e90ff;
margin: 0.3rem auto 0;
}
.site_nav .nav_wrap nav ul li .nav_ja {
font-size: 1rem;
line-height: 1.4;
letter-spacing: 0.08em;
}
.site_nav .nav_wrap nav ul li:last-child {
margin-top: 1.2rem;
border-top: none;
display: block;
}
.site_nav .nav_wrap nav ul li:last-child a {
width: min(100%, 270px);
margin: 0 auto;
padding: 0.9rem 1.5rem;
border-radius: 999px;
background: linear-gradient(135deg, #2a9cff, #1e90ff);
color: #fff;
box-shadow: 0 8px 18px rgba(30, 144, 255, 0.25);
transition:
transform 0.3s ease,
box-shadow 0.3s ease;
}
.site_nav .nav_wrap nav ul li:last-child a:hover {
transform: translateY(-2px);
box-shadow: 0 12px 22px rgba(30, 144, 255, 0.35);
}
.site_nav .nav_wrap nav ul li:last-child a:active {
transform: scale(0.97);
}
.site_nav .nav_wrap nav ul li:last-child .nav_en {
color: rgba(255, 255, 255, 0.85);
}
.site_nav .nav_wrap nav ul li:last-child .nav_en::after {
background: rgba(255, 255, 255, 0.8);
}
.site_nav .nav_wrap nav ul li:last-child .nav_ja {
color: #fff;
font-weight: 500;
}
.site_nav .nav_wrap .hamburger {
display: flex;
}
.site_nav .nav_wrap .nav-toggle:checked + .hamburger + nav {
opacity: 1;
visibility: visible;
pointer-events: auto;
}
.main_visual {
min-height: 70vh;
padding: 5rem 0 2rem;
}
.main_visual .wrap h2 {
font-size: 180%;
line-height: 1.4;
letter-spacing: 0.2rem;
}
.main_visual .wrap h2 span {
font-size: 60%;
line-height: 1.4;
letter-spacing: 0.1rem;
}
} footer .footer_contact {
padding: 6rem 0;
}
footer .footer_contact h2 {
width: min(100% - 4rem, 1200px);
margin: 0 auto 4rem;
font-size: 1.1rem;
font-weight: normal;
line-height: 1;
letter-spacing: 0.03em;
color: #4d4d4d;
text-align: center;
}
footer .footer_contact h2 span {
display: block;
margin-top: 0.5rem;
font-size: 3rem;
letter-spacing: 0.18em;
}
footer .footer_contact .contact_tel {
margin-bottom: 2.5rem;
text-align: center;
}
footer .footer_contact .contact_tel a {
display: inline-flex;
flex-direction: column;
align-items: center;
color: #1e90ff;
}
footer .footer_contact .contact_tel .tel_row {
display: flex;
align-items: center;
justify-content: center;
gap: 0.8rem;
}
footer .footer_contact .contact_tel .tel_icon {
width: 3.5rem;
flex-shrink: 0;
}
footer .footer_contact .contact_tel .tel_icon img {
width: 100%;
height: auto;
}
footer .footer_contact .contact_tel strong {
font-size: 3rem;
font-weight: 400;
line-height: 1.1;
letter-spacing: 0.18em;
}
footer .footer_contact .contact_tel small {
margin-top: 0.5rem;
font-size: 0.95rem;
line-height: 1.4;
letter-spacing: 0.08em;
}
footer .footer_contact .contact_btn {
width: min(100% - 4rem, 920px);
margin: 0 auto;
display: flex;
justify-content: center;
gap: 1.5rem;
flex-wrap: wrap;
}
footer .footer_contact .contact_mail,
footer .footer_contact .contact_line {
flex: 1;
min-width: 300px;
max-width: 420px;
}
footer .footer_contact .contact_mail a,
footer .footer_contact .contact_line a {
display: flex;
align-items: center;
justify-content: center;
gap: 1rem;
min-height: 5.5rem;
padding: 1rem 1.5rem;
border: 1px solid #1e90ff;
border-radius: 999px;
background: #fff;
color: #1e90ff;
transition: 0.3s;
}
footer .footer_contact .contact_mail span,
footer .footer_contact .contact_line span {
display: block;
flex-shrink: 0;
width: 3.3rem;
}
footer .footer_contact .contact_mail span img,
footer .footer_contact .contact_line span img {
display: block;
width: 100%;
height: auto;
}
footer .footer_contact .contact_mail p,
footer .footer_contact .contact_line p {
font-size: 1rem;
line-height: 1.5;
letter-spacing: 0.05em;
text-align: left;
color: #1e90ff;
}
footer .footer_content {
background-color: #e6e6e6;
}
footer .footer_content .footer_sns {
display: flex;
justify-content: center;
gap: 2rem;
margin-bottom: 2rem;
}
footer .footer_content .footer_sns a {
display: inline-block;
transition: 0.3s;
}
footer .footer_content .footer_sns a:hover {
opacity: 0.7;
transform: translateY(-2px);
}
footer .footer_content .footer_sns figure {
width: 3.5rem;
}
footer .footer_content .footer_sns img {
width: 100%;
height: auto;
display: block;
}
footer .footer_content .footer_logo {
width: 23%;
max-width: 260px;
min-width: 160px;
margin: 0 auto 2rem;
}
footer .footer_content p {
font-size: 0.8rem;
letter-spacing: 0.04em;
color: #666;
}
footer .footer_content .footer_links {
margin-bottom: 1rem;
text-align: center;
}
footer .footer_content .footer_links a {
font-size: 0.75rem;
color: #666;
letter-spacing: 0.05em;
text-decoration: underline;
}
footer .footer_content .footer_links a:hover {
opacity: 0.7;
}
@media screen and (max-width: 1024px) {
footer .footer_contact {
padding: 5rem 0;
}
footer .footer_contact h2 {
margin-bottom: 3.5rem;
}
footer .footer_contact h2 span {
font-size: 2.6rem;
}
footer .footer_contact .contact_tel strong {
font-size: 2.6rem;
letter-spacing: 0.12em;
}
footer .footer_contact .contact_btn {
width: min(100% - 3rem, 820px);
}
footer .footer_contact .contact_mail,
footer .footer_contact .contact_line {
max-width: 380px;
}
footer .footer_contact .contact_mail a,
footer .footer_contact .contact_line a {
min-height: 5rem;
}
footer .footer_content .footer_logo {
width: 30%;
}
}
@media screen and (max-width: 768px) {
footer .footer_contact {
padding: 2rem 0;
}
footer .footer_contact h2 {
width: min(100% - 2rem, 1200px);
margin-bottom: 3rem;
font-size: 1rem;
line-height: 1.4;
}
footer .footer_contact h2 span {
font-size: 2rem;
letter-spacing: 0.12em;
}
footer .footer_contact .contact_tel {
margin-bottom: 2rem;
}
footer .footer_contact .contact_tel .tel_row {
gap: 0.5rem;
align-items: center;
}
footer .footer_contact .contact_tel .tel_icon {
width: 3rem;
}
footer .footer_contact .contact_tel strong {
font-size: 2.5rem;
}
footer .footer_contact .contact_tel small {
font-size: 0.9rem;
}
footer .footer_contact .contact_btn {
width: min(100% - 2rem, 420px);
flex-direction: column;
gap: 1rem;
}
footer .footer_contact .contact_mail,
footer .footer_contact .contact_line {
width: 100%;
min-width: 0;
max-width: none;
}
footer .footer_contact .contact_mail a,
footer .footer_contact .contact_line a {
min-height: 4.8rem;
padding: 0.9rem 1rem;
}
footer .footer_contact .contact_mail span,
footer .footer_contact .contact_line span {
width: 3rem;
}
footer .footer_contact .contact_mail p,
footer .footer_contact .contact_line p {
font-size: 0.9rem;
line-height: 1.5;
}
footer .footer_content .footer_sns {
gap: 1.5rem;
margin-bottom: 1.5rem;
}
footer .footer_content .footer_sns figure {
width: 3rem;
}
footer .footer_content .footer_logo {
width: 55%;
min-width: 0;
max-width: 260px;
margin-bottom: 1.5rem;
}
footer .footer_content p {
font-size: 0.7rem;
}
footer .footer_content .footer_links {
margin-bottom: 0.8rem;
}
footer .footer_content .footer_links a {
font-size: 0.7rem;
}
} .section_policy,
.section_concerns,
.section_serviceprice,
.section_area,
.section_faq,
.section_info {
padding: 6rem 0;
}
.section_policy h2,
.section_concerns h2,
.section_serviceprice h2,
.section_area h2,
.section_faq h2,
.section_info h2 {
width: min(100% - 4rem, 1200px);
margin: 0 auto 4rem;
font-weight: normal;
letter-spacing: 0.03em;
color: #4d4d4d;
}
.section_serviceprice h2,
.section_area h2,
.section_faq h2,
.section_info h2 {
font-size: 1.1rem;
line-height: 1;
}
.section_serviceprice h2 span,
.section_area h2 span,
.section_faq h2 span,
.section_info h2 span {
display: block;
margin-top: 0.5rem;
font-size: 3rem;
letter-spacing: 0.18em;
} .section_policy {
overflow: hidden;
}
.section_policy h2 {
font-size: 0.8rem;
line-height: 0.9;
text-align: left;
}
.section_policy h2 span {
display: block;
margin-top: 0.5rem;
font-size: 2.5rem;
letter-spacing: 0.18em;
}
.section_policy .policy_content,
.section_policy .policy_content_2 {
width: min(100% - 4rem, 1200px);
margin: 0 auto;
display: grid;
gap: 2.5rem;
align-items: center;
position: relative;
}
.section_policy .policy_content {
grid-template-columns: 1fr 30rem;
margin-bottom: 6rem;
}
.section_policy .policy_content > p {
justify-self: end;
width: min(100%, 25rem);
margin: 0;
}
.section_policy .policy_content_2 {
grid-template-columns: 25rem 1fr;
}
.section_policy .policy_content_2 > p {
order: 1;
margin: 0;
}
.section_policy .policy_content_2 .policy_content_text {
order: 2;
position: relative;
padding-top: 2rem;
}
.section_policy .policy_content_2 .policy_main_image {
width: min(100%, 25rem);
margin-left: calc((35vw - min(100% - 4rem, 1200px)) / -2);
}
.section_policy .policy_content_text {
max-width: 34rem;
text-align: left;
}
.section_policy .policy_content_text h3 {
margin-bottom: 2rem;
font-size: 3.125rem;
font-weight: 500;
line-height: 1.42;
}
.section_policy .policy_content_text p {
font-size: 1rem;
line-height: 2.2;
color: #222;
}
.section_policy .policy_content > p img,
.section_policy .policy_content_2 > p img {
display: block;
width: 100%;
aspect-ratio: 4 / 5;
object-fit: cover;
box-shadow: 0 1.5rem 3rem rgba(0, 0, 0, 0.08);
}
.section_policy .policy_sub_image {
position: absolute;
top: -2rem;
right: -18rem;
width: 24rem;
margin: 0;
z-index: 2;
}
.section_policy .policy_sub_image img {
width: 100%;
aspect-ratio: 16 / 9;
object-fit: cover;
box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.08);
} .section_concerns {
background-color: #dde6f5;
}
.section_concerns h2 {
font-size: 2.5rem;
line-height: 0.7;
}
.section_concerns h2 span {
display: block;
margin-top: 0.5rem;
font-size: 1.3rem;
letter-spacing: 0.18em;
}
.section_concerns .concerns_content {
width: min(100% - 4rem, 1200px);
margin: 0 auto;
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 2rem;
}
.section_concerns .concerns_content .concerns_content_box {
background: #fff;
padding: 1.3rem;
display: flex;
gap: 1.5rem;
align-items: center;
border-radius: 1rem;
}
.section_concerns .concerns_content .concerns_content_box > p {
flex: 0 0 30%;
margin: 0;
}
.section_concerns .concerns_content .concerns_content_box .concerns_content_box_text {
flex: 1;
}
.section_concerns .concerns_content .concerns_content_box .concerns_content_box_text h3 {
font-size: 1.8rem;
color: #0099ff;
border-bottom: 3px solid #dde6f5;
margin-bottom: 1rem;
}
.section_concerns .concerns_content .concerns_content_box .concerns_content_box_text p {
font-size: 1.3rem;
} .section_serviceprice .service_content {
width: min(100% - 4rem, 1200px);
margin: 0 auto 6rem;
display: flex;
gap: 2rem;
}
.section_serviceprice .service_content .service_box {
display: block;
text-decoration: none;
color: inherit;
flex: 1;
}
.section_serviceprice .service_content .service_box:hover {
opacity: 0.8;
}
.section_serviceprice .service_content .service_box p {
margin-bottom: 0.5rem;
}
.section_serviceprice .service_content .service_box h3 {
font-weight: normal;
}
.section_serviceprice .price_content {
width: min(100% - 4rem, 1000px);
margin: 0 auto;
}
.section_serviceprice .price_content table {
width: 100%;
border-collapse: separate;
margin-bottom: 1rem;
}
.section_serviceprice .price_content thead,
.section_serviceprice .price_content tbody {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 0.75rem;
margin-bottom: 0.75rem;
}
.section_serviceprice .price_content tr {
display: contents;
}
.section_serviceprice .price_content th,
.section_serviceprice .price_content td {
text-align: center;
padding: 1.3rem 1rem;
}
.section_serviceprice .price_content th {
background: #dde6f5;
font-size: 1rem;
color: #4d4d4d;
}
.section_serviceprice .price_content td {
background: #e6e6e6;
font-size: 1.25rem;
color: #4d4d4d;
}
.section_serviceprice .price_content p {
text-align: left;
font-size: 0.9rem;
line-height: 2;
} .section_area {
background-color: #dde6f5;
}
.section_area .area_content {
width: min(100% - 4rem, 1000px);
margin: 0 auto;
text-align: center;
}
.section_area .area_content h3 {
font-size: 1.4rem;
font-weight: normal;
margin-bottom: 1rem;
}
.section_area .area_content figure {
margin-bottom: 2rem;
}
.section_area .area_content p {
width: 75%;
margin: 0 auto;
} .section_faq .faq_content {
width: min(100% - 4rem, 1000px);
margin: 0 auto;
border: 0.0625rem solid #d9d9d9;
}
.section_faq .faq_item.is-open .faq_icon::after {
opacity: 0;
transform: translate(-50%, -50%) rotate(90deg);
}
.section_faq .faq_item.is-open .faq_question::after {
opacity: 0;
}
.section_faq .faq_item.is-open .faq_answer_inner {
opacity: 1;
transform: translateY(0);
}
.section_faq .faq_question {
width: 100%;
background: transparent;
border: none;
cursor: pointer;
padding: 1.625rem 2.125rem 1.625rem 1.875rem;
display: flex;
justify-content: space-between;
align-items: center;
text-align: left;
position: relative;
}
.section_faq .faq_question span:first-child {
font-size: 1rem;
color: #4d4d4d;
line-height: 1.7;
padding-right: 1.25rem;
}
.section_faq .faq_question::after {
content: "";
position: absolute;
left: 1.875rem;
right: 1.875rem;
bottom: 0;
border-bottom: 0.0625rem dotted #9d9d9d;
transition: opacity 0.3s ease;
}
.section_faq .faq_item:last-child .faq_question::after {
display: none;
}
.section_faq .faq_icon {
width: 1.5rem;
height: 1.5rem;
min-width: 1.5rem;
border-radius: 50%;
background: #b3b3b3;
position: relative;
}
.section_faq .faq_icon::before,
.section_faq .faq_icon::after {
content: "";
position: absolute;
background: #fff;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
transition:
opacity 0.3s ease,
transform 0.35s ease;
}
.section_faq .faq_icon::before {
width: 0.625rem;
height: 0.125rem;
}
.section_faq .faq_icon::after {
width: 0.125rem;
height: 0.625rem;
}
.section_faq .faq_answer {
height: 0;
overflow: hidden;
transition: height 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.section_faq .faq_answer_inner {
padding: 1.25rem 1.875rem 1.5rem;
opacity: 0;
transform: translateY(-0.5rem);
transition:
opacity 0.35s ease,
transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.section_faq .faq_answer_inner p {
margin: 0;
font-size: 1rem;
line-height: 1.9;
color: #0099ff;
text-align: left;
} .section_info {
background-color: #dde6f5;
}
.section_info .info_content {
width: min(100% - 4rem, 1200px);
margin: 0 auto 5rem;
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 5rem;
}
.section_info .info_content .info_content_box a {
color: inherit;
text-decoration: none;
}
.section_info .info_content .info_content_box figure {
width: 100%;
aspect-ratio: 4 / 3;
overflow: hidden;
margin: 0 0 0.75rem;
background: #f5f5f5;
}
.section_info .info_content .info_content_box figure img {
width: 100% !important;
height: 100% !important;
max-width: none;
object-fit: cover;
display: block;
}
.section_info .info_content .info_content_box time {
display: block;
text-align: left;
font-size: 0.9rem;
border-bottom: 1px solid #cccccc;
margin-bottom: 0.3rem;
}
.section_info .info_content .info_content_box h3 {
text-align: left;
font-size: 1rem;
font-weight: normal;
}
.section_info .info_btn a.btn_10 {
display: flex;
justify-content: center;
align-items: center;
width: 300px;
height: 50px;
box-sizing: border-box;
background: transparent;
position: relative;
margin: 0 auto;
text-decoration: none;
}
.section_info .info_btn a.btn_10 span {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
height: 50px;
background: #fff;
box-sizing: border-box;
color: #4d4d4d;
font-size: 1rem;
letter-spacing: 0.1em;
text-decoration: none;
box-shadow:
0px 5px 12px #cad4e2,
-6px -6px 12px #fff;
border-radius: 10px;
position: absolute;
top: -5px;
left: 0;
transition-duration: 0.2s;
}
.section_info .info_btn a.btn_10:hover span {
top: 0;
left: 0;
box-shadow:
0 0 4px #cad4e2,
-2px -2px 4px #fff;
} @media screen and (max-width: 1024px) {
.section_policy .policy_content {
grid-template-columns: 1fr 24rem;
gap: 3rem;
}
.section_policy .policy_content_2 {
grid-template-columns: 24rem 1fr;
}
.section_policy .policy_content_2 .policy_main_image {
margin-left: -2rem;
width: min(100%, 22rem);
}
.section_policy .policy_content_text h3 {
font-size: 2.5rem;
}
.section_policy .policy_sub_image {
top: -3rem;
right: -2rem;
width: 12rem;
}
.section_serviceprice .service_content {
gap: 1.5rem;
}
.section_info .info_content {
gap: 2rem;
}
.section_area .area_content p {
width: 90%;
}
} @media screen and (max-width: 768px) {
.section_policy,
.section_concerns,
.section_serviceprice,
.section_area,
.section_faq,
.section_info {
padding: 2rem 0;
}
.section_policy h2,
.section_concerns h2,
.section_serviceprice h2,
.section_area h2,
.section_faq h2,
.section_info h2 {
width: min(100% - 2rem, 1200px);
margin-bottom: 2rem;
}
.section_serviceprice h2,
.section_area h2,
.section_faq h2,
.section_info h2 {
font-size: 1rem;
line-height: 1.2;
}
.section_serviceprice h2 span,
.section_area h2 span,
.section_faq h2 span,
.section_info h2 span {
font-size: 2rem;
}
.section_policy h2 {
font-size: 1rem;
}
.section_policy h2 span {
font-size: 2rem;
}
.section_policy .policy_content,
.section_policy .policy_content_2 {
width: min(100% - 2rem, 1200px);
grid-template-columns: 1fr;
gap: 2rem;
}
.section_policy .policy_content {
margin-bottom: 2rem;
}
.section_policy .policy_content > p {
justify-self: center;
}
.section_policy .policy_content_2 > p {
order: 2;
}
.section_policy .policy_content_2 .policy_content_text {
order: 1;
padding-top: 0;
}
.section_policy .policy_content_2 .policy_content_text h3 {
margin-top: 0;
}
.section_policy .policy_content_2 .policy_main_image {
margin-left: 0;
justify-self: center;
}
.section_policy .policy_content_text {
max-width: none;
}
.section_policy .policy_content_text h3 {
font-size: 2rem;
line-height: 1.5;
}
.section_policy .policy_content_text p {
font-size: 0.9375rem;
}
.section_policy .policy_content_text p br {
display: none;
}
.section_policy .policy_sub_image {
position: static;
width: min(100%, 15rem);
margin: 0 auto;
margin-bottom: 2rem;
}
.section_policy .target_img { margin-right: calc(50% - 50vw);
}
.section_policy .target_img img {
width: 100%;
display: block;
}
.section_concerns h2 {
font-size: 1.6rem;
line-height: 1.2;
}
.section_concerns h2 span {
font-size: 1.2rem;
margin-bottom: 0.5rem;
}
.section_concerns .concerns_content {
width: min(100% - 2rem, 1200px);
grid-template-columns: 1fr;
}
.section_concerns .concerns_content .concerns_content_box {
padding: 1rem;
gap: 1rem;
display: block;
}
.section_concerns .concerns_content .concerns_content_box > p {
max-width: 55%;
margin: 0 auto 1rem;
}
.section_concerns .concerns_content .concerns_content_box .concerns_content_box_text h3 {
font-size: 1.3rem;
}
.section_concerns .concerns_content .concerns_content_box .concerns_content_box_text p {
font-size: 1.1rem;
line-height: 1.6;
}
.section_serviceprice .service_content {
width: min(100% - 2rem, 1200px);
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 1.5rem;
margin-bottom: 4rem;
}
.section_serviceprice .service_content .service_box h3 {
font-size: 1rem;
text-align: center;
}
.section_serviceprice .price_content {
width: min(100% - 2rem, 1000px);
}
.section_serviceprice .price_content table {
display: grid;
grid-template-columns: 1fr;
gap: 0.75rem;
}
.section_serviceprice .price_content thead,
.section_serviceprice .price_content tbody,
.section_serviceprice .price_content tr {
display: contents;
}
.section_serviceprice .price_content th,
.section_serviceprice .price_content td {
padding: 1rem;
}
.section_serviceprice .price_content th:nth-child(1) {
order: 1;
}
.section_serviceprice .price_content td:nth-child(1) {
order: 2;
}
.section_serviceprice .price_content th:nth-child(2) {
order: 3;
}
.section_serviceprice .price_content td:nth-child(2) {
order: 4;
}
.section_serviceprice .price_content th:nth-child(3) {
order: 5;
}
.section_serviceprice .price_content td:nth-child(3) {
order: 6;
}
.section_serviceprice .price_content p {
font-size: 0.85rem;
line-height: 1.8;
}
.section_area .area_content {
width: min(100% - 2rem, 1000px);
margin: 0 auto;
}
.section_area .area_content h3 {
font-size: 1.2rem;
margin-bottom: 1.5rem;
}
.section_area .area_content figure {
width: 100vw;
margin-left: calc(50% - 50vw);
margin-bottom: 2rem;
}
.section_area .area_content p {
width: calc(100vw - 1rem);
margin-left: calc(50% - 50vw + 0.5rem);
}
.section_faq .faq_content {
width: min(100% - 2rem, 1000px);
}
.section_faq .faq_question {
padding: 1.25rem 1rem;
}
.section_faq .faq_question span:first-child {
font-size: 0.9375rem;
line-height: 1.6;
padding-right: 0.875rem;
}
.section_faq .faq_question::after {
left: 1rem;
right: 1rem;
}
.section_faq .faq_icon {
width: 1.375rem;
height: 1.375rem;
min-width: 1.375rem;
}
.section_faq .faq_answer_inner {
padding: 1rem 1rem 1.125rem;
}
.section_faq .faq_answer_inner p {
font-size: 0.875rem;
line-height: 1.8;
}
.section_info .info_content {
width: auto;
display: flex;
gap: 1.5rem;
overflow-x: auto;
padding: 0 1rem 1rem;
margin-bottom: 3rem;
scroll-snap-type: x mandatory;
-webkit-overflow-scrolling: touch;
}
.section_info .info_content .info_content_box {
flex: 0 0 85%;
scroll-snap-align: start;
}
.section_info .info_content::-webkit-scrollbar {
height: 6px;
}
.section_info .info_content::-webkit-scrollbar-track {
background: rgba(255, 255, 255, 0.6);
border-radius: 999px;
}
.section_info .info_content::-webkit-scrollbar-thumb {
background: #aebedb;
border-radius: 999px;
}
.section_info .info_btn a.btn_10 {
width: 220px;
}
} .p_service {
margin-top: 0;
}
.p_service h1 {
width: min(100% - 4rem, 1200px);
margin: 0 auto 4rem;
font-size: 1.1rem;
font-weight: normal;
line-height: 1;
letter-spacing: 0.03em;
color: #4d4d4d;
}
.p_service h1 span {
display: block;
margin-top: 0.5rem;
font-size: 3rem;
letter-spacing: 0.18em;
}
.p_service .p_service_box ul {
display: grid;
grid-template-columns: repeat(5, 1fr);
gap: 1rem;
list-style: none;
padding: 0;
margin: 0;
}
.p_service .p_service_box li {
border: 1px solid #4d4d4d;
}
.p_service .p_service_box a {
display: block;
padding: 1rem 1.5rem;
text-decoration: none;
color: #333;
position: relative;
overflow: hidden;
transition: color 0.3s;
text-align: center;
}
.p_service .p_service_box a::before {
content: "";
position: absolute;
inset: 0;
background: #2a9cff;
transform: translateY(100%);
transition: transform 0.3s ease;
z-index: 0;
}
.p_service .p_service_box a span {
position: relative;
z-index: 1;
}
.p_service .p_service_box a:hover {
color: #fff;
}
.p_service .p_service_box a:hover::before {
transform: translateY(0);
}
.p_service_content {
border-bottom: 1px solid #b3b3b3;
}
.p_service_content .p_service_content_box {
margin-bottom: 10rem;
text-align: center;
}
.p_service_content .p_service_content_box h2 {
background: #dde6f5;
padding: 0.5rem 1rem;
margin-bottom: 1.5rem;
font-weight: normal;
font-size: 1.6rem;
}
.p_service_content .p_service_content_box figure {
margin-bottom: 2rem;
}
.p_service_content .p_service_content_box h3 {
font-size: 1.4rem;
margin-bottom: 2rem;
line-height: 1.8;
}
.p_service_content .p_service_content_box p {
font-size: 1.2rem;
line-height: 2;
}
.p_service_content .service_detail {
max-width: 760px;
margin: 5rem auto 0;
padding: 2.5rem 2rem;
text-align: center;
background: #fff;
}
.p_service_content .service_detail h4 {
display: inline-block;
position: relative;
margin: 0 0 3rem;
padding: 0 2.5rem;
font-size: 1.3rem;
font-weight: normal;
color: #4d4d4d;
letter-spacing: 0.08em;
}
.p_service_content .service_detail h4::before,
.p_service_content .service_detail h4::after {
content: "";
position: absolute;
top: 50%;
width: 2rem;
height: 1px;
background: #b3b3b3;
}
.p_service_content .service_detail h4::before {
left: 0;
}
.p_service_content .service_detail h4::after {
right: 0;
}
.p_service_content .service_detail .service_detail_box {
display: flex;
justify-content: center;
gap: 2rem; }
.p_service_content .service_detail .service_detail_box .circle_text {
width: clamp(120px, 18vw, 150px);
aspect-ratio: 1 / 1;
border-radius: 50%;
background-color: #dde6f5;
display: flex;
justify-content: center;
align-items: center;
text-align: center;
padding: 1rem;
box-sizing: border-box;
font-size: 1.05rem;
line-height: 1.5;
font-weight: bold;
color: #333;
}
.p_service_content small {
font-size: 0.9rem;
margin: 2rem auto 0;
display: block;
line-height: 1.5; }
#souji,
#ryouri,
#sentaku,
#kurashi,
#kosodate {
padding-top: 120px;
margin-top: -120px;
}
@media screen and (max-width: 1024px) {
.p_service h1 {
width: min(100% - 3rem, 1200px);
margin-bottom: 3.5rem;
}
.p_service h1 span {
font-size: 2.6rem;
}
.p_service .p_service_box ul {
grid-template-columns: repeat(3, 1fr);
}
.p_service .p_service_box a {
padding: 1rem;
font-size: 0.95rem;
}
.p_service_content .p_service_content_box {
margin-bottom: 8rem;
}
.p_service_content .p_service_content_box h2 {
font-size: 1.6rem;
}
.p_service_content .p_service_content_box h3 {
font-size: 1.25rem;
}
.p_service_content .p_service_content_box p {
font-size: 1rem;
}
.p_service_content .service_detail {
margin-top: 4rem;
padding: 2.2rem 1.5rem;
}
.p_service_content .service_detail .service_detail_box {
gap: 1.5rem;
}
.p_service_content .service_detail .service_detail_box .circle_text {
width: 140px;
font-size: 1rem;
}
}
@media screen and (max-width: 768px) {
#souji,
#ryouri,
#sentaku,
#kurashi,
#kosodate {
padding-top: 80px;
margin-top: -80px;
}
.p_service h1 {
width: min(100% - 2rem, 1200px);
margin-bottom: 3rem;
font-size: 1rem;
line-height: 1.4;
}
.p_service h1 span {
font-size: 2rem;
letter-spacing: 0.12em;
}
.p_service .p_service_box ul {
grid-template-columns: repeat(2, 1fr);
gap: 0.8rem;
}
.p_service .p_service_box a {
padding: 0.9rem 1rem;
font-size: 0.95rem;
}
.p_service_content .p_service_content_box {
margin-bottom: 5rem;
}
.p_service_content .p_service_content_box h2 {
font-size: 1.2rem;
padding: 0.6rem 1rem;
margin-bottom: 1.2rem;
}
.p_service_content .p_service_content_box figure {
margin-bottom: 1.5rem;
}
.p_service_content .p_service_content_box h3 {
font-size: 1.1rem;
line-height: 1.8;
margin-bottom: 1.5rem;
}
.p_service_content .p_service_content_box p {
font-size: 0.95rem;
line-height: 1.9;
text-align: left;
}
.p_service_content .service_detail {
width: 100%;
margin-top: 3rem;
padding: 2rem 1rem;
box-sizing: border-box;
}
.p_service_content .service_detail h4 {
margin-bottom: 1.8rem;
padding: 0 2rem;
font-size: 1.1rem;
}
.p_service_content .service_detail h4::before,
.p_service_content .service_detail h4::after {
width: 1.4rem;
}
.p_service_content .service_detail .service_detail_box {
gap: 1rem;
}
.p_service_content .service_detail .service_detail_box .circle_text {
width: 100px;
font-size: 0.75rem;
padding: 0.7rem;
}
.p_service_content small {
width: 100%;
font-size: 0.8rem;
line-height: 1.7;
}
}
@media screen and (max-width: 480px) {
.p_service .p_service_box ul {
grid-template-columns: 1fr;
}
} .p_company {
margin-top: 0;
}
.p_company h1 {
width: min(100% - 4rem, 1200px);
margin: 0 auto;
font-size: 1.1rem;
font-weight: normal;
line-height: 1;
letter-spacing: 0.03em;
color: #4d4d4d;
}
.p_company h1 span {
display: block;
margin-top: 0.5rem;
font-size: 3rem;
letter-spacing: 0.18em;
}
.p_company_content {
border-bottom: 1px solid #b3b3b3;
}
.p_company_content .p_company_content_box {
margin-bottom: 10rem;
}
.p_company_content .p_company_content_box h2 {
background: #dde6f5;
padding: 0.5rem 1rem;
margin-bottom: 1.5rem;
font-weight: normal;
font-size: 1.6rem;
}
.p_company_content .p_company_content_box .company_table dl {
margin: 0;
text-align: left;
}
.p_company_content .p_company_content_box .company_table dl > div {
display: flex;
border-bottom: 1px dotted #b3b3b3;
padding: 1rem 0;
}
.p_company_content .p_company_content_box .company_table dt {
width: 30%;
padding-left: 2rem;
font-weight: normal;
}
.p_company_content .p_company_content_box .company_table dd {
width: 70%;
margin: 0;
}
.p_company_content .p_company_content_box .map_wrap {
width: clamp(280px, 90%, 700px);
aspect-ratio: 16 / 9;
margin: 3rem auto 0;
}
.p_company_content .p_company_content_box .map_wrap iframe {
width: 100%;
height: 100%;
display: block;
}
.p_company_content .p_company_content_box .staff {
display: flex;
gap: 2rem;
}
.p_company_content .p_company_content_box .staff figure {
flex: 0 1 30%;
}
.p_company_content .p_company_content_box .staff p {
flex: 1;
text-align: left;
font-size: 1rem;
line-height: 2;
}
@media screen and (max-width: 1024px) {
.p_company h1 {
width: min(100% - 3rem, 1200px);
}
.p_company h1 span {
font-size: 2.6rem;
}
.p_company_content .p_company_content_box {
margin-bottom: 8rem;
}
.p_company_content .p_company_content_box h2 {
font-size: 1.6rem;
}
.p_company_content .p_company_content_box .company_table dt {
width: 35%;
padding-left: 1.5rem;
}
.p_company_content .p_company_content_box .company_table dd {
width: 65%;
}
.p_company_content .p_company_content_box .staff {
gap: 1.5rem;
}
.p_company_content .p_company_content_box .staff figure {
flex: 0 1 35%;
}
.p_company_content .p_company_content_box .staff p {
font-size: 1rem;
}
}
@media screen and (max-width: 768px) {
.p_company h1 {
width: min(100% - 2rem, 1200px);
margin-bottom: 2rem;
font-size: 1rem;
line-height: 1.4;
}
.p_company h1 span {
font-size: 2rem;
letter-spacing: 0.12em;
}
.p_company_content .p_company_content_box {
margin-bottom: 5rem;
}
.p_company_content .p_company_content_box h2 {
font-size: 1.2rem;
padding: 0.6rem 1rem;
margin-bottom: 1.2rem;
}
.p_company_content .p_company_content_box .company_table dl > div {
flex-direction: column;
padding: 0.9rem 0;
}
.p_company_content .p_company_content_box .company_table dt {
width: 100%;
padding-left: 0;
margin-bottom: 0.3rem;
font-size: 0.85rem;
color: #666;
}
.p_company_content .p_company_content_box .company_table dd {
width: 100%;
font-size: 0.95rem;
line-height: 1.7;
}
.p_company_content .p_company_content_box .map_wrap {
width: 100%;
margin-top: 2rem;
}
.p_company_content .p_company_content_box .staff {
flex-direction: column;
gap: 1.5rem;
}
.p_company_content .p_company_content_box .staff figure {
width: 70%;
margin: 0 auto;
}
.p_company_content .p_company_content_box .staff p {
font-size: 0.95rem;
line-height: 1.9;
text-align: left;
}
} .p_contact {
margin-top: 0;
}
.p_contact h1 {
width: min(100% - 4rem, 1200px);
margin: 0 auto;
font-size: 1.1rem;
font-weight: normal;
line-height: 1;
letter-spacing: 0.03em;
color: #4d4d4d;
padding-top: 2rem;
}
.p_contact h1 span {
display: block;
margin-top: 0.5rem;
font-size: 2.6rem;
letter-spacing: 0.18em;
}
.p_contact_content {
border-bottom: 1px solid #b3b3b3;
}
@media screen and (max-width: 768px) {
.p_contact h1 {
width: min(100% - 2rem, 1200px);
margin-bottom: 3rem;
font-size: 1rem;
}
.p_contact h1 span {
font-size: 2rem;
}
} .p_privacy {
margin-top: 0;
}
.p_privacy h1 {
width: min(100% - 4rem, 1200px);
margin: 0 auto;
font-size: 1rem;
font-weight: normal;
line-height: 1;
letter-spacing: 0.03em;
color: #4d4d4d;
}
.p_privacy h1 span {
display: block;
margin-top: 0.5rem;
font-size: 2rem;
letter-spacing: 0.18em;
}
.p_privacy_content {
border-bottom: 1px solid #b3b3b3;
}
.p_privacy_content .p_privacy_content_box {
margin-bottom: 10rem;
}
.p_privacy_content .p_privacy_content_box .privacy_table dl {
margin: 0;
text-align: left;
}
.p_privacy_content .p_privacy_content_box .privacy_table dl > div {
display: flex;
border-bottom: 1px dotted #b3b3b3;
padding: 1rem 0;
}
.p_privacy_content .p_privacy_content_box .privacy_table dt {
width: 35%;
padding-left: 2rem;
font-weight: normal;
color: #000;
}
.p_privacy_content .p_privacy_content_box .privacy_table dd {
width: 65%;
margin: 0;
color: #000;
line-height: 1.8;
}
.p_privacy_content .p_privacy_content_box .privacy_table dd small {
display: block;
margin-top: 0.3rem;
font-size: 0.8rem;
color: #666;
}
@media screen and (max-width: 1024px) {
.p_privacy h1 {
width: min(100% - 3rem, 1200px);
}
.p_privacy h1 span {
font-size: 1.8rem;
}
.p_privacy_content .p_privacy_content_box {
margin-bottom: 8rem;
}
.p_privacy_content .p_privacy_content_box .privacy_table dt {
width: 40%;
padding-left: 1.5rem;
}
.p_privacy_content .p_privacy_content_box .privacy_table dd {
width: 60%;
}
}
@media screen and (max-width: 768px) {
.p_privacy h1 {
width: min(100% - 2rem, 1200px);
margin-bottom: 3rem;
font-size: 1rem;
line-height: 1.4;
}
.p_privacy h1 span {
font-size: 1.2rem;
letter-spacing: 0.12em;
line-height: 1.5;
}
.p_privacy_content .p_privacy_content_box {
margin-bottom: 5rem;
}
.p_privacy_content .p_privacy_content_box .privacy_table dl > div {
flex-direction: column;
padding: 0.9rem 0;
}
.p_privacy_content .p_privacy_content_box .privacy_table dt {
width: 100%;
padding-left: 0;
margin-bottom: 0.3rem;
font-size: 0.85rem;
color: #666;
}
.p_privacy_content .p_privacy_content_box .privacy_table dd {
width: 100%;
font-size: 0.95rem;
line-height: 1.7;
}
.p_privacy_content .p_privacy_content_box .privacy_table dd small {
font-size: 0.75rem;
}
} .p_archive {
margin-top: 0;
}
.p_archive h1 {
width: min(100% - 4rem, 1200px);
margin: 0 auto;
font-size: 1.1rem;
font-weight: normal;
line-height: 1;
letter-spacing: 0.03em;
color: #4d4d4d;
}
.p_archive h1 span {
display: block;
margin-top: 0.5rem;
font-size: 3rem;
letter-spacing: 0.18em;
}
@media screen and (max-width: 768px) {
.p_archive h1 {
width: min(100% - 2rem, 1200px);
margin-bottom: 3rem;
font-size: 1rem;
line-height: 1.4;
}
.p_archive h1 span {
font-size: 2rem;
letter-spacing: 0.12em;
}
}  html,
body {
overflow-x: hidden;
} .main_visual {
position: relative;
background-image: url(//waiwaiservice.com/wp-content/themes/waiwaiservice/img/main.jpg);
background-size: cover;
background-position: center;
background-repeat: no-repeat;
min-height: 75vh;
display: flex;
justify-content: center;
align-items: center;
overflow: hidden; animation: none;
opacity: 1;
transform: none;
} @media screen and (max-width: 768px) {
.section_area .area_content figure {
width: 100%;
margin-left: 0;
}
.section_area .area_content p {
width: 100%;
margin: 0 auto;
}
.section_policy .target_img {
margin-right: 0;
}
.main_visual .wrap h2,
.main_visual .wrap h2 span {
max-width: 100%;
overflow-wrap: break-word;
}
}