@charset "UTF-8";
/******************************
 * reset
 ******************************/
@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@400;500;700&display=swap");
:root {
  --sans-serif: "", sans-serif;
  --serif: "", serif;
  --en-sans: "", sans-serif;
  --en-serif: "", serif;
  --base: #fff;
  --main: #4D382D;
  --accent: #A58953;
  --accent-rgb: 34,71,92;
  --base-width: 1220px;
  --sp-base-fs: 4vw;
  --sp-pad: 5vw;
}

html {
  font-size: 10px;
  scroll-behavior: smooth;
}
@media screen and (min-width: 768px) {
  html {
    min-width: 1310px;
  }
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
dl,
dt,
dd,
ol,
ul,
figure {
  all: unset;
  display: revert;
}

ul {
  list-style: none;
}

body {
  color: #4D382D !important;
  background: #F7F2E7;
  line-height: 1.9;
  font-feature-settings: "palt" 1;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  font-size: 1.6rem;
  font-family: "Century Gothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", 游ゴシック体, YuGothic, "Yu Gothic", メイリオ, Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  border-top: 6px solid #A58953;
  
}

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

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

h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.5;
}

@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    display: inline-block;
    pointer-events: none;
  }
}

button,
input[type=submit],
input[type=button],
input[type=reset] {
  -webkit-appearance: none;
  cursor: pointer;
}

select {
  line-height: 1.42857143;
  background: #fff;
}

label {
  display: inline-block;
}

sup {
  font-size: 10px;
  line-height: 1.1;
  vertical-align: top;
}

a {
  color: #4D382D;
  text-decoration: none;
  word-break: break-all;
}
a:hover {
  color: #DB5837;
}

hr {
  background: none;
  height: 0;
  border: 0;
  border-top: 1px solid #ccc;
}

small {
  font-size: 80%;
}

* {
  box-sizing: border-box;
}

::placeholder {
  color: #c1c1c1;
}

/*font size*/
body, input, select, textarea {
  font-family: var(--sans-serif);
}

@media screen and (max-width: 767px) {
  body {
    font-size: var(--sp-base-fs);
  }
  select, input, textarea {
    font-size: max(1.6rem, var(--sp-base-fs));
  }
}
/******************************
 * l-footer
 ******************************/
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.l-footer {
  line-height: 1.4;
}
.l-footer__last {
  background: var(--accent);
  color: #fff;
}
@media screen and (max-width: 767px) {
  .l-footer__last {
    padding: 1vw;
  }
}
.l-footer__last a {
  color: #fff;
}
@media screen and (min-width: 768px) {
  .l-footer__row {
    padding: 0 0 15px 0;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__row {
    padding-top: 13.3vw;
    padding-bottom: 10.3vw;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__row2 {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 15px 0;
  }
}
.l-footer__txt small {
  font-size: 1.2rem;
  display: inline-block;
  padding: 12px;
}
@media screen and (max-width: 767px) {
  .l-footer__txt {
    text-align: center;
    font-size: 3.5vw;
  }
  .l-footer__txt small {
    margin-top: 0.4em;
    font-size: 2.9vw;
  }
}
.l-footer__link {
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .l-footer__link {
    display: none;
  }
}
.l-footer__link a {
  display: inline-block;
}
.l-footer__link a:not(:first-child) {
  margin-left: 1em;
}
@media (hover: hover) {
  .l-footer__link a:hover {
    text-decoration: underline;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__wtxt {
    width: 350px;
  }
}
/*@media screen and (min-width: 768px) {
  .l-footer__logo {
    width: 459px;
  }
}*/
@media screen and (max-width: 767px) {
  .l-footer__logo {
    text-align: center;
  }
  .l-footer__logo img {
    width: 57.3vw;
  }
}
.l-footer__list {
  margin-top: 25px;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .l-footer__list {
    margin-top: 5.3vw;
    font-size: 4vw;
  }
}
.l-footer__list li {
  display: inline-block;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .l-footer__list li:not(:last-child) {
    margin-right: 1em;
  }
}
/*.l-footer__time-table {
  margin-top: 30px;
}*/
@media screen and (max-width: 767px) {
  .l-footer__time-table {
    margin-top: 6.7vw;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__wmap {
    width: 680px;
  }
}
@media screen and (min-width: 768px) {
  .l-footer__tel {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0 20px;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__tel {
    text-align: center;
    margin-top: 8vw;
    transform: translateX(-2vw);
  }
}
.l-footer__tel p {
  font-weight: 550;
  margin-top: -3px;
}
@media screen and (max-width: 767px) {
  .l-footer__tel p {
    padding-left: 5.9vw;
    font-size: 4vw;
  }
}
.l-footer__tel a {
  font-size: 3.2rem;
  color: var(--accent);
  font-weight: 500;
  line-height: 1.1;
  /*letter-spacing: 0.05em;*/
}
@media screen and (max-width: 767px) {
  .l-footer__tel a {
    font-size: 8vw;
  }
}
.l-footer__tel img {
  position: relative;
}
@media screen and (min-width: 768px) {
  .l-footer__tel img {
    top: -5px;
    margin-right: 8px;
  }
}
@media screen and (max-width: 767px) {
  .l-footer__tel img {
    margin-right: 2.1vw;
    top: -0.9vw;
    width: 10.4vw;
  }
}
.l-footer__line {
  margin-top: 25px;
}
@media screen and (max-width: 767px) {
  .l-footer__line {
    margin-top: 10.7vw;
  }
}
.l-footer__line img {
  box-shadow: 0px 3px 20px rgba(0, 0, 0, 0.16);
}
.l-footer__map {
  width: 100%;
  height: 420px;
}
@media screen and (max-width: 767px) {
  .l-footer__map {
    /*margin-top: 10.7vw;*/
    height: 152.1vw;
  }
}
.l-footer__map iframe {
  object-fit: cover;
  width: 100%;
  height: 100%;
  border-radius: 20px;
}
.l-footer__map-note {
  margin: 40px 0 70px 0;
  margin-right: auto;
  margin-left: auto;
  width: 730px;
}
@media screen and (max-width: 767px) {
  .l-footer__map-note {
    mask-type: 4vw;
    font-size: 4vw;
    width: 100%;
    margin-top: 30px;
  }
}
.l-footer__loop {
  overflow: hidden;
}
.l-footer__loop-inner {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 3886px;
  animation: infinity-scroll-left 20s infinite linear 0.5s both;
  animation-duration: 50s;
}
.l-footer__loop-item {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  width: 1943px;
}
/******************************
 * l-header
 ******************************/
.l-header {
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .l-header {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 101;
    width: 100%;
    background: #fff;
  }
}
@media screen and (min-width: 768px) {
  .l-header__inner {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 15px 30px 60px 30px;
  }
}
@media screen and (max-width: 767px) {
  .l-header__inner {
    padding: 2.2vw 3.7vw 2.0vw 1.9vw;
    /*min-height: 18.7vw;*/
  }
}
.l-header__desc {
  font-size: 1.6rem;
}
@media screen and (min-width: 768px) {
  .l-header__desc {
    margin-bottom: 25px;
    margin-top: 30px;
    /*width: 480px;*/
    width: 382px;
  }
  .l-header__logo {
    margin-top: 10px;
  }
}
@media screen and (max-width: 767px) {
  .l-header__logo {
    width: 60.7vw;
  }
}
@media screen and (min-width: 768px) {
  .l-header__box {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: 0 20px;
  }
}
.l-header__tel {
  text-align: right;
}
/*.l-header__tel p {
  font-weight: bold;
}*/

.l-page__footer .l-header__tel {
  text-align: left;
}

@media screen and (min-width: 768px) {
  .l-header__tel p {
    padding-left: 28px;
    line-height: 1.7;
  }
  
  .l-page__footer .l-header__tel p {
    padding-left: 0;
    line-height: 1.7;
    margin: 14px 10px 0 0;
  }
  
  .l-page__footer .l-header__tel p.fax {
    padding-left: 61px;
    margin: 0;
    margin-top: -9px;
    text-align: right;
  }
  
  .l-footer__wmap .l-header__tel {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.l-header__tel a {
  font-size: 3.2rem;
  color: #4D382D;
  /*color: var(--accent);*/
  font-weight: bold;
  line-height: 1.1;
  letter-spacing: -0.03em;
}
.l-header__tel img {
  position: relative;
}
@media screen and (min-width: 768px) {
  .l-header__tel img {
    top: -4px;
    margin-right: 7px;
  }
  .l-header__tel .fax {
    font-weight: bold;
    margin-top: -9px;
  }
}
@media screen and (min-width: 768px) {
  .l-header__nav {
    margin-top: 34px;
  }
}

.l-header__desc .txt-highlight {
  color: #4D382D;
  font-weight: bold;
  font-size: 1.7rem;
  padding:5px 5px;
  background: radial-gradient(circle at calc(100% - 7px) calc(100% - 7px), #F5EE84 7px, transparent 7px) ,
              radial-gradient(circle at 7px calc(100% - 7px), #F5EE84 7px, transparent 7px) ,
              linear-gradient(to bottom, #F7F2E7 calc(100% - 14px), transparent calc(100% - 14px)) ,
              linear-gradient(to right, transparent 7px, #F5EE84 7px, #F5EE84 calc(100% - 7px), transparent calc(100% - 7px));
  display:inline;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

@media screen and (max-width: 767px) {
  .l-header__tel .fax {
    margin-top: 0;
    margin-left: 0;
  }
}

/******************************
 * l-page
 ******************************/
 
@media screen and (min-width: 768px) {
  .l-page__row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: row-reverse;
  }
}
@media screen and (min-width: 768px) {
  .l-page__main {
    width: calc(100% - 275px);
  }
  .l-page__main-inner {
    margin: 0 auto;
    width: 900px;
  }
}

@media screen and (min-width: 768px) {
  .l-page__sidebar {
    width: 275px;
  }
}
@media screen and (max-width: 767px) {
  .l-page__sidebar {
    margin-top: 22.8205128205vw;
  }
}
/******************************
 * l-nav
 ******************************/
.l-nav__btn {
  padding: 0;
  background: transparent;
  border: 0;
}
@media screen and (min-width: 768px) {
  .l-nav__btn {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__btn {
    position: absolute;
    right: 0;
    top: 0;
    width: 15.1vw;
    height: 15.1vw;
    text-align: center;
    background-color: #4D382D;
  }
  .l-nav__btn svg {
    width: 6.1vw;
    margin-top: 3px;
  }
  .l-nav__btn span {
    display: block;
    font-size: 3.2vw;
    margin-top: 0.2em;
    color: #1A1311;
    font-weight: 500;
  }
  
  .l-nav__btn rect {
   fill: #fff;
  }
}
.l-nav__btn .is-line-1,
.l-nav__btn .is-line-4 {
  transform-origin: center;
  transition-property: opacity;
  transition-duration: 0.2s;
}
.l-nav__btn .is-line-2,
.l-nav__btn .is-line-3 {
  transform-origin: center;
  transition-property: transform;
  transition-duration: 0.2s;
}
.l-nav__btn.is-active {
  transform: translateX(0);
}
.l-nav__btn.is-active .is-line-1,
.l-nav__btn.is-active .is-line-4 {
  opacity: 0;
}
.l-nav__btn.is-active .is-line-2 {
  transform: rotate(45deg);
}
.l-nav__btn.is-active .is-line-3 {
  transform: rotate(-45deg);
}

.hd-sp-tel {
  position: absolute;
  top: 13px;
  right: 67px;
}

@media screen and (max-width: 767px) {
  .l-nav__body {
    transform: translateX(0);
    position: fixed;
    left: 0;
    top: 15.0vw;
    z-index: 100;
    overflow: auto;
    width: 100%;
    height: 100vh;
    height: 100dvh;
    background-color: #4D382D;
    /*background: var(--accent);*/
    transition: 0.25s transform;
    padding-bottom: 80px;
  }
  .l-nav__body[aria-hidden=true] {
    transform: translateX(-110vw);
  }
}
@media screen and (min-width: 768px) {
  .l-nav__list {
    text-align: center;
  }
  .l-nav__list li {
    display: inline-block;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__list a {
    color: #fff;
    line-height: 2;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__item {
    padding-bottom: 30px;
  }
  
}
@media screen and (max-width: 767px) {
  .l-nav__item {
    border-bottom: 1px solid #7B6C63;
  }
}

/*.l-nav__item.has-children.is-on a {
  position: relative;
}
.l-nav__item.has-children.is-on a::before {
  content: "";
  display: block;
  position: absolute;
  bottom: -36px;
  left: 50%;
  transform: translateX(-50%);
  width: 68px;
  height: 36px;
  background: url("../img/content/triangle.svg") 50% 100% / contain no-repeat;
}*/

@media screen and (max-width: 767px) {
  .l-nav__item.has-children {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
.l-nav__toggle {
  background: transparent;
  border: 0;
}
@media screen and (min-width: 768px) {
  .l-nav__toggle {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__toggle {
    margin-top: 4.3vw;
    width: 10.7vw;
    height: 10.7vw;
    border-left: 1px solid #7A919D;
  }
}
.l-nav__children {
  display: none;
}
@media screen and (min-width: 768px) {
  .l-nav__children {
    position: absolute;
    left: 0;
    z-index: 1000;
    background: rgba(var(--accent-rgb), 1.0); /*グロナビhover*/
    width: 100%;
    transform: translateY(30px);
    padding: 70px 0;
  }
}
.l-nav__children.is-on {
  display: block;
}
@media screen and (max-width: 767px) {
  .l-nav__children {
    padding-bottom: 6.7vw;
    font-size: 4vw;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__children-row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__children-hdr {
    color: #fff;
    width: 380px;
    line-height: 1.5;
    font-weight: 500;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__children-ttl {
    font-size: 2.7rem;
    margin-top: -10px;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__children-en {
    font-size: 1.3rem;
    margin-top: 0.1em;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__children-list {
    width: calc(100% - 380px);
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 17px 2.1212121212%;
  }
  .l-nav__children-list li {
    width: 22.8181818182%;
    /*width: 31.8181818182%;*/
  }
  .l-nav__children-list a {
    font-weight: 500;
    /*padding: 0.9em 1.2em 0.8em 1.2em;*/
    font-size: 1.7rem;
    display: block;
    /*background: #fff;
    border-radius: 100em;*/
    transition: 0.25s color;
    color: #fff;
  }
}
@media screen and (min-width: 768px) and (hover: hover) {
  .l-nav__children-list a:hover {
    /*color: var(--accent);*/
    opacity: 0.8;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__children-list a.has-pc-arrow {
    background: url("../img/icon/arrow_a_white.svg") calc(100% - 60px) 54%/9px 13px no-repeat;
    /*background: #fff url("../img/icon/arrow_a.svg") calc(100% - 20px) 54%/9px 13px no-repeat;*/
  }
  .l-nav__children-list a.has-icon {
    padding: 0.5em 1.2em;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0 15px;
  }
  .l-nav__children-list a .icon img {
    width: calc(var(--w) * 1px);
  }
}
@media screen and (max-width: 767px) {
  .l-nav__children-list > li + li {
    margin-top: 0.6em;
  }
  
  .l-nav__children-list li {
    margin-left: 17px;
  }
}
.l-nav__link {
  display: block;
  transition: .05s color;
}

@media (hover: hover) {
  .l-nav__link:hover {
  color: #DB5837;
    /*color: var(--accent);*/
  }
}
@media screen and (min-width: 768px) {
  .l-nav__link {
    padding: 0 45px;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 1px;
  }
  .l-nav__item:last-child .l-nav__link {
    padding-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__link {
    padding: 5.1vw 0;
    font-size: 4.5vw;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__other {
    margin-top: 6.9vw;
  }
  .l-nav__other li {
    margin-bottom: 0.8em;
  }
  .l-nav__other a {
    color: #fff;
  }
}

body .aligncenter {
  display: block;
  margin: 10px auto;
}
body .alignright {
  float: right;
  margin-right: 0 0 0 10px;
}
body .alignleft {
  float: left;
  margin: 0 10px 0 0;
}

/*========================================
  ボタン
========================================*/
.c-btn {
  cursor: pointer;
  position: relative;
  display: inline-block;
  line-height: 1.1;
  text-decoration: none;
  user-select: none;
  border: 0;
}

/*========================================
  アイコン
========================================*/
.c-icon {
  position: relative;
  display: inline-block;
  background: 50% 50% no-repeat;
  background-size: contain;
  vertical-align: top;
  line-height: 1;
  font-style: normal;
}

/*========================================
  ボタン
========================================*/
.p-btn-totop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: 0.25s opacity;
}
@media screen and (max-width: 767px) {
  .p-btn-totop {
    width: 17.3vw;
    right: 6px;
    bottom: 1vw;
  }
}
.p-btn-totop.is-scrolled {
  opacity: 1;
  pointer-events: fill;
}

.p-btn-a {
  background: rgba(var(--accent-rgb), 0.9);
  color: #fff;
  font-size: 1.7rem;
  border-radius: 100em;
  padding: 18px 22px;
  transition: 0.25s filter;
}
.p-btn-a.has-arrow {
  text-align: left;
}
@media screen and (min-width: 768px) {
  .p-btn-a.has-arrow {
    padding-left: 26px;
    padding-right: 40px;
  }
}
.p-btn-a.has-arrow .p-icon-arrow-a {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .p-btn-a {
    font-size: 4vw;
  }
}
.p-btn-a__row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 17px;
}
.p-btn-a .p-icon-arrow {
  transition: 0.25s transform;
}
@media (hover: hover) {
  .p-btn-a:hover {
    filter: brightness(110%);
  }
  .p-btn-a:hover .p-icon-arrow {
    transform: translateX(4px);
  }
}

.p-btn-b {
  border: 1px solid #003884;
  color: #003884;
  font-size: 1.7rem;
  border-radius: 100em;
  padding: 18px 22px;
  transition-property: color, background;
  transition-duration: 0.25s;
}
@media screen and (max-width: 767px) {
  .p-btn-b {
    font-size: 4.5vw;
  }
}
.p-btn-b__row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 10px;
}
.p-btn-b .p-icon-arrow {
  transition: 0.25s transform;
}
@media (hover: hover) {
  .p-btn-b:hover {
    background-color: #fff;
    color: var(--accent);
  }
  .p-btn-b:hover .p-icon-arrow {
    transform: translateX(4px);
    stroke: var(--accent);
  }
}

/*========================================
  hdr
========================================*/
.p-hdr-catch {
  text-align: center;
}
.p-hdr-catch__ttl {
  color: #4D382D;
  font-size: 3.4rem;
  font-weight: bold;
  letter-spacing: 2px;
  padding:5px 5px;
  line-height: 1.6;
  background: radial-gradient(circle at calc(100% - 7px) calc(100% - 7px), #F5EE84 7px, transparent 7px) ,
              radial-gradient(circle at 7px calc(100% - 7px), #F5EE84 7px, transparent 7px) ,
              linear-gradient(to bottom, #F7F2E7 calc(100% - 14px), transparent calc(100% - 14px)) ,
              linear-gradient(to right, transparent 7px, #F5EE84 7px, #F5EE84 calc(100% - 7px), transparent calc(100% - 7px));
  display:inline;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.p-hdr-catch h3 {
  font-size: 2.3rem;
  font-weight: bold;
}

.p-hdr-a {
  font-size: 3.6rem;
  text-align: center;
  font-weight: bold;
  letter-spacing: 4px;
}

.p-hdr-a:after {
  content: "";
  margin: 0 auto;
  display: block;
  width: 40px;
  height: 4px;
  background-color: #DB5837;
  margin-top: 10px;
  /*border-radius: 2px;
  background: linear-gradient(25deg, #F13F79, #FFC778);*/
}

.p-hdr-b {
  text-align: center;
}
.p-hdr-b .p-hdr-b__ttl {
  display: inline-block;
  font-size: 2.7rem;
  color: #fff;
  font-weight: bold;
  background-color: #DB5837;
  padding: 10px 80px;
  border-radius: 100px;
  line-height: 1.1;
}


.p-hdr-c__ttl {
  font-size: 2.7rem;
  font-weight: 500;
  border-left: 4px solid var(--accent);
  padding-left: 0.9523809524em;
}

.p-hdr-d {
  font-size: 3.1rem;
  letter-spacing: 3px;
  font-weight: 500;
}

.p-hdr-d__ttl {
  font-size: 2.4rem;
  font-weight: 500;
  color: #fff;
  background-color: #003884;
  padding: 13px;
  padding-left: 0.9523809524em;
  border-radius: 8px;
}

.p-hdr-e {
  text-align: center;
}

.p-hdr-e .string {
  position: relative;
  display: inline-block;
  font-size: 2.5rem;
  color: #003884;
}

.p-hdr-e .string:before {
  display: block;
  content: "";
  position: absolute;
  left: 0%;
  top: 50%;
  background: #999;
  width: 40px;
  height: 1px;
}

.p-hdr-e .string:after {
  display: block;
  content: "";
  position: absolute;
  right: 0%;
  top: 50%;
  background: #999;
  width: 40px;
  height: 1px;
}

.p-hdr-e .string:before {
  margin-left: -80px;
}

.p-hdr-e .string:after {
  margin-right: -80px;
}

.p-hdr-f__ttl {
  font-size: 2.1rem;
  font-weight: 500;
  color: #003884;
  background-color: #E8ECEE;
  padding: 8px 8px 6px 8px;
  padding-left: 0.9523809524em;
  border-radius: 8px;
}


@media screen and (max-width: 767px) {
  .p-hdr-catch__ttl {
  font-size: 2.8rem;
}

.p-hdr-catch h3 {
  font-size: 2.2rem;
}
  .p-hdr-c__ttl {
    font-size: 2.4rem;
  }
  
  .p-hdr-a {
    font-size: 3rem;
  }
  
  .p-hdr-b .p-hdr-b__ttl {
  font-size: 2.4rem;
  padding: 10px 0;
  width: 100%;
}
  
  /*.p-hdr-b {
    text-align: center;
  }*/
  .p-hdr-b h2 {
    font-size: 2.8rem;
  }
  .p-hdr-b h3 {
    font-size: 2.8rem;
  }
  
  .p-hdr-d {
    font-size: 2.4rem;
  }
  
  .p-hdr-d__ttl {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  
  .p-hdr-e {
    margin-bottom: 4vw;
  }

  .p-hdr-e .string {
    width: 60%;
    font-size: 6.0vw;
  }

  .p-hdr-e p {
    font-size: 4.6vw;
  }

  .p-hdr-e .string:before {
    width: 40px;
    left: 20px;
  }

  .p-hdr-e .string:after {
    width: 40px;
    right: 20px;
  }
}


/*========================================
  アイコン
========================================*/
.p-icon-arrow {
  width: 31px;
  height: 11px;
  stroke: #003884;
}
.p-icon-arrow-a {
  background-image: url("../img/icon/arrow_a_white.svg");
  width: 7px;
  height: 14px;
}
.p-icon-arrow-b {
  background-image: url("../img/icon/arrow_b_blue.svg");
  width: 10px;
  height: 19px;
  position: absolute;
  top: 41%;
  right: 30px;
}
@media screen and (max-width: 767px) {
  .p-icon-arrow {
    width: 6.9vw;
    height: 2.4vw;
  }
  .p-icon-arrow-a {
    width: 1.6vw;
    height: 5vw;
  }
}


.is .p-icon-toggle::before {
  transform: rotate(0);
}

.p-icon-toggle {
  width: 3.6vw;
  height: 3.6vw;
  margin-left: 5px;
}
.p-icon-toggle::before, .p-icon-toggle::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  background: #fff;
  transform: translateY(50%);
  border-radius: 10px;
}
.p-icon-toggle::before {
  transition: 0.25s transform;
  transform: rotate(90deg);
}
.p-icon-toggle::after {
  transform: rotate(0);
}

/*========================================
  fix-nav
========================================*/
.p-fix-nav {
  background: #fff;
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  z-index: 100;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  transform: translateY(100%);
  transition: 0.25s transform;
  border-top: 1px solid #ccc;
}
.p-fix-nav.is-scrolled {
  transform: translateY(0%);
}
@media screen and (min-width: 768px) {
  .p-fix-nav {
    display: none;
  }
}
.p-fix-nav__item {
  width: 50%;
}
.p-fix-nav__tel {
  text-align: center;
  padding: 3vw 0 0 0;
}
.p-fix-nav__tel p {
  font-weight: 500;
  font-size: 3.5vw;
  line-height: 1.1;
}
.p-fix-nav__tel div {
  line-height: 1.1;
  font-size: 7vw;
  color: var(--accent);
  font-weight: 500;
}
.p-fix-nav__tel img {
  position: relative;
  width: 4.0vw;
  top: -0.6vw;
  margin-right: 1vw;
}
/*========================================
  sidenav
========================================*/
@media screen and (max-width: 767px) {
  .p-sidenav {
    /*background: #F6F4EF;*/
    padding: 10vw 5vw 9vw 5vw;
  }
}
.p-sidenav__ttl {
  background: var(--accent);
  font-weight: 500;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .p-sidenav__ttl {
    margin-bottom: 15px;
    height: 78px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    padding: 2px 30px 0 80px;
    font-size: 1.9rem;
  }
  .p-sidenav__ttl .c-icon {
    left: 0;
    margin-right: 10px;
    transition: left 0.25s;
  }
}
@media screen and (max-width: 767px) {
  .p-sidenav__ttl {
    display: block;
    margin-bottom: 0.7em;
    padding: 3vw var(--sp-pad);
    font-size: 4.8717948718vw;
  }
  .p-sidenav__ttl .c-icon {
    top: 2.0512820513vw;
    margin-right: 2.5641025641vw;
  }
}
.p-sidenav__ttl.is-hover:hover {
  text-decoration: underline;
}
.p-sidenav__ttl.is-hover:hover .c-icon {
  left: 3px;
}
.p-sidenav__items li {
  font-size: 1.5rem;
}

.p-sidenav__items li ul {
  margin-left: 19px;
  padding-bottom: 7px;
}

@media screen and (max-width: 767px) {
  .p-sidenav__items li {
    margin-bottom: 0.5em;
  }

  .p-sidenav__items li ul {
    padding-top: 7px;
    padding-bottom: 1px;
  }
}
.p-sidenav__items a {
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-sidenav__items a {
    display: block;
    padding: 10px 20px 8px 80px;
    transition: color 0.25s;
  }
  .p-sidenav__items  li ul li a {
    padding-top: 0;
    padding-bottom: 3px;
  }
}
@media screen and (max-width: 767px) {
  .p-sidenav__items {
    padding-top: 10px;
  }
  .p-sidenav__items a {
    padding: 0 0 0 var(--sp-pad);
    font-size: 4vw;
    /*font-size: 3.8461538462vw;*/
  }

}
.p-sidenav__items a:hover {
  color: var(--accent);
}
.p-sidenav__items a:hover::after {
  opacity: 1;
  transform: translate(5px, -50%);
}
.p-sidenav__items a[aria-current=page] {
  color: var(--accent);
}
.p-sidenav__items a[aria-current=page]::after {
  opacity: 1;
  transform: translate(0, -50%);
}
.p-sidenav__items a::after {
  position: absolute;
  right: 15px;
  top: 53%;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: 6px;
  height: 9px;
  background: url("../img/icon/next.svg") 100% 50%/contain no-repeat;
  transition-property: opacity, transform;
  transition-duration: 0.4s;
}
.p-sidenav__select {
  margin: 40px 0 0 80px;
}
@media screen and (min-width: 768px) {
  .p-sidenav__select select {
    font-size: 1.5rem;
    padding: 0 0.3em;
  }
}
@media screen and (max-width: 767px) {
  .p-sidenav__select {
    margin: 5.1282051282vw 0 0 var(--sp-pad);
  }
  .p-sidenav__select select {
    font-size: 3.8461538462vw;
    padding: 0 0.3em;
  }

  .p-sidenav__items a::after {
    background: none;
  }
}



/*========================================
  breadcrumb
========================================*/
@media screen and (min-width: 768px) {
  .p-breadcrumb {
    padding: 20px 80px;
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .p-breadcrumb {
    display: none;
  }
}
.p-breadcrumb a {
  display: inline-block;
  color: var(--accent);
  text-decoration: underline;
}
.p-breadcrumb a::after {
  display: inline-block;
  margin: 0 0.5em 0 0.8em;
  content: ">";
}
.p-breadcrumb a:hover {
  text-decoration: underline;
}
/*========================================
  article
========================================*/

.p-article__hdrbox {
  padding: 30px 0 50px 0;
}
.p-article__hdr {
  border-top: 4px solid #4D382D;
}
.p-article__ttl {
  color: #4D382D;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .p-article__ttl {
		font-size: 2.7rem;
  }
}
@media screen and (max-width: 767px) {
  .p-article__hdrbox {
    padding: 6.4102564103vw 0 9.4102564103vw 0;
  }
}
.p-article__hdrbox {
	position: relative;
	display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-article__ttl {
    font-size: 6.3846153846vw;
  }
  
  .p-article__hdrbox dl {
    margin-bottom: 15px;
  }
}
.p-article__meta {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 15px;
  gap: 0 .8em;
}
.p-article__date {
  font-weight: 500;
}
.p-article .p-tax__link {
  padding-top: .2em;
  padding-bottom: .2em;
}
@media screen and (min-width: 768px) {
  .p-article__date {
    font-size: 1.5rem;
    color: #888;
    margin-top: 3px;
  }
}
@media screen and (max-width: 767px) {
  .p-article__date {
    font-size: 3.8461538462vw;
    color: #888;
    margin-top: 4px;
  }
}
.p-article__body {
  line-height: 1.9;
}
@media screen and (min-width: 768px) {
  .p-article__body {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .p-article__body {
    font-size: 4vw;
    /*font-size: 3.8461538462vw;*/
  }
}
.p-article__body > p,
.p-article__body > div,
.p-article__body > figure,
.p-article__body > ul,
.p-article__body > ol {
  margin-bottom: 2em;
}
@media screen and (max-width: 767px) {
  .p-article__body > p,
.p-article__body > div,
.p-article__body > ul,
.p-article__body > ol {
    margin-bottom: 2em;
  }
}
@media screen and (min-width: 768px) {
  .p-article__body h2 {
    font-size: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  .p-article__body h2 {
    font-size: 5.3846153846vw;
  }
}
@media screen and (min-width: 768px) {
  .p-article__body figcaption {
    margin: 1em 0 !important;
  }
}
.p-article__body .wp-block-column figcaption {
  text-align: center;
}
.p-article__wbtn {
  text-align: center;
  margin-top: 100px;
}
.p-article__wbtn .p-btn-a {
  min-width: 210px;
}
@media screen and (max-width: 767px) {
  .p-article__wbtn {
    margin-top: 18vw;
  }
  .p-article__wbtn .p-btn-a {
    min-width: 80%;
  }
}

/*========================================
  list
========================================*/
.p-list-disc {
  font-size: 1.8rem;
}
.p-list-disc.ss {
  font-size: 1.6rem;
  line-height: 1.7;
}

@media screen and (max-width: 767px) {
  .p-list-disc {
    font-size: 4vw;
  }
}
.p-list-disc > li {
  position: relative;
  padding-left: 1.6em;
}
.p-list-disc > li::before {
  position: absolute;
  left: 0;
  top: 0.43em;
  content: "";
  display: block;
  width: 1em;
  height: 1em;
  background-color: #A58953;
  /*background: var(--accent);*/
  border-radius: 100px;
}
.p-list-disc.ss > li::before {
  top: 0.3em;
}
.p-table-a .p-list-disc.ss > li::before {
  top: 0.3em;
}
.p-table-a .p-list-disc.ss.ib li {
  display: inline-block;
  margin-right: 15px;
}

.p-list-disc dt {
  color: #4D382D;
}

.p-list-disc.ib dd {
  display: inline-block;
  margin-right: 15px;
}

.p-list-disc > dd {
  position: relative;
  padding-left: 1.6em;
}
.p-list-disc > dd::before {
  position: absolute;
  left: 0;
  top: 0.6em;
  content: "";
  display: block;
  width: 1em;
  height: 1em;
  background-color: #A58953;
  /*background: var(--accent);*/
  border-radius: 100px;
}
.p-list-disc.ss > dd::before {
  top: 0.3em;
}
.p-table-a .p-list-disc.ss > dd::before {
  top: 0.3em;
}

.p-list-disc-dl > dt {
  position: relative;
  padding-left: 1.6em;
}
.p-list-disc-dl > dt::before {
  position: absolute;
  left: 0;
  top: 0.6em;
  content: "";
  display: block;
  width: 1em;
  height: 1em;
  background-color: #003884;
  /*background: var(--accent);*/
  border-radius: 100px;
}
.p-list-disc-dl.ss > dt::before {
  top: 0.4em;
}

.p-list-disc.ss.il li {
  display: inline-block;
  margin-right: 30px;
  margin-bottom: 5px;
}

.p-list-figtxt__fig {
  position: relative;
}
.p-list-figtxt__fig img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-list-figtxt__fig img {
    border-radius: 10px;
  }
}
.p-list-figtxt__icon {
  font-size: 1.9rem;
  line-height: 1.1;
  display: inline-block;
  background: #E24711;
  color: #fff;
  border-radius: 100em;
  padding: 0.4em 1em;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-list-figtxt__icon {
    transform: translateY(-50%);
  }
  
}
@media screen and (max-width: 767px) {
  .p-list-disc.ss > dd::before {
    top: 0.4em;
  }

  .p-list-disc.ss.il li {
    display: block;
    margin-right: 0;
  }
  
  .p-table-a .p-list-disc.ss.ib > li::before {
    top: 0.7rem;
  }
  
  .feature-2 .p-list-figtxt__fig p {
    text-align: right;
  }
  .feature-2 .p-list-figtxt__fig p img {
    width: 75%;
  }
  .feature-3 .p-list-figtxt__fig p {
    text-align: right;
  }
  .feature-3 .p-list-figtxt__fig p img {
    width: 75%;
  }
  
  .p-list-figtxt__icon {
    margin-bottom: 0.6em;
    margin-left: var(--sp-pad);
    font-size: 3.9vw;
  }
}
.p-list-figtxt__ttl {
  color: #003884;
  margin: 0 0 15px 0;
  font-size: 2.9rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-list-figtxt__ttl {
    margin-bottom: 10.7vw;
    padding-right: var(--sp-pad);
    padding-left: var(--sp-pad);
    font-size: 5.6vw;
  }
}
@media screen and (max-width: 767px) {
  .p-list-figtxt__txt {
    padding-top: var(--sp-pad);
    padding-right: var(--sp-pad);
    padding-left: var(--sp-pad);
    font-size: 4vw;
  }
}
.p-list-figtxt__wbtn {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .p-list-figtxt__wbtn {
    margin-top: 7vw;
    text-align: center;
  }
}

/*========================================
  time-table
========================================*/
@media screen and (max-width: 767px) {
  .p-time-table {
    font-size: 4vw;
  }
}
.p-time-table__table-wrap {
  overflow: hidden;
  border-radius: 10px;
  /*border: 1px solid #ccc;*/
}
.p-time-table__table-wrap.ct {
  border: 1px solid #ccc;
  border-bottom: 0;
}

.p-time-table__table {
  background: #fff;
  width: 100%;
}
.p-time-table__table.is tbody tr:last-child th, .p-time-table__table.is tbody tr:last-child td {
  border-bottom: 0;
}
.p-time-table__table th, .p-time-table__table td {
  padding: 0.6em 0.6em;
}
@media screen and (max-width: 767px) {
  .p-time-table__table-wrap {
    /*border: 1px solid #ccc;*/
    border-bottom: 0;
  }
  .p-time-table__table th, .p-time-table__table td {
    padding: 0.6em 0.2em;
    line-height: 1.4;
  }
  
  .p-time-table__table-wrap td small {
    font-size: 63%;
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .p-time-table__table th:last-child, .p-time-table__table td:last-child {
    padding-right: 22px;
  }
}
@media screen and (max-width: 767px) {
  .p-time-table__table th:last-child, .p-time-table__table td:last-child {
    padding-right: 0.3em;
  }
}
.p-time-table__table thead th {
  background: #003884;
  color: #fff;
  font-weight: bold;
  font-size: 1.8rem;
}
@media screen and (min-width: 768px) {
  .p-time-table__table thead th.is-1 {
    width: 180px;
  }
}
@media screen and (max-width: 767px) {
  .p-time-table__table thead th.is-1 {
    width: 4em;
    padding-left: 3vw;
  }
}

.p-time-table__table tbody .bd th, .p-time-table__table tbody .bd td {
  border-bottom: 1px solid #ccc;
}

/*.p-time-table__table tbody th, .p-time-table__table tbody td {
  border-bottom: 1px solid #ccc;
}*/

.p-time-table__table tbody th {
  text-align: left;
  font-size: 1.8rem;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .p-time-table__table tbody th {
    padding-left: 30px;
  }
  .p-time-table__table tbody th.morning {
    padding-left: 41px;
  }
}
@media screen and (max-width: 767px) {
  .p-time-table__table tbody th {
    padding-left: 3.3vw;
    font-size: 1.5rem;
  }
  .p-time-table__table tbody th.morning {
    padding-left: 3.3vw;
  }
}
.p-time-table__table td {
  text-align: center;
  font-size: 1.8rem;
  /*color: #003884;*/
}

.p-time-table__table td.is-none {
  color: #1A1311;
  font-family:'メイリオ', 'Meiryo','ＭＳ ゴシック','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
}
.p-time-table__note {
  line-height: 1.7;
}
@media screen and (min-width: 768px) {
  .p-time-table__note {
  text-align: center;
  margin-top: 20px;
    /*padding: 12px 30px;*/
  }
}
@media screen and (max-width: 767px) {
  
  .p-time-table__table thead th {
    font-size: 1.5rem;
    line-height: 1.4;
    padding: 10px;
    width: 14%;
  }
  .p-time-table__table tbody th {
    font-size: 1.3rem;
  }
  .p-time-table__table td {
    font-size: 1.5rem;
  }
  
  .p-time-table__note {
    margin-top: 4vw;
  }
}
.p-time-table__note.is {
  padding-left: 0;
  padding-right: 0;
}
.p-time-table__note a {
  text-decoration: underline;
}
@media screen and (max-width: 767px) {
  .p-time-table__time {
    margin-bottom: 6.5em;
  }
}
.p-time-table .icon-pin {
  margin-right: 5px;
  margin-top: -2px;
}
@media screen and (max-width: 767px) {
  .p-time-table .icon-pin {
    width: 3.7vw;
  }
}

/*========================================
  leed
========================================*/
.p-leed {
  padding: 110px 0 280px 0;
}
@media screen and (max-width: 767px) {
.p-leed {
  padding: 70px 0 150px 0;
}
}


/*========================================
  sinryo
========================================*/
.p-sinryo {
  background: url("../img/content/sinryo_bg.jpg") 50% 50%/cover;
  padding: 110px 0 110px 0;
}
@media screen and (max-width: 767px) {
  .p-sinryo {
    padding: 13.3vw 0 27.3vw 0;
  }
}
@media screen and (min-width: 768px) {
  .p-sinryo__lead {
    text-align: center;
    margin-top: 40px;
    margin-bottom: 80px;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .p-sinryo__lead {
    margin-top: 8vw;
    margin-bottom: 10.7vw;
  }
}
.p-sinryo__list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .p-sinryo__list {
    gap: 30px;
  }
}
@media screen and (max-width: 767px) {
  .p-sinryo__list {
    gap: 2.7vw 0;
    justify-content: space-between;
  }
}
@media screen and (min-width: 768px) {
  .p-sinryo__item {
    width: 200px;
  }
}
@media screen and (max-width: 767px) {
  .p-sinryo__item {
    width: 48.5714285714%;
  }
}
.p-sinryo__cont {
  display: block;
  height: 100%;
  color: #fff;
  border-radius: 10px;
  background: #003884;
  box-shadow: 0px 3px 4px rgba(0, 0, 0, 0.16);
  padding: 40px 20px;
}
@media screen and (max-width: 767px) {
  .p-sinryo__cont {
    padding: 8vw 5.3vw 5.3vw 5.3vw;
  }
}
@media (hover: hover) {
  .p-sinryo__cont:hover {
    box-shadow: 0px 3px 4px rgba(0, 0, 0, 0.3);
  }
  .p-sinryo__cont:hover .p-sinryo__wicon img {
    transform: translateY(-10px);
  }
}
.p-sinryo__wicon {
  text-align: center;
}
.p-sinryo__wicon img {
  transition: transform 0.25s;
  width: 47%;
}
@media screen and (max-width: 767px) {
  .p-sinryo__wicon img {
    width: calc(var(--w) / 300 * 100vw);
  }
}
.p-sinryo__ttl {
  margin: 12px 0 20px 0;
  text-align: center;
  line-height: 1.5;
  font-size: 2.3rem;
  font-weight: 500;
  text-align: center;
  letter-spacing: 2px;
}

.sinryo__wtxt {
  text-align: center;
  font-size: 2.1rem;
  padding-top: 15px;
  line-height: 1.3;
  letter-spacing: 3px;
}

@media screen and (max-width: 767px) {
  .p-sinryo__ttl {
    margin: 3.2vw 0 4.3vw 0;
    font-size: 5.1vw;
  }
  .p-sinryo__ttl span {
    letter-spacing: -1px;
  }
  .sinryo__wtxt {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .p-sinryo dd {
    line-height: 1.4;
    font-size: 4vw;
  }
}

/*========================================
  tax
========================================*/
.p-tax__link {
  font-size: 1.2rem;
  min-width: 88px;
  display: inline-block;
  border-radius: 100px;
  background: var(--accent);
  color: #fff;
  padding: 0.3em 0.3em 0.3em 0.3em;
  text-align: center;
  line-height: 1.1;
  font-weight: bold;
}
.p-tax__link.important {
  background: #E24711;
}
.p-tax__link.recruit {
  background: #448BEF;
}

/*========================================
  posts
========================================*/

/*.p-posts {
  border-top: 1px solid #ccc;
}
.p-posts > li {
  border-bottom: 1px solid #ccc;
}*/
.p-posts__row {

  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0 0 30px 0;
}
@media screen and (max-width: 767px) {
  .p-posts__row {
    padding: 8vw 0;
  }
}
@media (hover: hover) {
  .p-posts__row:hover .p-posts__fig img {
    scale: 1.2;
  }
}
.p-posts__fig {
  overflow: hidden;
  width: 120px;
  height: 90px;
}
@media screen and (max-width: 767px) {
  .p-posts__fig {
    width: 32vw;
    height: 24vw;
  }
}
.p-posts__fig img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: 0.25s scale;
}
@media screen and (min-width: 768px) {
  .p-posts__wtxt {
    width: calc(100% - 160px);
  }
}
@media screen and (max-width: 767px) {
  .p-posts__wtxt {
    width: 53.3vw;
  }
}
.p-posts__meta {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0 14px;
  margin-bottom: 0.5em;
}
.p-posts__date {
  font-weight: 500;
  color: #888888;
  font-size: 1.5rem;
}

.p-posts__meta .p-tax {
  margin-top: -3px;
}

.p-posts-tax {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.8em;
  line-height: 1.1;
}
@media screen and (max-width: 767px) {
  .p-posts-tax {
    margin: 10.7vw 0 6.7vw 0;
  }
}
.p-posts-tax a {
  display: inline-block;
  background: #F6F4EF;
  border-radius: 10px;
  padding: 0.4em 0.8em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-posts-tax a {
    font-size: 3.7vw;
  }
}
.p-posts-tax a.is-active {
  background: var(--accent);
  color: #fff;
}

/******************************
 * util display
 ******************************/
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal;
}

.u-hide {
  display: none;
}

.u-disp-ib {
  display: inline-block;
}

@media screen and (min-width: 768px) {
  .u-sp-only {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .u-pc-only {
    display: none;
  }
}
/******************************
 * util margin
 ******************************/
.u-mt-5 {
  margin-top: 5px;
}

.u-mr-5 {
  margin-right: 5px;
}

.u-mt-5 {
  margin-top: 5px;
}

.u-mb-5 {
  margin-bottom: 5px;
}

.u-ml-5 {
  margin-left: 5px;
}

.u-mt-10 {
  margin-top: 10px;
}

.u-mr-10 {
  margin-right: 10px;
}

.u-mt-10 {
  margin-top: 10px;
}

.u-mb-10 {
  margin-bottom: 10px;
}

.u-ml-10 {
  margin-left: 10px;
}

.u-mt-15 {
  margin-top: 15px;
}

.u-mr-15 {
  margin-right: 15px;
}

.u-mt-15 {
  margin-top: 15px;
}

.u-mb-15 {
  margin-bottom: 15px;
}

.u-ml-15 {
  margin-left: 15px;
}

.u-mt-20 {
  margin-top: 20px;
}

.u-mr-20 {
  margin-right: 20px;
}

.u-mt-20 {
  margin-top: 20px;
}

.u-mb-20 {
  margin-bottom: 20px;
}

.u-ml-20 {
  margin-left: 20px;
}

.u-mt-25 {
  margin-top: 25px;
}

.u-mt-30 {
  margin-top: 30px;
}

.u-mr-30 {
  margin-right: 30px;
}

.u-mt-30 {
  margin-top: 30px;
}

.u-mb-30 {
  margin-bottom: 30px;
}

.u-ml-30 {
  margin-left: 30px;
}

.u-mt-40 {
  margin-top: 40px;
}

.u-mr-40 {
  margin-right: 40px;
}

.u-mt-40 {
  margin-top: 40px;
}

.u-mb-40 {
  margin-bottom: 40px;
}

.u-ml-40 {
  margin-left: 40px;
}

.u-mt-50 {
  margin-top: 50px;
}

.u-mr-50 {
  margin-right: 50px;
}

.u-mt-50 {
  margin-top: 50px;
}

.u-mb-50 {
  margin-bottom: 50px;
}

.u-ml-50 {
  margin-left: 50px;
}

.u-mt-60 {
  margin-top: 60px;
}

.u-mr-60 {
  margin-right: 60px;
}

.u-mt-60 {
  margin-top: 60px;
}

.u-mb-60 {
  margin-bottom: 60px;
}

.u-ml-60 {
  margin-left: 60px;
}

.u-mt-70 {
  margin-top: 70px;
}

.u-mr-70 {
  margin-right: 70px;
}

.u-mt-70 {
  margin-top: 70px;
}

.u-mb-70 {
  margin-bottom: 70px;
}

.u-ml-70 {
  margin-left: 70px;
}

.u-mt-80 {
  margin-top: 80px;
}

.u-mr-80 {
  margin-right: 80px;
}

.u-mt-80 {
  margin-top: 80px;
}

.u-mb-80 {
  margin-bottom: 80px;
}

.u-ml-80 {
  margin-left: 80px;
}

.u-mt-90 {
  margin-top: 90px;
}

.u-mr-90 {
  margin-right: 90px;
}

.u-mt-90 {
  margin-top: 90px;
}

.u-mb-90 {
  margin-bottom: 90px;
}

.u-ml-90 {
  margin-left: 90px;
}

.u-mt-100 {
  margin-top: 100px;
}

.u-mr-100 {
  margin-right: 100px;
}

.u-mt-100 {
  margin-top: 100px;
}

.u-mb-100 {
  margin-bottom: 100px;
}

.u-ml-100 {
  margin-left: 100px;
}

.u-mb-120 {
  margin-bottom: 120px;
}

.u-mt-120 {
  margin-top: 120px;
}

.u-mb-130 {
  margin-bottom: 130px;
}

.u-mb-150 {
  margin-bottom: 150px;
}

.u-mt-150 {
  margin-top: 150px;
}

.u-mt-180 {
  margin-top: 180px;
}

.u-mt-200 {
  margin-top: 200px;
}

.u-mb-200 {
  margin-bottom: 200px;
}

.u-mb-300 {
  margin-bottom: 300px;
}

.reset-mt {
  margin-top: 0;
}

.reset-mr {
  margin-right: 0;
}

.reset-mb {
  margin-bottom: 0;
}

.reset-ml {
  margin-left: 0;
}

@media screen and (max-width: 767px) {
  .u-sp-mb-3 {
    margin-bottom: 3vw;
  }
  .u-sp-mt-2 {
    margin-top: 2vw;
  }
  .u-sp-mt-5 {
    margin-top: 5vw;
  }
  .u-sp-mr-5 {
    margin-right: 5vw;
  }
  .u-sp-mt-5 {
    margin-top: 5vw;
  }
  .u-sp-mb-5 {
    margin-bottom: 5vw;
  }
  .u-sp-ml-5 {
    margin-left: 5vw;
  }
  .u-sp-mt-10 {
    margin-top: 10vw;
  }
  .u-sp-mr-10 {
    margin-right: 10vw;
  }
  .u-sp-mt-10 {
    margin-top: 10vw;
  }
  .u-sp-mb-10 {
    margin-bottom: 10vw;
  }
  .u-sp-ml-10 {
    margin-left: 10vw;
  }
  .u-sp-mt-15 {
    margin-top: 15vw;
  }
  .u-sp-mr-15 {
    margin-right: 15vw;
  }
  .u-sp-mt-15 {
    margin-top: 15vw;
  }
  .u-sp-mb-15 {
    margin-bottom: 15vw;
  }
  .u-sp-ml-15 {
    margin-left: 15vw;
  }
  .u-sp-mt-20 {
    margin-top: 20vw;
  }
  .u-sp-mr-20 {
    margin-right: 20vw;
  }
  .u-sp-mt-20 {
    margin-top: 20vw;
  }
  .u-sp-mb-20 {
    margin-bottom: 20vw;
  }
  .u-sp-ml-20 {
    margin-left: 20vw;
  }
  .u-sp-mt-30 {
    margin-top: 30vw;
  }
  .u-sp-mr-30 {
    margin-right: 30vw;
  }
  .u-sp-mt-30 {
    margin-top: 30vw;
  }
  .u-sp-mb-30 {
    margin-bottom: 30vw;
  }
  .u-sp-ml-30 {
    margin-left: 30vw;
  }
  .u-sp-mt-40 {
    margin-top: 40vw;
  }
  .u-sp-mr-40 {
    margin-right: 40vw;
  }
  .u-sp-mt-40 {
    margin-top: 40vw;
  }
  .u-sp-mb-40 {
    margin-bottom: 40vw;
  }
  .u-sp-ml-40 {
    margin-left: 40vw;
  }
  .u-sp-mt-50 {
    margin-top: 50vw;
  }
  .u-sp-mr-50 {
    margin-right: 50vw;
  }
  .u-sp-mt-50 {
    margin-top: 50vw;
  }
  .u-sp-mb-50 {
    margin-bottom: 50vw;
  }
  .u-sp-ml-50 {
    margin-left: 50vw;
  }
  .u-sp-mt-60 {
    margin-top: 60vw;
  }
  .u-sp-mr-60 {
    margin-right: 60vw;
  }
  .u-sp-mt-60 {
    margin-top: 60vw;
  }
  .u-sp-mb-60 {
    margin-bottom: 60vw;
  }
  .u-sp-ml-60 {
    margin-left: 60vw;
  }
  .u-sp-mt-70 {
    margin-top: 70vw;
  }
  .u-sp-mr-70 {
    margin-right: 70vw;
  }
  .u-sp-mt-70 {
    margin-top: 70vw;
  }
  .u-sp-mb-70 {
    margin-bottom: 70vw;
  }
  .u-sp-ml-70 {
    margin-left: 70vw;
  }
  .u-sp-mt-80 {
    margin-top: 80vw;
  }
  .u-sp-mr-80 {
    margin-right: 80vw;
  }
  .u-sp-mt-80 {
    margin-top: 80vw;
  }
  .u-sp-mb-80 {
    margin-bottom: 80vw;
  }
  .u-sp-ml-80 {
    margin-left: 80vw;
  }
  .u-sp-mt-90 {
    margin-top: 90vw;
  }
  .u-sp-mr-90 {
    margin-right: 90vw;
  }
  .u-sp-mt-90 {
    margin-top: 90vw;
  }
  .u-sp-mb-90 {
    margin-bottom: 90vw;
  }
  .u-sp-ml-90 {
    margin-left: 90vw;
  }
  .u-sp-mt-100 {
    margin-top: 100vw;
  }
  .u-sp-mr-100 {
    margin-right: 100vw;
  }
  .u-sp-mt-100 {
    margin-top: 100vw;
  }
  .u-sp-mb-100 {
    margin-bottom: 100vw;
  }
  .u-sp-ml-100 {
    margin-left: 100vw;
  }
  .reset-sp-mt {
    margin-top: 0;
  }
  .reset-sp-mr {
    margin-right: 0;
  }
  .reset-sp-mb {
    margin-bottom: 0;
  }
  .reset-sp-ml {
    margin-left: 0;
  }
}
/******************************
 * util padding
 ******************************/
.u-pt-5 {
  padding-top: 5px;
}

.u-pr-5 {
  padding-right: 5px;
}

.u-pt-5 {
  padding-top: 5px;
}

.u-pb-5 {
  padding-bottom: 5px;
}

.u-pl-5 {
  padding-left: 5px;
}

.u-pt-10 {
  padding-top: 10px;
}

.u-pr-10 {
  padding-right: 10px;
}

.u-pt-10 {
  padding-top: 10px;
}

.u-pb-10 {
  padding-bottom: 10px;
}

.u-pl-10 {
  padding-left: 10px;
}

.u-pt-15 {
  padding-top: 15px;
}

.u-pr-15 {
  padding-right: 15px;
}

.u-pt-15 {
  padding-top: 15px;
}

.u-pb-15 {
  padding-bottom: 15px;
}

.u-pl-15 {
  padding-left: 15px;
}

.u-pt-20 {
  padding-top: 20px;
}

.u-pr-20 {
  padding-right: 20px;
}

.u-pt-20 {
  padding-top: 20px;
}

.u-pb-20 {
  padding-bottom: 20px;
}

.u-pl-20 {
  padding-left: 20px;
}

.u-pt-30 {
  padding-top: 30px;
}

.u-pr-30 {
  padding-right: 30px;
}

.u-pt-30 {
  padding-top: 30px;
}

.u-pb-30 {
  padding-bottom: 30px;
}

.u-pl-30 {
  padding-left: 30px;
}

.u-pt-40 {
  padding-top: 40px;
}

.u-pr-40 {
  padding-right: 40px;
}

.u-pt-40 {
  padding-top: 40px;
}

.u-pb-40 {
  padding-bottom: 40px;
}

.u-pl-40 {
  padding-left: 40px;
}

.u-pt-50 {
  padding-top: 50px;
}

.u-pr-50 {
  padding-right: 50px;
}

.u-pt-50 {
  padding-top: 50px;
}

.u-pb-50 {
  padding-bottom: 50px;
}

.u-pl-50 {
  padding-left: 50px;
}

.u-pt-60 {
  padding-top: 60px;
}

.u-pr-60 {
  padding-right: 60px;
}

.u-pt-60 {
  padding-top: 60px;
}

.u-pb-60 {
  padding-bottom: 60px;
}

.u-pl-60 {
  padding-left: 60px;
}

.u-pt-70 {
  padding-top: 70px;
}

.u-pr-70 {
  padding-right: 70px;
}

.u-pt-70 {
  padding-top: 70px;
}

.u-pb-70 {
  padding-bottom: 70px;
}

.u-pl-70 {
  padding-left: 70px;
}

.u-pt-80 {
  padding-top: 80px;
}

.u-pr-80 {
  padding-right: 80px;
}

.u-pt-80 {
  padding-top: 80px;
}

.u-pb-80 {
  padding-bottom: 80px;
}

.u-pl-80 {
  padding-left: 80px;
}

.u-pt-90 {
  padding-top: 90px;
}

.u-pr-90 {
  padding-right: 90px;
}

.u-pt-90 {
  padding-top: 90px;
}

.u-pb-90 {
  padding-bottom: 90px;
}

.u-pl-90 {
  padding-left: 90px;
}

.u-pt-100 {
  padding-top: 100px;
}

.u-pr-100 {
  padding-right: 100px;
}

.u-pt-100 {
  padding-top: 100px;
}

.u-pb-100 {
  padding-bottom: 100px;
}

.u-pl-100 {
  padding-left: 100px;
}

.u-reset-pt {
  padding-top: 0;
}

.u-reset-pr {
  padding-right: 0;
}

.u-reset-pb {
  padding-bottom: 0;
}

.u-reset-pl {
  padding-left: 0;
}

.u-pad-top {
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .u-pad-top {
    margin-top: 14vw;
  }
  .u-sp-pad {
    padding-right: var(--sp-pad);
    padding-left: var(--sp-pad);
  }
  .u-sp-pt-5 {
    padding-top: 5vw;
  }
  .u-sp-pr-5 {
    padding-right: 5vw;
  }
  .u-sp-pt-5 {
    padding-top: 5vw;
  }
  .u-sp-pb-5 {
    padding-bottom: 5vw;
  }
  .u-sp-pl-5 {
    padding-left: 5vw;
  }
  .u-sp-pt-10 {
    padding-top: 10vw;
  }
  .u-sp-pr-10 {
    padding-right: 10vw;
  }
  .u-sp-pt-10 {
    padding-top: 10vw;
  }
  .u-sp-pb-10 {
    padding-bottom: 10vw;
  }
  .u-sp-pl-10 {
    padding-left: 10vw;
  }
  .u-sp-pt-15 {
    padding-top: 15vw;
  }
  .u-sp-pr-15 {
    padding-right: 15vw;
  }
  .u-sp-pt-15 {
    padding-top: 15vw;
  }
  .u-sp-pb-15 {
    padding-bottom: 15vw;
  }
  .u-sp-pl-15 {
    padding-left: 15vw;
  }
  .u-sp-pt-20 {
    padding-top: 20vw;
  }
  .u-sp-pr-20 {
    padding-right: 20vw;
  }
  .u-sp-pt-20 {
    padding-top: 20vw;
  }
  .u-sp-pb-20 {
    padding-bottom: 20vw;
  }
  .u-sp-pl-20 {
    padding-left: 20vw;
  }
  .u-sp-pt-30 {
    padding-top: 30vw;
  }
  .u-sp-pr-30 {
    padding-right: 30vw;
  }
  .u-sp-pt-30 {
    padding-top: 30vw;
  }
  .u-sp-pb-30 {
    padding-bottom: 30vw;
  }
  .u-sp-pl-30 {
    padding-left: 30vw;
  }
  .u-sp-pt-40 {
    padding-top: 40vw;
  }
  .u-sp-pr-40 {
    padding-right: 40vw;
  }
  .u-sp-pt-40 {
    padding-top: 40vw;
  }
  .u-sp-pb-40 {
    padding-bottom: 40vw;
  }
  .u-sp-pl-40 {
    padding-left: 40vw;
  }
  .u-sp-pt-50 {
    padding-top: 50vw;
  }
  .u-sp-pr-50 {
    padding-right: 50vw;
  }
  .u-sp-pt-50 {
    padding-top: 50vw;
  }
  .u-sp-pb-50 {
    padding-bottom: 50vw;
  }
  .u-sp-pl-50 {
    padding-left: 50vw;
  }
  .u-sp-pt-60 {
    padding-top: 60vw;
  }
  .u-sp-pr-60 {
    padding-right: 60vw;
  }
  .u-sp-pt-60 {
    padding-top: 60vw;
  }
  .u-sp-pb-60 {
    padding-bottom: 60vw;
  }
  .u-sp-pl-60 {
    padding-left: 60vw;
  }
  .u-sp-pt-70 {
    padding-top: 70vw;
  }
  .u-sp-pr-70 {
    padding-right: 70vw;
  }
  .u-sp-pt-70 {
    padding-top: 70vw;
  }
  .u-sp-pb-70 {
    padding-bottom: 70vw;
  }
  .u-sp-pl-70 {
    padding-left: 70vw;
  }
  .u-sp-pt-80 {
    padding-top: 80vw;
  }
  .u-sp-pr-80 {
    padding-right: 80vw;
  }
  .u-sp-pt-80 {
    padding-top: 80vw;
  }
  .u-sp-pb-80 {
    padding-bottom: 80vw;
  }
  .u-sp-pl-80 {
    padding-left: 80vw;
  }
  .u-sp-pt-90 {
    padding-top: 90vw;
  }
  .u-sp-pr-90 {
    padding-right: 90vw;
  }
  .u-sp-pt-90 {
    padding-top: 90vw;
  }
  .u-sp-pb-90 {
    padding-bottom: 90vw;
  }
  .u-sp-pl-90 {
    padding-left: 90vw;
  }
  .u-sp-pt-100 {
    padding-top: 100vw;
  }
  .u-sp-pr-100 {
    padding-right: 100vw;
  }
  .u-sp-pt-100 {
    padding-top: 100vw;
  }
  .u-sp-pb-100 {
    padding-bottom: 100vw;
  }
  .u-sp-pl-100 {
    padding-left: 100vw;
  }
  .u-reset-sp-ml {
    margin-left: 0;
  }
  .u-reset-sp-pt {
    padding-top: 0;
  }
  .u-reset-sp-pr {
    padding-right: 0;
  }
  .u-reset-sp-pb {
    padding-bottom: 0;
  }
  .u-reset-sp-pl {
    padding-left: 0;
  }
}
/******************************
 * util width
 ******************************/
.u-fix-w {
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .u-fix-w {
    width: var(--base-width);
  }
}

.u-fix-w-m {
  margin-right: auto;
  margin-left: auto;
}
.u-fix-w-ml {
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .u-fix-w-m {
    width: 1080px;
  }
  .u-fix-w-ml {
    width: 1180px;
  }
}

.u-fix-w-s {
  margin-right: auto;
  margin-left: auto;
}

.u-fix-w-ss {
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .u-fix-w-s {
    width: 1000px;
  }
  
  .u-fix-w-ss {
    width: 920px;
  }
}

.u-w-10 {
  width: 10%;
}

.u-w-20 {
  width: 20%;
}

.u-w-30 {
  width: 30%;
}

.u-w-40 {
  width: 40%;
}

.u-w-50 {
  width: 50%;
}

.u-w-60 {
  width: 60%;
}

.u-w-70 {
  width: 70%;
}

.u-w-80 {
  width: 80%;
}

.u-w-90 {
  width: 90%;
}

.u-w-100 {
  width: 100%;
}

.u-w-180 {
  width: 180px;
}

.u-w-240 {
  width: 240px;
}

.u-w-250 {
  width: 250px;
}

.u-w-270 {
  width: 270px;
}

.u-w-320 {
  width: 320px;
}

.u-w-300 {
  width: 300px;
}

.u-w-370 {
  width: 370px;
}

.u-w-400 {
  width: 400px;
}

.u-w-430 {
  width: 430px;
}

.u-w-450 {
  width: 450px;
}

.u-w-480 {
  width: 480px;
}

.u-w-500 {
  width: 500px;
}

.u-w-530 {
  width: 530px;
}

.u-w-540 {
  width: 540px;
}

.u-w-550 {
  width: 550px;
}

.u-w-570 {
  width: 570px;
}

.u-w-580 {
  width: 580px;
}

.u-w-600 {
  width: 600px;
}

.u-w-630 {
  width: 630px;
}

.u-w-650 {
  width: 650px;
}

.u-w-680 {
  width: 680px;
}

.u-w-700 {
  width: 700px;
}

.u-w-full {
  width: 100%;
}

.reset-max-w {
  max-width: none;
}

@media screen and (max-width: 767px) {
  .sp-full-w {
    margin-right: calc(-1 * var(--sp-pad));
    margin-left: calc(-1 * var(--sp-pad));
  }
  .reset-sp-w {
    width: auto;
  }
}
/******************************
 * util align
 ******************************/
.u-block-c {
  margin-left: auto;
  margin-right: auto;
}

.u-align-c {
  text-align: center;
}

.u-align-r {
  text-align: right;
}

.u-align-l {
  text-align: left;
}

.u-valign-t {
  vertical-align: top;
}

.u-valign-m {
  vertical-align: middle;
}

.u-valign-b {
  vertical-align: bottom;
}

@media screen and (max-width: 767px) {
  .u-sp-align-c {
    text-align: center;
  }
  .u-sp-align-r {
    text-align: right;
  }
  .u-sp-align-l {
    text-align: left;
  }
}
/******************************
 * util font size
 ******************************/
.u-fs-11 {
  font-size: 1.1rem;
}

.u-fs-12 {
  font-size: 1.2rem;
}

.u-fs-13 {
  font-size: 1.3rem;
}

.u-fs-14 {
  font-size: 1.4rem;
}

.u-fs-15 {
  font-size: 1.5rem;
}

.u-fs-16 {
  font-size: 1.6rem;
}

.u-fs-17 {
  font-size: 1.7rem;
}

.u-fs-18 {
  font-size: 1.8rem;
}

.u-fs-19 {
  font-size: 1.9rem;
}

.u-fs-20 {
  font-size: 2rem;
}

.u-fs-21 {
  font-size: 2.1rem;
}

.u-fs-22 {
  font-size: 2.2rem;
}

.u-fs-23 {
  font-size: 2.3rem;
}
.u-sp-fs-23 {
  font-size: 2.3rem!important;
}

.u-fs-24 {
  font-size: 2.4rem;
}

.u-fs-25 {
  font-size: 2.5rem;
}

.u-fs-26 {
  font-size: 2.6rem;
}

.u-fs-27 {
  font-size: 2.7rem;
}

.u-fs-28 {
  font-size: 2.8rem;
}

.u-fs-29 {
  font-size: 2.9rem;
}

.u-fs-30 {
  font-size: 3rem;
}

/******************************
 * util other
 ******************************/
.u-pos-rel {
  position: relative;
}

.u-pos-abs {
  position: absolute;
}

.u-float-l {
  float: left;
}

.u-float-r {
  float: right;
}

.u-wbreak {
  word-break: break-all;
}

.u-nowrap {
  white-space: nowrap;
}

.u-ellipsis {
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reset-a-style {
  cursor: default;
}

@media screen and (max-width: 767px) {
  .reset-sp-pos {
    position: static;
  }
}
@media screen and (min-width: 768px) {
  .u-col-3 {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6.0163934426%;
  }
  .u-col-3 > li {
    width: 28.6557377049%;
  }
  
  .u-col-3.ft-bnr {
    gap: 4.0163934426%;
  }
  .u-col-3.ft-bnr > li {
    width: 30.6557377049%;
  }
}
@media screen and (max-width: 767px) {
  .u-col-3 > li + li {
    margin-top: 21.3vw;
  }
}
@media screen and (min-width: 768px) {
  .u-col-2 {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .u-col-2 > li {
    width: 47.5%;
  }
  
  .u-col-2 > dl {
    width: 46%;
  }
  
  .u-col-2.group > dl {
    width: 43%;
  }
  
  .u-col-3-u {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .u-col-3-u > dl {
    width: 30%;
  }
  
  .u-col-4 {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .u-col-4 > dl {
    width: 258px;
  }
  
}

.u-col-2 li {
    list-style: none;
  }

@media screen and (max-width: 767px) {
  .u-col-2 > li + li {
    margin-top: 21.3vw;
  }
  
  .u-col-2 > dl + dl {
    margin-top: 21.3vw;
  }
  
  .u-col-2.img > dl + dl {
    margin-top: 12.7vw;
  }
  
  .u-col-2.btn > li + li {
    margin-top: 4.3vw;
  }
  
  .u-col-3-u > li + li {
    margin-top: 21.3vw;
  }
}

.u-tran {
  transition-property: opacity, transform;
  transition-duration: 1s;
  opacity: 0;
  transform: translateY(20px);
}
.u-tran.is-fire {
  opacity: 1;
  transform: translateY(0);
}

.is-hover {
  transition: .25s opacity;
}

@media (hover: hover) {
  .is-hover:hover {
    opacity: .8;
  }
}


/*========================================
  vis-link
========================================*/
.p-vis-link {
  overflow: hidden;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0px 3px 20px rgba(0, 0, 0, 0.16);
  transition: 0.25s box-shadow;
}
@media screen and (min-width: 768px) {
  .p-vis-link {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .p-vis-link {
    font-size: 3.8461538462vw;
  }
}
.p-vis-link.is-hover:hover {
  color: #003884;
  box-shadow: 0px 3px 20px rgba(0, 0, 0, 0.3);
}
.p-vis-link.is-hover:hover .p-icon-carr {
  transform: translateX(3px);
}
.p-vis-link.is-hover:hover .p-vis-link__fig img {
  transform: scale(1.1);
}
.p-vis-link .p-icon-carr {
  margin-right: 15px;
  margin-top: 0;
  /*margin-top: 1px;*/
  transition: 0.25s transform;
}
@media screen and (max-width: 767px) {
  .p-vis-link .p-icon-carr {
    margin-right: 2.5641025641vw;
    margin-top: 0;
  }
}
.p-vis-link__wtxt {
  width: calc(100% - 175px);
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  font-weight: 500;
  padding: 10px 0 10px 30px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .p-vis-link__wtxt {
  width: calc(100% - 145px);
  padding: 2.5641025641vw 0 2.5641025641vw 0;
    /*padding: 2.5641025641vw 0 2.5641025641vw 5.0282051282vw;*/
    font-size: 4.5025641026vw;
  }
}
.p-vis-link__wfig {
  width: 140px;
}
@media screen and (max-width: 767px) {
  .p-vis-link__wfig {
    width: 28.9743589744vw;
  }
}
.p-vis-link__fig {
  overflow: hidden;
  height: 100px;
}
@media screen and (max-width: 767px) {
  .p-vis-link__fig {
    height: 20.5128205128vw;
  }
}
.p-vis-link__fig img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: 0.25s transform;
}


/*========================================
  under-table
========================================*/

.p-table-a {
  border-top: 1px solid #ccc;
}
.p-table-a th, .p-table-a td {
  padding: 0.625em 1.5625em;
}
.p-table-a th {
  padding-left: 0;
}
.p-table-a tr {
  border-bottom: 1px solid #ccc;
}
.p-table-a th {
  position: relative;
  text-align: left;
  padding-right: 0;
  /*color: #003884;*/
}
.p-table-a th p {
  padding: 1.25em 0;
}
.p-table-a th p::after {
  content: "";
  display: block;
  width: 1px;
  height: calc(100% - 2.5em);
  position: absolute;
  right: 0;
  top: 50%;
  background: #ddd;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) { 
  .p-table-a.is-sp-break {
    display: block;
  }
  .p-table-a.is-sp-break th, .p-table-a.is-sp-break td, .p-table-a.is-sp-break tr, .p-table-a.is-sp-break tbody {
    display: block;
  }
  .p-table-a.is-sp-break th, .p-table-a.is-sp-break td {
    padding: 0 0.625em;
  }
  .p-table-a.is-sp-break td {
    padding-bottom: 1.245em;
    padding-top: 0.125em;
    line-height: 1.7;
  }
  .p-table-a.is-sp-break th {
    padding-top: 1.125em;
    width: auto;
  }
  .p-table-a.is-sp-break th p {
    border-right: 0;
    padding: 0;
  }
  .p-table-a.is-sp-break th p::after {
    display: none;
  }
}

.u-rad-img {
  border-radius: 20px;
}