@charset "UTF-8";
/*!
* Theme Name:  bridal-port
* Theme URI:   https://bridal-port.com
* Author:	   Bridal Port co.,ltd.
* Author URI:  https://bridal-port.com
* Description: aivec base wp theme.
* Version:	   2.0.0
* License:	   GNU General Public License v2 or later
* License URI: http://www.gnu.org/licenses/gpl-2.0.html
* Text Domain: bridal-port
* Requires at least: 6.0.2
* Requires PHP: 8.x
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  font-size: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding: 0;
  margin: 0;
  border: 0;
  vertical-align: baseline;
}

ol,
ul {
  list-style: none;
}

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

em,
i {
  font-weight: normal;
  font-style: normal;
}

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

a {
  color: inherit;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  cursor: pointer;
}
a:focus {
  outline: none;
}
a:link, a:visited, a:hover, a:active {
  text-decoration: none;
}

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

ins {
  text-decoration: none;
}

hr {
  border: 0;
  height: 1px;
}

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

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

svg {
  fill: white;
}

picture,
picture img {
  display: inline-block;
}

:focus:not(:focus-visible) {
  outline: none;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  text-size-adjust: 100%;
}
html.is-scrollDisabled {
  overflow: hidden;
}
html body {
  font-family: hiragino-kaku-gothic-pron, "游ゴシック", yugothic, "メイリオ", meiryo, osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  position: relative;
  overflow: auto;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 300;
  font-feature-settings: "palt", "kern";
  font-kerning: normal;
  line-height: 1.65;
  letter-spacing: 0.05em;
  color: #704834;
  background-color: #FFF;
}
@media screen and (min-width: 769px) {
  html body {
    font-size: 16px;
    font-size: 1rem;
  }
}
html body:not(.home, .archive, .single) main {
  padding-top: 50px;
}
@media screen and (min-width: 769px) {
  html body:not(.home, .archive, .single) main {
    padding-top: 108px;
  }
}

img,
picture {
  width: 100%;
  height: auto;
}

img[src$=".svg"] {
  width: initial;
}

main {
  overflow: hidden;
}

p {
  line-height: 1.8;
}

.clearfix::after {
  content: "";
  height: 0;
  display: block;
  clear: both;
}

/**
 * タイトル
 */
.border-title {
  text-align: center;
  margin-bottom: 55px;
}
.border-title > span {
  font-size: 19px;
  font-size: 1.1875rem;
  line-height: 2.1;
  padding-bottom: 0.3em;
  border-bottom: solid 3px #fac34b;
}
@media screen and (min-width: 769px) {
  .border-title > span {
    font-size: 22px;
    font-size: 1.375rem;
  }
}
@media screen and (min-width: 769px) {
  .border-title {
    margin-bottom: 70px;
  }
}

.page-title:not(.contact .page-title, .reserve .page-title, .general-dressing .page-title, .salon .page-title) {
  width: 43.5897435897%;
  font-size: 18px;
  font-size: 1.125rem;
  margin: 30px 0 30px auto;
  border-bottom: solid 1px #ff9a2c;
}

.section-title {
  font-size: 22px;
  font-size: 1.375rem;
  text-align: center;
  color: #b26c53;
  margin-bottom: 25px;
}
@media screen and (min-width: 769px) {
  .section-title {
    margin-bottom: 40px;
  }
}
.section-title img {
  width: 11px;
  height: auto;
  margin-right: 0.5em;
  display: inline-block;
  vertical-align: middle;
}

/**
 * テキスト
 */
.min {
  font-family: hiragino-mincho-pron, serif;
}

.min-dnp {
  font-family: dnp-shuei-mincho-pr6n;
}

.orange {
  color: #ff9a2c;
}

.brown {
  color: #b26c53;
}

.purple {
  color: #b1a6cf;
}

/**
 * links
 */
a.underline {
  text-decoration: underline;
}
a.underline:hover {
  text-decoration: none;
}
a.underline__primary {
  color: #ff9a2c;
}
a.underline__secondary {
  color: #b26c53;
}

/**
 *  list
 */
.border {
  border-bottom: solid 1px #e6cfac;
}

/**
 *  icon
 */
.arrow-right {
  width: 9px !important;
  margin-right: 0.5em;
  vertical-align: middle;
}

/**
 * ボタン
 */
.btn-orange {
  color: #fff;
  font-weight: bold;
  text-align: center;
  padding: 0.1em 1em;
  background-color: #ff9a2c;
  border-radius: 13px;
  display: block;
}
.btn-orange__gradation {
  background: -moz-linear-gradient(100% 50% 180deg, rgb(237, 116, 49) 0%, rgb(241, 151, 0) 100%);
  background: -webkit-linear-gradient(180deg, rgb(237, 116, 49) 0%, rgb(241, 151, 0) 100%);
  background: -webkit-gradient(linear, 100% 50%, 0% 50%, color-stop(0, rgb(237, 116, 49)), color-stop(1, rgb(241, 151, 0)));
  background: -o-linear-gradient(180deg, rgb(237, 116, 49) 0%, rgb(241, 151, 0) 100%);
  background: -ms-linear-gradient(180deg, rgb(237, 116, 49) 0%, rgb(241, 151, 0) 100%);
  -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='#ED7431', endColorstr='#F19700' ,GradientType=0)";
  background: linear-gradient(-90deg, rgb(237, 116, 49) 0%, rgb(241, 151, 0) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#F19700',endColorstr='#ED7431' , GradientType=1);
}

.btn-brown {
  color: #fff;
  text-align: center;
  padding: 0.1em 1em;
  background-color: #b26c53;
  border-radius: 7px;
  display: block;
}

/**
 * ブロック
 */
.flex-box {
  display: box;
  display: flexbox;
  display: flex;
}
@media screen and (max-width: 768px) {
  .flex-box {
    flex-direction: column;
  }
}

/**
 * ページ内ナビ
 */
.pagenav {
  margin: 20px 0 50px;
}
.pagenav li a {
  font-size: 16px;
  font-size: 1rem;
  display: box;
  display: flexbox;
  display: flex;
  align-items: center;
  border-bottom: solid 1px #ff9a2c;
  justify-content: flex-end;
  padding: 0.5em 0.25em 0.25em;
}
.pagenav li:nth-child(even) a {
  border-bottom: solid 1px #e6cfac;
}
.pagenav img {
  width: 9px;
  margin-left: 0.5em;
}
.pagenav__column {
  width: 67.6923076923vw;
}
.pagenav__row ul {
  display: box;
  display: flexbox;
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
  column-gap: 30px;
}
@media screen and (max-width: 768px) {
  .pagenav__row ul {
    width: 67.6923076923vw;
    justify-content: flex-start;
    flex-flow: column wrap;
  }
}
.pagenav__row ul li {
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .pagenav__row ul li {
    width: 67.6923076923vw;
  }
}
.pagenav__row ul li a:nth-child(even) a {
  border-bottom: solid 1px #ff9a2c;
}

/**
 * ホバーイメージ
 */
.ov-img {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}
.ov-img img:not([src$=".svg"]) {
  min-width: 100%;
  max-width: 100%;
  min-height: 100%;
  max-height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  object-fit: cover;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 0.6s;
}
.ov-img:hover img:not([src$=".svg"]) {
  transform: scale(1.06);
}

/**
 * UTILITY
 */
.text-align {
  text-align: center;
}
@media screen and (min-width: 769px) {
  .text-align--cneter--min768 {
    text-align: center;
  }
}
.text-align--justify {
  text-align: justify;
}
.text-align--justify-last-left {
  text-align: justify;
  text-align-last: left;
  moz-text-align-last: left;
}
.text-align--justify-last-right {
  text-align: justify;
  text-align-last: right;
  moz-text-align-last: right;
}
.text-align--justify-last-center {
  text-align: justify;
  text-align-last: center;
  moz-text-align-last: center;
}

@media screen and (max-width: 768px) {
  .pc-on {
    display: none;
  }
}

@media screen and (min-width: 769px) {
  .sp-on {
    display: none;
  }
}

@media screen and (min-width: 769px) {
  .pc-br {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .sp-br {
    display: block;
  }
}

/**
 * object fit
 */
.fitimg {
  position: absolute !important;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 0 !important;
}
.fitimg img {
  width: 100%;
  height: 100%;
}
.fitimg--cover img {
  object-fit: cover;
}
.fitimg--contain img {
  object-fit: contain;
}
.fitimg--top img {
  object-position: center top;
}
.fitimg--bottom img {
  object-position: center bottom;
}

.mtop_0 {
  margin-top: 0px;
  display: inline-block;
}

.mbottom_0 {
  margin-bottom: 0px;
  display: inline-block;
}

.mleft_0 {
  margin-left: 0px;
  display: inline-block;
}

.mright_0 {
  margin-right: 0px;
  display: inline-block;
}

.ptop_0 {
  padding-top: 0px;
  display: inline-block;
}

.pbottom_0 {
  padding-bottom: 0px;
  display: inline-block;
}

.pleft_0 {
  padding-left: 0px;
  display: inline-block;
}

.pright_0 {
  padding-right: 0px;
  display: inline-block;
}

.mtop_5 {
  margin-top: 5px;
  display: inline-block;
}

.mbottom_5 {
  margin-bottom: 5px;
  display: inline-block;
}

.mleft_5 {
  margin-left: 5px;
  display: inline-block;
}

.mright_5 {
  margin-right: 5px;
  display: inline-block;
}

.ptop_5 {
  padding-top: 5px;
  display: inline-block;
}

.pbottom_5 {
  padding-bottom: 5px;
  display: inline-block;
}

.pleft_5 {
  padding-left: 5px;
  display: inline-block;
}

.pright_5 {
  padding-right: 5px;
  display: inline-block;
}

.mtop_10 {
  margin-top: 10px;
  display: inline-block;
}

.mbottom_10 {
  margin-bottom: 10px;
  display: inline-block;
}

.mleft_10 {
  margin-left: 10px;
  display: inline-block;
}

.mright_10 {
  margin-right: 10px;
  display: inline-block;
}

.ptop_10 {
  padding-top: 10px;
  display: inline-block;
}

.pbottom_10 {
  padding-bottom: 10px;
  display: inline-block;
}

.pleft_10 {
  padding-left: 10px;
  display: inline-block;
}

.pright_10 {
  padding-right: 10px;
  display: inline-block;
}

.mtop_15 {
  margin-top: 15px;
  display: inline-block;
}

.mbottom_15 {
  margin-bottom: 15px;
  display: inline-block;
}

.mleft_15 {
  margin-left: 15px;
  display: inline-block;
}

.mright_15 {
  margin-right: 15px;
  display: inline-block;
}

.ptop_15 {
  padding-top: 15px;
  display: inline-block;
}

.pbottom_15 {
  padding-bottom: 15px;
  display: inline-block;
}

.pleft_15 {
  padding-left: 15px;
  display: inline-block;
}

.pright_15 {
  padding-right: 15px;
  display: inline-block;
}

.mtop_20 {
  margin-top: 20px;
  display: inline-block;
}

.mbottom_20 {
  margin-bottom: 20px;
  display: inline-block;
}

.mleft_20 {
  margin-left: 20px;
  display: inline-block;
}

.mright_20 {
  margin-right: 20px;
  display: inline-block;
}

.ptop_20 {
  padding-top: 20px;
  display: inline-block;
}

.pbottom_20 {
  padding-bottom: 20px;
  display: inline-block;
}

.pleft_20 {
  padding-left: 20px;
  display: inline-block;
}

.pright_20 {
  padding-right: 20px;
  display: inline-block;
}

.mtop_25 {
  margin-top: 25px;
  display: inline-block;
}

.mbottom_25 {
  margin-bottom: 25px;
  display: inline-block;
}

.mleft_25 {
  margin-left: 25px;
  display: inline-block;
}

.mright_25 {
  margin-right: 25px;
  display: inline-block;
}

.ptop_25 {
  padding-top: 25px;
  display: inline-block;
}

.pbottom_25 {
  padding-bottom: 25px;
  display: inline-block;
}

.pleft_25 {
  padding-left: 25px;
  display: inline-block;
}

.pright_25 {
  padding-right: 25px;
  display: inline-block;
}

.mtop_30 {
  margin-top: 30px;
  display: inline-block;
}

.mbottom_30 {
  margin-bottom: 30px;
  display: inline-block;
}

.mleft_30 {
  margin-left: 30px;
  display: inline-block;
}

.mright_30 {
  margin-right: 30px;
  display: inline-block;
}

.ptop_30 {
  padding-top: 30px;
  display: inline-block;
}

.pbottom_30 {
  padding-bottom: 30px;
  display: inline-block;
}

.pleft_30 {
  padding-left: 30px;
  display: inline-block;
}

.pright_30 {
  padding-right: 30px;
  display: inline-block;
}

.mtop_35 {
  margin-top: 35px;
  display: inline-block;
}

.mbottom_35 {
  margin-bottom: 35px;
  display: inline-block;
}

.mleft_35 {
  margin-left: 35px;
  display: inline-block;
}

.mright_35 {
  margin-right: 35px;
  display: inline-block;
}

.ptop_35 {
  padding-top: 35px;
  display: inline-block;
}

.pbottom_35 {
  padding-bottom: 35px;
  display: inline-block;
}

.pleft_35 {
  padding-left: 35px;
  display: inline-block;
}

.pright_35 {
  padding-right: 35px;
  display: inline-block;
}

.mtop_40 {
  margin-top: 40px;
  display: inline-block;
}

.mbottom_40 {
  margin-bottom: 40px;
  display: inline-block;
}

.mleft_40 {
  margin-left: 40px;
  display: inline-block;
}

.mright_40 {
  margin-right: 40px;
  display: inline-block;
}

.ptop_40 {
  padding-top: 40px;
  display: inline-block;
}

.pbottom_40 {
  padding-bottom: 40px;
  display: inline-block;
}

.pleft_40 {
  padding-left: 40px;
  display: inline-block;
}

.pright_40 {
  padding-right: 40px;
  display: inline-block;
}

.mtop_45 {
  margin-top: 45px;
  display: inline-block;
}

.mbottom_45 {
  margin-bottom: 45px;
  display: inline-block;
}

.mleft_45 {
  margin-left: 45px;
  display: inline-block;
}

.mright_45 {
  margin-right: 45px;
  display: inline-block;
}

.ptop_45 {
  padding-top: 45px;
  display: inline-block;
}

.pbottom_45 {
  padding-bottom: 45px;
  display: inline-block;
}

.pleft_45 {
  padding-left: 45px;
  display: inline-block;
}

.pright_45 {
  padding-right: 45px;
  display: inline-block;
}

.mtop_50 {
  margin-top: 50px;
  display: inline-block;
}

.mbottom_50 {
  margin-bottom: 50px;
  display: inline-block;
}

.mleft_50 {
  margin-left: 50px;
  display: inline-block;
}

.mright_50 {
  margin-right: 50px;
  display: inline-block;
}

.ptop_50 {
  padding-top: 50px;
  display: inline-block;
}

.pbottom_50 {
  padding-bottom: 50px;
  display: inline-block;
}

.pleft_50 {
  padding-left: 50px;
  display: inline-block;
}

.pright_50 {
  padding-right: 50px;
  display: inline-block;
}

#header {
  width: 100%;
  position: fixed;
  top: 0;
  z-index: 10;
  background-color: rgba(255, 255, 255, 0.8);
}
#header .inner {
  height: 50px;
  padding: 0 10px 0 25px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#header .nav-btn {
  width: 40px;
  height: 40px;
  position: relative;
  display: block;
  transition: 0.3s ease transform;
}
#header .nav-btn span,
#header .nav-btn span::before,
#header .nav-btn span::after {
  width: 22px;
  height: 2px;
  margin-top: -1px;
  background: #ff9a2c;
  border-radius: 1px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
  transition: 0.2s;
  content: "";
}
#header .nav-btn span {
  background: #b26c53;
}
.is-navOpen #header .nav-btn {
  transform: rotate(90deg);
  transition: 0.3s ease transform;
}
#header .nav-btn span::before {
  transform: translate(-50%, -7px);
}
#header .nav-btn span::after {
  transform: translate(-50%, 7px);
}
@media screen and (max-width: 991px) {
  #header .logo {
    width: 120px;
  }
}
@media screen and (min-width: 992px) {
  #header .inner {
    height: 62px;
    align-items: center;
  }
  #header .nav-btn {
    display: none;
  }
  #header .logo {
    width: 228px;
  }
  #header .logo a:hover {
    opacity: 1;
  }
}

#header-nav {
  font-size: 12px;
  font-size: 0.75rem;
  font-weight: 500;
  display: flex;
}
#header-nav li {
  margin-left: 1vw;
}
#header-nav li.contact a {
  color: #FFF;
  padding: 0 1em;
}
#header-nav a {
  display: block;
}
@media screen and (max-width: 991px) {
  #header-nav {
    display: none;
  }
}
@media screen and (min-width: 992px) {
  #header-nav {
    font-size: 14px;
    font-size: 0.875rem;
  }
  #header-nav li {
    margin-left: 3.515625vw;
    position: relative;
  }
  #header-nav li:hover .sub-menu {
    display: block;
    visibility: visible;
    opacity: 1;
  }
  #header-nav .sub-menu {
    min-width: 285px;
    padding: 20px;
    position: absolute;
    top: 24px;
    left: 0;
    visibility: hidden;
    opacity: 0;
    z-index: 40;
    transition: all 0.4s ease-in-out;
  }
  #header-nav .sub-menu li {
    margin-left: 0;
    margin-bottom: 1em;
  }
  #header-nav .sub-menu li:hover {
    opacity: 0.6;
  }
}

#sp-nav {
  background-color: #FFF;
  position: fixed;
  top: 50px;
  right: 0;
  bottom: 0;
  left: 0;
  pointer-events: none;
  opacity: 0;
  z-index: 99;
  transition: 0.5s ease;
}
body.is-navOpen #sp-nav {
  opacity: 1;
  pointer-events: initial;
  transform: translateZ(1px);
}
body.is-navOpen #sp-nav.admin-bar header {
  top: 46px;
}
#sp-nav ul:not(.sub-menu) {
  padding: 2em 0;
  margin-right: 150px;
}
#sp-nav ul:not(.sub-menu) > li > a {
  border-bottom: 2px solid #e6cfac;
  display: block;
}
#sp-nav ul:not(.sub-menu) img {
  margin-right: 10px;
}
#sp-nav li {
  margin-top: 1em;
  text-align: right;
}
#sp-nav .sub-menu {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.3s ease;
  list-style: none;
  margin: 0;
  margin-left: 2em;
  margin-right: 2em;
}
#sp-nav .sub-menu li {
  position: relative;
}
#sp-nav .sub-menu li::after {
  content: "•";
  color: #e6cfac;
  font-size: 35px;
  position: absolute;
  transform: translateY(-35%);
}
#sp-nav .sub-menu li {
  font-size: 14px;
  font-size: 0.875rem;
}
#sp-nav .sub-menu.show {
  margin-left: 2em;
  margin-right: 2em;
  display: block;
  max-height: 500px;
}
#sp-nav .arrow-right {
  margin-left: 5px;
  transform: rotate(0deg);
  transition: transform 0.2s ease;
}
#sp-nav .arrow-right.rotated {
  transform: rotate(90deg);
}
#sp-nav a {
  font-weight: 700;
}
@media screen and (min-width: 992px) {
  #sp-nav {
    display: none;
  }
}
#sp-nav .right {
  margin-left: 150px;
  margin-right: 0 !important;
}
#sp-nav .right li {
  text-align: left;
}
#sp-nav {
  /* --- デコレーションの位置 --- */
}
#sp-nav .anim-box {
  position: fixed;
  top: 40px;
  right: 20px;
  display: flex;
  flex-direction: column;
  z-index: 10;
}
#sp-nav .anim-box img {
  width: 20px;
  opacity: 0;
  transform: translateY(-30px);
  display: block;
}
#sp-nav .anim-box img:nth-child(1),
#sp-nav .anim-box img:nth-child(2),
#sp-nav .anim-box img:nth-child(3),
#sp-nav .anim-box img:nth-child(4) {
  width: 20px;
  height: 7px;
}
#sp-nav .anim-box img:nth-child(5) {
  width: 15px;
  margin: auto;
  padding: 10px 0;
}

@media screen and (min-width: 769px) {
  .footer-main-menu {
    display: box;
    display: flexbox;
    display: flex;
    flex-flow: wrap;
    align-items: center;
  }
  .footer-main-menu li {
    font-size: 15px;
    font-size: 0.9375rem;
    margin-right: 1em;
    margin-bottom: 0.3em;
  }
  .footer-main-menu li:not(:last-child)::before {
    content: ">";
    color: #ff9a2c;
    margin-right: 0.25em;
  }
}

.footer-sub-menu {
  width: 50%;
  margin: 60px 0 30px;
}
@media screen and (min-width: 769px) {
  .footer-sub-menu {
    width: 100%;
    margin: 30px 0 80px;
  }
}
.footer-sub-menu a {
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .footer-sub-menu li {
    padding: 11px 0;
    border-top: solid 1px #e6cfac;
  }
  .footer-sub-menu li:last-child {
    border-bottom: solid 1px #e6cfac;
  }
}
@media screen and (min-width: 769px) {
  .footer-sub-menu {
    display: box;
    display: flexbox;
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
  .footer-sub-menu li:not(:last-child) {
    padding-right: 3em;
    position: relative;
  }
  .footer-sub-menu li:not(:last-child)::after {
    content: "|";
    color: #ff9a2c;
    position: absolute;
    right: 1.5em;
  }
}

.footer .inner {
  width: 78%;
  margin: 0 auto 10px;
  position: relative;
}
@media screen and (min-width: 769px) {
  .footer .inner {
    width: min(95%, 900px);
  }
}
.footer #pagetop {
  width: 66px;
  position: absolute;
  bottom: 90px;
  right: 0;
  cursor: pointer;
}
@media screen and (min-width: 769px) and (max-width: 991px) {
  .footer #pagetop {
    bottom: 10px;
  }
}
@media screen and (min-width: 992px) and (max-width: 1280px) {
  .footer #pagetop {
    bottom: 10px;
  }
}
@media screen and (min-width: 1170px) {
  .footer #pagetop {
    bottom: 130px;
    right: -120px;
  }
}
@media screen and (min-width: 769px) {
  .footer__contact {
    justify-content: space-between;
  }
}
.footer__contact > div {
  padding: 1.8em 2.5em;
  margin-bottom: 25px;
}
@media screen and (min-width: 769px) {
  .footer__contact > div {
    width: 31.5%;
    padding: 1.5em 1.15em;
  }
}
.footer__contact-line {
  border: solid 1px #e6cfac;
}
.footer__contact-line h2 {
  font-size: 16px;
  font-size: 1rem;
  text-align: center;
  margin-bottom: 15px;
}
@media screen and (min-width: 769px) {
  .footer__contact-line h2 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.footer__contact-line a {
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  padding: 0.3em 0;
  margin-top: 10px;
  background-color: #22b473;
  border-radius: 15px;
  display: block;
}
@media screen and (min-width: 769px) {
  .footer__contact-line dl {
    justify-content: space-between;
  }
  .footer__contact-line dt {
    width: 55px;
  }
  .footer__contact-line dd {
    width: calc(100% - 70px);
    font-size: 11px;
    font-size: 0.6875rem;
  }
}
.footer__contact-tel {
  border: solid 1px #ff9a2c;
}
@media screen and (min-width: 769px) {
  .footer__contact-tel {
    display: box;
    display: flexbox;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
  }
}
.footer__contact-tel h2 {
  font-size: 14px;
  font-size: 0.875rem;
  text-align: center;
  margin-bottom: 10px;
}
@media screen and (min-width: 769px) {
  .footer__contact-tel h2 {
    font-size: 17px;
    font-size: 1.0625rem;
  }
}
.footer__contact-tel a {
  font-family: "Noto Sans JP";
  font-size: 26px;
  font-size: 1.625rem;
  font-weight: 500;
  line-height: 1;
  text-align: center;
  display: block;
}
@media screen and (min-width: 769px) {
  .footer__contact-tel a {
    font-size: min(3.25vw, 33px);
  }
}
.footer__contact-mail {
  border: solid 1px #704834;
}
@media screen and (min-width: 769px) {
  .footer__contact-mail {
    display: box;
    display: flexbox;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
  }
}
.footer__contact-mail h2 {
  font-size: 14px;
  font-size: 0.875rem;
  text-align: center;
  margin-bottom: 10px;
}
@media screen and (min-width: 769px) {
  .footer__contact-mail h2 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
.footer__contact-mail a {
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  display: block;
}
@media screen and (min-width: 769px) {
  .footer__contact-mail a {
    font-size: 23px;
    font-size: 1.4375rem;
  }
}
.footer__info {
  padding-top: 45px;
  margin-top: 40px;
  border-top: 1px solid #ed7431;
  border-image: linear-gradient(to right, #ed7431 0%, #f19700 100%) 1;
}
@media screen and (min-width: 769px) {
  .footer__info {
    justify-content: space-between;
  }
}
@media screen and (min-width: 769px) {
  .footer__info-main {
    width: 42.3333333333%;
  }
}
.footer__info-main .logo {
  width: 70px;
  margin: 0 auto 40px;
  display: block;
}
@media screen and (min-width: 769px) {
  .footer__info-main .logo {
    width: 93px;
  }
}
.footer__info-main h2, .footer__info-main p {
  font-size: 14px;
  font-size: 0.875rem;
}
@media screen and (min-width: 769px) {
  .footer__info-main h2 {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
@media screen and (min-width: 769px) {
  .footer__info-main p {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
.footer__info-main a {
  margin-bottom: 10px;
  display: block;
}
@media screen and (min-width: 769px) {
  .footer__info-menu {
    width: 50.5555555556%;
  }
}
.footer .copy {
  font-size: 12px;
  font-size: 0.75rem;
  text-align: center;
}

/**
 * スクロール　フェイドIN
 */
.fade {
  min-width: 1px;
  min-height: 1px;
  opacity: 0;
  visibility: hidden;
  filter: inherit;
  perspective: 1000;
}
.fade--up.scrollin {
  animation-name: fadeInAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  visibility: visible;
}
.fade--up.delay300 {
  animation-delay: 0.3s;
}
.fade--up.delay500 {
  animation-delay: 0.5s;
}
.fade--up.delay700 {
  animation-delay: 0.7s;
}
.fade--opacity.scrollin {
  animation-name: fadeInAnimeOpacity;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  visibility: visible;
}
.fade--slide {
  max-width: 0;
  box-sizing: content-box;
  transition: 3s;
  opacity: 1;
  overflow: hidden;
  visibility: visible;
  white-space: nowrap;
}
.fade--slide.scrollin {
  max-width: 100vw;
  visibility: visible;
}

@keyframes fadeInAnime {
  from {
    opacity: 0;
    transform: translateY(10vh);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInAnimeOpacity {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}