@charset 'UTF-8';

@import url('https://fonts.googleapis.com/css?family=Roboto:400,900');

@font-face {
  font-family: 'iconfont';
  src: url('../fonts/iconfont.woff') format('woff'), url('../fonts/iconfont.ttf') format('truetype');
}

.icon-arrow01:before,
.p-free-format .button-b:before {
  font-family: 'iconfont';
  font-weight: normal;
  font-style: normal;
  font-variant: normal;
  text-decoration: none;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-arrow01:before,
.p-free-format .button-b:before {
  content: '';
}

/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 */

html {
  line-height: 1.15;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers (opinionated).
 */

body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */

article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: .67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */

figcaption,
figure,
main {
  /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */

figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  /* 1 */
  overflow: visible;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */

a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */
}

/**
 * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  border-bottom: none;
  /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */

b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */

dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */

mark {
  color: #000;
  background-color: #ff0;
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -.25em;
}

sup {
  top: -.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */

audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */

img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */

svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */

button,
html [type='button'],
[type='reset'],
[type='submit'] {
  -webkit-appearance: button;
  /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type='button']:-moz-focusring,
[type='reset']:-moz-focusring,
[type='submit']:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: .35em .75em .625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
  /* 2 */
  display: table;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
  color: inherit;
  /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */

[type='checkbox'],
[type='radio'] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type='search'] {
  /* 1 */
  outline-offset: -2px;
  -webkit-appearance: textfield;
  /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */

[type='search']::-webkit-search-cancel-button,
[type='search']::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  /* 1 */
  font: inherit;
  -webkit-appearance: button;
  /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */

details,
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */

template {
  display: none;
}

/* Hidden
   ========================================================================== */

/**
 * Add the correct display in IE 10-.
 */

[hidden] {
  display: none;
}

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-wrap: break-word;
  word-break: normal;
  overflow-wrap: break-word;
}

body {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  color: #c8c8c8;
}

body.p-body-bg {
  background-color: #f4f4f4;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin: 0;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

a {
  text-decoration: none;
  color: #222;
}

a:hover {
  text-decoration: none;
}

a:visited {
  color: #222;
}

.bx-wrapper {
  margin: 0 !important;
  border: none !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
}

sup {
  font-size: 16px;
  font-size: 1rem;
  top: -.25em;
}

.c-button,
.c-button-a {
  display: block;
  overflow: hidden;
  width: 40px;
  height: 40px;
  white-space: nowrap;
  text-indent: 999%;
  border: 2px solid #000;
  border-radius: 100%;
  background-color: #fff;
}

.c-button:focus,
.c-button-a:focus {
  outline: none;
}

.c-button-d,
.p-blog-button-b,
.p-news-button-b,
.p-free-format .button-a,
.p-free-format .button-b {
  padding: 5px 10px;
  -webkit-transition: all .3s;
  -o-transition: all .3s;
  transition: all .3s;
  color: #000;
  border: 1px solid #000;
  background-color: transparent;
}

.c-button-d:hover,
.p-blog-button-b:hover,
.p-news-button-b:hover,
.p-free-format .button-a:hover,
.p-free-format .button-b:hover {
  color: #fff;
  background-color: #000;
}

.c-button-d:focus,
.p-blog-button-b:focus,
.p-news-button-b:focus,
.p-free-format .button-a:focus,
.p-free-format .button-b:focus {
  color: #000;
  outline: none;
}

.c-button-d:visited,
.p-blog-button-b:visited,
.p-news-button-b:visited,
.p-free-format .button-a:visited,
.p-free-format .button-b:visited {
  color: #000;
}

.p-header {
  position: fixed;
  z-index: 100;
  top: 0;
  width: 100%;
  height: 80px;
  background-color: #fff;
}

.p-header-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.p-header-logo {
  display: block;
  overflow: hidden;
  width: 172px;
  height: 48px;
  margin-left: 15px;
  white-space: nowrap;
  text-indent: 999%;
  background: url(../img/header/logo.gif) center/contain no-repeat;
}

.p-header-logo a {
  display: block;
  height: 100%;
}

.p-header-nav {
  position: fixed;
  z-index: 200;
  top: -100vh;
  visibility: hidden;
  width: 100%;
  height: 100vh;
  padding: 60px 15px;
  -webkit-transition: top .3s;
  -o-transition: top .3s;
  transition: top .3s;
  background-color: rgba(0, 0, 0, .9);
}

.p-header-nav ul {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: scroll;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  height: 100%;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.p-header-nav a {
  color: #fff;
}

.p-header-nav.js-active {
  top: 0;
  visibility: visible;
}

.p-header-link {
  font-size: 12px;
  font-size: .75rem;
  border-top: 1px solid #333;
}

.p-header-link:last-of-type {
  border-bottom: 1px solid #333;
}

.p-header-link span {
  font-family: 'Roboto', sans-serif;
  font-size: 13px;
  font-size: .8125rem;
  font-weight: bold;
  margin-right: 15px;
}

.p-header-link a {
  display: block;
  padding: 20px 15px;
}

.p-header-button-a {
  position: absolute;
  z-index: 201;
  top: 0;
  right: 25px;
  bottom: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 25px;
  height: 20px;
  margin: auto 0;
  cursor: pointer;
  -webkit-transition: all .4s;
  -o-transition: all .4s;
  transition: all .4s;
  color: #f4f4f4;
  border: none;
}

.p-header-button-a:focus {
  border-color: orange;
  outline: 0;
}

.p-header-button-a span {
  position: absolute;
  left: 0;
  display: inline-block;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  height: 2px;
  -webkit-transition: all .4s;
  -o-transition: all .4s;
  transition: all .4s;
  background-color: #000;
}

.p-header-button-a span:nth-child(1) {
  top: 0;
}

.p-header-button-a span:nth-child(2) {
  top: 9px;
}

.p-header-button-a span:nth-child(3) {
  top: 18px;
}

.p-header-button-a.js-active span {
  background-color: #fff;
}

.p-header-button-a.js-active span:nth-child(1) {
  -webkit-transform: translateY(9px) rotate(-45deg);
  -ms-transform: translateY(9px) rotate(-45deg);
  transform: translateY(9px) rotate(-45deg);
}

.p-header-button-a.js-active span:nth-child(2) {
  opacity: 0;
}

.p-header-button-a.js-active span:nth-child(3) {
  -webkit-transform: translateY(-9px) rotate(45deg);
  -ms-transform: translateY(-9px) rotate(45deg);
  transform: translateY(-9px) rotate(45deg);
}

.p-footer {
  background-color: #1d1d1d;
}

.p-footer small {
  font-family: 'Roboto', sans-serif;
  font-size: 11px;
  font-size: .6875rem;
  display: block;
  width: 100%;
  padding: 20px 15px;
  text-align: center;
  color: #b7b7b7;
  background-color: #0d0d0d;
}

.p-footer-nav {
  margin-bottom: 20px;
}

.p-footer-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border: 1px solid #333;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.p-footer-nav li {
  width: 50%;
  border-bottom: 1px solid #333;
}

.p-footer-nav li:nth-child(odd) {
  border-right: 1px solid #333;
}

.p-footer-nav li:nth-last-child(-n+1) {
  border-bottom: none;
}

.p-footer-nav a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 15px;
  text-align: center;
}

.p-footer-link a {
  font-size: 12px;
  font-size: .75rem;
  color: #b7b7b7;
}

.p-footer-middle {
  margin: 0;
  padding-bottom: 40px;
}

.p-footer-middle address {
  font-style: normal;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 0;
  padding: 0 15px;
  color: #b7b7b7;
}

.p-footer-address h3 {
  font-size: 13px;
  font-size: .8125rem;
  font-weight: normal;
  margin-bottom: 5px;
}

.p-footer-address p {
  font-size: 11px;
  font-size: .6875rem;
  line-height: 1.5;
}

.p-footer-logo {
  display: block;
  overflow: hidden;
  width: 172px;
  height: 48px;
  margin: 0 auto 20px;
  white-space: nowrap;
  text-indent: 999%;
  background: url(../img/footer/logo.png) center/contain no-repeat;
}

.p-footer-logo a {
  display: block;
  height: 100%;
}

.p-footer-bottom {
  margin-bottom: 0;
  padding: 20px 15px;
}

.p-footer-bottom ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1080px;
  margin: 0 auto;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.p-footer-bottom li {
  width: 50%;
  height: 60px;
}

.p-footer-bottom a {
  display: block;
  width: 100%;
  height: 100%;
}

.p-footer-banner-a {
  display: block;
  overflow: hidden;
  max-width: 163px;
  white-space: nowrap;
  text-indent: 999%;
  background: url(../img/footer/footer-banner-a-sp.png) center/contain no-repeat;
}

.p-footer-banner-b {
  display: block;
  overflow: hidden;
  max-width: 163px;
  white-space: nowrap;
  text-indent: 999%;
  background: url(../img/footer/footer-banner-b-sp.png) center/contain no-repeat;
}

.p-footer-banner-c {
  display: block;
  overflow: hidden;
  max-width: 163px;
  white-space: nowrap;
  text-indent: 999%;
  background: url(../img/footer/footer-banner-c-sp.png) center/contain no-repeat;
}

.p-footer-banner-d {
  display: block;
  overflow: hidden;
  width: 163px;
  white-space: nowrap;
  text-indent: 999%;
  background: url(../img/footer/footer-banner-d-sp.png) center/contain no-repeat;
}

.p-section-a,
.p-section-b {
  padding-top: 60px;
  color: #fff;
}

.p-section-a h2,
.p-section-b h2,
.p-section-a__title,
.p-section-b h2,
.p-mainview-a h1,
.p-mainview-b h1,
.p-mainview-c h1 {
  font-size: 14px;
  font-size: .875rem;
  margin-bottom: 30px;
  text-align: center;
  color: #121f3f;
}

.p-section-a h2 span,
.p-section-b h2 span,
.p-section-a__title span,
.p-section-b h2 span,
.p-mainview-a h1 span,
.p-mainview-b h1 span,
.p-mainview-c h1 span {
  font-family: 'Roboto', sans-serif;
  font-size: 48px;
  font-size: 3rem;
  line-height: 1;
  display: block;
  margin-bottom: 5px;
  letter-spacing: .05em;
}

.p-section-a__text {
  padding: 80px 20px;
  text-align: center;
}

.p-section-a__text h3 {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
  font-size: 22px;
  font-size: 1.375rem;
  font-weight: normal;
  margin-bottom: 40px;
}

.p-section-a__text p {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  font-size: 15px;
  font-size: .9375rem;
  line-height: 2;
  margin-bottom: 40px;
}

.p-section-b {
  position: static;
}

.p-section-b h3,
.p-section-b h3 + p {
  padding: 0 20px;
}

.p-section-b h3 {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: normal;
  line-height: 1.708;
  margin-bottom: 40px;
  text-align: center;
  color: #000;
}

.p-section-b h3 + p {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  font-size: 15px;
  font-size: .9375rem;
  line-height: 2;
  margin-bottom: 40px;
  text-align: center;
  color: #000;
}

.p-section-b__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding: 0 40px;
}

.p-section-b__content > div {
  margin-bottom: 30px;
  text-align: center;
}

.p-section-b__content img {
  width: 100%;
  margin-bottom: 20px;
}

.p-section-b__content h4 {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.4;
  margin-bottom: 10px;
  text-align: center;
  color: #222;
}

.p-mainview-top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100vh;
  -webkit-transition: opacity 3s;
  -o-transition: opacity 3s;
  transition: opacity 3s;
  opacity: 0;
  background: url(../img/top/mainview-bg.jpg) center/cover no-repeat;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-mainview-top.js-show {
  opacity: 1;
}

.p-mainview-top-content {
  width: 100%;
}

.p-mainview-top-text {
  display: block;
  overflow: hidden;
  width: 100%;
  max-width: 340px;
  height: 180px;
  margin: 0 auto;
  white-space: nowrap;
  text-indent: 999%;
  border-radius: 8px;
  background: rgba(0, 0, 0, .2) url(../img/top/mainview-text-01-sp.png) center/294px 136px no-repeat;
}

.p-mainview-a,
.p-mainview-b,
.p-mainview-c {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 150px;
  margin-top: 65px;
  padding: 55px 15px 0;
  background: url(../img/common/mainview-bg.jpg) center/cover no-repeat;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-mainview-a h1,
.p-mainview-b h1,
.p-mainview-c h1 {
  font-size: 13px;
  font-size: .8125rem;
  color: #fff;
}

.p-mainview-a h1 span,
.p-mainview-b h1 span,
.p-mainview-c h1 span {
  font-size: 30px;
  font-size: 1.875rem;
}

.p-mainview-b {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-top: 0;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-mainview-b h1 {
  margin-bottom: 0;
  padding-top: 10px;
}

.p-mainview-b h1 span {
  margin-bottom: 10px;
}

.p-mainview-c {
  padding-top: 0;
}

.p-mainview-c h1 {
  margin-bottom: 0;
  padding-top: 10px;
}

.p-mainview-c h1 span {
  margin-bottom: 10px;
}

.p-mainview-bg_service {
  background: url(../img/common/mainview-bg-service.jpg) center/cover no-repeat;
}

.p-mainview-bg_contact {
  background: url(../img/common/contact-bg.jpg) center/cover no-repeat;
}

.p-mainview-bg_blog {
  background: url(../img/common/mainview-bg-blog.jpg) center/cover no-repeat;
}

.p-visual-a {
  background: url(../img/top/vision-bg.jpg) center/cover no-repeat;
}

.p-vision-title {
  line-height: 1.5;
  letter-spacing: -.05em;
}

.p-vision-title.p-vision-title {
  margin-bottom: 50px;
}

.p-vision-title-a.p-vision-title-a {
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
}

.p-vision-text-a.p-vision-text-a {
  font-size: 18px;
  font-size: 1.125rem;
}

.p-vision-text-b.p-vision-text-b {
  font-size: 16px;
  font-size: 1rem;
}

.p-vision-text-b.p-vision-text-b span {
  font-size: 13px;
  font-size: .8125rem;
}

.p-vision-block-a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-vision-block-a.p-vision-block-a p {
  font-size: 12px;
  font-size: .75rem;
  margin: 25px 15px 15px 0;
}

.p-vision-block-a.p-vision-block-a img {
  max-width: 121px;
  height: 29px;
}

.p-button-d,
.p-blog-button-b,
.p-news-button-b,
.p-free-format .button-a,
.p-free-format .button-b {
  font-family: 'Roboto', sans-serif;
  font-size: 13px;
  font-size: .8125rem;
  display: block;
  width: 240px;
  margin: 0 auto;
  padding: 15px 20px;
  text-align: center;
  letter-spacing: .05em;
  color: #fff;
  border: 1px solid #fff;
}

.p-button-d.p-button-d:hover,
.p-blog-button-b:hover,
.p-news-button-b:hover,
.p-free-format .button-a:hover,
.p-free-format .button-b:hover {
  color: #000;
  background-color: #fff;
}

.p-button-d:focus,
.p-blog-button-b:focus,
.p-news-button-b:focus,
.p-free-format .button-a:focus,
.p-free-format .button-b:focus {
  color: #fff;
}

.p-button-d:visited,
.p-blog-button-b:visited,
.p-news-button-b:visited,
.p-free-format .button-a:visited,
.p-free-format .button-b:visited {
  color: #fff;
}

.p-button-d--color_a.p-button-d--color_a,
.p-blog-button-b,
.p-news-button-b,
.p-free-format .button-a,
.p-free-format .button-b {
  color: #121f3f;
  border: 1px solid #121f3f;
  background-color: #fff;
}

.p-button-d--color_a.p-button-d--color_a:hover,
.p-blog-button-b:hover,
.p-news-button-b:hover,
.p-free-format .button-a:hover,
.p-free-format .button-b:hover {
  color: #fff;
  background-color: #121f3f;
}

.p-button-d--color_b.p-button-d--color_b {
  color: #fff;
  border: 1px solid #fff;
}

.p-button-d--color_b.p-button-d--color_b:hover {
  color: #121f3f;
  background-color: #fff;
}

.p-business-top {
  padding-bottom: 60px;
}

.p-business-button-a {
  font-size: 14px;
  font-size: .875rem;
  width: 100%;
}

.p-business-button-a-wrapper {
  margin-top: 40px;
  padding: 0 20px;
}

.p-blog-top {
  padding-bottom: 40px;
  background-color: #f4f4f4;
}

.p-blog-top-articles {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding: 0 20px;
}

.p-blog-top-article {
  margin-bottom: 20px;
}

.p-blog-top-article a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #222;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.p-blog-top-article:last-of-type {
  margin-bottom: 0;
}

.p-blog-top-article__img {
  line-height: 0;
  width: 34.7826%;
  min-width: 120px;
}

.p-blog-top-article__img img {
  width: 100%;
  height: auto;
}

.p-blog-top-article__contant {
  line-height: 1;
  margin-left: 10px;
  -webkit-box-flex: 0;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
}

.p-blog-top-article__contant time {
  font-size: 13px;
  font-size: .8125rem;
  display: block;
  margin-bottom: 8px;
  color: #aaa;
}

.p-blog-top-article__contant p {
  font-size: 15px;
  font-size: .9375rem;
  line-height: 1.5;
}

.p-blog-top-link {
  display: none;
}

.p-blog-archive-cat {
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 0 5px -1px;
  border-right: 1px solid #aaa;
  border-left: 1px solid #aaa;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-blog-archive-cat.active {
  font-weight: bold;
}

.p-blog-archive-cat.active a {
  color: #1c3060;
}

.p-blog-archive-cat-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 60px 0 40px;
  padding: 0 15px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.p-blog-archive-cat-list a {
  font-size: 14px;
  font-size: .875rem;
}

.p-blog-archive-cat a {
  display: block;
  width: 100%;
  padding: 0 10px;
  text-align: center;
  color: #aaa;
}

.p-blog-archive-articles {
  margin-top: 40px;
  margin-bottom: 40px;
}

.p-blog-cat-and-time.p-blog-cat-and-time {
  font-size: 14px;
  font-size: .875rem;
  margin-bottom: 30px;
  text-align: center;
  color: #aaa;
}

.p-blog-title-a {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: normal;
  margin-bottom: 30px;
  text-align: center;
}

.p-blog-title-a + * {
  margin-top: 30px;
}

.p-blog-button-a,
.p-free-format .button-a,
.p-free-format .button-b {
  font-size: 14px;
  font-size: .875rem;
  width: 100%;
}

.p-blog-button-a-wrapper {
  margin-top: 40px;
  padding: 0 20px;
}

.p-blog-button-b.p-blog-button-b {
  text-decoration: none;
  color: #121f3f;
  background-color: #fff;
}

.p-blog-button-b.p-blog-button-b:hover {
  color: #fff;
  background-color: #121f3f;
}

.p-link-a {
  font-family: 'Roboto', sans-serif;
  font-size: 14px;
  font-size: .875rem;
  color: #222;
}

.p-link-a h4 {
  font-weight: normal;
}

.p-link-a p span {
  font-size: 12px;
  font-size: .75rem;
  display: inline-block;
  -webkit-transform: translate(10px, 0);
  -ms-transform: translate(10px, 0);
  transform: translate(10px, 0);
}

.p-map-top {
  padding: 40px 20px;
  background-color: #f4f4f4;
}

.p-map-top-block-banner {
  margin-bottom: 10px;
}

.p-map-top-block-banner ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 350px;
  margin: 0 auto;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.p-map-top-block-banner li {
  width: 47.5%;
  max-width: 165px;
  margin-bottom: 15px;
}

.p-map-top-block-banner li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.p-map-top-block-banner li p {
  font-size: 13px;
  font-size: .8125rem;
  margin-top: 5px;
  text-align: center;
  color: #a7a7a7;
}

.p-map-top-img-a,
.p-map-top-img-b,
.p-map-top-img-c,
.p-map-top-img-d {
  display: block;
  overflow: hidden;
  width: 100%;
  max-width: 165px;
  height: 24vw;
  max-height: 90px;
  margin: 0 auto;
  white-space: nowrap;
  text-indent: 999%;
  background: url(../img/top/machiya-residence-inn-sp.png) center/contain no-repeat;
}

.p-map-top-img-b {
  background-image: url(../img/top/the-machiya-hotel-sp.png);
}

.p-map-top-img-c {
  background-image: url(../img/top/the-machiya-villa-sp.png);
}

.p-map-top-img-d {
  background-image: url(../img/top/dozen-sp.png);
}

.p-map-top-block-map {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-map-top-block-map img {
  width: 100%;
  max-width: 492px;
}

.p-news-top {
  padding-bottom: 40px;
}

.p-news-top-cat {
  font-size: 10px;
  font-size: .625rem;
  min-width: 86px;
  margin-bottom: 5px;
  padding: 2px 6px;
  text-align: center;
  letter-spacing: .05em;
  color: #fff;
  background-color: #888;
}

.p-news-top-cat-list {
  margin: 0 10px 10px 0;
}

.p-news-top-cat-list:empty {
  display: none;
}

.p-news-top-cat:last-of-type {
  margin-bottom: 0;
}

.p-news-top-cat--press-release {
  background-color: #e5555c;
}

.p-news-top-cat--case-study {
  background-color: #3d4b6f;
}

.p-news-top-articles {
  margin-bottom: 40px;
  padding: 0 20px;
}

.p-news-top-article,
.p-news-archive-article,
.p-blog-archive-article {
  border-top: 1px solid #d0d0d0;
}

.p-news-top-article a,
.p-news-archive-article a,
.p-blog-archive-article a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px 0;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-news-top-article a:hover,
.p-news-archive-article a:hover,
.p-blog-archive-article a:hover {
  opacity: .7;
  color: #222;
}

.p-news-top-article time,
.p-news-archive-article time,
.p-blog-archive-article time {
  font-size: 11px;
  font-size: .6875rem;
  margin-bottom: 10px;
  color: #aaa;
}

.p-news-top-article h3,
.p-news-archive-article h3,
.p-blog-archive-article h3 {
  font-size: 14px;
  font-size: .875rem;
  font-weight: normal;
  width: 100%;
}

.p-news-top-article:last-of-type,
.p-news-archive-article:last-of-type,
.p-blog-archive-article:last-of-type {
  border-bottom: 1px solid #d0d0d0;
}

.p-news-archive-cat {
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 0 5px -1px;
  border-right: 1px solid #aaa;
  border-left: 1px solid #aaa;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-news-archive-cat.active {
  font-weight: bold;
}

.p-news-archive-cat.active a {
  color: #1c3060;
}

.p-news-archive-cat-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 60px 0 40px;
  padding: 0 15px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.p-news-archive-cat-list a {
  font-size: 14px;
  font-size: .875rem;
}

.p-news-archive-cat a {
  display: block;
  width: 100%;
  padding: 0 10px;
  text-align: center;
  color: #aaa;
}

.p-news-archive-articles,
.p-blog-archive-articles {
  margin-bottom: 40px;
  padding: 0 15px;
}

.p-news-archive-article a,
.p-blog-archive-article a {
  padding: 20px 10px;
}

.p-news-archive-year {
  margin-bottom: 60px;
  padding: 0 15px;
}

.p-news-archive-year-list {
  font-size: 15px;
  font-size: .9375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px;
  background-color: #f4f4f4;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-news-archive-year-list li {
  margin: 5px;
}

.p-news-archive-year-title {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 15px;
  color: #222;
}

.p-news-button-a {
  width: 100%;
}

.p-news-button-a-wrapper {
  padding: 0 20px;
}

.p-news-button-b.p-news-button-b {
  text-decoration: none;
  color: #121f3f;
  background-color: #fff;
}

.p-news-button-b.p-news-button-b:hover {
  color: #fff;
  background-color: #121f3f;
}

.p-news-cat-and-time.p-news-cat-and-time {
  font-size: 14px;
  font-size: .875rem;
  margin-bottom: 30px;
  text-align: center;
  color: #aaa;
}

.p-news-title-a {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: normal;
  margin-bottom: 30px;
  text-align: center;
}

.p-news-title-a + * {
  margin-top: 30px;
}

.p-contact {
  padding: 60px 20px;
  background: url(../img/common/contact-bg-sp.jpg) center/cover no-repeat;
}

.p-contact h2 {
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: normal;
  margin-bottom: 30px;
  text-align: center;
  letter-spacing: .025em;
  color: #fff;
}

.p-contact h2,
.p-contact h2 > * {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
}

.p-contact p {
  font-size: 15px;
  font-size: .9375rem;
  line-height: 2;
  margin-bottom: 35px;
  text-align: center;
  color: #fff;
}

.p-contact-title-a {
  line-height: 1.75;
  padding: 0 15px;
  text-align: center;
}

.p-contact-title-b.p-contact-title-b {
  font-size: 20px;
  font-size: 1.25rem;
  margin-top: 0;
  text-align: center;
}

.p-contact-text-a {
  padding: 0 15px;
}

.p-contact-text-a--plr_0.p-contact-text-a--plr_0 {
  padding-right: 0;
  padding-left: 0;
}

.p-contact-text-a.p-contact-text-a {
  margin-bottom: 10px;
  text-align: center;
}

.p-contact-text-a.p-contact-text-a + * {
  margin-top: 10px;
}

.p-contact-text-b {
  font-family: 'Roboto', sans-serif;
  padding: 0 15px;
  text-align: center;
}

.p-contact-text-b--plr_0.p-contact-text-b--plr_0 {
  padding-right: 0;
  padding-left: 0;
}

.p-contact-block-a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 345px;
  margin: 0 auto 40px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.p-contact-stap-a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.p-contact-stap-a div:first-of-type {
  font-size: 15px;
  font-size: .9375rem;
  font-weight: bold;
  margin-bottom: 10px;
  color: #121f3f;
}

.p-contact-stap-a div:last-of-type {
  font-size: 12px;
  font-size: .75rem;
  line-height: 1.5;
  padding: 15px;
  text-align: center;
  color: #121f3f;
  border: 1px solid #121f3f;
  background-color: #fff;
}

.p-contact-stap-a.active div:last-of-type {
  color: #fff;
  background-color: #121f3f;
}

.p-contact-arrow-a {
  width: 26px;
  margin-top: 22px;
  background: url(../img/contact/arrow-a-sp.png) center/14px 9px no-repeat;
}

.p-contact-form {
  padding: 60px 15px;
  background-color: #f4f4f4;
}

.p-contact-form-item {
  margin-bottom: 40px;
}

.p-contact-form-item:last-of-type {
  margin-bottom: 0;
}

.p-contact-form-title.p-contact-form-title {
  font-size: 15px;
  font-size: .9375rem;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 0;
  color: #888;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-contact-form-title .required {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  font-size: 12px;
  font-size: .75rem;
  display: inline-block;
  margin-right: 10px;
  padding: 4px 15px 2px;
  color: #fff;
  background-color: #d40f1b;
}

.p-contact-form-title .name {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
}

.p-contact-form-title .en {
  font-family: 'Roboto', sans-serif;
  font-weight: normal;
  margin-left: 10px;
}

.p-contact-form-input input,
.p-contact-form-input textarea {
  width: 100%;
  padding: 15px;
  border: 1px solid #d0d0d0;
  -webkit-appearance: none;
}

.p-contact-form-input input:focus,
.p-contact-form-input textarea:focus {
  outline: 0;
}

.p-contact-form-input input:-webkit-autofill {
  color: #222 !important;
  -webkit-box-shadow: 0 0 0 1000px #f4f4f4 inset;
}

.p-contact-form-button-list {
  margin-top: 40px;
  padding-top: 40px;
  border-top: 1px solid #d0d0d0;
}

.p-contact-form-button-confirm-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.p-contact-form-button-confirm-list p {
  display: none;
}

.p-contact-form-button-a input,
.p-contact-form-button-b input,
.p-contact-form-button-c input {
  font-size: 14px;
  font-size: .875rem;
  padding: 20px;
}

.p-contact-form-button-b.p-contact-form-button-b {
  width: 48%;
}

.p-contact-form-button-b.p-contact-form-button-b input {
  width: 100%;
  background-color: #dbdbdb;
}

.p-contact-form-button-c.p-contact-form-button-c {
  width: 48%;
}

.p-contact-form-button-c.p-contact-form-button-c input {
  width: 100%;
}

.p-contact-form-button-d.p-contact-form-button-d {
  margin-top: 40px;
}

.p-contact-form-button-d.p-contact-form-button-d a {
  width: 100%;
  padding: 20px;
  text-decoration: none;
}

.p-contact-form-error-a.p-contact-form-error-a {
  font-size: 12px;
  font-size: .75rem;
  line-height: 1.5;
  display: none;
  margin-top: 40px;
  padding: 15px;
  color: #d40f1b;
  border: 1px solid #d40f1b;
  background-color: #ffeeef;
}

.p-contact-form form.invalid .p-contact-form-error-a {
  display: block;
}

.p-contact-form .wpcf7-not-valid {
  border: 1px solid #d40f1b;
  background-color: #ffeeef;
}

.p-contact-form .wpcf7-not-valid-tip {
  font-size: 12px;
  font-size: .75rem;
  margin-top: 10px;
  color: #d40f1b;
}

.p-contact-form .wpcf7-response-output.wpcf7-validation-errors {
  display: none !important;
}

.p-contact-form .wpcf7c-conf {
  padding: 15px  0;
  color: #222;
  border: none;
  background-color: transparent;
}

.p-contact-form .ajax-loader {
  display: none !important;
}

.p-pager ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 400px;
  margin: 0 auto 50px;
  padding: 0 15px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-pager li {
  font-family: 'Roboto', sans-serif;
  font-weight: bold;
  padding: 0 2px;
  padding-bottom: 3px;
  color: #121f3f;
}

.p-pager li a {
  display: block;
  width: 100%;
  color: #121f3f;
}

.p-pager li a:hover {
  opacity: .7;
}

.p-pager li.dot {
  -webkit-transform: translate(0, -3px);
  -ms-transform: translate(0, -3px);
  transform: translate(0, -3px);
}

.p-pager li.prev,
.p-pager li.next {
  font-size: 12px;
  font-size: .75rem;
  min-width: 40px;
  min-height: 40px;
  padding: 0;
  border: 1px solid #121f3f;
}

.p-pager li.prev a,
.p-pager li.next a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 40px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-pager li.prev a:hover,
.p-pager li.next a:hover {
  opacity: 1;
  color: #fff;
  background-color: #121f3f;
}

.p-pager li.current {
  padding-bottom: 0;
  border-bottom: 3px solid #d40f1b;
}

.p-free-format {
  padding: 60px 15px;
  counter-reset: head-a-count 0;
  color: #222;
  *zoom: 1;
}

.p-free-format--width_100.p-free-format--width_100 {
  padding: 50px 0;
}

.p-free-format--pb_0.p-free-format--pb_0 {
  padding: 50px 0 0;
}

.p-free-format:after {
  display: table;
  clear: both;
  content: '';
}

.p-free-format > *:first-child {
  margin-top: 0;
}

.p-free-format > *:last-child {
  margin-bottom: 0;
}

.p-free-format .aligncenter {
  position: relative;
  display: table;
  margin: 0 auto;
  text-align: center;
}

.p-free-format .alignright {
  position: relative;
  float: right;
  margin-left: 20px;
}

.p-free-format .alignleft {
  position: relative;
  float: left;
  margin-right: 20px;
}

.p-free-format .wp-caption-text {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0 1em 0;
  text-align: center;
}

.p-free-format .clear {
  clear: both;
}

.p-free-format p {
  font-size: 15px;
  font-size: .9375rem;
  line-height: 1.8;
  margin: 20px 0;
}

.p-free-format h2,
.p-free-format .h2 {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: normal;
  margin: 50px 0 20px;
  color: #222;
}

.p-free-format h2.title-a,
.p-free-format .h2.title-a {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  font-size: 18px;
  font-size: 1.125rem;
  margin-bottom: 20px;
  padding: 15px;
  background-color: #f4f4f4;
}

.p-free-format h2.title-b,
.p-free-format .h2.title-b {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: bold;
}

.p-free-format h3,
.p-free-format .h3 {
  font-family: '游明朝', 'Yu Mincho', YuMincho, 'Hiragino Mincho ProN', 'HGS明朝E', 'メイリオ', Meiryo, serif;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: normal;
  margin: 40px 0 15px;
}

.p-free-format h3.title-a,
.p-free-format .h3.title-a {
  font-family: '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック体', YuGothic, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  padding-bottom: 10px;
  border-bottom: 1px solid #888;
}

.p-free-format h4,
.p-free-format .h4 {
  font-size: 14px;
  font-size: .875rem;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 40px 0 15px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-free-format h4:before,
.p-free-format .h4:before {
  display: block;
  width: .75rem;
  height: .75rem;
  margin-right: 3px;
  content: '';
  background-color: #d40f1b;
}

.p-free-format h5,
.p-free-format h6 {
  font-size: 14px;
  font-size: .875rem;
  margin: 10px 0;
}

.p-free-format h5 + *,
.p-free-format h6 + * {
  margin-top: 10px;
}

.p-free-format a {
  text-decoration: underline;
  color: #d40f1b;
}

.p-free-format a:hover {
  text-decoration: none;
}

.p-free-format *.icon-psd:before {
  display: inline-block;
  width: 13px;
  height: 16px;
  margin-left: 3px;
  content: '';
  -webkit-transform: translateY(2px);
  -ms-transform: translateY(2px);
  transform: translateY(2px);
  background: url(../img/common/pdf.png) center/13px 16px no-repeat;
}

.p-free-format ul,
.p-free-format ol {
  font-size: 15px;
  font-size: .9375rem;
  margin: 30px 0;
  padding-left: 0;
}

.p-free-format ul {
  margin: 30px 0;
}

.p-free-format ul ul,
.p-free-format ul ol {
  margin: 5px 0;
}

.p-free-format ul > li {
  position: relative;
  padding-left: 1.25em;
  list-style-type: none;
}

.p-free-format ul > li:before {
  position: absolute;
  left: 0;
  content: '●';
}

.p-free-format ul li.list-hide:before {
  content: normal;
}

.p-free-format ul ul > li:before {
  content: '・';
}

.p-free-format ol {
  counter-reset: free-format-count 0;
}

.p-free-format ol ul,
.p-free-format ol ol {
  margin: 5px 0;
}

.p-free-format ol > li {
  position: relative;
  padding-left: 2em;
  list-style-type: none;
}

.p-free-format ol > li:before {
  position: absolute;
  left: 0;
  content: '(' counter(free-format-count) ')';
  counter-increment: free-format-count 1;
}

.p-free-format ol li.list-hide:before {
  content: normal;
}

.p-free-format ol ul > li:before {
  content: '・';
}

.p-free-format img {
  max-width: 100%;
  height: auto;
  margin: 20px 0;
}

.p-free-format img + * {
  margin-top: 20px;
}

.p-free-format img.alignnone {
  margin-right: 0;
  margin-left: 0;
}

.p-free-format img.alignright,
.p-free-format img.alignleft {
  display: block;
  float: none;
  margin: 0 auto 20px;
}

.p-free-format table {
  display: block;
  overflow: auto;
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  white-space: nowrap;
  color: #888;
}

.p-free-format table tbody,
.p-free-format table thead {
  display: table;
  width: 100%;
}

.p-free-format table thead tr {
  border-bottom: none;
}

.p-free-format table tr {
  width: 100%;
  border-bottom: 1px solid #888;
}

.p-free-format table tr:first-of-type {
  border-top: 1px solid #888;
}

.p-free-format table td,
.p-free-format table th {
  font-size: 15px;
  font-size: .9375rem;
  font-weight: bold;
  padding: 20px 15px;
}

.p-free-format table td:first-of-type,
.p-free-format table th:first-of-type {
  font-weight: bold;
  padding-right: 50px;
  padding-left: 15px;
}

.p-free-format table th {
  text-align: left;
  background-color: #dbdbdb;
}

.p-free-format table.no-scroll {
  white-space: normal;
}

.p-free-format table.no-scroll td:first-of-type,
.p-free-format table.no-scroll th:first-of-type {
  width: 40%;
  max-width: 100px;
  padding: 20px 15px;
}

.p-free-format figure {
  margin: 0;
}

.p-free-format figure .wp-caption-text {
  font-size: 13px;
  font-size: .8125rem;
  padding: 0;
  text-align: left;
}

.p-free-format .ta_c {
  text-align: center;
}

.p-free-format .fw_b {
  font-weight: bold;
}

.p-free-format .kome {
  content: '※';
}

.p-free-format .button-a,
.p-free-format .button-b {
  margin: 0;
  text-decoration: none;
}

.p-free-format .button-b {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  width: 70%;
  min-width: 240px;
  margin: 0;
  padding: 12px 20px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-free-format .block-a {
  margin: 40px 0;
  padding: 20px;
  background-color: #f4f4f4;
}

.p-free-format .block-b {
  margin: 40px 0;
  padding: 30px 15px;
  background-color: #f4f4f4;
}

.p-free-format .block-b > * {
  padding: 20px;
  border: 1px solid #d0d0d0;
  background-color: #fff;
}

.p-service-title-a {
  padding: 0 15px;
  letter-spacing: -.05em;
}

.p-service-title-a + p {
  padding: 0 15px;
}

.p-service-title-b.p-service-title-b,
.p-recruit-title-b {
  font-size: 22px;
  font-size: 1.375rem;
  margin-bottom: 35px;
  padding-top: 50px;
  text-align: center;
  color: #222;
}

.p-service-title-b__en,
.p-recruit-title-b__en {
  font-family: 'Roboto', sans-serif;
  font-size: 12px;
  font-size: .75rem;
  font-weight: normal;
  display: block;
  margin-bottom: 10px;
  color: #888;
}

.p-service-block-a {
  margin: 0;
  background: url(../img/service/block-bg-sp.gif) top center repeat-x;
}

.p-service-block-a__contents {
  padding: 0 15px;
}

.p-service-block-a__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-bottom: 60px;
}

.p-service-block-a__content:last-child,
.p-service-block-a__content > *:last-child {
  margin-bottom: 0;
}

.p-service-block-a__content img {
  width: 100%;
  margin: 0;
}

.p-service-block-a__content h4 {
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5;
  margin-bottom: 15px;
}

.p-service-block-a__content h4:before {
  content: normal;
}

.p-service-block-a__content p {
  font-size: 15px;
  font-size: .9375rem;
  margin-top: 0;
}

.p-service-block-a__content ul {
  line-height: 1.5;
  margin: 0 0 20px;
  padding-left: 25px;
}

.p-service-block-a__content ul li {
  margin-bottom: 5px;
  padding: 0;
  list-style-type: disc;
}

.p-service-block-a__content ul li:before {
  content: '';
}

.p-about-table,
.p-recruit-table {
  font-size: 15px;
  font-size: .9375rem;
}

.p-about-table-map-a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.p-about-table-map-a a {
  font-weight: bold;
  text-decoration: none;
}

.p-about-table-map-a a:before {
  margin-right: 3px;
  content: '>';
}

.p-about-table-map-b {
  display: none;
}

.p-about-table-m-rl_0.p-about-table-m-rl_0 {
  margin: 0;
}

.p-about-table > dl > div > dt,
.p-recruit-table > dl > div > dt {
  font-weight: bold;
  padding: 15px 10px;
  color: #888;
  background-color: #dbdbdb;
}

.p-about-table > dl > div > dd,
.p-recruit-table > dl > div > dd {
  margin: 20px 10px;
}

.p-about-table > dl > div > dd *:first-child,
.p-recruit-table > dl > div > dd *:first-child {
  margin-top: 0;
}

.p-about-table > dl > div > dd *:last-child,
.p-recruit-table > dl > div > dd *:last-child {
  margin-bottom: 0;
}

.p-about-table > dl > div > dd > dl,
.p-recruit-table > dl > div > dd > dl {
  margin: 0;
}

.p-about-table > dl > div > dd > dl > div > dt,
.p-recruit-table > dl > div > dd > dl > div > dt {
  padding: 20px 10px;
  background-color: #f4f4f4;
}

.p-about-table > dl > div > dd > dl > div > dd,
.p-recruit-table > dl > div > dd > dl > div > dd {
  margin: 0;
  padding: 20px 10px;
}

.p-about-table > dl > div > dd > ul,
.p-recruit-table > dl > div > dd > ul {
  line-height: 1.7;
}

.p-about-table > dl > div > dd > ul li,
.p-recruit-table > dl > div > dd > ul li {
  padding-left: 1em;
}

.p-about-table > dl > div > dd > ul li:before,
.p-recruit-table > dl > div > dd > ul li:before {
  content: '•';
}

.p-recruit-content:after {
  display: block;
  margin: 0 15px;
  content: '';
  border-bottom: 1px solid #d0d0d0;
}

.p-recruit-content > * {
  padding: 0 15px;
}

.p-recruit-content > *:first-child {
  margin-top: 0;
}

.p-recruit-content > *:last-child {
  margin-bottom: 0;
}

.p-recruit-title-a {
  line-height: 1.7;
  text-align: center;
}

.p-recruit-title-b.p-recruit-title-b {
  font-size: 20px;
  font-size: 1.25rem;
  margin: 0;
  padding: 60px 15px 30px;
  background-color: #f4f4f4;
}

.p-recruit-title-c.p-recruit-title-c {
  font-size: 16px;
  font-size: 1rem;
  font-weight: bold;
  margin: 30px 0;
  text-align: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-recruit-title-c.p-recruit-title-c:before {
  content: normal;
}

.p-recruit-text-a-wrapper {
  position: relative;
  overflow: hidden;
  height: 100%;
  max-height: 250px;
  -webkit-transition: all .75s;
  -o-transition: all .75s;
  transition: all .75s;
}

.p-recruit-text-a-wrapper:after {
  position: absolute;
  bottom: 0;
  display: block;
  width: 100%;
  height: 125px;
  content: '';
  -webkit-transition: all .5s;
  -o-transition: all .5s;
  transition: all .5s;
  background: -webkit-linear-gradient(rgba(255, 255, 255, 0) 0, #fff 100px);
  background: -o-linear-gradient(rgba(255, 255, 255, 0) 0, #fff 100px);
  background: linear-gradient(rgba(255, 255, 255, 0) 0, #fff 100px);
}

.p-recruit-text-a-wrapper.js-active {
  max-height: 1500px;
}

.p-recruit-text-a-wrapper.js-active:after {
  height: 0;
}

.p-recruit-text-b.p-recruit-text-b {
  font-weight: bold;
  margin-bottom: 0;
}

.p-recruit-text-b.p-recruit-text-b + * {
  margin-top: 0;
}

.p-recruit-button-a {
  width: 50px;
  height: 50px;
  margin: 0 auto;
  margin-bottom: 30px;
  background: url(../img/recruit/button-a.png) center left/100px 50px no-repeat;
}

.p-recruit-button-a.js-active {
  background: url(../img/recruit/button-a.png) center right/100px 50px no-repeat;
}

.p-recruit-img-a.p-recruit-img-a {
  line-height: 0;
  display: none;
}

.p-recruit-img-b.p-recruit-img-b {
  line-height: 0;
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
}

.p-recruit-img-b.p-recruit-img-b img {
  width: 100%;
  margin: 0;
}

.p-recruit-block-a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  margin-bottom: 60px;
}

.p-recruit-block-a > div {
  font-size: 15px;
  font-size: .9375rem;
  line-height: 1.75;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  min-height: 80px;
  margin-bottom: 2px;
  padding: 15px;
  text-align: center;
  color: #fff;
  background-color: #121f3f;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-recruit-block-a > div:last-of-type {
  margin-bottom: 0;
}

.p-recruit-block-a--pc.p-recruit-block-a--pc {
  display: none;
}

.p-recruit-block-a--sp.p-recruit-block-a--sp {
  display: block;
}

.u-br {
  display: block;
}

.u-br-pc {
  display: inline;
}

.u-br-sp {
  display: block;
}

@media screen and (min-width: 768px) {
  .p-header {
    height: 100px;
  }

  .p-header-content {
    padding: 0 20px;
  }

  .p-header-logo {
    margin: 0;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto;
  }

  .p-header-nav {
    position: static;
    top: 0;
    visibility: visible;
    height: auto;
    height: 100%;
    padding: 0;
    background-color: transparent;
  }

  .p-header-nav ul {
    position: static;
    overflow: visible;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }

  .p-header-nav a {
    color: #121f3f;
  }

  .p-header-nav a:hover,
  .p-header-nav a:hover > * {
    opacity: .7;
  }

  .p-header-link--top {
    display: none;
  }

  .p-header-link.active.p-header-link.active {
    border-bottom: #d40f1b 3px solid;
  }

  .p-header-link {
    font-size: 12px;
    font-size: .75rem;
    padding: 0;
    padding: 40px 12px 0;
    text-align: center;
    letter-spacing: .05em;
    border: none;
  }

  .p-header-link:first-of-type {
    margin-left: 0;
  }

  .p-header-link:last-of-type {
    margin-right: 0;
    border: none;
  }

  .p-header-link a {
    padding: 0;
  }

  .p-header-link span {
    font-size: 13px;
    font-size: .8125rem;
    display: block;
    width: 100%;
    margin: 0 auto 5px;
    text-align: center;
  }

  .p-header-button-a {
    display: none;
  }

  .p-footer small {
    padding: 30px 15px;
  }

  .p-footer-nav {
    border-bottom: 1px solid #333;
  }

  .p-footer-nav ul {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 20px;
    border: none;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }

  .p-footer-nav li {
    border: none;
  }

  .p-footer-nav li:nth-child(odd) {
    border: none;
  }

  .p-footer-nav a {
    padding: 15px 0;
  }

  .p-footer-nav a:hover {
    opacity: .7;
  }

  .p-footer-middle {
    padding: 60px 0;
  }

  .p-footer-middle > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 20px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .p-footer-middle address {
    width: 60%;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .p-footer-address h3 {
    font-size: 14px;
    font-size: .875rem;
  }

  .p-footer-address p {
    font-size: 12px;
    font-size: .75rem;
  }

  .p-footer-bottom {
    padding: 40px 20px;
  }

  .p-footer-bottom ul {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }

  .p-footer-bottom li {
    width: 23%;
  }

  .p-footer-bottom li:hover {
    opacity: .7;
  }

  .p-footer-banner-a.p-footer-banner-a {
    max-width: 238px;
    background-image: url(../img/footer/footer-banner-a.png);
  }

  .p-footer-banner-b {
    max-width: 193px;
    background-image: url(../img/footer/footer-banner-b.png);
  }

  .p-footer-banner-c {
    max-width: 201px;
    background-image: url(../img/footer/footer-banner-c.png);
  }

  .p-footer-banner-d {
    max-width: 173px;
    background-image: url(../img/footer/footer-banner-d.png);
  }

  .p-section-a,
  .p-section-b {
    padding-top: 100px;
  }

  .p-section-a h2,
  .p-section-b h2,
  .p-section-a__title,
  .p-section-b h2,
  .p-mainview-a h1,
  .p-mainview-b h1,
  .p-mainview-c h1 {
    margin-bottom: 60px;
  }

  .p-section-a h2 span,
  .p-section-b h2 span,
  .p-section-a__title span,
  .p-section-b h2 span,
  .p-mainview-a h1 span,
  .p-mainview-b h1 span,
  .p-mainview-c h1 span {
    font-size: 60px;
    font-size: 3.75rem;
  }

  .p-section-a__text h3 {
    font-size: 32px;
    font-size: 2rem;
  }

  .p-section-a__text p {
    font-size: 14px;
    font-size: .875rem;
  }

  .p-section-b h3 {
    font-size: 32px;
    font-size: 2rem;
  }

  .p-section-b h3 + p {
    font-size: 16px;
    font-size: 1rem;
    margin-bottom: 80px;
  }

  .p-section-b__content-wrapper {
    background-size: 100% 120px;
  }

  .p-section-b__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .p-section-b__content > div {
    width: 48.61111%;
    max-width: 700px;
    margin: 0 10px 30px;
  }

  .p-section-b__content h4 {
    font-size: 26px;
    font-size: 1.625rem;
  }

  .p-section-b__content img {
    width: 100%;
  }

  .p-section-b__content a {
    font-weight: normal;
  }

  .p-section-b__content a:hover {
    opacity: .5;
  }

  .p-mainview-top-content {
    max-width: 1680px;
    padding-left: 50px;
  }

  .p-mainview-top-text {
    max-width: 600px;
    height: 320px;
    margin: 0 auto 0 0;
    border-radius: 15px;
    background-image: url(../img/top/mainview-text-01.png);
    background-size: 524px 247px;
  }

  .p-mainview-a,
  .p-mainview-b,
  .p-mainview-c {
    height: 400px;
    margin-top: 100px;
  }

  .p-mainview-a h1,
  .p-mainview-b h1,
  .p-mainview-c h1 {
    font-size: 14px;
    font-size: .875rem;
    margin-bottom: 0;
  }

  .p-mainview-a h1 span,
  .p-mainview-b h1 span,
  .p-mainview-c h1 span {
    font-size: 60px;
    font-size: 3.75rem;
  }

  .p-mainview-b h1 {
    font-size: 18px;
    font-size: 1.125rem;
  }

  .p-mainview-b h1 span {
    margin-bottom: 15px;
  }

  .p-mainview-c h1 {
    font-size: 18px;
    font-size: 1.125rem;
  }

  .p-mainview-c h1 span {
    margin-bottom: 15px;
  }

  .p-visual-a {
    background-attachment: fixed;
  }

  .p-vision-content {
    max-width: 920px;
    margin: 0 auto;
  }

  .p-business-button-a {
    max-width: 240px;
  }

  .p-blog-top {
    padding-bottom: 80px;
  }

  .p-blog-top-articles {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    width: 100%;
    max-width: 1120px;
    margin: 0 auto;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .p-blog-top-article {
    width: 31%;
    max-width: 336px;
  }

  .p-blog-top-article a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .p-blog-top-article a:hover {
    opacity: .7;
  }

  .p-blog-top-article img {
    width: 100%;
  }

  .p-blog-top-article__img {
    width: 100%;
    margin-bottom: 20px;
    border: 1px solid #c8c8c8;
  }

  .p-blog-top-article__contant time {
    font-size: 15px;
    font-size: .9375rem;
    margin-bottom: 5px;
  }

  .p-blog-top-article__contant p {
    font-size: 16px;
    font-size: 1rem;
  }

  .p-blog-top-article__contant time {
    margin-bottom: 20px;
  }

  .p-blog-top-article__contant p {
    margin-bottom: 25px;
  }

  .p-blog-top-link {
    display: block;
  }

  .p-blog-archive-cat-list {
    width: 100%;
    max-width: 1080px;
    margin: 100px auto 50px;
  }

  .p-blog-archive-cat-list a:hover {
    font-weight: bold;
    color: #1c3060;
  }

  .p-blog-archive-articles.p-blog-archive-articles {
    margin: 50px auto;
  }

  .p-blog-title-a {
    font-size: 32px;
    font-size: 2rem;
    margin-bottom: 50px;
  }

  .p-blog-button-a,
  .p-free-format .button-a,
  .p-free-format .button-b {
    max-width: 240px;
  }

  .p-link-a {
    display: block;
  }

  .p-link-a:hover {
    opacity: .7;
  }

  .p-link-a p span {
    -webkit-transform: translate(10px, -1px);
    -ms-transform: translate(10px, -1px);
    transform: translate(10px, -1px);
  }

  .p-map-top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-height: 500px;
    margin: 0 auto;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .p-map-top-block-banner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-right: 20px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .p-map-top-block-banner ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    max-width: 530px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .p-map-top-block-banner li {
    width: 48%;
    max-width: 252px;
    max-width: 252px;
  }

  .p-map-top-img-a,
  .p-map-top-img-b,
  .p-map-top-img-c,
  .p-map-top-img-d {
    width: 100%;
    max-width: none;
    height: 110px;
    max-height: none;
    background-image: url(../img/top/machiya-residence-inn.png);
    background-position: center bottom;
  }

  .p-map-top-img-b {
    background-image: url(../img/top/the-machiya-hotel.png);
  }

  .p-map-top-img-c {
    background-image: url(../img/top/the-machiya-villa.png);
  }

  .p-map-top-img-d {
    background-image: url(../img/top/dozen.png);
  }

  .p-map-top-block-map {
    width: 50%;
  }

  .p-news-top {
    padding-bottom: 80px;
  }

  .p-news-top-cat-list {
    margin: 0 40px 0 0;
  }

  .p-news-top-cat {
    font-size: 12px;
    font-size: .75rem;
    min-width: 100px;
    padding: 3px 6px;
    letter-spacing: 0;
  }

  .p-news-top-articles {
    max-width: 1120px;
    margin: 0 auto 50px;
  }

  .p-news-top-article,
  .p-news-archive-article,
  .p-blog-archive-article {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }

  .p-news-top-article a,
  .p-news-archive-article a,
  .p-blog-archive-article a {
    padding: 20px;
  }

  .p-news-top-article time,
  .p-news-archive-article time,
  .p-blog-archive-article time {
    font-size: 12px;
    font-size: .75rem;
    margin: 0 40px 0 0;
  }

  .p-news-top-article h3,
  .p-news-archive-article h3,
  .p-blog-archive-article h3 {
    font-size: 16px;
    font-size: 1rem;
    width: auto;
  }

  .p-news-archive-cat-list {
    width: 100%;
    max-width: 1080px;
    margin: 100px auto 50px;
  }

  .p-news-archive-cat-list a:hover {
    font-weight: bold;
    color: #1c3060;
  }

  .p-news-archive-articles,
  .p-blog-archive-articles {
    width: 100%;
    max-width: 1080px;
    margin: 0 auto 50px;
  }

  .p-news-archive-year {
    width: 100%;
    max-width: 1080px;
    margin: 0 auto 50px;
  }

  .p-news-archive-year-list {
    padding: 20px 25px;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .p-news-archive-year-list li {
    margin: 10px 5px;
  }

  .p-news-archive-year-list a:hover {
    opacity: .7;
  }

  .p-news-button-a {
    max-width: 240px;
  }

  .p-news-title-a {
    font-size: 32px;
    font-size: 2rem;
    margin-bottom: 50px;
  }

  .p-contact {
    background: url(../img/common/contact-bg.jpg) center/cover no-repeat;
  }

  .p-contact h2 {
    font-size: 32px;
    font-size: 2rem;
  }

  .p-contact p {
    font-size: 16px;
    font-size: 1rem;
  }

  .p-contact-title-b.p-contact-title-b {
    font-size: 26px;
    font-size: 1.625rem;
  }

  .p-contact-text-a.p-contact-text-a {
    font-size: 16px;
    font-size: 1rem;
    margin-bottom: 40px;
  }

  .p-contact-text-a.p-contact-text-a + * {
    margin-top: 0;
  }

  .p-contact-block-a {
    max-width: 760px;
    margin-bottom: 50px;
  }

  .p-contact-stap-a {
    width: 100%;
    max-width: 200px;
    padding: 0 15px;
  }

  .p-contact-stap-a div:last-of-type {
    width: 100%;
  }

  .p-contact-arrow-a {
    background: url(../img/contact/arrow-a.png) center/24px 12px no-repeat;
  }

  .p-contact-form.p-contact-form > div {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 15px;
  }

  .p-contact-form-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  .p-contact-form-title.p-contact-form-title {
    width: 100%;
    max-width: 280px;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }

  .p-contact-form-title .en {
    display: block;
    margin: 10px 0 0 0;
  }

  .p-contact-form-input {
    -webkit-box-flex: 1;
    -ms-flex: auto;
    flex: auto;
  }

  .p-contact-form-input textarea {
    resize: vertical;
  }

  .p-contact-form-button-a.p-contact-form-button-a,
  .p-contact-form-button-a .p-contact-form-button-b,
  .p-contact-form-button-a .p-contact-form-button-c,
  .p-contact-form-button-b.p-contact-form-button-a,
  .p-contact-form-button-b .p-contact-form-button-b,
  .p-contact-form-button-b .p-contact-form-button-c,
  .p-contact-form-button-c.p-contact-form-button-a,
  .p-contact-form-button-c .p-contact-form-button-b,
  .p-contact-form-button-c .p-contact-form-button-c {
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
  }

  .p-contact-form-button-a.p-contact-form-button-a input,
  .p-contact-form-button-a .p-contact-form-button-b input,
  .p-contact-form-button-a .p-contact-form-button-c input,
  .p-contact-form-button-b.p-contact-form-button-a input,
  .p-contact-form-button-b .p-contact-form-button-b input,
  .p-contact-form-button-b .p-contact-form-button-c input,
  .p-contact-form-button-c.p-contact-form-button-a input,
  .p-contact-form-button-c .p-contact-form-button-b input,
  .p-contact-form-button-c .p-contact-form-button-c input {
    width: 100%;
    cursor: pointer;
  }

  .p-contact-form-button-b.p-contact-form-button-b {
    width: 100%;
    max-width: 360px;
  }

  .p-contact-form-button-b.p-contact-form-button-b input {
    width: 100%;
    cursor: pointer;
  }

  .p-contact-form-button-c.p-contact-form-button-c {
    width: 100%;
    max-width: 360px;
  }

  .p-contact-form-button-c.p-contact-form-button-c input {
    width: 100%;
    cursor: pointer;
  }

  .p-contact-form-button-d.p-contact-form-button-d a {
    width: 100%;
    max-width: 360px;
  }

  .p-pager ul {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .p-pager li {
    margin: 0 8px;
  }

  .p-free-format--width_100.p-free-format--width_100 {
    width: 100%;
    max-width: none;
    margin: auto;
    padding: 100px 0;
  }

  .p-free-format--pb_0.p-free-format--pb_0 {
    padding: 100px 0 0;
  }

  .p-free-format {
    width: 100%;
    max-width: 1080px;
    margin: auto;
    padding: 100px 15px;
  }

  .p-free-format h2,
  .p-free-format .h2 {
    font-size: 32px;
    font-size: 2rem;
  }

  .p-free-format img {
    margin: 15px;
  }

  .p-free-format img.alignright,
  .p-free-format img.alignleft {
    margin-bottom: 30px;
  }

  .p-free-format img.alignright {
    float: right;
    margin-left: 20px;
  }

  .p-free-format img.alignleft {
    float: left;
    margin-right: 20px;
  }

  .p-free-format .block-b {
    width: 100%;
    margin: 40px 0;
    padding: 30px;
  }

  .p-free-format .block-b > * {
    width: 100%;
    max-width: 1050px;
    margin: 0 auto;
  }

  .p-service-title-b.p-service-title-b,
  .p-recruit-title-b {
    font-size: 24px;
    font-size: 1.5rem;
    margin-bottom: 50px;
    padding-top: 80px;
  }

  .p-service-title-b__en,
  .p-recruit-title-b__en {
    font-size: 14px;
    font-size: .875rem;
    margin-bottom: 20px;
  }

  .p-service-block-a {
    margin: 100px 0 0;
    padding-top: 50px;
    background-image: url(../img/service/block-bg.gif);
  }

  .p-service-block-a__contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .p-service-block-a__content {
    width: 30%;
    margin: 0 1.6665%;
  }

  .p-service-block-a__content img {
    margin: 0;
  }

  .p-about-table-child {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }

  .p-about-table-map-a a {
    display: none;
  }

  .p-about-table-map-b {
    display: block;
    margin-left: 10px;
  }

  .p-about-table,
  .p-recruit-table {
    line-height: 1.5;
  }

  .p-about-table > dl > *:last-child,
  .p-recruit-table > dl > *:last-child {
    border-bottom: 1px solid #d0d0d0;
  }

  .p-about-table > dl > div,
  .p-recruit-table > dl > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 25px 20px;
    border-top: 1px solid #d0d0d0;
  }

  .p-about-table > dl > div > dt,
  .p-recruit-table > dl > div > dt {
    width: 15%;
    max-width: 180px;
    padding: 0;
    background-color: transparent;
  }

  .p-about-table > dl > div > dd,
  .p-recruit-table > dl > div > dd {
    width: 85%;
    margin: 0;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto;
  }

  .p-about-table > dl > div > dd > dl,
  .p-recruit-table > dl > div > dd > dl {
    margin: 0;
  }

  .p-about-table > dl > div > dd > dl > div,
  .p-recruit-table > dl > div > dd > dl > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 25px 0;
    border-bottom: 1px solid #d0d0d0;
  }

  .p-about-table > dl > div > dd > dl > div > dt,
  .p-recruit-table > dl > div > dd > dl > div > dt {
    width: 15%;
    max-width: 160px;
    padding: 0;
    background-color: transparent;
  }

  .p-about-table > dl > div > dd > dl > div > dd,
  .p-recruit-table > dl > div > dd > dl > div > dd {
    padding: 0;
  }

  .p-about-table > dl > div > dd > dl > *:first-child,
  .p-recruit-table > dl > div > dd > dl > *:first-child {
    padding-top: 0;
  }

  .p-about-table > dl > div > dd > dl > *:last-child,
  .p-recruit-table > dl > div > dd > dl > *:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }

  .p-about-table > dl > div > dd > ul,
  .p-recruit-table > dl > div > dd > ul {
    margin: 0;
  }

  .p-recruit-content:after {
    content: normal;
  }

  .p-recruit-title-b.p-recruit-title-b {
    font-size: 26px;
    font-size: 1.625rem;
    padding: 80px 15px 60px;
  }

  .p-recruit-title-c.p-recruit-title-c {
    margin: 60px 0 30px;
  }

  .p-recruit-text-a-wrapper {
    max-height: none;
  }

  .p-recruit-text-a-wrapper:after {
    content: normal;
  }

  .p-recruit-text-a {
    text-align: center;
  }

  .p-recruit-table {
    width: 100%;
    max-width: 1080px;
    margin: 50px auto;
  }

  .p-recruit-table dd > *:first-child {
    margin-top: 0;
  }

  .p-recruit-table dd > *:last-child {
    margin-bottom: 0;
  }

  .p-recruit-button-a {
    display: none;
  }

  .p-recruit-img-a.p-recruit-img-a {
    display: block;
    width: 100%;
    margin-top: 50px;
    padding: 0;
  }

  .p-recruit-img-a.p-recruit-img-a img {
    width: 100%;
    margin: 0;
  }

  .p-recruit-img-b.p-recruit-img-b {
    display: none;
  }

  .p-recruit-block-a {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    margin-bottom: 80px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .p-recruit-block-a > div {
    width: 100%;
    max-width: 268px;
    margin: 0 1px;
  }

  .p-recruit-block-a--pc.p-recruit-block-a--pc {
    display: block;
  }

  .p-recruit-block-a--sp.p-recruit-block-a--sp {
    display: none;
  }

  .u-br-pc {
    display: block;
  }

  .u-br-sp {
    display: inline;
  }
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  body {
    font-family: 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', Osaka, sans-serif;
  }
}