@charset "UTF-8";
/******************************
 * reset
 ******************************/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap");
:root {
  --sans-serif: "Noto Sans JP", "ヒラギノ角ゴシック", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",
  	sans-serif;
  --serif: "Noto Serif JP", serif;
  --en-sans: "ヒラギノ角ゴシック", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
  --en-serif: "", serif;
  --base: #fff;
  --main: #222;
  --accent: #ff8c00;   /*#0E68B7;*/
  --base-width: 1184px;
  --sp-base-fs: 4vw;
  --sp-pad: 5.7vw;
}

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

html {
  font-size: 10px;
  scroll-behavior: smooth;
  scroll-padding-top: 108px;
}

@media screen and (max-width: 767px) {
  html {
    scroll-padding-top: 18vw;
  }
}

body {
  line-height: 2.2;
  font-feature-settings: "palt" 1;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  font-family: var(--sans-serif);
  font-size: 1.6rem;
}
@media screen and (min-width: 768px) {
  body {
    min-width: 1300px;
  }
}

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

ol,
ul {
  list-style: none;
}

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

img {
  vertical-align: middle;
}

@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: #000;
  text-decoration: none;
}

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

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

small {
  font-size: 80%;
}

figcaption {
  line-height: 1.6;
}

* {
  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: 1.6rem;
  }
}
@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    display: inline-block;
    pointer-events: none;
  }
}

img {
  letter-spacing: 0;
  height: auto;
}

:focus-visible {

/*
    outline: 2px solid #000;
*/
    outline: 1px solid #0061e0; 
    box-shadow: 0 0 0 3px color-mix(in srgb, #0061e0 25%, transparent);

}




img,
svg,
iframe,
video,
picture {
  max-width: 100%;
}

/******************************
 * l-footer
 ******************************/


.l-footer {
background-color: #3c3c3c;
  line-height: 1.4;
  padding: 80px 0;
}

@media screen and (max-width: 767px) {
  .l-footer {
/*    margin: 10.3vw 0 0 0;*/
  }







}
@media screen and (min-width: 768px) {
  .l-footer__row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }


    .l-footer__wlink  li:not(:last-child) {
        border-right: 1px solid #fff;
        padding-right: 15px;
        margin-right: 15px;
        margin-bottom: 0;
      }




}
.l-footer__wlink {
  font-size: 1.4rem;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin: 0 auto;
  padding :20px 0px;
}
.l-footer__wlink > li {
  margin-right: 1em;
}

@media screen and (max-width: 767px) {
  .l-footer__wlink {
    display: block;
    text-align: center;

    font-size: 3.8vw;
    justify-content: left;
    margin-left: 5.7vw;
    margin-right: 5.7vw;
  }
  .l-footer__wlink > li {
    margin-bottom: 1.7vw;
  }
}

.l-footer__wlink > li a {
  color: #fff;
}

@media (hover: hover) {
  .l-footer__wlink a:hover {
    text-decoration: underline;
  }
}







.l-footer__copy {
  font-size: 1.3rem;
  color: #fff;
  margin: 0 auto;
  padding :30px 0px;
}
@media screen and (max-width: 767px) {
  .l-footer__copy {
    margin-top: 6.7vw;
    display: block;
    text-align: center;
    font-size: 3.1vw;
    margin-left: 5.7vw;
    margin-right: 5.7vw;
  }
}








.l-footer__logo {
  font-size: 2.5rem;
  color: #fff;
  margin: 0 auto;
  padding-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .l-footer__logo {
    margin-top: 6.7vw;
    display: block;
    text-align: center;
    font-size: 5.1vw;
    margin-left: 5.7vw;
    margin-right: 5.7vw;
  }
}






.l-footer__address {
  font-size: 1.5rem;
  color: #fff;
  margin: 0 auto;
  padding :5px 0px;
}
@media screen and (max-width: 767px) {
  .l-footer__address {
    margin-top: 6.7vw;
    display: block;
    text-align: center;
    font-size: 3.1vw;
    margin-left: 5.7vw;
    margin-right: 5.7vw;
  }
}





.l-footer__info {
  font-size: 1.5rem;
  color: #fff;
  margin: 0 auto;
padding :5px 0px;
}
.l-footer__info .br768 {
  display : none;
}
@media screen and (max-width: 767px) {
  .l-footer__info {
    margin-top: 2vw;
    display: block;
    text-align: center;
    font-size: 3.1vw;
    margin-left: 5.7vw;
    margin-right: 5.7vw;
  }
  .l-footer__info .br768 {
    display : inline;
  }

}









.l-footer__access {
  font-size: 1.5rem;
  color: #fff;
  margin: 0 auto;
  padding :20px 0px;
}


@media screen and (max-width: 767px) {
  .l-footer__access {
    margin-top: 3.1vw;
    display: block;
    text-align: center;
    font-size: 3.1vw;
    margin-left: 5.7vw;
    margin-right: 5.7vw;
  }
}














.l-footer__totop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  opacity: 0;
  z-index: 9;
  pointer-events: none;
  transition: filter 0.25s;
}
@media (hover: hover) {
  .l-footer__totop:hover {
    filter: brightness(110%);
  }
  .l-footer__totop:hover .c-icon {
    transform: translateX(4px);
  }
}
.l-footer__totop.is-show {
  opacity: 1;
  pointer-events: fill;
}

@media screen and (max-width: 767px) {
  .l-footer__totop {
    bottom: 10px;
    right: 10px;
    width: 15.7vw;
    height: 15.7vw;
  }
}

/******************************
 * l-header
 ******************************/
.l-header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 10;
/** background: white;**/

    background: rgba(255, 228, 8, 0.9);

  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
@media screen and (min-width: 768px) {
  .l-header {
    background: rgba(255, 228, 8, 0.9);


    padding: 20px 140px 5px 30px;
    min-width: var(--base-width);
  }
}
.l-header__inner {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (min-width: 768px) {
  .l-header__inner {
    align-items: center;
  }
}
.l-header__logo {
  width: 242px;
}
@media screen and (max-width: 767px) {
  .l-header__logo {
    width: 47.8vw;
  }
}
@media screen and (max-width: 767px) {
  .l-header__nav {
    background: var(--accent);
  }
}

/******************************
 * l-nav
 ******************************/
@media screen and (max-width: 767px) {
  .l-nav {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__sp-wlink {
    height: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding-left: 2.1vw;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__sp-link {
    margin: 0 1.3vw;
    width: 8.5vw;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    font-size: 1.5rem;
/*    margin-top: -14px;*/
    padding-right: 40px;
  }
}
.l-nav__link {
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .l-nav__link {
    font-size: 4.4vw;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__txt {
    display: inline-block;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__txt {
    border-top: 1px solid #fff;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
/*    padding: 5.1vw 0 0 0;*/
    padding: 3.1vw 0 0 0;
  }
  .l-nav__txt.is-nb {
    border-top: 0;
  }
  .l-nav__item.btm {
    border-bottom: 1px solid #fff;
/*    padding-bottom: 5.1vw;*/
    padding-bottom: 3.1vw;
  }
}
.l-nav__toggle {
  background: transparent;
  border: 0;
  padding: 0;
  width: 11.5vw;
  height: 10.3vw;
  border-left: 1px solid #fff;
}
@media screen and (min-width: 768px) {
  .l-nav__toggle {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__body {
    transition: top 0.25s;
    background: var(--accent);
    color: #fff;
    position: fixed;
    left: 0;
    top: 16.6vw;
    width: 100%;
    height: 100vh;
    overflow: auto;
    padding: 1vw 5.1vw 120px 5.1vw;
  }
  .l-nav__body[aria-hidden=true] {
    top: -110vh;
  }
  .l-nav__body a {
    color: #fff;
  }
}
.l-nav__item {
  position: relative;
}
@media screen and (min-width: 768px) {
  .l-nav__item:not(:last-child)::after {
    display: inline-block;
    content: "｜";
    margin: 0 0.8em;
  }
  .l-nav__item:hover .l-nav__link {
    color: var(--accent);
  }
  .l-nav__item:hover .l-nav__children {
    display: block;
    opacity: 1;
    pointer-events: fill;
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
  }
}
@media screen and (max-width: 767px) {
  .l-nav__item {
/*    margin-top: 5.1vw;*/
    margin-top: 3.1vw;
  }
}
@media screen and (min-width: 768px) {
  .l-nav__children {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    left: 0;
    padding-top: 10px;
    padding-left: 10px;
    transition: all 0.4s;
    transform: translateY(-6px);
  }
  .l-nav__children ul {
    width: 186px;
    background: var(--accent);
    padding: 16px 22px;
    box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  }
  .l-nav__children a {
    color: #fff;
    display: block;
    padding: 8px;
  }
  #children-2.l-nav__children ul {
    width: 286px;
  }
}
@media screen and (min-width: 768px) and (hover: hover) {
  .l-nav__children a:hover {
    text-decoration: underline;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__children {
    display: none;
    font-size: 3.8vw;
  }
  .l-nav__children ul {
    padding-bottom: 1.3vw;
    margin-left: 4vw;
  }
  .l-nav__children li {
    margin-top: 2.6vw;
  }
}
.l-nav__line {
  fill: #fff;
  stroke: none;
  stroke-miterlimit: 10;
  stroke-width: 2px;
}
.l-nav__btn {
  background: transparent;
  border: 0;
  padding: 0;
}
@media screen and (min-width: 768px) {
  .l-nav__btn {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .l-nav__btn {
    width: 14.1vw;
  }
}
.l-nav__btn svg {
  vertical-align: top;
  width: 6.9vw;
}
.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);
}
.l-nav__link[aria-current=page] {
  color: var(--accent);
}
@media screen and (max-width: 767px) {
  .l-nav__sublink {
    font-size: 3.8vw;
    margin-top: 12.8vw;
  }
  .l-nav__sublink > li {
    margin-top: 0.4em;
  }
  
  .l-nav__link[aria-current=page] {
    color: #fff;
  }
}

/******************************
 * l-sideba
 ******************************/
.l-sidebar__ttl {
  background-color: var(--accent);
  color: #fff;
  font-weight: bold;
  margin-bottom: 15px;
  padding: 30px 80px;
}
@media screen and (max-width: 767px) {
  .l-sidebar__ttl {
    margin-bottom: 1em;
    padding: 1em 2em;
  }
}
.l-sidebar .cat-item {
  line-height: 1.5;
}
.l-sidebar .cat-item a {
  padding: 12px 80px;
  display: block;
}
@media screen and (max-width: 767px) {
  .l-sidebar .cat-item a {
    padding: 1em 2em 0 2em;
  }
}
@media (hover: hover) {
  .l-sidebar .cat-item a:hover {
    text-decoration: underline;
  }
}
.l-sidebar .cat-item a[aria-current=page] {
  font-weight: bold;
  color: var(--accent);
}

/******************************
 * l-sideba
 ******************************/
.l-row {
  margin-top: 100px;
}
@media screen and (min-width: 768px) {
  .l-row {
    display: grid;
    grid-auto-flow: column;
    grid-template: "b a";
    margin-bottom: 100px;
  }
}

.l-row__main {
  grid-area: a;
}
@media screen and (min-width: 768px) {
  .l-row__main {
    width: 797px;
  }
}
.l-row__main table {
  border-top: 1px solid #DDDDDD;
  border-bottom: 1px solid #DDDDDD;
  width: 100%;
}
.l-row__sidebar {
  grid-area: b;
}
@media screen and (min-width: 768px) {
  .l-row__sidebar {
    width: 275px;
  }
}
@media screen and (max-width: 767px) {
  .l-row {
    margin-top: 50px;
  }
  .l-row__sidebar {
    margin: 22.8vw 0 15.8vw 0;
  }
  .l-row__main table {
    border-bottom: 0;
  }
}

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-btn:hover {
  text-decoration: none;
}

/*========================================
  アイコン
========================================*/
.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-a {
  background: var(--accent);
  color: #fff;
  padding: 20px 24px 20px 30px;
  border-radius: 100px;
  font-weight: bold;
  transition: filter 0.25s;
}
@media screen and (max-width: 767px) {
  .p-btn-a {
    padding: 5.1vw 7.7vw;
    font-size: 4.1vw;
  }
}
.p-btn-a .c-icon {
  margin-left: 10px;
  vertical-align: bottom;
  transition: transform 0.25s;
}
@media (hover: hover) {
  .p-btn-a:hover {
    filter: brightness(110%);
  }
  .p-btn-a:hover .c-icon {
    transform: translateX(4px);
  }
}

.p-btn-b {
  border: 2px solid var(--accent);
  color: var(--accent);
  padding: 24px 20px;
  border-radius: 100px;
  font-weight: bold;
  transition-property: background, color;
  transition-duration: 0.25s;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-btn-b {
    min-width: 258px;
  }
}
@media screen and (max-width: 767px) {
  .p-btn-b {
    font-size: 4.1vw;
    padding: 1em 2em;
  }
}
@media (hover: hover) {
  .p-btn-b:hover {
    background-color: var(--accent);
    color: #fff !important;
  }
}

.p-btn-c {
  background: var(--accent);
  color: #fff;
  padding: 26px 40px 26px 30px;
  font-weight: bold;
  transition: filter 0.25s;
}
@media screen and (max-width: 767px) {
  .p-btn-c {
    padding: 5.1vw 8.7vw 5.1vw 6.7vw;
    font-size: 4.1vw;
  }
}
.p-btn-c .c-icon {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  vertical-align: bottom;
  transition: transform 0.25s;
}
@media (hover: hover) {
  .p-btn-c:hover {
    filter: brightness(110%);
  }
  .p-btn-c:hover .c-icon {
    transform: translate(4px, -50%);
  }
}

.p-btn-d {
  border: 3px solid var(--accent);
  border-radius: 100px;
  color: var(--accent);
  font-size: 2.1rem;
  font-weight: bold;
  padding: 1.4285714286em 3.3333333333em 1.4285714286em 1.9047619048em;
  transition-property: color, background;
  transition-duration: 0.25s;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .p-btn-d {
    padding: 1em 2em;
    font-size: 4.4vw;
    line-height: 1.6;
  }
}
.p-btn-d svg {
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  fill: none;
  stroke: var(--accent);
  transition-property: stroke, transform;
  transition-duration: .25s;
}
@media screen and (max-width: 767px) {
  .p-btn-d svg {
    right: 3.6vw;
  }
  
  .p-btn-d.is-red {
    width: 100%;
  }
}
.p-btn-d.is-red {
  border-color: #90224E;
  color: #90224E;
}
@media (hover: hover) {
  .p-btn-d.is-red:hover {
    background: #90224E;
  }
}
.p-btn-d.is-red svg {
  stroke: #90224E;
}
@media (hover: hover) {
  .p-btn-d:hover {
    background: var(--accent);
    color: #fff;
  }
  .p-btn-d:hover svg {
    stroke: #fff;
    transform: translate(6px, -50%);
  }
}

/*========================================
  hdr
========================================*/
.p-hdr-page {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  background: 50% 50%/cover no-repeat;
  color: #fff;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .p-hdr-page {
    padding-top: 108px;
    height: 420px;
  }
}
@media screen and (max-width: 767px) {
  .p-hdr-page {
    padding-top: 17.9vw;
    height: 62.6vw;
  }
}
.p-hdr-page__inner {
  padding: 0 80px;
}
@media screen and (max-width: 767px) {
  .p-hdr-page__inner {
    padding: 0 var(--sp-pad);
  }
}
.p-hdr-page__ttl {
  font-size: 4.5rem;
/*  text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);*/
  text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.8);
}
@media screen and (max-width: 767px) {
  .p-hdr-page__ttl {
    font-size: 7.4vw;
  }
}
.p-hdr-page__en {
  margin-top: 0.5em;
  font-size: 1.8rem;
  font-family: var(--en-sans);
/*  text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);*/
  text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.8);
}
@media screen and (max-width: 767px) {
  .p-hdr-page__en {
    margin-top: 0.2em;
    font-size: 4.1vw;
  }
}

.p-hdr-a {
  text-align: center;
  margin-bottom: 55px;
}
@media screen and (max-width: 767px) {
  .p-hdr-a {
    margin-bottom: 9vw;
  }
}
.p-hdr-a.is-firstview {
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-hdr-a.is-firstview {
    margin-top: 12.8vw;
  }
}
.p-hdr-a.is-firstitem {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .p-hdr-a.is-firstitem {
    margin-top: 9vw;
  }
}
.p-hdr-a__en {
  font-family: var(--en-sans);
  color: var(--accent);
  font-size: 4.2rem;
  line-height: 1;
  font-weight: bold;
  margin-bottom: 8px;
}
@media screen and (max-width: 767px) {
  .p-hdr-a__en {
    font-size: 8.2vw;
  }
}
.p-hdr-a__en.is-red {
  color: #90224E;
}
.p-hdr-a__ja {
  color: var(--accent);
  font-size: 3.8rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-hdr-a__ja {
    font-size: 6.2vw;
  }
}
.p-hdr-a__ttl {
  font-size: 1.6rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-hdr-a__ttl {
    font-size: 3.8vw;
  }
}

/*.p-hdr-b {
  margin-bottom: 0.9677419355em;
}*/
@media screen and (max-width: 767px) {
  .p-hdr-b {
    margin-bottom: 6.7vw;
  }
}
.p-hdr-b__ttl {
  font-size: 3.1rem;
  font-weight: bold;
  line-height: 1.9;
}
.p-hdr-b__ttl.small {
  font-size: 2.7rem;
  line-height: 1.8;
}

@media screen and (max-width: 767px) {
  .p-hdr-b__ttl {
    font-size: 5.8vw;
  }
  
  .p-hdr-b__ttl.small {
    font-size: 5.8vw;
  }
  
}

.p-hdr-c {
/*  margin-bottom: 80px;*/
    width:100%;

}
@media screen and (max-width: 767px) {
  .p-hdr-c {
    margin-bottom: 10.3vw;
  }
}
.p-hdr-c.is-red .p-hdr-c__ttl {
  background: #90224E;
}
.p-hdr-c__ttl {
  background-color: var(--accent);
  color: #fff;
  border-radius: 100px;
  font-size: 2.5rem;
  font-weight: bold;
  padding: 0.56em 1.4em;
}
@media screen and (max-width: 767px) {
  .p-hdr-c__ttl {
    font-size: 5.6vw;
    border-radius: 20px;
    padding: 0.56em 1em;
  }
}

/*.p-hdr-d {
  margin-bottom: 30px;
}*/
@media screen and (max-width: 767px) {
  /*.p-hdr-d {
    margin-bottom: 6.4vw;
  }*/
}
.p-hdr-d__ttl {
  font-size: 2.1rem;
  font-weight: bold;
  border-left: 4px solid var(--accent);
  padding-left: 0.9523809524em;
}
@media screen and (max-width: 767px) {
  .p-hdr-d__ttl {
    font-size: 4.9vw;
  }
}

.p-hdr-e {
  margin-bottom: 1.625em;
  padding-bottom: 1em;
  border-bottom: 1px solid var(--accent);
}
.p-hdr-e__ttl {
  color: var(--accent);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-hdr-e {
    margin-bottom: 1.125em;
  }

  .p-hdr-e__ttl {
    font-size: 4.4vw;
  }
}

.p-hdr-f__ttl {
  background-color: rgba(14, 104, 183, 0.07);
  color: var(--accent);
  border-radius: 100px;
  font-size: 2.5rem;
  font-weight: bold;
  padding: 0.56em 1.4em 0.76em 1.4em;
}
@media screen and (max-width: 767px) {
  .p-hdr-f__ttl {
    font-size: 5.1vw;
    border-radius: 20px;
    padding: 0.56em 1em 0.76em 1em;
  }
}

.p-hdr-g {
  background-color: var(--accent);
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  height: 310px;
  margin-top: 110px;
  padding: 10px 80px;
  color: #fff;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-hdr-g {
    margin-top: 14.1vw;
    padding: 7.7vw 7.7vw 5.7vw 7.7vw;
    height: 41vw;
  }
}
.p-hdr-g__en {
  font-family: var(--en-sans);
  font-size: 1.8rem;
  /*margin-top: 0.4em;*/
}
@media screen and (max-width: 767px) {
  .p-hdr-g__en {
    margin-top: 0.2em;
    font-size: 3.6vw;
  }
}
.p-hdr-g__ttl {
  font-size: 4.5rem;
  text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .p-hdr-g__ttl {
    font-size: 7.7vw;
  }
}

/*========================================
  アイコン
========================================*/
.p-icon-arr-a {
  stroke: #fff;
  fill: none;
  width: 27px;
  height: 9px;
}
@media screen and (max-width: 767px) {
  .p-icon-arr-a {
    width: 6.7vw;
    height: 2.3vw;
  }
}

.p-icon-arr-b {
  fill: none;
  stroke: #28A8EA;
  width: 40px;
  height: 9px;
}
@media screen and (max-width: 767px) {
  .p-icon-arr-b {
    width: 10.3vw;
    height: 2.3vw;
  }
}
.p-icon-arr-b.is-science {
  stroke: #9D6119;
}
.p-icon-arr-b.is-reform {
  stroke: #893888;
}
.p-icon-arr-b.is-other {
  stroke: #29C8DC;
}

.p-icon-arr-c {
  stroke: #fff;
  width: 10px;
  height: 19px;
}
@media screen and (max-width: 767px) {
  .p-icon-arr-c {
    width: 2.6vw;
    height: 5.1vw;
  }
}

.p-icon-scope {
  background-image: url("../img/icon/scope.svg");
  width: 37px;
  height: 18px;
}
.p-icon-scope * {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-icon-scope {
    width: 9.5vw;
    height: 4.6vw;
  }
}

.p-icon-arrbtm {
  background-image: url("../img/icon/arrow_btm.svg");
  width: 20px;
  height: 12px;
}

.p-icon-tax {
  width: 105px;
  border-radius: 6px;
  background: #0E68B7;
  color: #fff;
  padding: 0.7em;
  text-align: center;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .p-icon-tax {
    font-size: 3.3vw;
  }
}
.p-icon-tax.is-blog {
  background: #E28C2B;
}
.p-icon-tax.is-work {
  background: #157385;
}
.p-icon-tax.is-event {
  background: #90224E;
}

.p-icon-work {
  border-radius: 14px;
  background: #f6f3ed;
  color: var(--accent);
  font-size: 1.4rem;
  padding: 0.5em 1em;
}
@media screen and (max-width: 767px) {
  .p-icon-work {
    font-size: 3.3vw;
  }
}

.p-icon-wtax {
  border-radius: 6px;
  background: #28A8EA;
  color: #fff;
  padding: 0.4em 0.8em 0.5em 0.8em;
  text-align: center;
  font-size: 1.5rem;
}
@media screen and (max-width: 767px) {
  .p-icon-wtax {
    font-size: 3.8vw;
  }
}
.p-icon-wtax.is-science {
  background: #9D6119;
}
.p-icon-wtax.is-reform {
  background: #893888;
}
.p-icon-wtax.is-other {
  background: #29C8DC;
}

.p-icon-toggle {
  width: 3.6vw;
  height: 3.6vw;
}
.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);
}
.p-icon-toggle.is-open::before {
  transform: rotate(0);
}

/*========================================
  bnr
========================================*/
.p-bnr {
  margin-top: 40px;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .p-bnr {
    width: 1043px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-bnr {
    margin-top: 8.7vw;
  }
}
.p-bnr__list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-bnr__list {
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .p-bnr__list {
    padding-left: var(--sp-pad);
  }
}
.p-bnr__list > li {
  --sp-w: 128;
}
@media screen and (max-width: 767px) {
  .p-bnr__list > li {
    margin-right: 2.6vw;
    margin-bottom: 2.6vw;
    width: calc(var(--sp-w) / 350 * 100vw);
  }
  .p-bnr__list > li:nth-child(3) {
    margin-right: 0;
  }
  .p-bnr__list > li:nth-child(4), .p-bnr__list > li:nth-child(5) {
    margin-bottom: 6.4vw;
  }
  .p-bnr__list > li:nth-child(9) {
    margin-top: 5.1vw;
    margin-left: auto;
    margin-right: auto;
  }
}
.p-bnr__list a {
  transition: 0.25s opacity;
}
@media (hover: hover) {
  .p-bnr__list a:hover {
    opacity: 0.7;
  }
}

.u-btn-hover a {
  transition: 0.25s opacity;
}
@media (hover: hover) {
  .u-btn-hover a:hover {
    opacity: 0.7;
  }
}

/*========================================
  contact
========================================*/
.p-contact {
  margin-left: auto;
  margin-right: auto;
}

.p-contact-page {
  margin-left: auto;
  margin-right: auto;
}

.page-id-6 .p-contact {
  display: none;
}
.page-id-9 .p-contact {
  display: none;
}

@media screen and (min-width: 768px) {
  .p-contact {
    width: 1080px;
  }
  
  .p-contact-page {
    width: 1080px;
  }
}
.p-contact__lead {
  font-weight: bold;
  font-size: 2.1rem;
}
@media screen and (min-width: 768px) {
  .p-contact__lead {
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__lead {
    margin-top: 7.7vw;
    font-size: 4.6vw;
  }
}
@media screen and (min-width: 768px) {
  .p-contact__list {
    margin-top: 70px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__list {
    margin-top: 9.8vw;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__item + .p-contact__item {
    margin-top: 7.1vw;
  }
}
.p-contact__item {
  position: relative;
  background: #F6F3ED;
  border: 4px solid #DDDDDD;
  border-radius: 30px;
  text-align: center;
  padding: 75px 20px;
}
@media screen and (min-width: 768px) {
  .p-contact__item {
    margin: 0 auto;
    width: 85%;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__item {
    padding: 8.8vw 4.1vw;
  }
}

/*
.p-contact__item::before {
  content: "";
  display: block;
  width: 290px;
  height: 4px;
  background: var(--accent);
  position: absolute;
  left: 50%;
  top: -4px;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .p-contact__item::before {
    width: 51.3vw;
  }
}
*/


.p-contact__ttl {
  font-size: 2.8rem;
  font-weight: bold;
  color: var(--accent);
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-contact__ttl {
    font-size: 5.5vw;
  }
}
.p-contact__res {
  line-height: 1.5;
  font-weight: bold;
  margin-top: 0.4em;
}
@media screen and (max-width: 767px) {
  .p-contact__res {
    font-size: 4.3vw;
    margin-top: 0.3em;
  }
}
@media screen and (max-width: 767px) {
  .p-contact__wicon {
    width: 11.5vw;
    margin-right: 2.6vw;
  }
}
.p-contact__tel {
  margin-top: 40px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .p-contact__tel {
    margin-top: 6.4vw;
  }
  .p-contact__tel p {
    line-height: 1.6;
  }
}
@media screen and (min-width: 768px) {
    .p-contact__value {
    margin-left: 15px;
  }
}
.p-contact__value a {
  font-size: 5rem;
  font-weight: bold;
  color: var(--accent);
  line-height: 1.1;
  font-family: var(--en-sans);
}
@media screen and (max-width: 767px) {
    .p-contact__value a {
    font-size: 7.1vw;
  }
}
.p-contact__value small {
  font-size: 1.6rem;
  display: block;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
    .p-contact__value small {
    font-size: 3.8vw;
  }
}






@media screen and (min-width: 768px) {
    .p-contact__value_mail {
    margin-left: 15px;
  }
}
.p-contact__value_mail a {
  font-size: 3.1rem;
  font-weight: bold;
  color: var(--accent);
  line-height: 1.1;
  font-family: var(--en-sans);
}
@media screen and (max-width: 767px) {
    .p-contact__value_mail a {
    font-size: 4.2vw;
  }
}
















.p-contact__wbtn {
  display: flex;


  margin-top: 33px;
}
@media screen and (max-width: 767px) {
  .p-contact__wbtn {
  display: block;
    margin-top: 6.4vw;
  }
}
.p-contact__btnicon {
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  .p-contact__btnicon {
    margin-right: 1.5vw;
    width: 10.3vw;
  }
}
.p-contact__btn {

  display: flex;
  flex-direction: row;
  flex-wrap: wrap;


  justify-content: center;

  align-items: center;
  background: #fff;
  border: 2px solid var(--accent);
  color: var(--accent);
  padding: 15px 30px;
  border-radius: 100px;
  font-weight: bold;
  transition-property: background, color;
  transition-duration: 0.25s;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .p-contact__btn {
    width: 290px;
    text-align: center;



  }
}
@media screen and (max-width: 767px) {
  .p-contact__btn {
    padding: 2.6vw;
    font-size: 4.2vw;
    justify-content: flex-start;
    width: 67vw;
    text-align: center;
  }
}
@media (hover: hover) {
  .p-contact__btn:hover {
    background-color: var(--accent);
    color: #fff;
  }
}












/*
 *
 */
.p-contact-comp {
    font-weight: bold;
}

.p-contact-comp__title {
    text-align: center;
    font-size: 2.6rem;
}
.p-contact-comp__body {
    text-align: left;
    font-size: 2.0rem;
}
.p-contact-comp__company {
    text-align: left;
    font-size: 1.8rem;
}













/*========================================
  contact-form
========================================*/

.set-col {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.set-col.is-col2 {
  justify-content: space-between;
}

.p-icon-require {
  border-radius: 6px;
  background: #cc0033;
  font-size: 1.4rem;
  color: #fff;
  width: 50px;
  text-align: center;
  padding: 0.4em 0.3em;
  font-weight: normal;
}
.p-icon-require2 {
  border-radius: 6px;
  background: #4169e1;
  font-size: 1.4rem;
  color: #fff;
  width: 50px;
  text-align: center;
  padding: 0.4em 0.3em;
  font-weight: normal;
}
@media screen and (max-width: 767px) {
  .p-icon-require, 
  .p-icon-require2 {
    width: 12.8205128205vw;
    font-size: 3.5769230769vw;
    border-radius: 1.5641025641vw;
  }
}







.mw_wp_form_confirm .is-confirm-hide {
  display: none;
}

@media screen and (min-width: 768px) {
  /*.p-form {
    font-size: 1.5rem;
  }*/
}
@media screen and (max-width: 767px) {
  /*.p-form {
    font-size: 3.8461538462vw;
  }*/
}
.p-form__wicon {
  padding-top: 0.3em;
}
.p-form__agree {
  margin-top: 60px;
  text-align: center;
}
.p-form__agree span {
  font-weight: bold;
}

.mw_wp_form .vertical-item + .vertical-item {
  margin-top: 0!important;
}

@media screen and (max-width: 767px) {
  .p-form__agree {
    margin-top: 7.6923076923vw;
  }
  .p-form__wicon {
    padding-top: 0.4em;
  }
}
@media screen and (min-width: 768px) {
  .p-form__wbtn {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    flex-direction: row-reverse;
    margin-top: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-form__wbtn {
    text-align: center;
    margin-top: 5.1282051282vw;
  }
  .p-form__wbtn > *:not(:last-child) {
    margin-bottom: 1em;
  }
}

.p-form__btn input {
  border: 2px solid var(--accent);
  color: var(--accent);
  padding: 24px 20px;
  border-radius: 100px;
  font-weight: bold;
  transition-property: background, color;
  transition-duration: 0.25s;
  text-align: center;
  font-size: 1.8rem;
  background-color: #fff;
}

@media screen and (min-width: 768px) {
  .p-form__btn input {
    min-width: 258px;
  }
}
@media screen and (max-width: 767px) {
  .p-form__btn input {
    font-size: 5.1vw;
    padding: 1em 2em;
  }
}
@media (hover: hover) {
  .p-form__btn input:hover {
    background-color: var(--accent);
    color: #fff !important;
  }
}

.p-form input[type=radio] {
  position: relative;
  top: 1px;
  transform: scale(1.5);
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  .p-form input[type=radio] {
    top: -0.5128205128vw;
  }
}



.p-form input[type=checkbox] {
  position: relative;
  top: 1px;
  transform: scale(1.5);
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  .p-form input[type=checkbox] {
    top: -0.5128205128vw;
  }
}
















.p-form select,
.p-form input[type=text],
.p-form input[type=email] {
  border-radius: 6px;
/*  background: #ffeeee;*/
  border: 2px solid #bbb;
  padding: 0.5em;
  max-width: 100%;
  font-size: 1.6rem;
}
.p-form input[type=text].is-age,
.p-form input[type=email].is-age {
  width: 4em;
}
@media screen and (min-width: 768px) {
  .p-form select,
  .p-form input[type=text],
  .p-form input[type=email] {
    height: 40px;
  }
  .p-form select.is-mini,
  .p-form input[type=text].is-mini {
    width: 120px;
  }
  .p-form select.is-short,
  .p-form input[type=text].is-short,
  .p-form input[type=email].is-short {
    width: 230px;
  }
  .p-form select.is-middle,
  .p-form input[type=text].is-middle,
  .p-form input[type=email].is-middle {
    width: 358px;
  }

  .p-form select.is-long,
  .p-form input[type=text].is-long,
  .p-form input[type=email].is-long {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .p-form input[type=text],
  .p-form input[type=email] {
    padding: 0.5em 0.5em;
  }
}


.p-form select:not(:placeholder-shown),
.p-form input[type=text]:not(:placeholder-shown),
.p-form input[type=email]:not(:placeholder-shown) {
  background: #fff;
}
.p-form textarea {
  padding: 0.5em;
  border-radius: 6px;
/*  background: #ffeeee;*/
  border: 2px solid #bbb;
  width: 100%;
  height: 200px;
}
.p-form textarea:not(:placeholder-shown) {
  background: #fff;
}
.p-form textarea.is-r-short {
  height: 100px;
}












.p-btn-back {
  border-radius: 100px;
  background-color: #efefef;
  border: 2px solid #ddd;
  text-align: center;
  font-weight: bold;
  transition-property: box-shadow;
  transition-duration: 0.25s;
  padding: 1.25em 2.5em;
  transition: 0.25s background-position;
  font-size: 1.8rem;
  font-weight: normal;
}
@media screen and (min-width: 768px) {
  .p-btn-back {
    min-width: 250px;
    margin-right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-btn-back {
    color: #222;
    min-width: 65.1025641026vw;
    font-size: 5.1025641026vw;
  }
}
.p-btn-back.is-hover:hover {
  box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.16);
  background-position: 20px 50%;
}


/*========================================
  breadcrumb
========================================*/
.p-breadcrumb {
  font-size: 1.3rem;
  line-height: 1.4;
}
@media screen and (min-width: 768px) {
  .p-breadcrumb {
    padding: 20px 80px;
    background-color: #eee;
  }
}
@media screen and (max-width: 767px) {
  /*.p-breadcrumb {
    font-size: 3.1vw;
    padding: 0.6em var(--sp-pad);
  }*/
  
  .p-breadcrumb {
    display: none;
  }
}
.p-breadcrumb a:not(:last-child)::after {
  content: "　＞　";
}

.p-breadcrumb a span {
  color: #0E68B7;
  text-decoration: underline;
}

/*========================================
  fix-nav
========================================*/
.p-fix-nav {
  position: fixed;
  right: 0;
  top: 0;
  z-index: 30;
  background: var(--accent);
  padding: 30px 0;
  width: 80px;
  writing-mode: vertical-rl;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: #fff;
  border-radius: 0 0 0 13px;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
.p-fix-nav__label {
  display: flex;
  justify-content: center;
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 12px;
}
.p-fix-nav > .p-fix-nav__link {
  margin-top: 10px;
}

/*========================================
  p-figtxt
========================================*/
@media screen and (min-width: 768px) {
  .p-figtxt {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .p-figtxt > * + * {
    margin-top: 10.3vw;
  }
}
@media screen and (min-width: 768px) {
  .p-figtxt__wtxt {
    width: 580px;
  }
}
@media screen and (min-width: 768px) {
  .p-figtxt__fig {
    width: 540px;
  }
}
@media screen and (min-width: 768px) {
  .p-figtxt__fig img {
    max-width: none;
  }
}

/*========================================
  info
========================================*/
.p-info {
  margin-top: 120px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-info {
    margin-top: 15.4vw;
  }
}
.p-info__table {
  width: 1042px;
  margin: 0 auto;
  border-top: 1px solid #DDD;
}
@media screen and (max-width: 767px) {
  .p-info__table {
    border-bottom: 1px solid #DDD;
    width: 100%;
    border-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-info tr {
    display: block;
    padding: 5.1vw 0;
    border-top: 1px solid #DDD;
  }
}
@media screen and (min-width: 768px) {
  .p-info th, .p-info td {
    padding-top: 25px;
    padding-bottom: 25px;
    border-bottom: 1px solid #DDD;
  }
}
@media screen and (max-width: 767px) {
  .p-info th, .p-info td {
    display: block;
    font-size: 4.1vw;
  }
}
.p-info th {
  color: var(--accent);
  text-align: left;
}
@media screen and (min-width: 768px) {
  .p-info th {
    width: 390px;
  }
}
@media screen and (max-width: 767px) {
  .p-info th {
    text-align: left;
  }
}

/*========================================
  lead
========================================*/
.p-lead {
  font-size: 3.1rem;
}

.p-lead .small {
  font-size: 2.7rem;
  line-height: 1.8;
}

@media screen and (max-width: 767px) {
  .p-lead {
    margin-top: 10.3vw;
    margin-bottom: 10.3vw;
    font-size: 5.8vw;
  }
  
  .p-lead span {
    font-size: 6.7vw;
    line-height: 1.4;
  }
  
  .p-lead .small {
    font-size: 1.8rem;
    line-height: 2;
  }
}

/*========================================
  list
========================================*/
.p-list-disc > li {
  position: relative;
  padding-left: 1.5em;
}
.p-list-disc > li::before {
  content: "";
  display: block;
  width: 0.875em;
  height: 0.875em;
  background-color: var(--accent);
  position: absolute;
  border-radius: 100px;
  left: 0;
  top: 0.7em;
}

.p-list-ol {
  list-style: decimal;
  margin-left: 20px;
}

.p-list-bg li {
  margin-bottom: 6px;
}

.p-list-bg li b {
  background-color: #FBE822;
}

@media screen and (min-width: 768px) {
  .p-list-count {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
  }
}
.p-list-count > li {
  background: #fff;
  border-radius: 30px;
  padding: 3.125em 1.875em;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
@media screen and (min-width: 768px) {
  .p-list-count > li {
    width: 320px;
    margin: 40px 20px 0 20px;
  }
  .p-list-count > li:nth-child(1), .p-list-count > li:nth-child(2), .p-list-count > li:nth-child(3) {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-list-count > li:not(:last-child) {
    margin-bottom: 7.7vw;
  }
  
  .p-table-b .p-list-disc > li::before {
    top: 0.5em;
  }
}
.p-list-count__num {
  position: relative;
  font-size: 5.1rem;
  font-weight: bold;
  color: var(--accent);
  text-align: center;
  font-family: var(--en-sans);
  line-height: 1;
  margin-bottom: 0.3137254902em;
  padding-bottom: 0.3921568627em;
}
@media screen and (max-width: 767px) {
  .p-list-count__num {
    font-size: 12.8vw;
  }
}
.p-list-count__num::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 8px 0 8px;
  border-color: #0E68B7 transparent transparent transparent;
}
.p-list-count__ttl {
  position: relative;
  font-size: 2.5rem;
  font-weight: bold;
  color: var(--accent);
  text-align: center;
  margin-bottom: 0.8em;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-list-count__ttl {
    font-size: 6.4vw;
  }
}
.p-list-count__txt {
  line-height: 2;
}

/*========================================
  table
========================================*/
.p-table {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  .p-table {
    font-size: 1.3rem;
  }
  .p-table td {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .p-table {
    border-top: 1px solid #DDD;
    display: block;
  }
}
.p-table.is-pickup {
  border-top: 0;
  /*margin: 1.5vw var(--sp-pad) 1vw var(--sp-pad);*/
}
.p-table.is-pickup tr {
  border-bottom: 0;
}
@media screen and (max-width: 767px) {
  .p-table tbody {
    display: block;
  }
  .p-table.is-pickup {
    margin: 1.5vw var(--sp-pad) 5vw var(--sp-pad);
  }
}
.p-table tr:last-child th, .p-table tr:last-child td {
  border-bottom: 0;
}
@media screen and (max-width: 767px) {
  .p-table tr {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    padding: 3.8vw 0;
    border-bottom: 1px solid #DDD;
  }
}
@media screen and (min-width: 768px) {
  .p-table th {
    padding-top: 22px;
    padding-bottom: 18px;
    border-bottom: 1px solid #DDD;
  }
  .p-table td {
    padding-top: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid #DDD;
  }
}
.p-table th {
  font-size: 1.3rem;
  color: #888;
}
@media screen and (min-width: 768px) {
  .p-table th {
    width: 146px;
    padding-left: 25px;
  }
}
@media screen and (max-width: 767px) {
  .p-table th {
    font-size: 3.8vw;
    display: inline-block;
    margin-right: 1em;
    line-height: 1.1;
  }
}
.p-table td.is-wicon {
  width: 104px;
}
@media screen and (min-width: 768px) {
  .p-table td.is-wicon {
    padding-top: 25px;
  }
}
@media screen and (max-width: 767px) {
  .p-table td.is-wicon {
    display: inline-block;
    line-height: 1.1;
  }
}
@media screen and (min-width: 768px) {
  .p-table td.is-ttl {
    padding-left: 25px;
    max-width: 624px;
  }
}
@media screen and (max-width: 767px) {
  .p-table td.is-ttl {
    display: block;
    width: 100%;
    margin-top: 0.5em;
    line-height: 1.5;
  }
}
@media (hover: hover) {
  .p-table a:hover {
    text-decoration: underline;
  }
}

.p-table-fixed {
  table-layout: fixed;
}

.p-table-a {
  table-layout: fixed;
}
.p-table-a thead th {
  background: var(--accent);
  color: #fff;
  text-align: center;
}
.p-table-a th, .p-table-a td {
  padding: 10px 20px;
  border: 1px solid #CCCCCC;
}
.p-table-a th {
  background: #F6F3ED;
  font-weight: bold;
  text-align: left;
}

.p-form .p-table-a th {
  padding: 20px 20px 15px 20px;
  border: 1px solid #CCCCCC;
}

.p-form .p-table-a td {
  padding: 20px 20px;
  border: 1px solid #CCCCCC;
}
.p-form .p-table-a td.t-area {
  padding: 20px 20px 10px 20px;
}

.p-table-b {
  border-top: 1px solid #DDDDDD;
}
.p-table-b th, .p-table-b td {
  padding: 0.625em 1.5625em;
}
.p-table-b tr {
  border-bottom: 1px solid #DDDDDD;
}
.p-table-b th {
  position: relative;
  text-align: left;
  padding-right: 0;
}
.p-table-b th p {
  padding: 1.25em 0;
}
.p-table-b 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-form .p-table-a {
    border-bottom: 1px solid #CCCCCC;
  }
  .p-form .p-table-a th {
    border-bottom: 0;
    padding-bottom: 7px;
    padding-top: 15px;
  }
  .p-form .p-table-a td {
    border-bottom: 0;
    padding-bottom: 20px;
    padding-top: 20px;
  }
  
  .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-b.is-sp-break {
    display: block;
  }
  .p-table-b.is-sp-break th, .p-table-b.is-sp-break td, .p-table-b.is-sp-break tr, .p-table-b.is-sp-break tbody {
    display: block;
  }
  .p-table-b.is-sp-break th, .p-table-b.is-sp-break td {
    padding: 0 0.625em;
  }
  .p-table-b.is-sp-break td {
    padding-bottom: 1.245em;
    padding-top: 0.125em;
    line-height: 1.7;
  }
  .p-table-b.is-sp-break th {
    padding-top: 1.125em;
    width: auto;
  }
  .p-table-b.is-sp-break th p {
    border-right: 0;
    padding: 0;
  }
  .p-table-b.is-sp-break th p::after {
    display: none;
  }
}

.p-table-auto {
  table-layout: auto;
}
/*========================================
  p-thmtxt
========================================*/
.p-thmtxt {
  padding: 50px 0;
  border-top: 1px solid #DDD;
}
@media screen and (max-width: 767px) {
  .p-thmtxt {
    padding: 10.4vw 0 14.4vw 0;
  }
}
.p-thmtxt:last-child {
  border-bottom: 1px solid #DDD;
}
@media screen and (min-width: 768px) {
  .p-thmtxt {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    /*align-items: center;*/
  }
}
@media screen and (min-width: 768px) {
  .p-thmtxt__wtxt {
    width: calc(100% - 305px);
  }
}
@media screen and (max-width: 767px) {
  .p-thmtxt__wtxt {
    padding: 3.8vw 0 0 0;
  }
}
.p-thmtxt__date {
  color: #888;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .p-thmtxt__date {
    font-size: 3.3vw;
  }
}
.p-thmtxt__ttl {
  font-size: 2.1rem;
  font-weight: bold;
  margin-bottom: 0.9523809524em;
}
@media screen and (max-width: 767px) {
  .p-thmtxt__ttl {
    font-size: 5.4vw;
    margin-bottom: 7.8vw;
  }
}
.p-thmtxt__meta {
  margin-top: 1.1904761905em;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
}
.p-thmtxt__meta > *:not(:last-child) {
  margin-right: 0.9523809524em;
}
.p-thmtxt__gallery a {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
}
@media (hover: hover) {
  .p-thmtxt__gallery a:hover {
    text-decoration: underline;
  }
}
.p-thmtxt__gallery a .c-icon {
  margin-left: 5px;
}
@media screen and (min-width: 768px) {
  .p-thmtxt__thumb {
    width: 245px;
  }
}
@media screen and (max-width: 767px) {
  .p-thmtxt__thumb {
    text-align: center;
  }
}





.p-thmtxt__thumb img {
    border-radius: 5px;
    box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.7);
}





/*========================================
  thmtxt-list
========================================*/
@media screen and (min-width: 768px) {
  .p-thmtxt-list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .p-thmtxt-list > li {
/*    width: 47.9846449136%;*/
    width: 45%;
    margin-top: 45px;
  }
  .p-thmtxt-list > li:nth-child(1), .p-thmtxt-list > li:nth-child(2) {
    margin-top: 0;
  }
}
.p-thmtxt-list > li {
/*  background: #fff;*/


}
@media screen and (max-width: 767px) {
  .p-thmtxt-list > li {
    margin-top: 5.1vw;
  }
}
@media (hover: hover) {
  .p-thmtxt-list__cont:hover .p-thmtxt-list__fig img {
    transform: scale(1.06);
  }
}
.p-thmtxt-list__fig {
  overflow: hidden;
box-shadow: 0px 2px 4px rgba(0,0,0,.7);
}
.p-thmtxt-list__fig img {
  transition: 0.25s transform;
}
.p-thmtxt-list__meta {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list__meta {
    margin-bottom: 2.6vw;
  }
}
.p-thmtxt-list__wtxt {
  padding: 13px 25px 25px 27px;
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list__wtxt {
    padding: 3.1vw 5.1vw 5.1vw 5.1vw;
  }
}
.p-thmtxt-list__date {
  font-size: 1.3rem;
  color: #888888;
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list__date {
    font-size: 3.3vw;
    margin-top: 0.3em;
  }
}
.p-thmtxt-list__txt {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list__txt {
    font-size: 4.1vw;
    padding-bottom: 10px;
  }
}
.p-thmtxt-list__wicon {
  text-align: right;
  font-size: 1px;
  line-height: 1;
}

.p-thmtxt-list-a {
width: 100%;

  border-top: 1px solid #DDDDDD;
}
.p-thmtxt-list-a__item {
  padding: 50px 0;
  border-bottom: 1px solid #DDDDDD;
}
@media screen and (min-width: 768px) {
  .p-thmtxt-list-a__item {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list-a__item {
    padding: 7.7vw 0 10.3vw 0;
  }
}
@media screen and (min-width: 768px) {
  .p-thmtxt-list-a__fig {
    width: 360px;
  }
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list-a__fig {
    margin-top: 5.1vw;
  }
}
@media screen and (min-width: 768px) {
  .p-thmtxt-list-a__wtxt {
    width: 510px;
  }
}
.p-thmtxt-list-a__hdr {
  margin-bottom: 1.875em;
}
@media screen and (min-width: 768px) {
  .p-thmtxt-list-a__hdr {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list-a__hdr {
    margin-bottom: 5.1vw;
  }
}
@media screen and (min-width: 768px) {
  .p-thmtxt-list-a__ttl + .p-thmtxt-list-a__tax {
    position: relative;
    margin-left: 30px;
    /*top: 0.2em;*/
  }
}
.p-thmtxt-list-a__ttl {
  font-size: 2.7rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list-a__ttl {
    font-size: 6.7vw;
  }
}
.p-thmtxt-list-a__tax {
  background: var(--accent);
  color: #fff;
  border-radius: 6px;
  color: #fff;
  padding: 0.4em 0.8em 0.5em 0.8em;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list-a__tax {
    margin-top: 3.1vw;
    /*font-size: 3.1vw;*/
  }
}
.p-thmtxt-list-a__prof {
  margin-top: 2.5em;
}
@media screen and (max-width: 767px) {
  .p-thmtxt-list-a__prof {
    margin-top: 5.1vw;
  }
}
.p-thmtxt-list-a__prof > li {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.p-thmtxt-list-a__prof p {
  width: calc(100% - 5.5em);
}
.p-thmtxt-list-a__prof p.is-val {
  position: relative;
  padding-left: 1em;
}
.p-thmtxt-list-a__prof p.is-val::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "： ";
}
.p-thmtxt-list-a__prof p.is-label {
  width: 5em;
}

/*========================================
  p-pagenav
========================================*/
.p-pagenav {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  line-height: 1.5;
}
.p-pagenav.is-center {
  justify-content: center;
}
.p-pagenav > li {
  text-align: center;
  border-top: 1px solid #DDD;
  border-bottom: 1px solid #DDD;
  padding: 0.9375em 0;
}
.p-pagenav > li.is-row-2n {
  border-top: 0;
}
@media screen and (max-width: 767px) {
  .p-pagenav > li.is-sp-nbt {
    border-top: 0;
  }
  .p-pagenav > li.is-sp-nbr a {
    border-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-pagenav > li.is-sp-row-2n {
    border-top: 0;
  }
}
.p-pagenav a {
  position: relative;
  display: block;
  padding: 0.5em 0.625em 1.875em 0.625em;
  border-right: 1px dashed #555555;
}
@media screen and (min-width: 768px) {
  .p-pagenav a.is-pc-nbr {
    border-right: 0;
  }
}
@media (hover: hover) {
  .p-pagenav a:hover .c-icon {
    bottom: -4px;
  }
}
.p-pagenav p {
  font-weight: bold;
}
.p-pagenav .c-icon {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: 0.25s bottom;
}

/*========================================
  bnr
========================================*/
.p-map iframe {
  width: 100%;
  height: 596px;
}
@media screen and (max-width: 767px) {
  .p-map iframe {
    height: 76.9vw;
  }
}

/*========================================
  contact
========================================*/
.p-tel {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-tel__wicon {
    width: 11.5vw;
    margin-right: 2.6vw;
  }
}
@media screen and (min-width: 768px) {
  .p-tel__value {
    margin-left: 20px;
  }
}
.p-tel__value a {
  font-size: 3.2rem;
  font-weight: bold;
  color: #90224E;
  line-height: 1.1;
  font-family: var(--en-sans);
}

@media screen and (max-width: 767px) {
  .p-tel__value a {
    font-size: 7.5vw;
  }
}
.p-tel__value small {
  font-size: 1.6rem;
  display: block;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .p-tel__value small {
    font-size: 3.8vw;
  }
}

/*========================================
  p-full-figs
========================================*/
.p-full-figs {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
}
.p-full-figs__item {
  position: relative;
  width: 50%;
}
.p-full-figs__item > img {
  width: 100%;
}
.p-full-figs__bnr {
  position: absolute;
  right: 17px;
  bottom: 15px;
}
@media screen and (max-width: 767px) {
  .p-full-figs__bnr {
    width: 10vw;
    right: 2vw;
    bottom: 2vw;
  }
}

/*========================================
  pagination
========================================*/
.p-pagination {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .p-pagination {
    margin-top: 12.8vw;
  }
}
.p-pagination .page-numbers {
  width: 32px;
  height: 32px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  border: 1px solid #BBBBBB;
  font-size: 1.5rem;
  margin: 0 3px;
  line-height: 1.1;
  transition-property: border, background, color;
  transition-duration: 0.25s;
}
.p-pagination .page-numbers.current {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}
.p-pagination .page-numbers.prev {
  position: absolute;
  left: 0;
}
.p-pagination .page-numbers.prev::before {
  content: "";
  display: inline-block;
  background: url("../img/icon/arrow_blue.svg") 0 0/contain no-repeat;
  width: 8px;
  height: 13px;
  transform: rotate(180deg);
  margin-right: 0.5em;
}
.p-pagination .page-numbers.next {
  position: absolute;
  right: 0;
}
.p-pagination .page-numbers.next::after {
  content: "";
  display: inline-block;
  background: url("../img/icon/arrow_blue.svg") 0 0/contain no-repeat;
  width: 8px;
  height: 13px;
  margin-left: 0.5em;
}
@media (hover: hover) {
  .p-pagination .page-numbers:hover {
    border-color: var(--accent);
    background: var(--accent);
    color: #fff;
  }
}
.p-pagination .page-numbers.dots, .p-pagination .page-numbers.prev, .p-pagination .page-numbers.next {
  width: auto;
  height: auto;
  border: 0;
}
@media (hover: hover) {
  .p-pagination .page-numbers.dots:hover, .p-pagination .page-numbers.prev:hover, .p-pagination .page-numbers.next:hover {
    background-color: transparent;
    color: currentColor;
  }
}
@media (hover: hover) {
  .p-pagination .page-numbers.prev:hover, .p-pagination .page-numbers.next:hover {
    text-decoration: underline;
  }
}

/*========================================
  post
========================================*/
.p-post__hdr {
  border-top: 4px solid var(--accent);
  padding-top: 1.875em;
}
@media screen and (max-width: 767px) {
  .p-post__hdr {
    padding-top: 3.8vw;
    margin-top: 60px;
  }
}
.p-post__meta {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .p-post__meta {
    padding-bottom: 1vw;
  }
}
.p-post__date {
  margin-right: 1.5384615385em;
  color: #888888;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .p-post__date {
    font-size: 4.1vw;
  }
}
.p-post__ttl {
  font-size: 2.8rem;
  font-weight: bold;
  margin-bottom: 1.2em;
}
@media screen and (max-width: 767px) {
  .p-post__ttl {
    font-size: 6.2vw;
  }
}
.p-post__body {
  font-size: 1.5rem;
  margin-top: 60px;
}
.p-post__body > * {
  margin-bottom: 2em;
}
.p-post__body p {
  overflow: hidden;
}
.p-post__body * > p {
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  .p-post__body * > p {
    margin-top: 0.5em;
  }
}
.p-post__wbtn {
  text-align: center;
  margin-top: 100px;
  margin-bottom: 150px;
}
@media screen and (max-width: 767px) {
  .p-post__wbtn {
    margin-top: 7.7vw;
    margin-bottom: 20px;
  }
}

/******************************
 * util flex
 ******************************/
.u-flex {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
}
.u-flex--start {
  justify-content: flex-start;
}
.u-flex--center {
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.u-flex--r {
  flex-flow: row-reverse;
}
.u-flex--col2 .u-flex__item {
  width: 48%;
}
.u-flex--col3 .u-flex__item {
  width: 32%;
}
@media screen and (max-width: 767px) {
  .flex--sp-col2 .u-flex__item {
    width: 48%;
    margin-top: 4vw;
  }
  .flex--sp-col2 .u-flex__item img {
    width: 100%;
  }
  
  .u-flex--reset-sp {
    display: block;
  }
  .u-flex--reset-sp .u-flex__item {
    width: auto;
  }
}

.u-bg-f6f3ed {
  background: #F6F3ED;
  padding-top: 1px;
  padding-bottom: 1px;
}

.u-bg-ffffff {
  background: #ffffff;
  /*padding-top: 1px;
  padding-bottom: 1px;*/
}

/******************************
 * util display
 ******************************/
.u-screen-reader,
.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-1em {
  margin-top: 1em;
}

.u-mt-2em {
  margin-top: 2em;
}

.u-mt-3em {
  margin-top: 3em;
}

.u-mb-1em {
  margin-bottom: 1em;
}

.u-mb-2em {
  margin-bottom: 2em;
}

.u-mb-3em {
  margin-bottom: 3em;
}

.u-m-lr-auto {
  margin-left: auto;
  margin-right: auto;
}

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

.u-mr-5 {
  margin-right: 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-mb-10 {
  margin-bottom: 10px;
}

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

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

.u-mr-15 {
  margin-right: 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-mb-20 {
  margin-bottom: 20px;
}

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

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

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

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

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

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

.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-mb-40 {
  margin-bottom: 40px;
}

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

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

.u-mr-50 {
  margin-right: 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-mb-60 {
  margin-bottom: 60px;
}

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

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

.u-mr-70 {
  margin-right: 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-mb-80 {
  margin-bottom: 80px;
}

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

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

.u-mr-90 {
  margin-right: 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-mb-100 {
  margin-bottom: 100px;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.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-mt-1 {
    margin-top: 1vw;
  }
  .u-sp-mr-1 {
    margin-right: 1vw;
  }
  .u-sp-mb-1 {
    margin-bottom: 1vw;
  }
  .u-sp-ml-1 {
    margin-left: 1vw;
  }
  .u-sp-mt-2 {
    margin-top: 2vw;
  }
  .u-sp-mr-2 {
    margin-right: 2vw;
  }
  .u-sp-mb-2 {
    margin-bottom: 2vw;
  }
  .u-sp-ml-2 {
    margin-left: 2vw;
  }
  .u-sp-mt-5 {
    margin-top: 5vw;
  }
  .u-sp-mr-5 {
    margin-right: 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-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-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-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-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-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-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-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-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-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-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-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-pb-5 {
  padding-bottom: 5px;
}

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

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

.u-pr-10 {
  padding-right: 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-pb-15 {
  padding-bottom: 15px;
}

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

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

.u-pr-20 {
  padding-right: 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-pb-30 {
  padding-bottom: 30px;
}

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

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

.u-pr-40 {
  padding-right: 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-pb-50 {
  padding-bottom: 50px;
}

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

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

.u-pr-60 {
  padding-right: 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-pb-70 {
  padding-bottom: 70px;
}

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

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

.u-pr-80 {
  padding-right: 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-pb-90 {
  padding-bottom: 90px;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.u-p-25 {
  padding: 25px 25px 30px 25px;
}
@media screen and (max-width: 767px) {
  .u-p-25 {
    padding: 6.4vw 5.1vw 6.4vw 5.1vw;
  }
}

.u-p-40 {
  padding: 40px;
}
@media screen and (max-width: 767px) {
  .u-p-40 {
    padding: 10.3vw 7.7vw;
  }
}

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

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

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

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

@media screen and (max-width: 767px) {
  .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-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-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-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-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-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-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-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-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-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-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-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-pb-100 {
    padding-bottom: 100vw;
  }
  .u-sp-pl-100 {
    padding-left: 100vw;
  }
  .u-sp-pt-110 {
    padding-top: 110vw;
  }
  .u-sp-pr-110 {
    padding-right: 110vw;
  }
  .u-sp-pb-110 {
    padding-bottom: 110vw;
  }
  .u-sp-pl-110 {
    padding-left: 110vw;
  }
  .u-sp-pt-120 {
    padding-top: 120vw;
  }
  .u-sp-pr-120 {
    padding-right: 120vw;
  }
  .u-sp-pb-120 {
    padding-bottom: 120vw;
  }
  .u-sp-pl-120 {
    padding-left: 120vw;
  }
  .u-sp-pt-130 {
    padding-top: 130vw;
  }
  .u-sp-pr-130 {
    padding-right: 130vw;
  }
  .u-sp-pb-130 {
    padding-bottom: 130vw;
  }
  .u-sp-pl-130 {
    padding-left: 130vw;
  }
  .u-sp-pt-140 {
    padding-top: 140vw;
  }
  .u-sp-pr-140 {
    padding-right: 140vw;
  }
  .u-sp-pb-140 {
    padding-bottom: 140vw;
  }
  .u-sp-pl-140 {
    padding-left: 140vw;
  }
  .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-mm {
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .u-fix-w-mm {
    width: 1040px;
  }
}

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

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

@media screen and (max-width: 767px) {
  .u-sp-fix-w {
    width: 920px;
  }
}

.u-w-5em {
  width: 5em;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@media screen and (max-width: 767px) {
  .u-sp-w-10 {
    width: 10vw;
  }
  .u-sp-w-20 {
    width: 20vw;
  }
  .u-sp-w-30 {
    width: 30vw;
  }
  .u-sp-w-40 {
    width: 40vw;
  }
  .u-sp-w-45 {
    width: 45vw;
  }
  .u-sp-w-50 {
    width: 50vw;
  }
  .u-sp-w-60 {
    width: 60vw;
  }
  .u-sp-w-70 {
    width: 70vw;
  }
  .u-sp-w-80 {
    width: 80vw;
  }
  .u-sp-w-90 {
    width: 90vw;
  }
  .u-sp-w-100 {
    width: 100vw;
  }
  .u-sp-w-110 {
    width: 110vw;
  }
  .u-sp-w-120 {
    width: 120vw;
  }
  .u-sp-w-130 {
    width: 130vw;
  }
  .u-sp-w-150 {
    width: 150vw;
  }
  .u-sp-w-160 {
    width: 160vw;
  }
  .u-sp-w-180 {
    width: 180vw;
  }
  .u-sp-w-185 {
    width: 185vw;
  }
  .u-sp-w-200 {
    width: 200vw;
  }
  .u-sp-w-230 {
    width: 230vw;
  }
  .u-sp-w-280 {
    width: 280vw;
  }
  .u-sp-w-300 {
    width: 300vw;
  }
  .u-sp-w-340 {
    width: 340vw;
  }
  .u-sp-w-370 {
    width: 370vw;
  }
  .u-sp-w-400 {
    width: 400vw;
  }
  .u-sp-w-490 {
    width: 490vw;
  }
  .u-sp-w-700 {
    width: 700vw;
  }
  .u-sp-w-50per {
    width: 50%;
  }
  .sp-w-full {
    width: 100%;
  }
  .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-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;
}

@media screen and (max-width: 767px) {
  .u-sp-fs-2 {
    font-size: 2vw;
  }
  .u-sp-fs-3 {
    font-size: 3vw;
  }
  .u-sp-fs-4 {
    font-size: 4vw;
  }
  .u-sp-fs-5 {
    font-size: 5vw;
  }
  .u-sp-fs-6 {
    font-size: 6vw;
  }
  .u-sp-fs-7 {
    font-size: 7vw;
  }
  .u-sp-fs-8 {
    font-size: 8vw;
  }
  .u-sp-fs-9 {
    font-size: 9vw;
  }
  .u-sp-fs-10 {
    font-size: 10vw;
  }
  .u-sp-fs-11 {
    font-size: 11vw;
  }
  .u-sp-fs-12 {
    font-size: 12vw;
  }
  .u-sp-fs-13 {
    font-size: 13vw;
  }
  .u-sp-fs-14 {
    font-size: 14vw;
  }
  .u-sp-fs-15 {
    font-size: 15vw;
  }
  .u-sp-fs-16 {
    font-size: 16vw;
  }
  .u-sp-fs-17 {
    font-size: 17vw;
  }
  .u-sp-fs-18 {
    font-size: 18vw;
  }
  .u-sp-fs-19 {
    font-size: 19vw;
  }
  .u-sp-fs-20 {
    font-size: 20vw;
  }
  .u-sp-fs-21 {
    font-size: 21vw;
  }
  .u-sp-fs-22 {
    font-size: 22vw;
  }
  .u-sp-fs-23 {
    font-size: 23vw;
  }
  .u-sp-fs-24 {
    font-size: 24vw;
  }
  .u-sp-fs-25 {
    font-size: 25vw;
  }
  .u-sp-fs-26 {
    font-size: 26vw;
  }
  .u-sp-fs-27 {
    font-size: 27vw;
  }
  .u-sp-fs-28 {
    font-size: 28vw;
  }
  .u-sp-fs-29 {
    font-size: 29vw;
  }
  .u-sp-fs-30 {
    font-size: 30vw;
  }
}
@media screen and (max-width: 767px) {
  .u-sp-fs-3_6 {
    font-size: 3.6vw;
  }
}
.u-fs-large {
  font-size: 112.5%;
}

.u-fs-llarge {
  font-size: 132.5%;
}

/******************************
 * util other
 ******************************/
@media screen and (min-width: 768px) {
  .u-pc-row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .u-pc-row.is-cewnter {
    justify-content: center;
  }
  .u-pc-row.is-btween {
    justify-content: space-between;
  }
  .u-pc-row.is-align-c {
    align-items: center;
  }
}

.u-bg-cover {
  background: 50% 50%/cover no-repeat;
  padding: 120px 0;
}
@media screen and (max-width: 767px) {
  .u-bg-cover {
    padding: 17.9vw 0;
  }
}

.u-bg-f6f3ed {
  background-color: #F6F3ED;
}

.u-color-blue {
  color: var(--accent);
}

.u-color-red {
  color: #90224E;
}

.u-tdu {
  text-decoration: underline;
}

.u-en {
  font-family: var(--en-sans);
}

.u-pos-rel {
  position: relative;
}

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

.u-hv-op {
  transition: 0.25s opacity;
}
@media (hover: hover) {
  .u-hv-op:hover {
    opacity: 0.8;
  }
}

.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;
}

.u-ov-auto {
  overflow: auto;
}

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

@media screen and (max-width: 767px) {
  .reset-sp-pos {
    position: static;
  }
}
*.is-firstview {
  padding-top: 130px;
}
@media screen and (max-width: 767px) {
  *.is-firstview {
    padding-top: 17.9vw;
  }
}

.u-ff-en {
  font-family: var(--en-sans);
}

.u-ff-serif {
  font-family: var(--serif);
}

.u-low-line {
  line-height: 1.6;
}

.sciencehome-bnr {
  margin-left: 50px;
}

.sciencehome-bnr li {
  display: inline-block;
}

.sciencehome-bnr li a {
  transition: 0.25s opacity;
}
@media (hover: hover) {
  .sciencehome-bnr li a:hover {
    opacity: 0.7;
  }
}

@media screen and (max-width: 767px) {
  .sciencehome-bnr {
    margin-left: 0;
    text-align: center;
  }
  .sciencehome-bnr li {
    display: block;
    margin-right: 0;
  }
}


/******************************
 * 施工事例（ピックアップ）
 ******************************/

.pickup-works .p-post__hdr .p-post__ttl {
  display: inline-block;
  margin-right: 30px;
}
.pickup-works .p-post__hdr p.point {
  display: inline-block;
}

.pickup-works a {
  transition: 0.25s opacity;
}

.pickup-works .p-list-disc > li::before {
  background-color: #90224E;
}

@media (hover: hover) {
  .pickup-works a:hover {
    opacity: 0.7;
  }
}

.pickup-works .p-post__hdr {
  border-top: 4px solid #90224E;
}

@media screen and (max-width: 767px) {
  .pickup-works .p-post__hdr .p-post__ttl {
    display: block;
    margin-right: 0;
  }
  .pickup-works .p-post__hdr p.point {
    display: block;
  }

}




/******************************
 * 施工事例（ピックアップ）
 ******************************/

.intro-dtl .p-post__hdr .p-post__ttl {
  display: inline-block;
  margin-right: 30px;
}
.intro-dtl .p-post__hdr p.point {
  display: inline-block;
}

.intro-dtl a {
  transition: 0.25s opacity;
}

.intro-dtl .p-list-disc > li::before {
  background-color: #90224E;
}

@media (hover: hover) {
  .intro-dtl a:hover {
    opacity: 0.7;
  }
}

.intro-dtl .p-post__hdr {
  border-top: 4px solid #90224E;
}

@media screen and (max-width: 767px) {
  .intro-dtl .p-post__hdr .p-post__ttl {
    display: block;
    margin-right: 0;
  }
  .intro-dtl .p-post__hdr p.point {
    display: block;
  }

}











.u-img-shadow img {
  border-radius: 5px;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.7);
}






/*.renov-dtl {
  margin-bottom: 80px;
}*/
/*
@media screen and (max-width: 767px) {
  .renov-dtl {
    margin-bottom: 10.3vw;
  }
}
.renov-dtl.is-red .renov-dtl__ttl {
  background: #90224E;
}
.renov-dtl__ttl {
  background-color: var(--accent);
  color: #fff;
  border-radius:  0px 50px 50px 0px;
  font-size: 2.5rem;
  font-weight: bold;
  padding: 0.56em 1.4em;
}
@media screen and (max-width: 767px) {
  .renov-dtl__ttl {
    font-size: 5.6vw;
    border-radius:  0px 50px 50px 0px;
    padding: 0.56em 1em;
  }
}
*/



.renov-dtl {
  background: #f4f4f4;
  padding: 0.56em 1.4em;
width: 100%;
}

@media screen and (max-width: 767px) {
  .renov-dtl {
    margin-bottom: 10.3vw;
  }
}
.renov-dtl.is-red .renov-dtl__ttl {
  background: #90224E;
}


.renov-dtl__ttl {
  color: var(--accent);
  font-size: 2.5rem;
  font-weight: bold;
  padding: 0.56em 0;

border-bottom: 4px solid 
}
@media screen and (max-width: 767px) {
  .renov-dtl__ttl {
    font-size: 5.6vw;
    padding: 0.56em 0;
  }
}







.renov-dtl__sep {
  margin: auto;
  content: "";
  width: 200px;
  border-top: 50px solid var(--accent);
  border-right: 100px solid transparent;
  border-left: 100px solid transparent;
}





























/*========================================
  construction
========================================*/
.p-construction {
  margin-left: auto;
  margin-right: auto;
}

.p-construction-page {
  margin-left: auto;
  margin-right: auto;
}

.page-id-6 .p-construction {
  display: none;
}
.page-id-9 .p-construction {
  display: none;
}

@media screen and (min-width: 768px) {
  .p-construction {
    width: 1080px;
  }
  
  .p-construction-page {
    width: 1080px;
  }
}





.p-construction__lead {
    width: 100%;
    font-weight: bold;
    font-size: 2.1rem;
}
@media screen and (min-width: 768px) {
  .p-construction__lead {
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .p-construction__lead {
    margin-top: 7.7vw;
    font-size: 4.6vw;
  }
}




@media screen and (min-width: 768px) {
  .p-construction__list {
    margin-top: 70px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (max-width: 767px) {
  .p-construction__list {
    margin-top: 9.8vw;
  }
}
@media screen and (max-width: 767px) {
  .p-construction__item + .p-construction__item {
    margin-top: 7.1vw;
  }
}
.p-construction__item {
  position: relative;
  background: #F6F3ED;
  border: 4px solid #DDDDDD;
  border-radius: 30px;
  text-align: center;
  padding: 75px 20px;
}
@media screen and (min-width: 768px) {
  .p-construction__item {
    margin: 0 auto;
    width: 85%;
  }
}
@media screen and (max-width: 767px) {
  .p-construction__item {
    padding: 8.8vw 4.1vw;
  }
}

/*
.p-construction__item::before {
  content: "";
  display: block;
  width: 290px;
  height: 4px;
  background: var(--accent);
  position: absolute;
  left: 50%;
  top: -4px;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .p-construction__item::before {
    width: 51.3vw;
  }
}
*/


.p-construction__ttl {
  font-size: 2.8rem;
  font-weight: bold;
  color: var(--accent);
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-construction__ttl {
    font-size: 5.5vw;
  }
}
.p-construction__res {
  line-height: 1.5;
  font-weight: bold;
  margin-top: 0.4em;
}
@media screen and (max-width: 767px) {
  .p-construction__res {
    font-size: 4.3vw;
    margin-top: 0.3em;
  }
}
@media screen and (max-width: 767px) {
  .p-construction__wicon {
    width: 11.5vw;
    margin-right: 2.6vw;
  }
}
.p-construction__tel {
  margin-top: 40px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .p-construction__tel {
    margin-top: 6.4vw;
  }
  .p-construction__tel p {
    line-height: 1.6;
  }
}
@media screen and (min-width: 768px) {
    .p-construction__value {
    margin-left: 15px;
  }
}
.p-construction__value a {
  font-size: 5rem;
  font-weight: bold;
  color: var(--accent);
  line-height: 1.1;
  font-family: var(--en-sans);
}
@media screen and (max-width: 767px) {
    .p-construction__value a {
    font-size: 7.1vw;
  }
}
.p-construction__value small {
  font-size: 1.6rem;
  display: block;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
    .p-construction__value small {
    font-size: 3.8vw;
  }
}






@media screen and (min-width: 768px) {
    .p-construction__value_mail {
    margin-left: 15px;
  }
}
.p-construction__value_mail a {
  font-size: 3.1rem;
  font-weight: bold;
  color: var(--accent);
  line-height: 1.1;
  font-family: var(--en-sans);
}
@media screen and (max-width: 767px) {
    .p-construction__value_mail a {
    font-size: 4.2vw;
  }
}
















.p-construction__wbtn {
  display: flex;


  margin-top: 33px;
}
@media screen and (max-width: 767px) {
  .p-construction__wbtn {
  display: block;
    margin-top: 6.4vw;
  }
}
.p-construction__btnicon {
  margin-right: 10px;
}
@media screen and (max-width: 767px) {
  .p-construction__btnicon {
    margin-right: 1.5vw;
    width: 10.3vw;
  }
}
.p-construction__btn {

  display: flex;
  flex-direction: row;
  flex-wrap: wrap;


  justify-content: center;

  align-items: center;
  background: #fff;
  border: 2px solid var(--accent);
  color: var(--accent);
  padding: 15px 30px;
  border-radius: 100px;
  font-weight: bold;
  transition-property: background, color;
  transition-duration: 0.25s;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .p-construction__btn {
    width: 290px;
    text-align: center;



  }
}
@media screen and (max-width: 767px) {
  .p-construction__btn {
    padding: 2.6vw;
    font-size: 4.2vw;
    justify-content: flex-start;
    width: 67vw;
    text-align: center;
  }
}
@media (hover: hover) {
  .p-construction__btn:hover {
    background-color: var(--accent);
    color: #fff;
  }
}










.alert-danger {
  color: #721c24;
  background-color: #f8d7da;
  border-color: #f5c6cb;
}
.alert {
  position: relative;
  padding: 0.75rem 1.25rem;
  margin-bottom: 2rem;
  border: 1px solid transparent;
    border-top-color: transparent;
    border-right-color: transparent;
    border-bottom-color: transparent;
    border-left-color: transparent;
  border-radius: 0.25rem;
}


.invalid-feedback {
  /*display: none;*/
  width: 100%;
  margin-top: 0.25rem;
 /* font-size: 80%;*/

  color: #dc3545;
}


.txtAttention {
/*
  border-radius: 8px;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  margin: 0px 5px 20px 5px;*/

  color: #DF0101;
}



