@charset "UTF-8";
/**  Mixins */ /*------------------------------------*\
    breakpoint vars
\*------------------------------------*/
/*------------------------------------*\
    breakpoint mixin
\*------------------------------------*/
/** Break desktop first**/
/** Global **/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif:wght@300;400;600;700&display=swap");
@font-face {
    font-family: "HiraMinPro";
    src: url("../fonts/HiraMinPro-W3/HiraMinPro-W3.eot");
    src: url("../fonts/HiraMinPro-W3/HiraMinPro-W3.eot?#iefix") format("embedded-opentype"), url("../fonts/HiraMinPro-W3/HiraMinPro-W3.woff2") format("woff2"), url("../fonts/HiraMinPro-W3/HiraMinPro-W3.woff") format("woff"), url("../fonts/HiraMinPro-W3/HiraMinPro-W3.ttf") format("truetype");
    font-weight: 300;
}
@font-face {
    font-family: "HiraMinPro";
    src: url("../fonts/HiraMinPro-W6/HiraMinPro-W6.eot");
    src: url("../fonts/HiraMinPro-W6/HiraMinPro-W6.eot?#iefix") format("embedded-opentype"), url("../fonts/HiraMinPro-W6/HiraMinPro-W6.woff2") format("woff2"), url("../fonts/HiraMinPro-W6/HiraMinPro-W6.woff") format("woff"), url("../fonts/HiraMinPro-W6/HiraMinPro-W6.ttf") format("truetype");
    font-weight: 600;
}
*,
*::before,
*::after {
    box-sizing: border-box;
}
video{
    width: 70%;
    text-align: right; /* カラム内の要素を右寄せ */
    overflow: hidden;
    float: right;
}
.plan-banner__image video{
    /* margin-bottom: 50px; */
    width: 100%;
    padding: 10px;
}
html {
    font-family: sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.container{
 margin: 10px 0;
}

article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
    display: block;
}
body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
}

[tabindex="-1"]:focus {
    outline: 0 !important;
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin-top: 0;
    margin-bottom: 0.5rem;
}

p {
    margin-top: 0;
    margin-bottom: 1rem;
}

abbr[title],
abbr[data-original-title] {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
    cursor: help;
    border-bottom: 0;
    -webkit-text-decoration-skip-ink: none;
    text-decoration-skip-ink: none;
}

address {
    margin-bottom: 1rem;
    font-style: normal;
    line-height: inherit;
}

ol,
ul,
dl {
    margin-top: 0;
    margin-bottom: 1rem;
}

ol ol,
ul ul,
ol ul,
ul ol {
    margin-bottom: 0;
}

dt {
    font-weight: 700;
}

dd {
    margin-bottom: 0.5rem;
    margin-left: 0;
}

blockquote {
    margin: 0 0 1rem;
}

b,
strong {
    font-weight: 600;
}

small {
    font-size: 80%;
}

sub,
sup {
    position: relative;
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

a {
    color: #6096c4;
    text-decoration: none;
}
a:hover {
    opacity: 0.8;
}

a:not([href]):not([tabindex]) {
    color: inherit;
    text-decoration: none;
}

a:not([href]):not([tabindex]):hover,
a:not([href]):not([tabindex]):focus {
    color: inherit;
    text-decoration: none;
}

a:not([href]):not([tabindex]):focus {
    outline: 0;
}

pre,
code,
kbd,
samp {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 1em;
}

pre {
    margin-top: 0;
    margin-bottom: 1rem;
    overflow: auto;
}

figure {
    margin: 0;
    padding: 0;
}

img {
    vertical-align: middle;
    border-style: none;
}

svg {
    overflow: hidden;
    vertical-align: middle;
}

table {
    border-collapse: collapse;
}

caption {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    color: #6c757d;
    text-align: left;
    caption-side: bottom;
}

th {
    text-align: inherit;
}

label {
    display: inline-block;
    margin-bottom: 0.5rem;
}

button {
    border-radius: 0;
}

button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color;
}

input,
button,
select,
optgroup,
textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

button,
input {
    overflow: visible;
}

button,
select {
    text-transform: none;
}

select {
    word-wrap: normal;
}

button,
[type=button],
[type=reset],
[type=submit] {
    -webkit-appearance: button;
}

button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
    cursor: pointer;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
    padding: 0;
    border-style: none;
}

input[type=radio],
input[type=checkbox] {
    box-sizing: border-box;
    padding: 0;
}

input[type=date],
input[type=time],
input[type=datetime-local],
input[type=month] {
    -webkit-appearance: listbox;
}

textarea {
    overflow: auto;
    resize: vertical;
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

legend {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: 0.5rem;
    font-size: 1.5rem;
    line-height: inherit;
    color: inherit;
    white-space: normal;
}

progress {
    vertical-align: baseline;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto;
}

[type=search] {
    outline-offset: -2px;
    -webkit-appearance: none;
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-file-upload-button {
    font: inherit;
    -webkit-appearance: button;
}

output {
    display: inline-block;
}

summary {
    display: list-item;
    cursor: pointer;
}

template {
    display: none;
}

[hidden] {
    display: none !important;
}

:root {
    --white: #ffffff;
    --#1a1a1a: #000000;
    --smoke: #f4f5ef;
    --gray: #e5e5e5;
    --primary: #1A1A1A;
    --second: #C7A546;
    --text-body: #1A1A1A;
    --bg-gray: #DAD4D0;
    --radius: 5px;
}

/* Base Setting
---------------------------------------- */
html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    font-size: 16px;
    font-family: "YuMincho", "游明朝", "Times New Roman", "Hiragino Mincho ProN", "HGS明朝B", "ＭＳ Ｐ明朝", serif;
    overflow-wrap: break-word;
    font-weight: 400;
    color: var(--text-body);
    overflow-x: hidden;
    line-height: 1.7;
    position: relative;
    width: 100%;
    background: var(--white);
}

a {
    transition: all 0.3s;
    color: var(--primary);
    outline: none !important;
}
a:hover {
    opacity: 1;
    color: var(--second);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "YuMincho", "游明朝", "Times New Roman", "Hiragino Mincho ProN", "HGS明朝B", "ＭＳ Ｐ明朝", serif;
    font-weight: 400;
    color: var(--primary);
}

h1 {
    font-size: 20px;
    line-height: 1.4;
    margin-bottom: 0px;
}
@media (min-width: 48em) {
    h1 {
        font-size: 30px;
    }
}

h2 {
    font-size: 40px;
    line-height: 1.5;
}
@media (min-width: 48em) {
    h2 {
        font-size: 56px;
    }
}

h3 {
    padding-top: 20px;
    font-size: 20px;
    line-height: 1.6;
}
@media (min-width: 48em) {
    h3 {
        margin-top: 5%;
        font-size: 30px;
    }
}

h4 {
    font-size: 28px;
    line-height: 1.6;
}
@media (min-width: 48em) {
    h4 {
        font-size: 36px;
    }
}

h5 {
    font-size: 20px;
    line-height: 1.6;
}
@media (min-width: 48em) {
    h5 {
        font-size: 24px;
    }
}

h6 {
    font-size: 18px;
    line-height: 1.7;
}
@media (min-width: 48em) {
    h6 {
        font-size: 20px;
    }
}

img {
    max-width: 100%;
    vertical-align: bottom;
}

.container-fluid, .container {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0;
    position: relative;
}

.fixed-contact ul, .footer-site__bottom ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
.fixed-contactpc ul, .footer-site__bottom ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

input[type=text],
input[type=email],
input[type=password],
input[type=phone],
input[type=search],
input[type=tel],
textarea,
select {
    border: 1px solid var(--gray);
    border-radius: var(--radius);
    padding: 15px 24px;
    outline: none !important;
}

.btn,
button,
input[type=button],
input[type=submit] {
    transition: all 0.3s;
    text-align: center;
    display: inline-block;
    outline: none !important;
    text-transform: uppercase;
    border: 0;
    background: #E8E8E8;
    border-radius: 7px;
    padding: 3px 20px;
    min-width: 142px;
    color: var(--text-body);
    font-weight: 400;
    font-size: 15px;
}
@media only screen and (min-width: 768px) {
    .btn,
    button,
    input[type=button],
    input[type=submit] {
        font-size: 16px;
    }
}
.btn:hover,
button:hover,
input[type=button]:hover,
input[type=submit]:hover {
    opacity: 0.9;
    color: var(--white);
    background: var(--text-body);
}
.btn svg,
button svg,
input[type=button] svg,
input[type=submit] svg {
    margin-right: 15px;
    max-height: 20px;
}
.btn.btn-white,
button.btn-white,
input[type=button].btn-white,
input[type=submit].btn-white {
    color: var(--primary);
    background: var(--white);
}

.btn-outline {
    transition: all 0.3s;
    color: var(--primary);
    padding: 15px 25px;
    min-width: 230px;
    text-align: center;
    font-weight: 700;
    display: inline-block;
    outline: none !important;
    border-radius: var(--radius);
    background: none;
    text-transform: uppercase;
    border: 1px solid var(--primary);
}
.btn-outline:hover {
    opacity: 0.9;
    color: var(--white);
}
.btn-outline svg {
    margin-right: 15px;
    max-height: 20px;
}
.btn-outline.btn-white {
    border-color: var(--white);
    color: var(--white);
}

.container-fluid {
    max-width: 1920px;
}
@media (min-width: 48em) {
    .container-fluid {
        padding: 0 64px;
    }
}

.hamburger {
    position: relative;
    width: 60px;
    height: 60px;
    line-height: 1;
    cursor: pointer;
    display: block;
    right: 0;
    z-index: 99;
    align-self: flex-end;
    border: 2px solid var(--white);
    opacity: 1;
}
.hamburger__line {
    width: 29px;
    height: 3px;
    background: var(--#1a1a1a);
    backface-visibility: hidden;
    position: absolute;
    display: block;
    margin: auto;
    transition: 0.3s all ease;
    transform: rotate(0deg);
    border-radius: 5px;
    top: calc(50% - 1.5px);
    left: calc(50% - 14.5px);
}
.hamburger__line::before, .hamburger__line::after {
    content: "";
    transform-origin: center center;
    width: 29px;
    height: 3px;
    background: var(--#1a1a1a);
    backface-visibility: hidden;
    position: absolute;
    left: 0;
    top: 10px;
    transition: 0.3s all ease;
    border-radius: 5px;
    opacity: 1;
}
.hamburger__line::after {
    top: -10px;
}
.hamburger.active .hamburger__line {
    transform: rotate(225deg);
}
.hamburger.active .hamburger__line::before {
    transform: rotate(-90deg);
    top: 0;
}
.hamburger.active .hamburger__line::after {
    opacity: 0;
}

@media screen and (min-width: 1024px) {
    .pcbr {
        display: block;
    }
    .spbr {
        display: none;
    }
}
@media screen and (max-width: 1024px) {
    .pcbr {
        display: none;
    }
    .spbr {
        display: block;
    }
}
@media only screen and (min-width: 768px) {
    .hide-pc {
        display: none;
    }
}

@media only screen and (max-width: 767px) {
    .hide-sp {
        display: none;
    }
}

.checkbox-wrap {
    display: block;
    position: relative;
    padding-left: 30px;
    margin: 0;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    min-height: 25px;
    display: inline-flex;
    align-items: center;
    font-size: 12px;
}
@media only screen and (min-width: 768px) {
    .checkbox-wrap {
        padding-left: 25px;
        min-height: 20px;
    }
}
@media only screen and (min-width: 992px) {
    .checkbox-wrap {
        font-size: 16px;
        min-height: 34px;
        padding-left: 45px;
    }
    .plan-banner__image video{
        /* margin-bottom: 50px; */
        width: 100%;
        /* padding: 60px; */
    }
}
.checkbox-wrap input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}
.checkbox-wrap input:checked ~ .checkmark:after {
    display: block;
}
.checkbox-wrap .checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 25px;
    width: 25px;
    background-color: #E8E8E8;
    border-radius: 7px;
}
@media only screen and (min-width: 768px) {
    .checkbox-wrap .checkmark {
        height: 20px;
        width: 20px;
    }
}
@media only screen and (min-width: 992px) {
    .checkbox-wrap .checkmark {
        height: 34px;
        width: 34px;
    }
}
.checkbox-wrap .checkmark:after {
    content: "";
    position: absolute;
    display: none;
    background: url("../images/check-icon.svg") no-repeat 50% 50%/44%;
    width: 100%;
    height: 100%;
}

.header-site {
    width: 100%;
}
@media only screen and (min-width: 768px) {
    .header-site {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 99;
    }
}
.header-site__inner {
    padding: 3px;
}
@media only screen and (min-width: 768px) {
    .header-site__inner {
        padding: 24px;
    }
}
@media only screen and (min-width: 992px) {
    .header-site__inner {
        padding: 40px;
    }
}
@media only screen and (max-width: 767px) {
    .header-site__inner {
        text-align: center;
    }
    .fixed-contactpc {
        display: none;
    } 
}
.header-site a img {
    height: 24px;
}

.footer-site p{
    color: var(--#1a1a1a);
    text-align: center;
    padding: 10px 0 0;
    /* position: absolute; */
}
.footer-site img{
    color: var(--#1a1a1a);
    text-align: center;
    padding: 2px 0 0;
    /* position: absolute; */
}

.footer-site video{
    width: 100%;
    padding: 20px;
    margin: auto;
    /* position: relative; */
}

@media only screen and (min-width: 768px) {
    .footer-site {
        padding: 35px 0 30px;
    }
    .footer-site video{
        width: 50%;
        padding: 10px;
        float: right;
    }
    .footer-site__top{
        margin: auto;
        font-size: 14px;
        padding:60px 0px;
    }
}
@media only screen and (min-width: 992px) {
    /* .footer-site {
        padding: 30px 0 0;
    } */
    .footer-site__top{
        margin: auto;
        font-size: 14px;
        padding:85px 0px;
    }
}
.footer-site .container {
    max-width: 982px;
    padding: 0 15px;
}
.footer-site a {
    color: var(--#1a1a1a);
}
.footer-site__top {
    /* padding-bottom: 16px; */
    /* border-bottom: 1px solid #BCBCBC; */
    font-size: 12px;
    line-height: 1.9;
}
@media only screen and (min-width: 768px) {
    .footer-site__top {
        font-size: 13px;
        line-height: 1.7;
    }
}
@media only screen and (min-width: 992px) {
    .footer-site__top {
        font-size: 16px;
    }
}
@media only screen and (min-width: 768px) {
    .footer-site__top br {
        display: none;
    }
}
.footer-site__top p {
    margin: 0;
}
.footer-site__top a {
    text-transform: uppercase;
    font-family: "YuMincho", "游明朝", "Times New Roman", "Hiragino Mincho ProN", "HGS明朝B", "ＭＳ Ｐ明朝", serif;
    margin-left: 20px;
}
.footer-site__top a:hover {
    text-decoration: underline;
}
/* .footer-site__bottom {
    padding: 12px 0;
}
.footer-site__bottom h3 {
    font-size: 12px;
    text-transform: uppercase;
    color: var(--white);
    margin: 0 0 10px;
} */
@media only screen and (min-width: 768px) {
    .footer-site__bottom h3 {
        font-size: 13px;
    }
}
@media only screen and (min-width: 992px) {
    .footer-site__bottom h3 {
        font-size: 16px;
    }
}
.footer-site__bottom ul {
    display: flex;
    align-items: center;
    gap: 40px;
    justify-content: center;
    margin-bottom: 20px;
    font-size: 12px;
}
@media only screen and (min-width: 768px) {
    .footer-site__bottom ul {
        font-size: 13px;
    }
}
@media only screen and (min-width: 992px) {
    .footer-site__bottom ul {
        font-size: 16px;
    }
}
/* .footer-site__bottom ul li a {
    display: flex;
    align-items: center;
    gap: 10px;
}
.footer-site__bottom ul li a img {
    max-height: 24px;
}
.footer-site__bottom p {
    margin: 0;
    font-size: 10px;
} */

.fixed-contact {
    position: sticky;
    bottom: 0;
    left: 0;
    z-index: 99;
    width: 100%;
    background: var(--white);
    border-top: 1px solid #DCD6D2;
}
 
@media only screen and (min-width: 768px) {
    .fixed-contact {
        display: none;
    } 
    .fixed-contactpc {
        position: sticky;
        bottom: 0;
        left: 90%;
        z-index: 99;
        width: 20%;
        background: var(--white);
        border-top: 1px solid #DCD6D2;
    }
}
.fixed-contact ul {
    width: 100%;
    display: flex;
}
.fixed-contactpc ul {
    width: 100%;
    display: flex;
}


.fixed-contact ul li {
    flex-basis: 0;
    flex-grow: 1;
}
.fixed-contactpc ul li {
    flex-basis: 0;
    flex-grow: 1;
}


.fixed-contact ul li a {
    display: block;
    font-size: 16px;
    display: flex;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    line-height: 1.3;
    padding: 13px;
}
.fixed-contactpc ul li a {
    display: block;
    font-size: 16px;
    display: flex;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    line-height: 1.3;
    padding: 13px;
}


.fixed-contact ul li a small {
    font-size: 12px;
}
.fixed-contactpc ul li a small {
    font-size: 12px;
}


.fixed-contact ul li:first-child {
    position: relative;
}
.fixed-contactpc ul li:first-child {
    position: relative;
}


.fixed-contact ul li:first-child::after {
    content: "";
    height: calc(100% - 10px);
    position: absolute;
    top: 5px;
    right: 0;
    border-right: 1px solid #DCD6D2;
}
.fixed-contactpc ul li:first-child::after {
    content: "";
    height: calc(100% - 10px);
    position: absolute;
    top: 5px;
    right: 0;
    border-right: 1px solid #DCD6D2;
}


.fixed-contact ul li.fixed-contact--special a {
    background: var(--second);
    color: var(--white);
}
.fixed-contactpc ul li.fixed-contact--special a {
    background: var(--second);
    color: var(--white);
}

/** Pages */
.heading-full {
    background: var(--second);
    margin: 0;
    padding: 5px 20px;
    z-index: 2;
    position: relative;
}
@media only screen and (min-width: 768px) {
    .heading-full {
        padding: 10px 24px;
    }
}
@media only screen and (min-width: 992px) {
    .heading-full {
        padding: 16px 36px;
    }
}
.heading-full h2 {
    color: var(--white);
    font-size: 22px;
    position: relative;
}
@media only screen and (min-width: 768px) {
    .heading-full h2 {
        font-size: 18px;
        gap: 115px;
        display: flex;
        align-items: center;
    }
}
@media only screen and (min-width: 992px) {
    .heading-full h2 {
        font-size: 30px;
        gap: 115px;
    }
}
.heading-full small {
    font-size: 18px;
}
@media only screen and (min-width: 768px) {
    .heading-full small {
        font-size: 11px;
    }
}
@media only screen and (min-width: 992px) {
    .heading-full small {
        font-size: 18px;
    }
}
@media only screen and (max-width: 767px) {
    .heading-full small {
        position: absolute;
        right: 6px;
        bottom: -16px;
        /* color: var(--text-body); */
    }
}

.heading-center {
    text-align: center;
    margin-bottom: 24px;
    padding-inline: 0 15px;
}
@media only screen and (min-width: 768px) {
    .heading-center {
        margin-bottom: 50px;
    }
}
.heading-center svg {
    max-height: 36px;
    margin-bottom: 16px;
}
@media only screen and (min-width: 768px) {
    .heading-center svg {
        max-height: 41px;
        margin-bottom: 24px;
    }
}
@media only screen and (min-width: 992px) {
    .heading-center svg {
        max-height: 68px;
        margin-bottom: 40px;
    }
}
.heading-center h2 {
    font-size: 19px;
}
@media only screen and (min-width: 768px) {
    .heading-center h2 {
        font-size: 22px;
    }
}
@media only screen and (min-width: 992px) {
    .heading-center h2 {
        font-size: 36px;
    }
}

.heading-bg h2 {
    margin: 0;
    font-size: 20px;
}
@media only screen and (min-width: 768px) {
    .heading-bg h2 {
        font-size: 18px;
    }
}
@media only screen and (min-width: 992px) {
    .heading-bg h2 {
        font-size: 30px;
    }
}
@media only screen and (max-width: 767px) {
    .heading-bg h2 {
        margin-bottom: 28px;
        text-align: center;
    }
}
.heading-bg span {
    background: var(--second);
    text-align: center;
    color: var(--white);
    display: inline-block;
    padding: 8px 20px;
    min-width: 242px;
}
@media only screen and (min-width: 768px) {
    .heading-bg span {
        padding: 6px 20px;
        min-width: 213px;
    }
}
@media only screen and (min-width: 992px) {
    .heading-bg span {
        padding: 10px 20px;
        min-width: 356px;
    }
}

.banner-section video {
    width: 100%;
}

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

.about-section {
    text-align: center;
    line-height: 1.72;
    padding: 65px 15px;
}
@media only screen and (min-width: 768px) {
    .about-section {
        padding: 56px 15px;
    }
}
@media only screen and (min-width: 992px) {
    .about-section {
        padding: 86px 15px;
    }
}
.about-section h3 {
    margin: 0 0 8px;
    font-size: 14px;
}
@media only screen and (min-width: 768px) {
    .about-section h3 {
        font-size: 13px;
    }
}
@media only screen and (min-width: 992px) {
    .about-section h3 {
        font-size: 20px;
    }
}
.about-section h2 {
    font-size: 20px;
    margin: 0 0 20px;
}
@media only screen and (min-width: 768px) {
    .about-section h2 {
        font-size: 22px;
    }
}
@media only screen and (min-width: 992px) {
    .about-section h2 {
        font-size: 36px;
    }
}
.about-section p {
    font-size: 16px;
    margin: 0;
}
@media only screen and (min-width: 768px) {
    .about-section p {
        font-size: 14px;
    }
}
@media only screen and (min-width: 992px) {
    .about-section p {
        font-size: 22px;
    }
}

.image-background {
    position: relative;
    z-index: 1;
}
.image-background .container {
    padding: 120px 0 10px;
}
@media only screen and (min-width: 768px) {
    .image-background .container {
        padding: 120px 0 28px;
        display: flex;
        gap: 36px;
        align-items: flex-start;
    }
}
.image-background .container::before, .image-background .container::after {
    content: "";
    background: #DCD6D2;
    position: absolute;
    z-index: -1;
}
@media only screen and (min-width: 768px) {
    .image-background .container::before, .image-background .container::after {
        background: var(--bg-gray);
    }
}
.image-background .container::before {
    top: 0;
    right: 0;
    width: 45.5%;
    height: 42.4%;
}
@media only screen and (min-width: 768px) {
    .image-background .container::before {
        width: 33.5%;
        height: 64.4%;
        left: 24%;
        right: auto;
    }
}
.image-background .container::after {
    bottom: 0;
    right: 45%;
    width: 45.5%;
    height: 22.5%;
}
@media only screen and (min-width: 768px) {
    .image-background .container::after {
        right: 9%;
        width: 48.3%;
        height: 46.6%;
        bottom: 60px;
    }
}
.image-background img {
    width: 100%;
    flex-grow: 1;
}
/* .image-background .gallery_image .item:nth-child(1) {
  width: 78%;
}
@media only screen and (min-width: 768px) {
  .image-background .gallery_image .item:nth-child(1) {
    width: 34.2%;margin-top: -70px;
  }
}
@media only screen and (min-width: 768px) {
  .image-background .gallery_image .item:nth-child(2) {
    width: 65.8%;
  }
}
@media only screen and (max-width: 767px) {
  .image-background .gallery_image .item:nth-child(2) {
    margin-top: -15vw;
  }
} */
ul.gallery_image {
    list-style: none;
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 15px;flex-wrap: wrap;
}
ul.gallery_image li{
    width:calc(33.3333% - 15px);
}
ul.gallery_image li img{
    margin-bottom:10px;
}
.content-border {
    padding: 35px 32px;
}
@media only screen and (max-width: 767px) {
    .image-background .container {
        padding: 30px 0 10px;
    }
    ul.gallery_image li {
        width: calc(50% - 8px);
    }
    ul.gallery_image li:first-child {
        width: 80%;margin-bottom: -70px;
    }
}
@media only screen and (min-width: 768px) {
    .content-border {
        padding: 0px 0 50px;
    }
}
.content-border__inner {
    margin: 0 auto;
    text-align: center;
    border-top: 1px solid var(--#1a1a1a);
    border-bottom: 1px solid var(--#1a1a1a);
    padding: 20px 0;
}
@media only screen and (min-width: 768px) {
    .content-border__inner {
        padding: 16px 0;
        max-width: 480px;
    }
}
@media only screen and (min-width: 992px) {
    .content-border__inner {
        padding: 26px 0;
        max-width: 805px;
    }
}
.content-border__inner p {
    margin: 0;
    font-size: 14px;
    line-height: 1.75;
    text-align: left;
}
@media only screen and (min-width: 768px) {
    .content-border__inner p {
        font-size: 13px;
    }
}
@media only screen and (min-width: 992px) {
    .content-border__inner p {
        font-size: 20px;
    }
}


.slider-images {
    margin-bottom: 40px;
}
@media only screen and (min-width: 768px) {
    .slider-images {
        margin-bottom: 56px;
    }
}
@media only screen and (min-width: 992px) {
    .slider-images {
        margin-bottom: 94px;
    }
}
.slider-images .slick-list {
    padding: 0 30%;
}
@media only screen and (min-width: 768px) {
    .slider-images .slick-list {
        padding: 0 32%;
    }
}
@media only screen and (min-width: 1500px) {
    .slider-images .slick-list {
        padding: 0 15%;
    }
}
.slider-images .slick-list img {
    margin: 0 5px;
}
@media only screen and (min-width: 768px) {
    .slider-images .slick-list img {
        margin: 0 8px;
    }
}
@media only screen and (min-width: 992px) {
    .slider-images .slick-list img {
        margin: 0 12px;
    }
}

.image-content {
    /* z-index: 1; */
    margin-bottom: 56px;
    padding-bottom: 16px;
    position: relative;
}
@media only screen and (min-width: 768px) {
    .image-content {
        padding-bottom: 20px;
        margin-bottom: 35px;
    }
}
@media only screen and (min-width: 992px) {
    .image-content {
        padding-bottom: 30px;
        margin-bottom: 70px;
    }
}
@media only screen and (min-width: 768px) {
    .image-content .container {
        display: flex;
    }
}
.image-content img {
    width: 100%;
}
.image-content::before {
    content: "";
    position: absolute;
    top: 18px;
    right: 0;
    width: calc(100% - 24px);
    height: calc(100% - 18px);
    z-index: -1;
    background: #F8F8FF;
}
@media only screen and (min-width: 768px) {
    .image-content::before {
        height: 100%;
        top: 0;
        width: calc(100% - 36px);
        background: #F8F8FF;
    }
}
@media only screen and (min-width: 992px) {
    .image-content::before {
        width: calc(100% - 60px);
    }
}
@media only screen and (min-width: 1500px) {
    .image-content::before {
        width: 100%;
    }
}
@media only screen and (min-width: 768px) {
    .image-content__left {
        width: 50%;
        padding-right: 50px;
        display: flex;
        flex-direction: column;
    }
}
@media only screen and (max-width: 767px) {
    .image-content__left img {
        max-width: calc(100% - 30px);
    }
}
@media only screen and (min-width: 768px) {
    .image-content__right {
        width: 50%;
        padding-top: 20px;
    }
}
@media only screen and (min-width: 992px) {
    .image-content__right {
        padding-top: 30px;
    }
}
.image-content__content {
    flex-basis: 0;
    flex-grow: 1;
    padding: 24px 15px 0px 45px;
}
@media only screen and (min-width: 768px) {
    .image-content__content {
        padding: 0 24px 0 65px;
        display: flex;
        align-items: center;
    }
}
@media only screen and (min-width: 992px) {
    .image-content__content {
        padding: 30px 24px 0 110px;
    }
}
.image-content__content p {
    margin: 0;
    font-size: 13px;
    line-height: 1.71;
}
@media only screen and (min-width: 992px) {
    .image-content__content p {
        font-size: 18px;
        line-height: 1.7;
    }
}
@media only screen and (max-width: 991px) {
    .image-content.margin-bottom-none {
        margin-bottom: 0;
    }
}

@media only screen and (min-width: 768px) {
    .plan-list {
        margin-bottom: 20px;
    }
}
.plan-list .container {
    display: flex;
    max-width: 1000px;
}
.plan-list__item {
    flex-basis: 0;
    flex-grow: 1;
    display: flex;
    justify-content: center;
}
@media only screen and (max-width: 767px) {
    .plan-list__item {
        padding: 0 10px;
    }
}
.plan-list__item--inner {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.plan-list__item--inner  a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.plan-list__item h3 {
    line-height: 1;
    text-transform: uppercase;
    display: flex;
    flex-direction: column;
    align-items: center;
    align-self: flex-start;
    margin: 0;
}
.plan-list__item h3 small {
    font-size: 12px;
    font-weight: 500;
}
@media only screen and (min-width: 768px) {
    .plan-list__item h3 small {
        font-size: 14px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-list__item h3 small {
        font-size: 16px;
    }
}
.plan-list__item h3 span {
    font-size: 30px;
    font-family: "YuMincho", "游明朝", "Times New Roman", "Hiragino Mincho ProN", "HGS明朝B", "ＭＳ Ｐ明朝", serif;
}
@media only screen and (min-width: 768px) {
    .plan-list__item h3 span {
        font-size: 50px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-list__item h3 span {
        font-size: 58px;
    }
}
.plan-list__item figure {
    width: 100px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 2px 2px 15px rgba(0, 0, 0, 0.1);
    border-radius: 100%;
    margin: 0 0 5px;
}
@media only screen and (min-width: 768px) {
    .plan-list__item figure {
        width: 120px;
        height: 120px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-list__item figure {
        width: 200px;
        height: 200px;
    }
}
.plan-list__item figure img {
    max-width: 50px;
    max-height: 50px;
}
@media only screen and (min-width: 768px) {
    .plan-list__item figure img {
        max-width: 58px;
        max-height: 58px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-list__item figure img {
        max-width: 95px;
        max-height: 95px;
    }
}
.plan-list__item p {
    font-size: 16px;
    margin: 0 0 5px;
}
@media only screen and (min-width: 768px) {
    .plan-list__item p {
        font-size: 18px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-list__item p {
        font-size: 30px;
    }
}
.plan-list__item svg {
    height: 10px;
}
@media only screen and (min-width: 768px) {
    .plan-list__item svg {
        height: 11px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-list__item svg {
        height: 18px;
    }
}
.plan-list__item svg path {
    fill: none;
    stroke: #333;
    stroke-miterlimit: 10;
    stroke-width: 1.88px;
}

.plan-banner {
    padding: 20px 0;
    margin: 0 auto;
}
@media only screen and (min-width: 768px) {
    .plan-banner {
        padding: 50px 0;
        /* max-width: 600px; */
    }
}
@media only screen and (min-width: 992px) {
    .plan-banner {
        max-width: 1000px;
    }
}
.plan-banner__image {
    position: relative;
    overflow: hidden;
}
/* .plan-banner__image::after {
    content: "";
    width: calc(100% - 72px);
    bottom: 0;
    left: 36px;
    background: var(--white);
    height: 40px;
    position: absolute;
} */
/* @media only screen and (min-width: 768px) {
    .plan-banner__image::after {
        height: 60px;
        width: calc(100% - 120px);
        left: 60px;
    }
} */
/* @media only screen and (min-width: 992px) {
    .plan-banner__image::after {
        height: 100px;
        width: calc(100% - 200px);
        left: 100px;
    }
} */
/* .plan-banner__image--content {
    position: absolute;
    bottom: -30px;
    padding-top: 16px;
    width: 240px;
    height: 100px;
    left: 50%;
    background: var(--white);
    transform: translate(-50%, 0);
    border-radius: 100%;
    display: flex;
    align-items: center;
    flex-direction: column;
    z-index: 1;
} */
@media only screen and (min-width: 768px) {
    .plan-banner__image--content {
        bottom: -60px;
        padding-top: 20px;
        width: 280px;
        height: 150px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-banner__image--content {
        width: 335px;
        height: 335px;
    }
}
/* .plan-banner__image--content h2 {
    font-size: 24px;
    line-height: 1.25;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    margin-bottom: 0;
} */
.plan-banner__image--content .plan {
    font-size: 15px;
}
@media only screen and (min-width: 768px) {
    .plan-banner__image--content h2 {
        font-size: 35px;
    }
    .plan-banner__image--content .plan {
        font-size: 17px;
    }
    .plan-banner__content h2{
        font-size: 28px;
    }
    .plan-banner__content p{
        font-size: 17px;
    }
}
@media only screen and (max-width: 768px) {
    .plan-banner__content h2{
        font-size: 18px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-banner__image--content h2 {
        font-size: 60px;
    }
}
.plan-banner__image--content img {
    max-height: 2px;
    max-width: 100%;
    margin-top: 6px;
}
@media only screen and (min-width: 768px) {
    .plan-banner__image--content img {
        max-height: 4px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-banner__image--content img {
        max-height: 6px;
    }
}
.plan-banner__content {
    text-align: center;
    line-height: 1.7;
    font-size: 13px;
    margin: 0 auto;
}
@media only screen and (min-width: 768px) {
    .plan-banner__content {
        font-size: 18px;
        line-height: 1.83;
        /* max-width: 600px; */
    }
}
@media only screen and (min-width: 992px) {
    .plan-banner__content {
        max-width: 1000px;
        font-size: 22px;
    }
}
.plan-banner__content p {
    margin: 0;
    text-align: left;
}

@media only screen and (min-width: 768px) {
    .plan-info .container {
        display: flex;
    }
}
@media only screen and (min-width: 768px) {
    .plan-info picture {
        width: 50%;
    }
}
.plan-info picture img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}
.plan-info__body {
    background: #D2B48C;
    padding: 10px 15px 20px;
    display: flex;
    flex-direction: column;
}
@media only screen and (min-width: 768px) {
    .plan-info__body {
        width: 50%;
        background: #D2B48C;
        padding: 10px 24px 24px;
    }
}
.plan-info__body h3 {
    font-size: 22px;
    line-height: 1.35;
    text-align: center;
    color: var(--white);
    margin: 0 0 8px;
}
@media only screen and (min-width: 768px) {
    .plan-info__body h3 {
        font-size: 21px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-info__body h3 {
        font-size: 35px;
    }
}
.plan-info__box {
    background: var(--white);
    padding: 16px 2px 10px;
    text-align: center;
    flex-grow: 1;
}
@media only screen and (min-width: 768px) {
    .plan-info__box {
        padding: 26px 5px 20px;
    }
}
.plan-info__box > p {
    font-size: 20px;
    line-height: 1.5;
    margin: 0 0 24px;
}
@media only screen and (min-width: 768px) {
    .plan-info__box > p {
        font-size: 19px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-info__box > p {
        font-size: 32px;
    }
}
.plan-info__price {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 32px;
    border-bottom: 1px dashed #736357;
    line-height: 1.2;
    margin: 0 24px 20px;
}
@media only screen and (min-width: 768px) {
    .plan-info__price {
        gap: 24px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-info__price {
        gap: 64px;
    }
}
.plan-info__price span {
    font-size: 20px;
}
@media only screen and (min-width: 768px) {
    .plan-info__price span {
        font-size: 19px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-info__price span {
        font-size: 32px;
    }
}
.plan-info__price strong {
    font-size: 28px;
    font-weight: 600;
    color: var(--second);
    font-style: italic;
}
@media only screen and (min-width: 768px) {
    .plan-info__price strong {
        font-size: 27px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-info__price strong {
        font-size: 45px;
    }
}
.plan-info__services {
    display: flex;
    flex-wrap: wrap;
    gap: 0 1%;
    justify-content: center;
}
.plan-info__services--item {
    width: 19%;
    padding: 20px 0;
}
.plan-info__services--item figure {
    height: 40px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    margin-bottom: 12px;
}
@media only screen and (min-width: 768px) {
    .plan-info__services--item figure {
        height: 44px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-info__services--item figure {
        height: 70px;
    }
}
.plan-info__services--item figure img {
    max-width: 38px;
    max-height: 40px;
}
@media only screen and (min-width: 768px) {
    .plan-info__services--item figure img {
        max-width: 40px;
        max-height: 44px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-info__services--item figure img {
        max-width: 60px;
        max-height: 70px;
    }
}
.plan-info__services--item p {
    margin: 0;
    font-size: 12px;
    line-height: 1.5;
}
@media only screen and (min-width: 992px) {
    .plan-info__services--item p {
        font-size: 19px;
    }
}
.plan-info__services--item-break {
    width: 100%;
}

@media only screen and (min-width: 768px) {
    .plan-about .container {
        display: flex;
        padding: 40px 0;
    }
}
.plan-about__body {
    padding: 30px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
@media only screen and (min-width: 768px) {
    .plan-about__body {
        width: 39%;
        padding: 30px 24px 30px 36px;
    }
}
.plan-about__body h2 {
    font-size: 22px;
    line-height: 1.3;
    margin: 0 0 12px;
    text-align: center;
}
@media only screen and (min-width: 768px) {
    .plan-about__body h2 {
        font-size: 18px;
        margin: 0 0 16px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-about__body h2 {
        font-size: 30px;
        margin: 0 0 20px;
    }
}
.plan-about__body h3 {
    font-size: 14px;
    background: var(--second);
    color: var(--white);
    padding: 2px 30px;
    margin: 0 0 20px;
}
@media only screen and (min-width: 768px) {
    .plan-about__body h3 {
        font-size: 12px;
        margin: 0 0 40px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-about__body h3 {
        font-size: 18px;
        margin: 0 0 80px;
    }
}
.plan-about__body--content {
    border-top: 1px solid #736357;
    border-bottom: 1px solid #736357;
    padding: 16px 10px;
}
@media only screen and (min-width: 768px) {
    .plan-about__body--content {
        padding: 24px 0;
    }
}
@media only screen and (min-width: 992px) {
    .plan-about__body--content {
        padding: 40px 0;
    }
}
.plan-about__body--content h5 {
    font-size: 14px;
    line-height: 1.7;
    margin: 0 0 14px;
}
@media only screen and (min-width: 768px) {
    .plan-about__body--content h5 {
        margin: 0 0 20px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-about__body--content h5 {
        font-size: 20px;
        margin: 0 0 36px;
    }
}
.plan-about__body--content p {
    margin: 0;
    font-size: 12px;
    line-height: 2;
}
@media only screen and (min-width: 992px) {
    .plan-about__body--content p {
        font-size: 18px;
        line-height: 1.77;
    }
}
@media only screen and (min-width: 768px) {
    .plan-about picture {
        width: 61%;
    }
}
.plan-about picture img {
    width: 100%;
}

.plan-point {
    background: #EAE5E2;
}
.plan-point .container {
    padding: 16px 12px 34px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
@media only screen and (min-width: 768px) {
    .plan-point .container {
        padding: 10px 30px 20px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-point .container {
        padding: 12px 46px 34px;
    }
}
.plan-point__heading {
    background: var(--white);
    width: 350px;
    height: 350px;
    border-radius: 100%;
    margin-bottom: -268px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 20px;
}
@media only screen and (min-width: 768px) {
    .plan-point__heading {
        width: 247px;
        height: 247px;
        margin-bottom: -175px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-point__heading {
        width: 412px;
        height: 412px;
        margin-bottom: -318px;
    }
}
.plan-point__heading figure {
    max-width: 48%;
    width: 100%;
    margin: 0 0 -22px;
}
@media only screen and (min-width: 768px) {
    .plan-point__heading figure {
        max-width: 59%;
    }
}
@media only screen and (min-width: 992px) {
    .plan-point__heading figure {
        max-width: 54%;
        margin: 0 0 -32px;
    }
}
.plan-point__heading h2 {
    font-size: 16px;
    line-height: 1.5;
    margin: 0;
}
@media only screen and (min-width: 768px) {
    .plan-point__heading h2 {
        font-size: 14px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-point__heading h2 {
        font-size: 20px;
    }
}
.plan-point__heading > img {
    height: 3px;
    margin-top: 8px;
}
@media only screen and (min-width: 768px) {
    .plan-point__heading > img {
        height: 2px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-point__heading > img {
        height: 3px;
    }
}
.plan-point__list {
    background: var(--white);
    width: 100%;
    padding: 50px 15px 30px;
}
@media only screen and (min-width: 768px) {
    .plan-point__list {
        display: flex;
        padding: 50px 50px 30px;
        flex-wrap: wrap;
        gap: 30px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-point__list {
        gap: 48px;
        padding: 90px 100px 70px;
    }
}
.plan-point__item {
    margin-bottom: 16px;
    text-align: center;
}
@media only screen and (min-width: 768px) {
    .plan-point__item {
        width: calc(33.33% - 20px);
        margin-bottom: 0;
    }
}
@media only screen and (min-width: 992px) {
    .plan-point__item {
        width: calc(33.33% - 32px);
    }
}
@media only screen and (max-width: 767px) {
    .plan-point__item {
        display: flex;
        gap: 10px;
    }
}
.plan-point__item picture {
    display: block;
}
@media only screen and (min-width: 768px) {
    .plan-point__item picture {
        margin: 0 0 24px;
    }
}
@media only screen and (max-width: 767px) {
    .plan-point__item picture {
        width: 55%;
    }
}
.plan-point__item picture img {
    width: 100%;
}
.plan-point__item p {
    margin: 0;
    font-size: 12px;
    line-height: 1.83;
}
@media only screen and (min-width: 992px) {
    .plan-point__item p {
        font-size: 16px;
        line-height: 1.375;
    }
}
@media only screen and (max-width: 767px) {
    .plan-point__item p {
        width: calc(45% - 10px);
        display: flex;
        align-items: center;
    }
}
@media only screen and (max-width: 767px) {
    .plan-point__item:nth-child(even) picture {
        order: 2;
    }
}

.plan-video {
    padding: 24px 15px 12px;
    text-align: center;
}
@media only screen and (min-width: 768px) {
    .plan-video {
        padding: 40px;
    }
}
.plan-video video {
    width: 100%;
    max-width: 942px;
    margin: 0 auto 6px;
}
@media only screen and (min-width: 768px) {
    .plan-video video {
        max-width: 563px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-video video {
        max-width: 942px;
    }
}
.plan-video h2 {
    font-size: 14px;
    line-height: 1.3;
    margin: 0;
}
@media only screen and (min-width: 768px) {
    .plan-video h2 {
        font-size: 23px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-video h2 {
        font-size: 38px;
    }
}

.plan-more {
    padding:20px 0px;
}
@media only screen and (min-width: 768px) {
    .plan-more {
        padding: 0 0 24px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-more {
        padding: 0 0 50px;
    }
}
.plan-more__heading {
    /* display: flex; */
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 30px;
    margin:50 0 0 6px;
}
@media only screen and (min-width: 768px) {
    .plan-more__heading {
        gap: 24px;
        margin: 50px 0 20px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-more__heading {
        gap: 36px;
        margin: 50px 0 20px;
    }
}
.plan-more__heading::before, .plan-more__heading::after {
    content: "";
    width: 66px;
    border-bottom: 1px solid #898075;
}
@media only screen and (min-width: 768px) {
    .plan-more__heading::before, .plan-more__heading::after {
        width: 30px;
    }
}
@media only screen and (min-width: 992px) {
    .plan-more__heading::before, .plan-more__heading::after {
        width: 100px;
    }
}

.plan-more__heading h2 {
    font-size: 20px;
    line-height: 1.57;
    margin: 5;
}
.content p{
        text-align: left;
    }

@media only screen and (min-width: 768px) {
    .plan-more__heading h2 {
        font-size: 25px;
    }
    .content h3{
        font-size: 25px;
    }
    .content p{
        font-size: 20px;
    }
}
@media only screen and (max-width: 768px) {
    .content h3{
        font-size: 20px;
    }
}

@media only screen and (min-width: 992px) {
    .plan-more__heading h2 {
        font-size: 24px;
        line-height: 1.45;
    }
}
.plan-more__list {
    padding: 0 15px;
    text-align: center;
}
@media only screen and (min-width: 768px) {
    .plan-more__list {
        /* display: flex; */
        flex-wrap: wrap;
    }
}
@media only screen and (min-width: 992px) {
    .plan-more__list {
        padding: 0;
    }
}
@media only screen and (min-width: 768px) {
    .plan-more__item {
        width: 100%; 
        padding: 12px 0;
    }
}
@media only screen and (min-width: 992px) {
    .plan-more__item {
        padding: 24px 44px 24px 0;
    }
}
.plan-more__item picture {
    width: 44%;
}
@media only screen and (min-width: 768px) {
    .plan-more__item picture {
        width: 42.3%;
    }
}
.plan-more__item picture img {
    width: 100%;
}
.plan-more__item--body {
    width: 56%;
    padding-left: 10px;
}
.plan-more__item--bodyy {
    width: 100%;
    padding-left: 10px;
}
.plan-more__item--bodyy p{
    font-size: 14px;
}

.plan-more__item--bodyy p{
    text-align: left;
}

@media only screen and (min-width: 768px) {
    .plan-more__item--body {
        width: 57.7%;
        padding-left: 16px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .plan-more__item--bodyy {
        width: 100%;
        /* padding-left: 16px; */
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .plan-more__item--bodyy p{
        font-size: 15px;
        text-align:center;
    }
}

@media only screen and (max-width: 767px) {
    .plan-more__item--body {
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .plan-more__item--bodyy {
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
}
.plan-more__item--body h3 {
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 6px;
}
.plan-more__item--bodyy h3 {
    font-size: 17px;
    line-height: 1.5;
    margin: 0 0 6px;
    text-align: center;
}
@media only screen and (min-width: 768px) {
    .plan-more__item--body h3 {
        font-size: 120%;
    }
}
/* @media only screen and (min-width: 992px) {
    .plan-more__item--body h3 {
        font-size: 80%;
    }
} */
.plan-more__item--body p {
    font-size: 13px;
    line-height: 1.4;
    margin: 2%;
    text-align: left;
}
@media only screen and (min-width: 992px) {
    .plan-more__item--body p {
        font-size: 16px;
        line-height: 1.6;
        margin: 2%;
    }
    .plan-more__item--body h3 {
        font-size: 150%;
    }
}

.image-section {
    padding: 20px 0 0;
}
@media only screen and (min-width: 768px) {
    .image-section {
        padding: 20px 56px 0;
    }
}
@media only screen and (min-width: 768px) {
    .image-section__inner {
        padding-bottom: 46px;
        border-bottom: 1px dashed #736357;
        padding-bottom: 30px;
    }
}
.image-section h2 {
    text-align: center;
    font-weight: 600;
    font-size: 20px;
    margin: 0 0 16px;
}
@media only screen and (min-width: 768px) {
    .image-section h2 {
        font-size: 24px;
        margin: 0 0 24px;
    }
}
@media only screen and (min-width: 992px) {
    .image-section h2 {
        font-size: 40px;
        margin: 0 0 50px;
    }
}
.image-section picture {
    display: block;
    margin: 0 auto;
}
@media only screen and (min-width: 768px) {
    .image-section picture {
        max-width: 560px;
    }
}
@media only screen and (min-width: 992px) {
    .image-section picture {
        max-width: 926px;
    }
}

@media only screen and (min-width: 768px) {
    .services .container {
        display: flex;
        gap: 24px 60px;
        flex-wrap: wrap;
        padding: 23px 23px 16px;
    }
}
@media only screen and (min-width: 992px) {
    .services .container {
        gap: 24px 69px;
        padding: 30px 56px 24px;
    }
}
@media only screen and (min-width: 768px) {
    .services__item {
        width: calc(33.33% - 46px);
    }
}
@media only screen and (max-width: 767px) {
    .services__item {
        position: relative;
        margin-top: 26px;
    }
    .services__item::before {
        content: "";
        width: calc(100% - 30px);
        left: 15px;
        top: 0;
        position: absolute;
        border-top: 1px dotted #1C1C1C;
    }
}
@media only screen and (max-width: 767px) {
    .services__item--body {
        padding: 24px;
    }
}
.services__item h3 {
    font-family: "YuMincho", "游明朝", "Times New Roman", "Hiragino Mincho ProN", "HGS明朝B", "ＭＳ Ｐ明朝", serif;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    line-height: 1.3;
    margin: 0;
}
@media only screen and (min-width: 992px) {
    .services__item h3 {
        font-size: 22px;
    }
}
.services__item h3 span {
    font-size: 50px;
    font-style: italic;
}
@media only screen and (min-width: 768px) {
    .services__item h3 span {
        font-size: 30px;
    }
}
@media only screen and (min-width: 992px) {
    .services__item h3 span {
        font-size: 60px;
    }
}
.services__item p {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.78;
    margin: 0;
}
@media only screen and (min-width: 768px) {
    .services__item p {
        font-size: 12px;
    }
}
@media only screen and (min-width: 992px) {
    .services__item p {
        font-size: 14px;
    }
}
@media only screen and (max-width: 991px) {
    .services__item p br {
        display: none;
    }
}
.services__item figure {
    margin: 30px 0 16px;
}
@media only screen and (max-width: 767px) {
    .services__item figure {
        padding: 0 25px;
        margin: 0;
    }
}
.services__item figure img {
    width: 100%;
}
.services__item .btn {
    font-size: 18px;
    font-weight: 600;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 8px 20px;
    color: var(--white);
    background: #7E7E7E;
}
@media only screen and (min-width: 768px) {
    .services__item .btn {
        font-size: 13px;
    }
}
@media only screen and (min-width: 992px) {
    .services__item .btn {
        font-size: 20px;
    }
}
@media only screen and (max-width: 767px) {
    .services__item .btn {
        max-width: 300px;
        margin: 20px auto;
    }
}
.services__item .btn svg {
    height: 12px;
}
@media only screen and (min-width: 768px) {
    .services__item .btn svg {
        height: 8px;
    }
}
@media only screen and (min-width: 992px) {
    .services__item .btn svg {
        height: 12px;
    }
}
.services__item .btn svg path {
    fill: #fff;
    stroke: #fff;
    stroke-miterlimit: 10;
    stroke-width: 1.16px;
}
@media only screen and (max-width: 767px) {
    .services__item:first-child figure {
        padding: 0;
    }
}

.service-content {
    padding: 0 0 20px;
    /*display: none;*/
    order: 99;
    width: 100%;
}
@media only screen and (max-width: 767px) {
    .service-content {
        padding: 0 30px;
        display: none;
    }
}
.service-content__inner {
    border-top: 2px solid #BB9465;
    border-bottom: 2px solid #BB9465;
    padding: 24px 0;
    line-height: 1.73;
    font-size: 15px;
    font-weight: 700;
}
@media only screen and (min-width: 768px) {
    .service-content__inner {
        font-size: 12px;
        padding: 24px 0;
    }
}
@media only screen and (min-width: 992px) {
    .service-content__inner {
        font-size: 19px;
        line-height: 1.75;
        padding: 36px 20px;
        border-top-width: 1px;
        border-bottom-width: 1px;
    }
}
.service-content__inner p {
    margin: 0;
}

.gallery {
    padding: 40px 0 30px;
}
@media only screen and (min-width: 768px) {
    .gallery {
        padding: 30px 0 25px;
    }
}
@media only screen and (min-width: 992px) {
    .gallery {
        padding: 55px 0 40px;
    }
}
.gallery h2 {
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    margin: 0 0 2px;
}
@media only screen and (min-width: 768px) {
    .gallery h2 {
        font-size: 24px;
        margin: 0 0 10px;
    }
}
@media only screen and (min-width: 992px) {
    .gallery h2 {
        font-size: 40px;
    }
}
.gallery h3 {
    text-align: center;
    font-weight: 600;
    font-size: 14px;
    margin: 0 0 16px;
}
@media only screen and (min-width: 768px) {
    .gallery h3 {
        font-size: 20px;
        margin: 0 0 40px;
    }
}
@media only screen and (min-width: 992px) {
    .gallery h3 {
        font-size: 28px;
        margin: 0 0 68px;
    }
}
.gallery picture {
    display: block;
}
.gallery picture img {
    width: 100%;
}
.gallery__list {
    display: grid;
    gap: 2px;
    grid-template-columns: repeat(3, 1fr);
}
@media only screen and (min-width: 768px) {
    .gallery__list {
        gap: 8px;
    }
}
.gallery__list figure img {
    width: 100%;
}

.step-section .container {
    padding: 16px 0 0;
}
@media only screen and (min-width: 768px) {
    .step-section .container {
        padding: 26px 36px 0;
    }
}
.step-section h2 {
    font-size: 22px;
    margin: 0 0 16px;
}
@media only screen and (min-width: 768px) {
    .step-section h2 {
        font-size: 23px;
    }
   
}
@media only screen and (min-width: 992px) {
    .step-section h2 {
        font-size: 30px;
    }
}
.step-section p {
    font-size: 15px;
    margin: 0 0 16px;
}
@media only screen and (min-width: 992px) {
    .step-section p {
        font-size: 20px;
    }
}
@media only screen and (max-width: 767px) {
    .step-section__heading {
        padding-inline: 30px;
        margin-bottom: 36px;
    }
}
.step-section__heading span {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1;
    font-size: 14px;
}
@media only screen and (min-width: 768px) {
    .step-section__heading span {
        display: none;
    }
}
.step-section__heading svg {
    height: 8px;
}
.step-section__heading svg polyline {
    fill: none;
    stroke: #1a1a1a;
    stroke-miterlimit: 10;
}
.step-section__list {
    display: flex;
    gap: 5px;
}

@media only screen and (min-width: 768px) {
    .step-section__list {
        width: calc(100% + 36px);
    }
}
@media only screen and (min-width: 992px) {
    .step-section__list {
        /* flex-wrap: wrap; */
        width: 100%;
    }
}
@media only screen and (max-width: 991px) {
    .step-section__list {
        overflow-x: auto;
    }
}
.step-section__item {
    height: auto;
    padding: 5px;
    width: calc(25% - 18px);
    min-width: 270px;
}
@media only screen and (min-width: 768px) {
    .step-section__item {
        min-width: 300px;
    }

}
@media only screen and (min-width: 992px) {
    .step-section__item {
        /* min-width: auto; */
    }
    .step-section__list {
        overflow-x: auto;
    }
    
}
.step-section__item--inner {
    background: #8B8074;
    height: 100%;
}
.step-section__item--inner figure {
    position: relative;
}
.step-section__item--inner figure::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    clip-path: polygon(100% 0, 0 100%, 100% 100%);
    background: #8B8074;
    width: 100%;
    height: 71px;
    z-index: 1;
}
@media only screen and (min-width: 768px) {
    .step-section__item--inner figure::after {
        height: 58px;
    }
}
@media only screen and (min-width: 992px) {
    .step-section__item--inner figure::after {
        height: 77px;
    }
}
.step-section__item--inner figure img {
    width: 100%;
}
.step-section__item--inner figure span {
    position: absolute;
    right: 15px;
    bottom: 0;
    z-index: 2;
    font-size: 24px;
    color: var(--white);
    right: 15px;
    bottom: 10px;
}
@media only screen and (min-width: 768px) {
    .step-section__item--inner figure span {
        font-size: 17px;
    }
}
@media only screen and (min-width: 992px) {
    .step-section__item--inner figure span {
        font-size: 17px;
    }
}
.step-section__item--inner p {
    /* margin: 0;
    padding: 15px 2px; */
    text-align: center;
    font-size: 13.5px;
    line-height: 1.4;
    color: var(--white);
}
@media only screen and (min-width: 768px) {
    .step-section__item--inner p {
        font-size: 12px;
    }
}
@media only screen and (min-width: 992px) {
    .step-section__item--inner p {
        font-size: 14px;
    }
}

.line-section {
    padding: 20px;
}
@media only screen and (min-width: 768px) {
    .line-section {
        padding: 40px 20px;
    }
}
.line-section__inner {
    border: 1px solid #898075;
    text-align: center;
    display: flex;align-items: center;
    flex-direction: column;
    padding: 20px;
    max-width: 638px;
    margin: 0 auto;
}
@media only screen and (min-width: 768px) {
    .line-section__inner {
        max-width: 382px;
    }
}
@media only screen and (min-width: 992px) {
    .line-section__inner {
        max-width: 638px;
    }
}
.line-section__inner > img {
    max-height: 30px;
    width: 151px;
}

@media only screen and (min-width: 992px) {
    .line-section__inner > img {
        max-height: 41px;width: 207px;
    }
}
.line-section__inner a img {
    width: 78px;
    max-width: 78px;
}

@media only screen and (min-width: 992px) {
    .line-section__inner a img {
        max-width: 114px;width: 114px;
    }
}
.line-section__inner p {
    margin: 12px 0 0;
    font-size: 12px;
}
@media only screen and (min-width: 992px) {
    .line-section__inner p {
        font-size: 18px;
        margin: 20px 0 0;
    }
}

.contact-section {
    background: #EAE5E2;
}
.contact-section .container {
    padding: 20px;
}
@media only screen and (min-width: 768px) {
    .contact-section .container {
        padding: 20px 50px;
    }
}
.contact-section__inner {
    background: var(--white);
    padding: 12px 12px 34px;
}
@media only screen and (min-width: 768px) {
    .contact-section__inner {
        padding: 20px 20px 64px;
    }
}
.contact-section__inner > h2 {
    text-align: center;
    font-size: 28px;
    line-height: 1.2;
    margin: 0 0 6px;
}
@media only screen and (min-width: 768px) {
    .contact-section__inner > h2 {
        font-size: 24px;
        margin: 0 0 8px;
    }
}
@media only screen and (min-width: 992px) {
    .contact-section__inner > h2 {
        font-size: 40px;
        margin: 0 0 16px;
    }
}
.contact-section__inner > p {
    font-size: 14px;
    line-height: 1.77;
    margin: 0 0 24px;
    text-align: center;
}
@media only screen and (min-width: 768px) {
    .contact-section__inner > p {
        font-size: 12px;
    }
}
@media only screen and (min-width: 992px) {
    .contact-section__inner > p {
        font-size: 18px;
    }
}
.contact-section__inner form {
    max-width: 835px;
    margin: 0 auto;
}
.contact-section__inner .form-row {
    margin-bottom: 16px;
}
.contact-section__inner .form-row > label {
    font-size: 14px;
    line-height: 1.75;
    margin: 0 0 8px;
    display: block;
}
@media only screen and (min-width: 768px) {
    .contact-section__inner .form-row > label {
        font-size: 13px;
    }
}
@media only screen and (min-width: 992px) {
    .contact-section__inner .form-row > label {
        font-size: 18px;
    }
}
.contact-section__inner .form-row input[type=text],
.contact-section__inner .form-row input[type=email],
.contact-section__inner .form-row textarea,
.contact-section__inner .form-row select {
    width: 100%;
    background: #E8E8E8;
    border-radius: 7px;
    padding: 13px 20px;
    font-size: 13px;
}
@media only screen and (min-width: 768px) {
    .contact-section__inner .form-row input[type=text],
    .contact-section__inner .form-row input[type=email],
    .contact-section__inner .form-row textarea,
    .contact-section__inner .form-row select {
        padding: 9px 20px;
    }
}
@media only screen and (min-width: 992px) {
    .contact-section__inner .form-row input[type=text],
    .contact-section__inner .form-row input[type=email],
    .contact-section__inner .form-row textarea,
    .contact-section__inner .form-row select {
        font-size: 16px;
        padding: 18px;
    }
}
.contact-section__inner .form-row select {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    background: url("../images/arrow-down-select.svg") no-repeat calc(100% - 20px) 50%/10px #E8E8E8;
    padding-right: 50px;
    width: auto;
    min-width: 145px;
}
@media only screen and (min-width: 768px) {
    .contact-section__inner .form-row select {
        min-width: 420px;
        background-size: 20px;
    }
}
.contact-section__inner .form-row__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 11px 20px;
}
@media only screen and (min-width: 768px) {
    .contact-section__inner .form-row__list {
        grid-template-columns: repeat(4, 1fr);
        gap: 28px 24px;
    }
}
@media only screen and (max-width: 767px) {
    .contact-section__inner .form-row__list--sp {
        grid-template-columns: 1fr;
    }
}
.contact-section__inner .form-submit {
    margin-top: 40px;
    text-align: center;
}
.contact-section__inner .booking-check {
    display: none;
}
.contact-section__inner .booking-check.show {
    display: block;
}
label.error {
    color: red;
    font-style: italic;
}
/*# sourceMappingURL=styles.css.map */



HTML CSS JS

Result
Skip Results Iframe

EDIT ON

@charset "utf-8";


/*==================================================
ふわっ
===================================*/

/* その場で */
.fadeIn{
    animation-name:fadeInAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes fadeInAnime{
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* 下から */

.fadeUp{
    animation-name:fadeUpAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes fadeUpAnime{
    from {
        opacity: 0;
        transform: translateY(100px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* 上から */

.fadeDown{
    animation-name:fadeDownAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes fadeDownAnime{
    from {
        opacity: 0;
        transform: translateY(-100px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* 左から */

.fadeLeft{
    animation-name:fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes fadeLeftAnime{
    from {
        opacity: 0;
        transform: translateX(-100px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* 右から */

.fadeRight{
    animation-name:fadeRightAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes fadeRightAnime{
    from {
        opacity: 0;
        transform: translateX(100px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/

.fadeInTrigger,
.fadeUpTrigger,
.fadeDownTrigger,
.fadeLeftTrigger,
.fadeRightTrigger{
    opacity: 0;
}

/*==================================================
パタッ
===================================*/


/* 下へ */
.flipDown{
    animation-name:flipDownAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes flipDownAnime{
    from {
        transform: perspective(2500px) rotateX(100deg);
        opacity: 0;
    }

    to {
        transform: perspective(2500px) rotateX(0);
        opacity: 1;
    }
}


/* 左へ */
.flipLeft{
    animation-name:flipLeftAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    perspective-origin:left center;
    opacity:0;
}

@keyframes flipLeftAnime{
    from {
        transform: perspective(600px) translate3d(0, 0, 0) rotateY(30deg);
        opacity: 0;
    }

    to {
        transform: perspective(600px) translate3d(0, 0, 0) rotateY(0deg);
        opacity: 1;
    }
}


/* 左上へ */
.flipLeftTop{
    animation-name:flipLeftTopAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes flipLeftTopAnime{
    from {
        transform: translate(-20px,80px) rotate(-15deg);
        opacity: 0;
    }

    to {
        transform: translate(0,0) rotate(0deg);
        opacity: 1;
    }
}

/* 右へ */
.flipRight{
    animation-name:flipRightAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    perspective-origin:right center;
    opacity:0;
}

@keyframes flipRightAnime{
    from {
        transform: perspective(600px) translate3d(0, 0, 0) rotateY(-30deg);
        opacity: 0;
    }

    to {
        transform: perspective(600px) translate3d(0, 0, 0) rotateY(0deg);
        opacity: 1;
    }
}

/* 右上へ */
.flipRightTop{
    animation-name:flipRightTopAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes flipRightTopAnime{
    from {
        transform: translate(-20px,80px) rotate(25deg);
        opacity: 0;
    }

    to {
        transform: translate(0,1) rotate(0deg);
        opacity: 1;
    }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/

.flipDownTrigger,
.flipLeftTrigger,
.flipLeftTopTrigger,
.flipRightTrigger,
.flipRightTopTrigger{
    opacity: 0;
}

/*==================================================
くるっ
===================================*/


/* X 軸（縦へ） */
.rotateX{
    animation-name:rotateXAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
}

@keyframes rotateXAnime{
    from{
        transform: rotateX(0);
        opacity: 0;
    }
    to{
        transform: rotateX(-360deg);
        opacity: 1;
    }
}

/*　Y軸（横へ） */
.rotateY{
    animation-name:rotateYAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
}

@keyframes rotateYAnime{
    from{
        transform: rotateY(0);
        opacity: 0;
    }
    to{
        transform: rotateY(-360deg);
        opacity: 1;
    }
}

/* Z 軸（左へ） */
.rotateLeftZ{
    animation-name:rotateLeftZAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
}

@keyframes rotateLeftZAnime{
    from{
        transform: rotateZ(0);
        opacity: 0;
    }
    to{
        transform: rotateZ(-360deg);
        opacity: 1;
    }
}

/*　Z 軸（右へ） */
.rotateRightZ{
    animation-name:rotateRightZAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
}

@keyframes rotateRightZAnime{
    from{
        transform: rotateZ(0);
        opacity: 0;
    }
    to{
        transform: rotateZ(360deg);
        opacity: 1;
    }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/

.rotateXTrigger,
.rotateYTrigger,
.rotateLeftZTrigger,
.rotateRightZTrigger{
    opacity: 0;
}

/*==================================================
ボンッ、ヒュッ
===================================*/

/* 拡大 */
.zoomIn{
    animation-name:zoomInAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
}

@keyframes zoomInAnime{
    from {
        transform: scale(0.6);
        opacity: 0;
    }

    to {
        transform: scale(1);
        opacity: 1;
    }
}

/* 縮小 */
.zoomOut{
    animation-name:zoomOutAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
}

@keyframes zoomOutAnime{
    from {
        transform: scale(1.2);
        opacity: 0;
    }

    to {
        transform:scale(1);
        opacity: 1;
    }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/

.zoomInTrigger,
.zoomOutTrigger{
    opacity: 0;
}

/*==================================================
じわっ
===================================*/

/* ぼかしから出現 */
.blur{
    animation-name:blurAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
}

@keyframes blurAnime{
    from {
        filter: blur(10px);
        transform: scale(1.02);
        opacity: 0;
    }

    to {
        filter: blur(0);
        transform: scale(1);
        opacity: 1;
    }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/

.blurTrigger{
    opacity: 0;
}

/*==================================================
にゅーん
===================================*/

/* 滑らかに変形して出現 */
.smooth{
    animation-name:smoothAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
  　transform-origin: left;
    opacity:0;
}

@keyframes smoothAnime{
    from {
        transform: translate3d(0, 100%, 0) skewY(12deg);
        opacity:0;
    }

    to {
        transform: translate3d(0, 0, 0) skewY(0);
        opacity:1;
    }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/

.smoothTrigger{
    opacity: 0;
}

/*==================================================
スーッ（枠線が伸びて出現）
===================================*/

/*枠線が伸びて出現*/

.lineTrigger{
    position: relative; /* 枠線が書かれる基点*/
    opacity:0;
}

.lineTrigger.lineanime{
    animation-name:lineAnimeBase;
    animation-duration:1s;
    animation-fill-mode:forwards;
}

@keyframes lineAnimeBase{
    from {
        opacity:0;
    }

    to {
        opacity:1;
    }
}

/*上下線*/
.lineTrigger::before,
.lineTrigger::after{
    position: absolute;
    content:"";
    width:0;
    height:1px;
    background:#333;/* 枠線の色*/
}

/*左右線*/
.line2::before,
.line2::after{
    position: absolute;
    content:"";
    width: 1px;
    height:0;
    background:#333;/* 枠線の色*/
}

/*上線*/
.lineTrigger::before {
    top:0;
    left:0;
}

.lineTrigger.lineanime::before {
    animation: lineAnime .5s linear 0s forwards;/*表示されて0秒後に上線が0.5秒かけて表示*/
}

/*右線*/
.line2::before{
    top:0;
    right:0;
}

.lineTrigger.lineanime .line2::before {
    animation: lineAnime2 .5s linear .5s forwards;/*表示されて0.5秒後に右線が0.5秒かけて表示*/
}

/*下線*/
.lineTrigger::after {
    bottom:0;
    right:0;
}

.lineTrigger.lineanime::after {
    animation: lineAnime .5s linear 1s forwards;/*表示されて1秒後に下線が0.5秒かけて表示*/
}

/*左線*/
.line2::after{
    bottom:0;
    left:0;
}

.lineTrigger.lineanime .line2::after {
    animation: lineAnime2 .5s linear 1.5s forwards;/*表示されて1.5秒後に左線が0.5秒かけて表示*/
}

@keyframes lineAnime {
    0% {width:0%;}
    100%{width:100%;}
}

@keyframes lineAnime2 {
    0% {height:0%;}
    100%{height:100%;}
}

/*枠線内側の要素*/

.lineTrigger.lineanime .lineinappear{
    animation: lineInnerAnime .5s linear 1.5s forwards;/*1.5秒後に中央のエリアが0.5秒かけて表示*/
    opacity: 0;/*初期値を透過0にする*/
}

@keyframes lineInnerAnime{
    0% {opacity:0;}
    100% {opacity:1;}
}


/*==================================================
シャッ（背景色が伸びて出現）
===================================*/

/*背景色が伸びて出現（共通）*/
.bgextend{
    animation-name:bgextendAnimeBase;
    animation-duration:1s;
    animation-fill-mode:forwards;
    position: relative;
    overflow: hidden;/*　はみ出た色要素を隠す　*/
    opacity:0;
}

@keyframes bgextendAnimeBase{
    from {
        opacity:0;
    }

    to {
        opacity:1;
    }
}

/*中の要素*/
.bgappear{
    animation-name:bgextendAnimeSecond;
    animation-duration:1s;
    animation-delay: 0.6s;
    animation-fill-mode:forwards;
    opacity: 0;
}

@keyframes bgextendAnimeSecond{
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

/*左から*/
.bgLRextend::before{
    animation-name:bgLRextendAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgLRextendAnime{
    0% {
        transform-origin:left;
        transform:scaleX(0);
    }
    50% {
        transform-origin:left;
        transform:scaleX(1);
    }
    50.001% {
        transform-origin:right;
    }
    100% {
        transform-origin:right;
        transform:scaleX(0);
    }
}

/*右から*/
.bgRLextend::before{
    animation-name:bgRLextendAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgRLextendAnime{
    0% {
        transform-origin:right;
        transform:scaleX(0);
    }
    50% {
        transform-origin:right;
        transform:scaleX(1);
    }
    50.001% {
        transform-origin:left;
    }
    100% {
        transform-origin:left;
        transform:scaleX(0);
    }
}

/*下から*/
.bgDUextend::before{
    animation-name:bgDUextendAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgDUextendAnime{
    0% {
        transform-origin:bottom;
        transform:scaleY(0);
    }
    50% {
        transform-origin:bottom;
        transform:scaleY(1);
    }
    50.001% {
        transform-origin:top;
    }
    100% {
        transform-origin:top;
        transform:scaleY(0);
    }
}

/*上から*/
.bgUDextend::before{
    animation-name:bgUDextendAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #666;/*伸びる背景色の設定*/
}
@keyframes bgUDextendAnime{
    0% {
        transform-origin:top;
        transform:scaleY(0);
    }
    50% {
        transform-origin:top;
        transform:scaleY(1);
    }
    50.001% {
        transform-origin:bottom;
    }
    100% {
        transform-origin:bottom;
        transform:scaleY(0);
    }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger,
.bgUDextendTrigger,
.bgDUextendTrigger,
.bgRLextendTrigger,
.bgLRextendTrigger{
    opacity: 0;
}


/*========= レイアウトのためのCSS ===============*/

.wrapper{
    overflow: hidden;
}

.flex{
    display:flex;
    flex-wrap: wrap;
}

.box{
    width: 220px;
    padding: 20px;
    margin: 0 20px 20px 20px;
    background: #666;
    color: #fff;
    box-sizing:border-box;
}

.bgextend,
.lineTrigger{
    width: 220px;
    padding: 20px;
    margin: 0 20px 20px 20px;
    box-sizing:border-box;
}



/*==================================================
アニメーション設定
===================================*/

/* アニメーションの回数を決めるCSS*/

.count2{
    animation-iteration-count: 2;/*この数字を必要回数分に変更*/
}

.countinfinite{
    animation-iteration-count: infinite;/*無限ループ*/
}

/* アニメーションスタートの遅延時間を決めるCSS*/

.delay-time05{
    animation-delay: 0.5s;
}

.delay-time1{
    animation-delay: 1s;
}

.delay-time15{
    animation-delay: 1.5s;
}

.delay-time2{
    animation-delay: 2s;
}

.delay-time25{
    animation-delay: 2.5s;
}

/* アニメーション自体が変化する時間を決めるCSS*/

.change-time05{
    animation-duration: 0.5s;
}

.change-time1{
    animation-duration: 1s;
}

.change-time15{
    animation-duration: 1.5s;
}

.change-time2{
    animation-duration: 2s;
}

.change-time25{
    animation-duration: 2.5s;
}

@media (min-width: 768px){
    .hidden--pc{
        display: none;
    }
    /* #wedding_plan{
        width: 50%;
        float: left;
    } */
    .service{
        font-size: 17px;
        line-height: 1.7;
        padding: 3%;
        text-align: left;
    }
    .plan-banner__content{
        font-size: 15PX;
        padding: 10px;
    }

}
@media (max-width: 767px){
    .hidden--sp{
        display:none;
    }
}
.insta-cover{
    position: absolute;
    top: 0;
    width: 100%;
    min-height: 1470px;
    display: block;
}


@media only screen and (min-width: 446px) {
    .plan-more__item {
        display: flex;
        border-bottom: 1px dashed #736357;
        padding: 12px 0;
    }

}

@media (max-width: 445px){

    .Instagram{
        height: 700px;

    }
    .insta-cover{
        position: absolute;
        top: 0;
        width: 100%;
        min-height: 758px;
        display: block;
    }
    .plan-more__item {
        border-bottom: 1px dashed #736357;
        padding: 12px 0;
    }
    .plan-more__item--body{
        width: 100%;
    }
    .plan-more__item picture{
        width: 100%;
    }
}

@media (max-width: 767px){
    .service{
        font-size: 14px;
        line-height: 1.7;
        padding: 3%;
        text-align: left;
    }
    .banner-section img {
     height: 360px;
     }
   .about-section {
    padding: 18px 15px;
    }
    #wedding_plan{
    width: 100%;
    float: left;
    }
    
}



/* #wedding_plan{
    width: 50%;
    float: left;
} */
.plan-banner__content{
    font-size: 13PX;
    padding: 10px;
}
#wedding_plan1{
    width: 50%;
}

.modal_wrap input{
  display: none;
}

.modal_overlay{
  display: flex;
  justify-content: center;
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.7);
  opacity: 0;
  transition: opacity 0.5s, transform 0s 0.5s;
  transform: scale(0);
}

.modal_trigger{
  position: absolute;
  width: 100%;
  height: 100%;
}

.modal_content{
  position: relative;
  align-self: center;
  width: 60%;
  max-width: 800px;
  padding: 30px 30px 15px;
  box-sizing: border-box;
  background: #fff;
  line-height: 1.4em;
  transition: 0.5s;
}

.close_button{
  position: absolute;
  top: 14px;
  right: 16px;
  font-size: 24px;
  cursor: pointer;
}

.modal_wrap input:checked ~ .modal_overlay{
  opacity: 1;
  transform: scale(1);
  transition: opacity 0.5s;
}

.open_button{
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 200px;
  height: 30px;
  margin: auto;
  padding: 8px 16px;
  color: #444;
  font-weight: bold;
  font-family: 'Montserrat', sans-serif;
  box-shadow: 0 1px 3px rgba(0,0,0,0.6);
  border-radius: 16px;
  cursor: pointer;
}






/* <ポップアップ> */

/*==============================================================*/
/*popup template design*/
.popup-background{
    /*position size*/
    position: fixed;
    z-index : 100;
    top : 0;
    left : 0;
    height : 100vh;
    width : 100vw;
  
    /*design*/
    background-color: gray;
    opacity : 0.5
  }
  .popup{
    /*position size*/
    --height : 80%;
    --width : 80%;
    z-index : 101;
    position: fixed;
    top : calc(50vh - calc(var(--height) / 2));
    left : calc(50vw - calc(var(--width) / 2));
    height : var(--height);
    width : var(--width);
  
    /*design*/
    overflow : hidden;
    background-color: white;
    border-radius: 10px;
    box-shadow: 0px 0px 3px 1px gray;
  }

  .step-section__item .popup{
    /*position size*/
    --height :36%;
    --width : 86%;
    z-index : 101;
    position: fixed;
    top : calc(50vh - calc(var(--height) / 2));
    left : calc(50vw - calc(var(--width) / 2));
    height : var(--height);
    width : var(--width);
  
    /*design*/
    overflow : hidden;
    background-color: white;
    border-radius: 10px;
    box-shadow: 0px 0px 3px 1px gray;
  }
  .popup > .close-button{
    /*position size*/
    --size : 30px;
    position:absolute;
    top : calc(var(--size)/4);
    left : calc(var(--width) - var(--size) * -15/4);/*css variables are available in children*/
    height : var(--size);
    width : var(--size);
  
    /*design*/
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: transparent;
    color : gray;
    font-size: var(--size);
    border-radius: calc(var(--size)/5);
  }
  @media (max-width: 767px){
    .popup > .close-button{
    /*position size*/
   --size : 20px;
    left : calc(var(--width) - var(--size) * -5/4);/*css variables are available in children*/
    }
  }
    







  .popup > .close-button:hover{
    /*design*/
    background-color: #ffee00;
    color : #1a1a1a;
  }
  .popup > .content{
    padding: 10px;
    text-align: center;
  }
  
  
  /*hide popup*/
  .popup-flag{
    display: none;
  }
  .popup-flag:not(:checked) + .popup-background{
    display:none;
  }
  .popup-flag:not(:checked) + * + .popup{
    display:none;
  }
  
  
  
  /*==============================================================*/

  /* #popupFlag2 + * +.popup{
    position size
    --height : 150px;
    --width : 150px;
  }
  #popupFlag3 + * +.popup{

    --height : 150px;
    --width : 350px;
    display:block;
    transform: rotate(30deg);
    box-shadow: 0px 0px 3px 1px gray;
    transition: 0.5s;
  }
  #popupFlag3:not(:checked) + * + .popup{
    --height : 0px;
    transform: rotate(0deg);
    box-shadow: 0px 0px 0px gray;
  }
   */
  
  
  /*==============================================================*/
  /*button-container*/
  .button-container,.button-container2,.button-container3,.button-container4,.button-container5,.button-container6,.button-container7,.button-container8{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-direction: column;
    font-size: 14px;
  }
  .button-container > *{
    margin : 15px;
  }
  
  /*button1*/
  .button-sample1,.button-sample2,.button-sample3,.button-sample4,.button-sample5,.button-sample6,.button-sample7,.button-sample8{
    color: #1a1a1a;
    background-color: white;
    border : 1px solid #1a1a1a;
    padding: 5px 10px;
    border-radius: 8px;
    transition: 0.2s;
    text-align: center;
    width: 85%;
  }
  .button-sample1:hover,.button-sample2:hover{
    color: #1a1a1a;
    background-color: white;
  }
  .button-sample1:active,.button-sample2:active{
    color: #1a1a1a;
    background-color: white;
    transition: 0.05s;
  }
  
.news-section .news-list {
  max-width: 500px;
  margin: 0 auto; }
  .news-section .news-list a {
    display: block;
    font-size: 12px;
    font-weight: 300;
    border-bottom: 1px solid #736357;
    padding: 4px 0;
    color: var(--black); }
    @media only screen and (min-width: 768px) {
      .news-section .news-list a {
        font-size: 14px;
        display: flex;
        padding: 12px 0; } }
    .news-section .news-list a time {
      font-weight: 300;
      display: block; }
      @media only screen and (min-width: 768px) {
        .news-section .news-list a time {
          min-width: 90px;
          padding-right: 10px; } }

          
.section--gray {
  background: #E7E7E7; 
padding-block: 30px;
}


.heading-section {
  margin-bottom: 20px;
  text-align: center; }
  @media only screen and (min-width: 768px) {
    .heading-section {
      margin-bottom: 28px; } }
  .heading-section h2 {
    font-family: Hiragino Mincho ProN, YuMincho, 游明朝, Times New Roman, HGS明朝B, ＭＳ Ｐ明朝, serif;
    /* font-family: "Hannari"; */
    position: relative;
    line-height: 1.75;
    color: var(--black);
    font-weight: 400;
    font-size: 25px;
    padding-bottom: 2px;
    margin: 0 0 15px; }
    @media only screen and (min-width: 768px) {
      .heading-section h2 {
        font-size: 32px;
        padding-bottom: 0;
        margin: 0 0 18px; } }
    .heading-section h2::before {
      content: '';
      position: absolute;
      width: 180px;
      left: 50%;
      transform: translateX(-50%);
      bottom: 0;
      border-bottom: 1px solid #736357; }
  .heading-section p {
    font-size: 12px;
    margin: -7px;
    font-weight: 300; }
    @media only screen and (min-width: 768px) {
      .heading-section p {
        font-size: 16px;
        font-weight: 500; } }


        .shadow-button {
    background-color: #EAE5E2; /* 背景色 */
    text-transform: none;
    padding: 10px 100px; /* パディング */
    text-align: center; /* 文字のアライメント */
    text-decoration: none; /* 文字装飾 */
    display: inline-block; /* ボタンの表示方法 */
    font-size: 16px; /* フォントサイズ */
    
    margin: 4px 2px; /* 外側の余白 */
    cursor: pointer; /* カーソル */
    border: none; /* ボーダーなし */
    border-radius: 5px; /* ボタンの角丸 */
    box-shadow: 2px 2px 8px rgba(0, 0, 0, 0.3); /* 影 */
}
.button{
    text-align: center;

}
 @media (max-width: 767px){
    .button{
        font-size: 14px;

    }
    }