@charset "UTF-8";
/**
 * App
 */
/* ==========================================================================
   Foundation
   ========================================================================== */
/*==================================
* breakpoint
==================================*/
/*==================================
* margin
==================================*/
/*==================================
* padding
==================================*/
/*==================================
* z-index
==================================*/
/*==================================
* round
==================================*/
/*==================================
* theme
==================================*/
/* Vendors
----------------------------------------------------------------- */
/**
 * #Normalize
 */
/* ==========================================================================
   Normalize.css
   ========================================================================== */
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 */
html {
  font-family: sans-serif; /* 1 */
  -ms-text-size-adjust: 100%; /* 2 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/**
 * Remove default margin.
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active,
a:hover {
  outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit; /* 1 */
  font: inherit; /* 2 */
  margin: 0; /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: button; /* 2 */
  cursor: pointer; /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type=checkbox],
input[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
input[type=search] {
  -webkit-appearance: textfield; /* 1 */
  box-sizing: content-box; /* 2 */
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/* Base
----------------------------------------------------------------- */
html {
  box-sizing: border-box;
  font-size: 62.5%;
  scroll-padding-top: 70px;
}
@media print, screen and (min-width: 1000px) {
  html {
    scroll-padding-top: 90px;
  }
}

body {
  width: 100%;
  font-size: 1.4rem;
  margin: 0 auto;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  font-weight: 400;
}
@media print, screen and (min-width: 768px) {
  body {
    font-size: 1.6rem;
  }
}

h1, h2, h3, h4, h5 {
  margin: 0;
  padding: 0;
  font-weight: normal;
  line-height: 1.3;
  font-size: 1.6em;
}

h1 {
  font-size: 2.5rem;
}

h2 {
  font-size: 2rem;
}

h3 {
  font-size: 1.75rem;
}

h4 {
  font-size: 1.5rem;
}

h5 {
  font-size: 1.25rem;
}

h6 {
  font-size: 1rem;
}

@media print, screen and (min-width: 768px) {
  h1 {
    font-size: 3rem;
  }
  h2 {
    font-size: 2.5rem;
  }
  h3 {
    font-size: 2.2rem;
  }
  h4 {
    font-size: 1.75rem;
  }
  h5 {
    font-size: 1.5rem;
  }
  h6 {
    font-size: 1rem;
  }
}
ol {
  margin: 0;
  padding: 0;
}

ul {
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
}

span {
  display: inline-block;
}

img {
  margin: 0;
  padding: 0;
  vertical-align: bottom;
}

p {
  margin: 0;
  padding: 0;
}

a {
  color: #3d70bb;
  text-decoration: none;
}
a:hover, a:focus {
  color: rgb(115.127016129, 153.2741935484, 209.372983871);
  text-decoration: none;
  opacity: 0.8;
}

/*=================================
* 印刷用
=================================*/
@media print {
  body {
    width: 1200px;
  }
  .l-header__menu {
    display: none;
  }
}
/* ==========================================================================
   Layout
========================================================================== */
/**
 * Footer
 */
/*==================================
* footer
==================================*/
footer {
  width: 100%;
}

/*　ナビゲーション　*/
.l-footer {
  padding: 20px;
  color: #fff;
  background-color: #333;
}
.l-footer .l-footer__inner .l-footer__log {
  margin-bottom: 20px;
  width: 130px;
}
.l-footer .l-footer__inner .l-footer__log img {
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: 5px;
}
.l-footer .l-footer__inner .l-footer__log p {
  text-align: center;
  font-size: 1rem;
}
.l-footer .l-footer__inner .l-footer__log p span {
  font-size: 1.2rem;
}
.l-footer .l-footer__inner .l-footer__menu {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit {
  width: 45%;
  margin-bottom: 20px;
}
.l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit:last-child {
  margin-bottom: 0;
}
.l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit span {
  margin-bottom: 7px;
  font-size: 1.6rem;
  font-weight: 700;
}
.l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit ul li {
  position: relative;
  margin-bottom: 7px;
}
.l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit ul li::before {
  content: "-";
  position: absolute;
  top: -1px;
  left: 0;
}
.l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit ul li a {
  display: inline-block;
  margin-left: 10px;
  font-size: 1.5rem;
  color: #fff;
}
.l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit ul:not(:last-child) {
  margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
  .l-footer {
    padding: 40px 8px;
  }
  .l-footer .l-footer__inner {
    display: flex;
    box-sizing: border-box;
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 8px;
  }
  .l-footer .l-footer__inner .l-footer__log {
    margin-bottom: 0;
    margin-right: 70px;
  }
  .l-footer .l-footer__inner .l-footer__log img {
    margin-bottom: 10px;
  }
  .l-footer .l-footer__inner .l-footer__log p {
    font-size: 1.4rem;
  }
  .l-footer .l-footer__inner .l-footer__log p span {
    font-size: 1.6rem;
  }
  .l-footer .l-footer__inner .l-footer__menu {
    flex-wrap: nowrap;
    width: calc(100% - 200px);
  }
  .l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit {
    width: 25%;
    margin-bottom: 0;
  }
  .l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit span {
    font-size: 1.8rem;
  }
  .l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit li {
    position: relative;
  }
  .l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit li::before {
    content: "-";
    position: absolute;
    top: -1px;
    left: 0;
  }
  .l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit li a {
    margin-left: 10px;
    padding-bottom: 2px;
    font-size: 1.6rem;
    border-bottom: solid 1px transparent;
  }
  .l-footer .l-footer__inner .l-footer__menu .l-footer__menu__unit li a:hover {
    border-bottom: solid 1px #fff;
  }
}

/*　フッター　*/
.l-footer__bottom {
  padding: 20px;
  color: #fff;
  background-color: #000;
}
.l-footer__bottom .l-footer__nav {
  margin-bottom: 15px;
}
.l-footer__bottom .l-footer__nav ul {
  display: flex;
  flex-wrap: wrap;
}
.l-footer__bottom .l-footer__nav ul li {
  padding: 5px 10px 5px 0;
}
.l-footer__bottom .l-footer__nav ul li a {
  display: inline-block;
  color: #fff;
}
.l-footer__bottom .l-footer__copyright {
  text-align: center;
}
.l-footer__bottom .l-footer__copyright p {
  font-size: 1.8rem;
  font-weight: bold;
}
.l-footer__bottom .l-footer__copyright p span {
  font-size: 1rem;
}
@media print, screen and (min-width: 768px) {
  .l-footer__bottom {
    padding: 40px 8px;
  }
  .l-footer__bottom .l-footer__bottom__inner {
    max-width: 1140px;
    margin: 0 auto;
  }
  .l-footer__bottom .l-footer__bottom__inner .l-footer__nav ul li {
    padding-right: 20px;
  }
  .l-footer__bottom .l-footer__bottom__inner .l-footer__nav ul li a {
    padding-bottom: 2px;
    border-bottom: solid 1px transparent;
  }
  .l-footer__bottom .l-footer__bottom__inner .l-footer__nav ul li a:hover {
    border-bottom: solid 1px #fff;
  }
  .l-footer__bottom .l-footer__bottom__inner .l-footer__copyright {
    text-align: left;
  }
  .l-footer__bottom .l-footer__bottom__inner .l-footer__copyright p {
    font-size: 2rem;
  }
  .l-footer__bottom .l-footer__bottom__inner .l-footer__copyright p span {
    font-size: 1.6rem;
  }
}

/*
 上へボタン
================================*/
.f-backto-top {
  color: #cdcdcd;
  height: auto;
  position: fixed;
  bottom: 20px;
  margin: 0;
  z-index: 10000;
  transition: all 0.3s ease 0s;
  right: 20px;
  visibility: hidden;
}
.f-backto-top.f-backto-top--on {
  opacity: 1;
  filter: alpha(opacity=100);
  visibility: visible;
  right: 25px;
}
.f-backto-top span {
  width: 52px;
  height: 52px;
  line-height: 52px;
  text-decoration: none;
  border-radius: 52px;
  border-radius: 52px;
  transition: all 0.2s ease 0s;
  border: 2px solid #e8e8e8;
  background: 0 0;
  text-align: center;
}
.f-backto-top span i {
  font-size: 22px;
  color: #b0b0b0;
  line-height: 52px;
}
@media print, screen and (min-width: 768px) {
  .f-backto-top {
    bottom: 65px;
  }
}

/**
 * #Header
 */
/*==================================
* header
==================================*/
header {
  width: 100%;
  height: 70px;
}
header .l-header {
  position: fixed;
  box-sizing: border-box;
  width: 100%;
  height: 70px;
  background-color: #ffffff;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.2);
  z-index: 99;
}
header .l-header .l-header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 70px;
}
header .l-header .l-header__inner .l-header__logo {
  display: flex;
  align-items: center;
  padding: 7px 0 7px 10px;
}
header .l-header .l-header__inner .l-header__logo a {
  display: flex;
  align-items: center;
  color: #333;
}
header .l-header .l-header__inner .l-header__logo a img {
  width: 90px;
}
header .l-header .l-header__inner .l-header__logo a span {
  margin-left: 15px;
  font-size: 1.7rem;
  font-weight: bold;
}
@media screen and (min-width: 1000px) and (max-width: 1320px) {
  header .l-header .l-header__inner .l-header__logo a span {
    display: none;
  }
}
header .l-header .l-header__inner .l-header__nav {
  display: none;
}
@media print, screen and (min-width: 1000px) {
  header {
    height: 90px;
  }
  header .l-header {
    height: 90px;
  }
  header .l-header .l-header__inner {
    height: 90px;
  }
  header .l-header .l-header__inner .l-header__logo {
    padding: 0 0 0 20px;
  }
  header .l-header .l-header__inner .l-header__logo a img {
    width: 120px;
  }
  header .l-header .l-header__inner .l-header__logo a span {
    font-size: 2.2rem;
  }
  header .l-header .l-header__inner .l-header__nav {
    display: flex;
    align-items: center;
    padding-right: 20px;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list {
    display: flex;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li {
    position: relative;
    display: inline-block;
    min-width: 90px;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li > a {
    display: block;
    padding: 5px 15px;
    color: #222;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li > a:hover {
    color: #044E80;
    opacity: 1;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li i {
    margin-left: 8px;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li ul {
    display: none;
    padding: 5px 10px;
    background-color: #ffffff;
    box-shadow: 0 2px 7px 1px rgba(118, 118, 118, 0.3);
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li ul li .l-header__gnav__child__title {
    display: block;
    margin: 5px 0 0 15px;
    font-size: 1.6rem;
    color: #6c757d;
    word-break: keep-all;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li ul li a {
    display: block;
    padding: 5px 15px;
    color: #222;
    white-space: nowrap;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li ul li a:hover {
    color: #044E80;
    opacity: 1;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li ul li.l-header__gnav__child a {
    position: relative;
    padding-left: 30px;
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li ul li.l-header__gnav__child a::before {
    position: absolute;
    top: 50%;
    left: 15px;
    content: "-";
    transform: translateY(-50%);
  }
  header .l-header .l-header__inner .l-header__nav .l-header__gnav__list > li:hover ul {
    position: absolute;
    display: block;
    margin: 0;
    top: 33px;
    left: 0;
  }
  header .l-header .l-header__inner .l-header__snav {
    margin-left: 10px;
  }
  header .l-header .l-header__inner .l-header__snav ul {
    display: flex;
  }
  header .l-header .l-header__inner .l-header__snav ul li {
    margin-left: 5px;
  }
  header .l-header .l-header__inner .l-header__snav ul li .l-header__button__login {
    display: block;
    padding: 7px 20px 8px 20px;
    font-weight: bold;
    border-radius: 5px;
    transition: all 0.3s;
    color: #044E80;
    border: solid 2px #044E80;
  }
  header .l-header .l-header__inner .l-header__snav ul li .l-header__button__login:hover {
    opacity: 1;
    color: #fff;
    background-image: linear-gradient(90deg, rgb(85, 156, 249), rgb(56, 96, 149) 65%, rgb(52, 88, 135));
  }
}

/*=============================
.l-header__menu-btn
=============================*/
.l-header__menu {
  width: 100%;
  height: 100%;
  background: #fefefe;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 30;
  padding: 70px 0 30px 0;
  transform: translateY(-100%);
  transition: transform 0.5s;
  box-sizing: border-box;
  overflow-y: scroll;
}
.l-header__menu .l-header__menu__nav {
  border-bottom: solid 1px #ccc;
  margin-bottom: 30px;
  padding: 20px;
}
.l-header__menu .l-header__menu__nav > ul > li > a {
  display: block;
  padding: 10px 0;
  position: relative;
  font-size: 1.8rem;
  font-weight: bold;
  color: #333;
}
.l-header__menu .l-header__menu__nav > ul > li > a:hover {
  color: #333;
  opacity: 1;
}
.l-header__menu .l-header__menu__nav > ul > li > a i {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
}
.l-header__menu .l-header__menu__nav > ul > li ul {
  display: none;
}
.l-header__menu .l-header__menu__nav > ul > li ul li .l-header__menu__nav__child__title {
  display: block;
  margin: 0 0 0 16px;
  font-size: 1.6rem;
  color: #6c757d;
}
.l-header__menu .l-header__menu__nav > ul > li ul li a {
  display: block;
  padding: 7px 0;
  margin-left: 20px;
  font-size: 1.6rem;
  color: #333;
}
.l-header__menu .l-header__menu__nav > ul > li ul li.l-header__menu__nav__child a {
  position: relative;
  padding-left: 30px;
}
.l-header__menu .l-header__menu__nav > ul > li ul li.l-header__menu__nav__child a::before {
  position: absolute;
  top: 50%;
  left: 15px;
  content: "-";
  transform: translateY(-50%);
}
.l-header__menu .l-header__menu__nav > ul > li ul li.l-header__menu__nav__child a:last-child {
  margin-bottom: 10px;
}
.l-header__menu.is-open {
  transform: translateY(0);
}
@media print, screen and (min-width: 1000px) {
  .l-header__menu {
    display: none;
  }
}

/*
 l-header__menu__button
=================================*/
.l-header__menu__button {
  display: block;
  position: relative;
  padding-right: 20px;
  width: 30px;
  height: 30px;
  transition: all 0.5s;
  cursor: pointer;
  z-index: 3;
}
@media print, screen and (min-width: 1000px) {
  .l-header__menu__button {
    display: none;
  }
}
.l-header__menu__button span {
  display: block;
  position: absolute;
  left: 0;
  width: 30px;
  height: 2px;
  background-color: #333;
  border-radius: 4px;
  transition: all 0.5s;
}
.l-header__menu__button span:nth-child(1) {
  top: 4px;
}
.l-header__menu__button span:nth-child(3) {
  bottom: 4px;
}
.l-header__menu__button span:nth-child(2) {
  top: 14px;
}

.is-open .l-header__menu__button span:nth-child(1) {
  transform: translateY(10px) rotate(45deg);
}
.is-open .l-header__menu__button span:nth-child(2) {
  opacity: 0;
}
.is-open .l-header__menu__button span:nth-child(3) {
  transform: translateY(-10px) rotate(-45deg);
}

/**
 * Main
 */
.l-main {
  display: block;
  width: 100%;
  box-sizing: border-box;
}
/**
 * Section
 */
/*==================================
* Section
==================================*/
.l-section {
  width: 100%;
  box-sizing: border-box;
  padding: 5rem 0;
  /* 画像 */
  /* 背景色あり */
  /* 背景色あり（プライマリ） */
  /* 中央寄せ */
  /* タイトル型（コメントなし） */
}
@media print, screen and (min-width: 768px) {
  .l-section {
    padding: 8rem 0;
  }
}
.l-section img {
  max-width: 100%;
  height: auto;
}
.l-section.l-section--gray {
  background-color: #f2f2f2;
}
.l-section.l-section--primary {
  background-color: #044E80;
  color: #FFF;
}
.l-section.l-section--l-blue {
  background-color: #f6f7f7;
}
.l-section .l-section--center {
  box-sizing: border-box;
  width: 100%;
  text-align: center;
}
.l-section.l-section--title--type02 {
  padding: 3rem 0;
  background-color: #044E80;
  color: #FFF;
}
.l-section.l-section--title--type02 h2 {
  font-size: 2.6rem;
  font-weight: bold;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .l-section.l-section--title--type02 {
    padding: 5rem 0;
  }
  .l-section.l-section--title--type02 h2 {
    width: 100%;
    margin: 0;
    font-size: 3.2rem;
  }
}

/*==================================
* Section Container
==================================*/
.l-section__container {
  padding: 0 8px;
}
@media print, screen and (min-width: 768px) {
  .l-section__container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0;
  }
}

/*==================================
* Section Header
==================================*/
.l-section__header {
  margin: 0 0 50px 0;
  padding: 0 5px;
  /* タイトル */
}
@media print, screen and (min-width: 768px) {
  .l-section__header {
    padding: 0;
  }
}
.l-section__header .l-section__header__title {
  margin: 0;
  padding: 0;
  font-size: 2.5rem;
  line-height: 2.4rem;
  font-weight: 500;
  color: #333;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .l-section__header .l-section__header__title {
    font-size: 3rem;
    line-height: 3.4rem;
  }
}

/*==================================
* Section Body
==================================*/
.l-section__body {
  padding: 0 5px;
}
@media print, screen and (min-width: 768px) {
  .l-section__body {
    padding: 0;
  }
}

/*==================================
* Section Block
==================================*/
.l-section__block {
  display: block;
  padding: 0;
}
.l-section__block:after {
  content: "";
  display: table;
  clear: both;
}
.l-section__block .l-section__block--left {
  margin-bottom: 50px;
}
@media print, screen and (min-width: 768px) {
  .l-section__block .l-section__block--left {
    float: left;
    width: 500px;
    margin: 0;
  }
}
.l-section__block .l-section__block--right {
  margin-bottom: 50px;
}
@media print, screen and (min-width: 768px) {
  .l-section__block .l-section__block--right {
    float: right;
    width: 500px;
    margin: 0;
  }
}

/**
 * Main Visual
 */
/*==================================
* main visual
==================================*/
/* コメントアウト中
.l-main-visual {
    background:  $primary;

    @include my-media-query(md) {
        width: 100%;
        height: 460px;
    }

    .l-main-visual__inner {

        @include my-media-query(md) {
            width: 1100px;
            margin: 0 auto;
            position: relative;
        }

        .l-main-visual__title {
            width: 100%;
            padding: 10px;
            color: #FFF;
            font-size: 1.2rem;
            box-sizing: border-box;

            @include my-media-query(md) {
                width: 45%;
                text-align: left;
                padding-top: 20px;
                font-size: 1.5rem;
                line-height: 1.2;
            }
        }

        .l-main-visual__image {
            margin: 0;
            padding: 0;
            text-align: center;

            > img {
                max-width: 100%;
                height: auto;
            }

            @include my-media-query(md) {
                position: absolute;
                top: 0px;
                right: 0px;
            }
        }

        .l-main-visual__entry {
            margin-bottom: 10px;
            text-align: center;

            @include my-media-query(md) {
                position: absolute;
                top: 310px;
                left: 20px;
                width: 400px;
            }

            .l-main-visual__button {
                width: 100%;
                margin: 0;
                padding: 15px 20px;
                color: $primary;
                background: $secondary;
                appearance: none;
                font-size: 2.5rem;
                border: none;
                box-sizing: border-box;
                display: inline-block;
                font-weight: 900;        

                @include my-media-query(md) {
                    width: 80%;
                }

                &:hover,
                &:active,
                &:focus {
                    text-decoration: none;
                    color: #FFF;
                }
            }
        }
    }
}
*/
/*==================================
* sub visual
==================================*/
.l-sub-visual__title {
  margin-bottom: 40px;
  font-size: 1.2rem;
  line-height: 1.5;
  color: #333;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .l-sub-visual__title {
    font-size: 1.4rem;
  }
}

/* ==========================================================================
   Object
========================================================================== */
/* Utitlity
----------------------------------------------------------------- */
/**
 * Float
 */
.u-float-right {
  float: right !important;
}

.u-float-left {
  float: left !important;
}

.u-float-none {
  float: none !important;
}

.u-clearfix:after {
  content: "" !important;
  display: table !important;
  clear: both !important;
}

/**
 * margin
 */
/**
 * m : margin
 *
 * a : all
 * t : top
 * b : bottom
 * l : left
 * r : right
 *
 * x : left and right
 * y : top and bottom

 * [$name]
 * xs
 * sm
 * md
 * lg
 * xl
 */
.u-ma-xs {
  margin: 0.5rem !important;
}

.u-mt-xs {
  margin-top: 0.5rem !important;
}

.u-mb-xs {
  margin-bottom: 0.5rem !important;
}

.u-ml-xs {
  margin-left: 0.5rem !important;
}

.u-mr-xs {
  margin-right: 0.5rem !important;
}

.u-mx-xs {
  margin-right: 0.5rem !important;
  margin-left: 0.5rem !important;
}

.u-my-xs {
  margin-top: 0.5rem !important;
  margin-bottom: 0.5rem !important;
}

.u-ma-sm {
  margin: 1rem !important;
}

.u-mt-sm {
  margin-top: 1rem !important;
}

.u-mb-sm {
  margin-bottom: 1rem !important;
}

.u-ml-sm {
  margin-left: 1rem !important;
}

.u-mr-sm {
  margin-right: 1rem !important;
}

.u-mx-sm {
  margin-right: 1rem !important;
  margin-left: 1rem !important;
}

.u-my-sm {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}

.u-ma-md {
  margin: 2rem !important;
}

.u-mt-md {
  margin-top: 2rem !important;
}

.u-mb-md {
  margin-bottom: 2rem !important;
}

.u-ml-md {
  margin-left: 2rem !important;
}

.u-mr-md {
  margin-right: 2rem !important;
}

.u-mx-md {
  margin-right: 2rem !important;
  margin-left: 2rem !important;
}

.u-my-md {
  margin-top: 2rem !important;
  margin-bottom: 2rem !important;
}

.u-ma-lg {
  margin: 3rem !important;
}

.u-mt-lg {
  margin-top: 3rem !important;
}

.u-mb-lg {
  margin-bottom: 3rem !important;
}

.u-ml-lg {
  margin-left: 3rem !important;
}

.u-mr-lg {
  margin-right: 3rem !important;
}

.u-mx-lg {
  margin-right: 3rem !important;
  margin-left: 3rem !important;
}

.u-my-lg {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}

.u-ma-xl {
  margin: 5rem !important;
}

.u-mt-xl {
  margin-top: 5rem !important;
}

.u-mb-xl {
  margin-bottom: 5rem !important;
}

.u-ml-xl {
  margin-left: 5rem !important;
}

.u-mr-xl {
  margin-right: 5rem !important;
}

.u-mx-xl {
  margin-right: 5rem !important;
  margin-left: 5rem !important;
}

.u-my-xl {
  margin-top: 5rem !important;
  margin-bottom: 5rem !important;
}

/*==================================
* margin
==================================*/
.u-m0 {
  margin: 0px !important;
}

.u-m1 {
  margin: 1px !important;
}

.u-m2 {
  margin: 2px !important;
}

.u-m3 {
  margin: 3px !important;
}

.u-m4 {
  margin: 4px !important;
}

.u-m5 {
  margin: 5px !important;
}

.u-m6 {
  margin: 6px !important;
}

.u-m7 {
  margin: 7px !important;
}

.u-m8 {
  margin: 8px !important;
}

.u-m9 {
  margin: 9px !important;
}

.u-m10 {
  margin: 10px !important;
}

.u-m11 {
  margin: 11px !important;
}

.u-m12 {
  margin: 12px !important;
}

.u-m13 {
  margin: 13px !important;
}

.u-m14 {
  margin: 14px !important;
}

.u-m15 {
  margin: 15px !important;
}

.u-m16 {
  margin: 16px !important;
}

.u-m17 {
  margin: 17px !important;
}

.u-m18 {
  margin: 18px !important;
}

.u-m19 {
  margin: 19px !important;
}

.u-m20 {
  margin: 20px !important;
}

.u-m21 {
  margin: 21px !important;
}

.u-m22 {
  margin: 22px !important;
}

.u-m23 {
  margin: 23px !important;
}

.u-m24 {
  margin: 24px !important;
}

.u-m25 {
  margin: 25px !important;
}

.u-m26 {
  margin: 26px !important;
}

.u-m27 {
  margin: 27px !important;
}

.u-m28 {
  margin: 28px !important;
}

.u-m29 {
  margin: 29px !important;
}

.u-m30 {
  margin: 30px !important;
}

/*==================================
* margin-top
==================================*/
.u-mt-0 {
  margin-top: 0px !important;
}

.u-mt-1 {
  margin-top: 1px !important;
}

.u-mt-2 {
  margin-top: 2px !important;
}

.u-mt-3 {
  margin-top: 3px !important;
}

.u-mt-4 {
  margin-top: 4px !important;
}

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

.u-mt-6 {
  margin-top: 6px !important;
}

.u-mt-7 {
  margin-top: 7px !important;
}

.u-mt-8 {
  margin-top: 8px !important;
}

.u-mt-9 {
  margin-top: 9px !important;
}

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

.u-mt-11 {
  margin-top: 11px !important;
}

.u-mt-12 {
  margin-top: 12px !important;
}

.u-mt-13 {
  margin-top: 13px !important;
}

.u-mt-14 {
  margin-top: 14px !important;
}

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

.u-mt-16 {
  margin-top: 16px !important;
}

.u-mt-17 {
  margin-top: 17px !important;
}

.u-mt-18 {
  margin-top: 18px !important;
}

.u-mt-19 {
  margin-top: 19px !important;
}

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

.u-mt-21 {
  margin-top: 21px !important;
}

.u-mt-22 {
  margin-top: 22px !important;
}

.u-mt-23 {
  margin-top: 23px !important;
}

.u-mt-24 {
  margin-top: 24px !important;
}

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

.u-mt-26 {
  margin-top: 26px !important;
}

.u-mt-27 {
  margin-top: 27px !important;
}

.u-mt-28 {
  margin-top: 28px !important;
}

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

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

/*==================================
* margin-left
==================================*/
.u-ml-0 {
  margin-left: 0px !important;
}

.u-ml-1 {
  margin-left: 1px !important;
}

.u-ml-2 {
  margin-left: 2px !important;
}

.u-ml-3 {
  margin-left: 3px !important;
}

.u-ml-4 {
  margin-left: 4px !important;
}

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

.u-ml-6 {
  margin-left: 6px !important;
}

.u-ml-7 {
  margin-left: 7px !important;
}

.u-ml-8 {
  margin-left: 8px !important;
}

.u-ml-9 {
  margin-left: 9px !important;
}

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

.u-ml-11 {
  margin-left: 11px !important;
}

.u-ml-12 {
  margin-left: 12px !important;
}

.u-ml-13 {
  margin-left: 13px !important;
}

.u-ml-14 {
  margin-left: 14px !important;
}

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

.u-ml-16 {
  margin-left: 16px !important;
}

.u-ml-17 {
  margin-left: 17px !important;
}

.u-ml-18 {
  margin-left: 18px !important;
}

.u-ml-19 {
  margin-left: 19px !important;
}

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

.u-ml-21 {
  margin-left: 21px !important;
}

.u-ml-22 {
  margin-left: 22px !important;
}

.u-ml-23 {
  margin-left: 23px !important;
}

.u-ml-24 {
  margin-left: 24px !important;
}

.u-ml-25 {
  margin-left: 25px !important;
}

.u-ml-26 {
  margin-left: 26px !important;
}

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

.u-ml-28 {
  margin-left: 28px !important;
}

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

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

/*==================================
* margin-right
==================================*/
.u-mr-0 {
  margin-right: 0px !important;
}

.u-mr-1 {
  margin-right: 1px !important;
}

.u-mr-2 {
  margin-right: 2px !important;
}

.u-mr-3 {
  margin-right: 3px !important;
}

.u-mr-4 {
  margin-right: 4px !important;
}

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

.u-mr-6 {
  margin-right: 6px !important;
}

.u-mr-7 {
  margin-right: 7px !important;
}

.u-mr-8 {
  margin-right: 8px !important;
}

.u-mr-9 {
  margin-right: 9px !important;
}

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

.u-mr-11 {
  margin-right: 11px !important;
}

.u-mr-12 {
  margin-right: 12px !important;
}

.u-mr-13 {
  margin-right: 13px !important;
}

.u-mr-14 {
  margin-right: 14px !important;
}

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

.u-mr-16 {
  margin-right: 16px !important;
}

.u-mr-17 {
  margin-right: 17px !important;
}

.u-mr-18 {
  margin-right: 18px !important;
}

.u-mr-19 {
  margin-right: 19px !important;
}

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

.u-mr-21 {
  margin-right: 21px !important;
}

.u-mr-22 {
  margin-right: 22px !important;
}

.u-mr-23 {
  margin-right: 23px !important;
}

.u-mr-24 {
  margin-right: 24px !important;
}

.u-mr-25 {
  margin-right: 25px !important;
}

.u-mr-26 {
  margin-right: 26px !important;
}

.u-mr-27 {
  margin-right: 27px !important;
}

.u-mr-28 {
  margin-right: 28px !important;
}

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

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

/*==================================
* margin-bottom
==================================*/
.u-mb-0 {
  margin-bottom: 0px !important;
}

.u-mb-1 {
  margin-bottom: 1px !important;
}

.u-mb-2 {
  margin-bottom: 2px !important;
}

.u-mb-3 {
  margin-bottom: 3px !important;
}

.u-mb-4 {
  margin-bottom: 4px !important;
}

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

.u-mb-6 {
  margin-bottom: 6px !important;
}

.u-mb-7 {
  margin-bottom: 7px !important;
}

.u-mb-8 {
  margin-bottom: 8px !important;
}

.u-mb-9 {
  margin-bottom: 9px !important;
}

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

.u-mb-11 {
  margin-bottom: 11px !important;
}

.u-mb-12 {
  margin-bottom: 12px !important;
}

.u-mb-13 {
  margin-bottom: 13px !important;
}

.u-mb-14 {
  margin-bottom: 14px !important;
}

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

.u-mb-16 {
  margin-bottom: 16px !important;
}

.u-mb-17 {
  margin-bottom: 17px !important;
}

.u-mb-18 {
  margin-bottom: 18px !important;
}

.u-mb-19 {
  margin-bottom: 19px !important;
}

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

.u-mb-21 {
  margin-bottom: 21px !important;
}

.u-mb-22 {
  margin-bottom: 22px !important;
}

.u-mb-23 {
  margin-bottom: 23px !important;
}

.u-mb-24 {
  margin-bottom: 24px !important;
}

.u-mb-25 {
  margin-bottom: 25px !important;
}

.u-mb-26 {
  margin-bottom: 26px !important;
}

.u-mb-27 {
  margin-bottom: 27px !important;
}

.u-mb-28 {
  margin-bottom: 28px !important;
}

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

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

/**
 * Padding
 */
/**
 * p : padding
 *
 * a : all
 * t : top
 * b : bottom
 * l : left
 * r : right
 *
 * x : left and right
 * y : top and bottom

 * [$name]
 * xs
 * sm
 * md
 * lg
 * xl
 */
.u-pa-xs {
  padding: 0.5rem !important;
}

.u-pt-xs {
  padding-top: 0.5rem !important;
}

.u-pb-xs {
  padding-bottom: 0.5rem !important;
}

.u-pl-xs {
  padding-left: 0.5rem !important;
}

.u-pr-xs {
  padding-right: 0.5rem !important;
}

.u-mx-xs {
  padding-right: 0.5rem !important;
  padding-left: 0.5rem !important;
}

.u-py-xs {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

.u-pa-sm {
  padding: 1rem !important;
}

.u-pt-sm {
  padding-top: 1rem !important;
}

.u-pb-sm {
  padding-bottom: 1rem !important;
}

.u-pl-sm {
  padding-left: 1rem !important;
}

.u-pr-sm {
  padding-right: 1rem !important;
}

.u-mx-sm {
  padding-right: 1rem !important;
  padding-left: 1rem !important;
}

.u-py-sm {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

.u-pa-md {
  padding: 2rem !important;
}

.u-pt-md {
  padding-top: 2rem !important;
}

.u-pb-md {
  padding-bottom: 2rem !important;
}

.u-pl-md {
  padding-left: 2rem !important;
}

.u-pr-md {
  padding-right: 2rem !important;
}

.u-mx-md {
  padding-right: 2rem !important;
  padding-left: 2rem !important;
}

.u-py-md {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
}

.u-pa-lg {
  padding: 3rem !important;
}

.u-pt-lg {
  padding-top: 3rem !important;
}

.u-pb-lg {
  padding-bottom: 3rem !important;
}

.u-pl-lg {
  padding-left: 3rem !important;
}

.u-pr-lg {
  padding-right: 3rem !important;
}

.u-mx-lg {
  padding-right: 3rem !important;
  padding-left: 3rem !important;
}

.u-py-lg {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}

.u-pa-xl {
  padding: 5rem !important;
}

.u-pt-xl {
  padding-top: 5rem !important;
}

.u-pb-xl {
  padding-bottom: 5rem !important;
}

.u-pl-xl {
  padding-left: 5rem !important;
}

.u-pr-xl {
  padding-right: 5rem !important;
}

.u-mx-xl {
  padding-right: 5rem !important;
  padding-left: 5rem !important;
}

.u-py-xl {
  padding-top: 5rem !important;
  padding-bottom: 5rem !important;
}

/*==================================
* padding
==================================*/
.u-p-0 {
  padding: 0px !important;
}

.u-p-1 {
  padding: 1px !important;
}

.u-p-2 {
  padding: 2px !important;
}

.u-p-3 {
  padding: 3px !important;
}

.u-p-4 {
  padding: 4px !important;
}

.u-p-5 {
  padding: 5px !important;
}

.u-p-6 {
  padding: 6px !important;
}

.u-p-7 {
  padding: 7px !important;
}

.u-p-8 {
  padding: 8px !important;
}

.u-p-9 {
  padding: 9px !important;
}

.u-p-10 {
  padding: 10px !important;
}

.u-p-11 {
  padding: 11px !important;
}

.u-p-12 {
  padding: 12px !important;
}

.u-p-13 {
  padding: 13px !important;
}

.u-p-14 {
  padding: 14px !important;
}

.u-p-15 {
  padding: 15px !important;
}

.u-p-16 {
  padding: 16px !important;
}

.u-p-17 {
  padding: 17px !important;
}

.u-p-18 {
  padding: 18px !important;
}

.u-p-19 {
  padding: 19px !important;
}

.u-p-20 {
  padding: 20px !important;
}

.u-p-21 {
  padding: 21px !important;
}

.u-p-22 {
  padding: 22px !important;
}

.u-p-23 {
  padding: 23px !important;
}

.u-p-24 {
  padding: 24px !important;
}

.u-p-25 {
  padding: 25px !important;
}

.u-p-26 {
  padding: 26px !important;
}

.u-p-27 {
  padding: 27px !important;
}

.u-p-28 {
  padding: 28px !important;
}

.u-p-29 {
  padding: 29px !important;
}

.u-p-30 {
  padding: 30px !important;
}

/*==================================
* padding-top
==================================*/
.u-pt-0 {
  padding-top: 0px !important;
}

.u-pt-1 {
  padding-top: 1px !important;
}

.u-pt-2 {
  padding-top: 2px !important;
}

.u-pt-3 {
  padding-top: 3px !important;
}

.u-pt-4 {
  padding-top: 4px !important;
}

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

.u-pt-6 {
  padding-top: 6px !important;
}

.u-pt-7 {
  padding-top: 7px !important;
}

.u-pt-8 {
  padding-top: 8px !important;
}

.u-pt-9 {
  padding-top: 9px !important;
}

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

.u-pt-11 {
  padding-top: 11px !important;
}

.u-pt-12 {
  padding-top: 12px !important;
}

.u-pt-13 {
  padding-top: 13px !important;
}

.u-pt-14 {
  padding-top: 14px !important;
}

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

.u-pt-16 {
  padding-top: 16px !important;
}

.u-pt-17 {
  padding-top: 17px !important;
}

.u-pt-18 {
  padding-top: 18px !important;
}

.u-pt-19 {
  padding-top: 19px !important;
}

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

.u-pt-21 {
  padding-top: 21px !important;
}

.u-pt-22 {
  padding-top: 22px !important;
}

.u-pt-23 {
  padding-top: 23px !important;
}

.u-pt-24 {
  padding-top: 24px !important;
}

.u-pt-25 {
  padding-top: 25px !important;
}

.u-pt-26 {
  padding-top: 26px !important;
}

.u-pt-27 {
  padding-top: 27px !important;
}

.u-pt-28 {
  padding-top: 28px !important;
}

.u-pt-29 {
  padding-top: 29px !important;
}

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

/*==================================
* padding-left
==================================*/
.u-pl-0 {
  padding-left: 0px !important;
}

.u-pl-1 {
  padding-left: 1px !important;
}

.u-pl-2 {
  padding-left: 2px !important;
}

.u-pl-3 {
  padding-left: 3px !important;
}

.u-pl-4 {
  padding-left: 4px !important;
}

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

.u-pl-6 {
  padding-left: 6px !important;
}

.u-pl-7 {
  padding-left: 7px !important;
}

.u-pl-8 {
  padding-left: 8px !important;
}

.u-pl-9 {
  padding-left: 9px !important;
}

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

.u-pl-11 {
  padding-left: 11px !important;
}

.u-pl-12 {
  padding-left: 12px !important;
}

.u-pl-13 {
  padding-left: 13px !important;
}

.u-pl-14 {
  padding-left: 14px !important;
}

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

.u-pl-16 {
  padding-left: 16px !important;
}

.u-pl-17 {
  padding-left: 17px !important;
}

.u-pl-18 {
  padding-left: 18px !important;
}

.u-pl-19 {
  padding-left: 19px !important;
}

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

.u-pl-21 {
  padding-left: 21px !important;
}

.u-pl-22 {
  padding-left: 22px !important;
}

.u-pl-23 {
  padding-left: 23px !important;
}

.u-pl-24 {
  padding-left: 24px !important;
}

.u-pl-25 {
  padding-left: 25px !important;
}

.u-pl-26 {
  padding-left: 26px !important;
}

.u-pl-27 {
  padding-left: 27px !important;
}

.u-pl-28 {
  padding-left: 28px !important;
}

.u-pl-29 {
  padding-left: 29px !important;
}

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

/*==================================
* padding-right
==================================*/
.u-pr-0 {
  padding-right: 0px !important;
}

.u-pr-1 {
  padding-right: 1px !important;
}

.u-pr-2 {
  padding-right: 2px !important;
}

.u-pr-3 {
  padding-right: 3px !important;
}

.u-pr-4 {
  padding-right: 4px !important;
}

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

.u-pr-6 {
  padding-right: 6px !important;
}

.u-pr-7 {
  padding-right: 7px !important;
}

.u-pr-8 {
  padding-right: 8px !important;
}

.u-pr-9 {
  padding-right: 9px !important;
}

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

.u-pr-11 {
  padding-right: 11px !important;
}

.u-pr-12 {
  padding-right: 12px !important;
}

.u-pr-13 {
  padding-right: 13px !important;
}

.u-pr-14 {
  padding-right: 14px !important;
}

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

.u-pr-16 {
  padding-right: 16px !important;
}

.u-pr-17 {
  padding-right: 17px !important;
}

.u-pr-18 {
  padding-right: 18px !important;
}

.u-pr-19 {
  padding-right: 19px !important;
}

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

.u-pr-21 {
  padding-right: 21px !important;
}

.u-pr-22 {
  padding-right: 22px !important;
}

.u-pr-23 {
  padding-right: 23px !important;
}

.u-pr-24 {
  padding-right: 24px !important;
}

.u-pr-25 {
  padding-right: 25px !important;
}

.u-pr-26 {
  padding-right: 26px !important;
}

.u-pr-27 {
  padding-right: 27px !important;
}

.u-pr-28 {
  padding-right: 28px !important;
}

.u-pr-29 {
  padding-right: 29px !important;
}

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

/*==================================
* padding-bottom
==================================*/
.u-pb-0 {
  padding-bottom: 0px !important;
}

.u-pb-1 {
  padding-bottom: 1px !important;
}

.u-pb-2 {
  padding-bottom: 2px !important;
}

.u-pb-3 {
  padding-bottom: 3px !important;
}

.u-pb-4 {
  padding-bottom: 4px !important;
}

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

.u-pb-6 {
  padding-bottom: 6px !important;
}

.u-pb-7 {
  padding-bottom: 7px !important;
}

.u-pb-8 {
  padding-bottom: 8px !important;
}

.u-pb-9 {
  padding-bottom: 9px !important;
}

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

.u-pb-11 {
  padding-bottom: 11px !important;
}

.u-pb-12 {
  padding-bottom: 12px !important;
}

.u-pb-13 {
  padding-bottom: 13px !important;
}

.u-pb-14 {
  padding-bottom: 14px !important;
}

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

.u-pb-16 {
  padding-bottom: 16px !important;
}

.u-pb-17 {
  padding-bottom: 17px !important;
}

.u-pb-18 {
  padding-bottom: 18px !important;
}

.u-pb-19 {
  padding-bottom: 19px !important;
}

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

.u-pb-21 {
  padding-bottom: 21px !important;
}

.u-pb-22 {
  padding-bottom: 22px !important;
}

.u-pb-23 {
  padding-bottom: 23px !important;
}

.u-pb-24 {
  padding-bottom: 24px !important;
}

.u-pb-25 {
  padding-bottom: 25px !important;
}

.u-pb-26 {
  padding-bottom: 26px !important;
}

.u-pb-27 {
  padding-bottom: 27px !important;
}

.u-pb-28 {
  padding-bottom: 28px !important;
}

.u-pb-29 {
  padding-bottom: 29px !important;
}

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

/**
 * Text
 */
/*==================================
* color
==================================*/
.u-fc-blue {
  color: #044E80 !important;
}

.u-fc-red {
  color: #dc3545 !important;
}

.u-fc-green {
  color: #03967a !important;
}

.u-fc-orange {
  color: #FEB808 !important;
}

.u-fc-white {
  color: #fff !important;
}

/*==================================
* font-size
==================================*/
.u-fs-0 {
  font-size: 0px !important;
}

.u-fs-1 {
  font-size: 1px !important;
}

.u-fs-2 {
  font-size: 2px !important;
}

.u-fs-3 {
  font-size: 3px !important;
}

.u-fs-4 {
  font-size: 4px !important;
}

.u-fs-5 {
  font-size: 5px !important;
}

.u-fs-6 {
  font-size: 6px !important;
}

.u-fs-7 {
  font-size: 7px !important;
}

.u-fs-8 {
  font-size: 8px !important;
}

.u-fs-9 {
  font-size: 9px !important;
}

.u-fs-10 {
  font-size: 10px !important;
}

.u-fs-11 {
  font-size: 11px !important;
}

.u-fs-12 {
  font-size: 12px !important;
}

.u-fs-13 {
  font-size: 13px !important;
}

.u-fs-14 {
  font-size: 14px !important;
}

.u-fs-15 {
  font-size: 15px !important;
}

.u-fs-16 {
  font-size: 16px !important;
}

.u-fs-17 {
  font-size: 17px !important;
}

.u-fs-18 {
  font-size: 18px !important;
}

.u-fs-19 {
  font-size: 19px !important;
}

.u-fs-20 {
  font-size: 20px !important;
}

.u-fs-21 {
  font-size: 21px !important;
}

.u-fs-22 {
  font-size: 22px !important;
}

.u-fs-23 {
  font-size: 23px !important;
}

.u-fs-24 {
  font-size: 24px !important;
}

.u-fs-25 {
  font-size: 25px !important;
}

.u-fs-26 {
  font-size: 26px !important;
}

.u-fs-27 {
  font-size: 27px !important;
}

.u-fs-28 {
  font-size: 28px !important;
}

.u-fs-29 {
  font-size: 29px !important;
}

.u-fs-30 {
  font-size: 30px !important;
}

.u-fs-h1 {
  font-size: 2.5rem !important;
}

.u-fs-h2 {
  font-size: 2rem !important;
}

.u-fs-h3 {
  font-size: 1.75rem !important;
}

.u-fs-h4 {
  font-size: 1.5rem !important;
}

.u-fs-h5 {
  font-size: 1.25rem !important;
}

.u-fs-h6 {
  font-size: 1rem !important;
}

@media print, screen and (min-width: 768px) {
  .u-fs-h1 {
    font-size: 3rem !important;
  }
  .u-fs-h2 {
    font-size: 2.5rem !important;
  }
  .u-fs-h3 {
    font-size: 2.2rem !important;
  }
  .u-fs-h4 {
    font-size: 1.75rem !important;
  }
  .u-fs-h5 {
    font-size: 1.5rem !important;
  }
  .u-fs-h6 {
    font-size: 1rem !important;
  }
}
/*==================================
* font-weight
==================================*/
.u-fw-light {
  font-weight: 300 !important;
}

.u-fw-normal {
  font-weight: 400 !important;
}

.u-fw-bold {
  font-weight: bold !important;
}

.u-fw-100 {
  font-weight: 100 !important;
}

.u-fw-200 {
  font-weight: 200 !important;
}

.u-fw-300 {
  font-weight: 300 !important;
}

.u-fw-400 {
  font-weight: 400 !important;
}

.u-fw-500 {
  font-weight: 500 !important;
}

.u-fw-600 {
  font-weight: 600 !important;
}

.u-fw-700 {
  font-weight: 700 !important;
}

.u-fw-800 {
  font-weight: 800 !important;
}

.u-fw-900 {
  font-weight: 900 !important;
}

/*==================================
* align
==================================*/
.u-text-top {
  vertical-align: top !important;
}

.u-text-center {
  text-align: center !important;
}

.u-text-right {
  text-align: right !important;
}

.u-text-left {
  text-align: left !important;
}

.u-text-middle {
  vertical-align: middle !important;
}

.u-text-bottom {
  vertical-align: bottom !important;
}

@media print, screen and (min-width: 768px) {
  .u-txt-pc-center {
    text-align: center;
  }
}

@media print, screen and (max-width: 767px) {
  .u-txt-sp-center {
    text-align: left;
  }
}

/*==================================
* その他
==================================*/
/* テキストを改行しない */
.u-text-nowrap {
  white-space: nowrap !important;
}

/* テキストを改行する */
.u-text-breakword {
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
}

/* テキストを両端揃え */
.u-text-justify {
  text-align: justify !important;
  text-justify: inter-ideograph !important;
}

/*==================================
* マーカー
==================================*/
.u-text-marker--yel {
  background: linear-gradient(transparent 65%, #ffff66 65%);
}

.u-text-marker--orn {
  background: linear-gradient(transparent 65%, #ffd1a3 65%);
}

.u-text-marker--grn {
  background: linear-gradient(transparent 65%, #bfff7f 65%);
}

.u-text-marker--pnk {
  background: linear-gradient(transparent 65%, #ffadd6 65%);
}

/**
 * width
 */
/*==================================
* width
==================================*/
.w0 {
  width: 0 !important;
}

.u-w0p {
  width: 0% !important;
}

.u-w1p {
  width: 1% !important;
}

.u-w2p {
  width: 2% !important;
}

.u-w3p {
  width: 3% !important;
}

.u-w4p {
  width: 4% !important;
}

.u-w5p {
  width: 5% !important;
}

.u-w6p {
  width: 6% !important;
}

.u-w7p {
  width: 7% !important;
}

.u-w8p {
  width: 8% !important;
}

.u-w9p {
  width: 9% !important;
}

.u-w10p {
  width: 10% !important;
}

.u-w11p {
  width: 11% !important;
}

.u-w12p {
  width: 12% !important;
}

.u-w13p {
  width: 13% !important;
}

.u-w14p {
  width: 14% !important;
}

.u-w15p {
  width: 15% !important;
}

.u-w16p {
  width: 16% !important;
}

.u-w17p {
  width: 17% !important;
}

.u-w18p {
  width: 18% !important;
}

.u-w19p {
  width: 19% !important;
}

.u-w20p {
  width: 20% !important;
}

.u-w21p {
  width: 21% !important;
}

.u-w22p {
  width: 22% !important;
}

.u-w23p {
  width: 23% !important;
}

.u-w24p {
  width: 24% !important;
}

.u-w25p {
  width: 25% !important;
}

.u-w26p {
  width: 26% !important;
}

.u-w27p {
  width: 27% !important;
}

.u-w28p {
  width: 28% !important;
}

.u-w29p {
  width: 29% !important;
}

.u-w30p {
  width: 30% !important;
}

.u-w31p {
  width: 31% !important;
}

.u-w32p {
  width: 32% !important;
}

.u-w33p {
  width: 33% !important;
}

.u-w34p {
  width: 34% !important;
}

.u-w35p {
  width: 35% !important;
}

.u-w36p {
  width: 36% !important;
}

.u-w37p {
  width: 37% !important;
}

.u-w38p {
  width: 38% !important;
}

.u-w39p {
  width: 39% !important;
}

.u-w40p {
  width: 40% !important;
}

.u-w41p {
  width: 41% !important;
}

.u-w42p {
  width: 42% !important;
}

.u-w43p {
  width: 43% !important;
}

.u-w44p {
  width: 44% !important;
}

.u-w45p {
  width: 45% !important;
}

.u-w46p {
  width: 46% !important;
}

.u-w47p {
  width: 47% !important;
}

.u-w48p {
  width: 48% !important;
}

.u-w49p {
  width: 49% !important;
}

.u-w50p {
  width: 50% !important;
}

.u-w51p {
  width: 51% !important;
}

.u-w52p {
  width: 52% !important;
}

.u-w53p {
  width: 53% !important;
}

.u-w54p {
  width: 54% !important;
}

.u-w55p {
  width: 55% !important;
}

.u-w56p {
  width: 56% !important;
}

.u-w57p {
  width: 57% !important;
}

.u-w58p {
  width: 58% !important;
}

.u-w59p {
  width: 59% !important;
}

.u-w60p {
  width: 60% !important;
}

.u-w61p {
  width: 61% !important;
}

.u-w62p {
  width: 62% !important;
}

.u-w63p {
  width: 63% !important;
}

.u-w64p {
  width: 64% !important;
}

.u-w65p {
  width: 65% !important;
}

.u-w66p {
  width: 66% !important;
}

.u-w67p {
  width: 67% !important;
}

.u-w68p {
  width: 68% !important;
}

.u-w69p {
  width: 69% !important;
}

.u-w70p {
  width: 70% !important;
}

.u-w71p {
  width: 71% !important;
}

.u-w72p {
  width: 72% !important;
}

.u-w73p {
  width: 73% !important;
}

.u-w74p {
  width: 74% !important;
}

.u-w75p {
  width: 75% !important;
}

.u-w76p {
  width: 76% !important;
}

.u-w77p {
  width: 77% !important;
}

.u-w78p {
  width: 78% !important;
}

.u-w79p {
  width: 79% !important;
}

.u-w80p {
  width: 80% !important;
}

.u-w81p {
  width: 81% !important;
}

.u-w82p {
  width: 82% !important;
}

.u-w83p {
  width: 83% !important;
}

.u-w84p {
  width: 84% !important;
}

.u-w85p {
  width: 85% !important;
}

.u-w86p {
  width: 86% !important;
}

.u-w87p {
  width: 87% !important;
}

.u-w88p {
  width: 88% !important;
}

.u-w89p {
  width: 89% !important;
}

.u-w90p {
  width: 90% !important;
}

.u-w91p {
  width: 91% !important;
}

.u-w92p {
  width: 92% !important;
}

.u-w93p {
  width: 93% !important;
}

.u-w94p {
  width: 94% !important;
}

.u-w95p {
  width: 95% !important;
}

.u-w96p {
  width: 96% !important;
}

.u-w97p {
  width: 97% !important;
}

.u-w98p {
  width: 98% !important;
}

.u-w99p {
  width: 99% !important;
}

.u-w100p {
  width: 100% !important;
}

/*==================================
* min-width
==================================*/
.u-min-w0p {
  min-width: 0% !important;
}

.u-min-w1p {
  min-width: 1% !important;
}

.u-min-w2p {
  min-width: 2% !important;
}

.u-min-w3p {
  min-width: 3% !important;
}

.u-min-w4p {
  min-width: 4% !important;
}

.u-min-w5p {
  min-width: 5% !important;
}

.u-min-w6p {
  min-width: 6% !important;
}

.u-min-w7p {
  min-width: 7% !important;
}

.u-min-w8p {
  min-width: 8% !important;
}

.u-min-w9p {
  min-width: 9% !important;
}

.u-min-w10p {
  min-width: 10% !important;
}

.u-min-w11p {
  min-width: 11% !important;
}

.u-min-w12p {
  min-width: 12% !important;
}

.u-min-w13p {
  min-width: 13% !important;
}

.u-min-w14p {
  min-width: 14% !important;
}

.u-min-w15p {
  min-width: 15% !important;
}

.u-min-w16p {
  min-width: 16% !important;
}

.u-min-w17p {
  min-width: 17% !important;
}

.u-min-w18p {
  min-width: 18% !important;
}

.u-min-w19p {
  min-width: 19% !important;
}

.u-min-w20p {
  min-width: 20% !important;
}

.u-min-w21p {
  min-width: 21% !important;
}

.u-min-w22p {
  min-width: 22% !important;
}

.u-min-w23p {
  min-width: 23% !important;
}

.u-min-w24p {
  min-width: 24% !important;
}

.u-min-w25p {
  min-width: 25% !important;
}

.u-min-w26p {
  min-width: 26% !important;
}

.u-min-w27p {
  min-width: 27% !important;
}

.u-min-w28p {
  min-width: 28% !important;
}

.u-min-w29p {
  min-width: 29% !important;
}

.u-min-w30p {
  min-width: 30% !important;
}

.u-min-w31p {
  min-width: 31% !important;
}

.u-min-w32p {
  min-width: 32% !important;
}

.u-min-w33p {
  min-width: 33% !important;
}

.u-min-w34p {
  min-width: 34% !important;
}

.u-min-w35p {
  min-width: 35% !important;
}

.u-min-w36p {
  min-width: 36% !important;
}

.u-min-w37p {
  min-width: 37% !important;
}

.u-min-w38p {
  min-width: 38% !important;
}

.u-min-w39p {
  min-width: 39% !important;
}

.u-min-w40p {
  min-width: 40% !important;
}

.u-min-w41p {
  min-width: 41% !important;
}

.u-min-w42p {
  min-width: 42% !important;
}

.u-min-w43p {
  min-width: 43% !important;
}

.u-min-w44p {
  min-width: 44% !important;
}

.u-min-w45p {
  min-width: 45% !important;
}

.u-min-w46p {
  min-width: 46% !important;
}

.u-min-w47p {
  min-width: 47% !important;
}

.u-min-w48p {
  min-width: 48% !important;
}

.u-min-w49p {
  min-width: 49% !important;
}

.u-min-w50p {
  min-width: 50% !important;
}

.u-min-w51p {
  min-width: 51% !important;
}

.u-min-w52p {
  min-width: 52% !important;
}

.u-min-w53p {
  min-width: 53% !important;
}

.u-min-w54p {
  min-width: 54% !important;
}

.u-min-w55p {
  min-width: 55% !important;
}

.u-min-w56p {
  min-width: 56% !important;
}

.u-min-w57p {
  min-width: 57% !important;
}

.u-min-w58p {
  min-width: 58% !important;
}

.u-min-w59p {
  min-width: 59% !important;
}

.u-min-w60p {
  min-width: 60% !important;
}

.u-min-w61p {
  min-width: 61% !important;
}

.u-min-w62p {
  min-width: 62% !important;
}

.u-min-w63p {
  min-width: 63% !important;
}

.u-min-w64p {
  min-width: 64% !important;
}

.u-min-w65p {
  min-width: 65% !important;
}

.u-min-w66p {
  min-width: 66% !important;
}

.u-min-w67p {
  min-width: 67% !important;
}

.u-min-w68p {
  min-width: 68% !important;
}

.u-min-w69p {
  min-width: 69% !important;
}

.u-min-w70p {
  min-width: 70% !important;
}

.u-min-w71p {
  min-width: 71% !important;
}

.u-min-w72p {
  min-width: 72% !important;
}

.u-min-w73p {
  min-width: 73% !important;
}

.u-min-w74p {
  min-width: 74% !important;
}

.u-min-w75p {
  min-width: 75% !important;
}

.u-min-w76p {
  min-width: 76% !important;
}

.u-min-w77p {
  min-width: 77% !important;
}

.u-min-w78p {
  min-width: 78% !important;
}

.u-min-w79p {
  min-width: 79% !important;
}

.u-min-w80p {
  min-width: 80% !important;
}

.u-min-w81p {
  min-width: 81% !important;
}

.u-min-w82p {
  min-width: 82% !important;
}

.u-min-w83p {
  min-width: 83% !important;
}

.u-min-w84p {
  min-width: 84% !important;
}

.u-min-w85p {
  min-width: 85% !important;
}

.u-min-w86p {
  min-width: 86% !important;
}

.u-min-w87p {
  min-width: 87% !important;
}

.u-min-w88p {
  min-width: 88% !important;
}

.u-min-w89p {
  min-width: 89% !important;
}

.u-min-w90p {
  min-width: 90% !important;
}

.u-min-w91p {
  min-width: 91% !important;
}

.u-min-w92p {
  min-width: 92% !important;
}

.u-min-w93p {
  min-width: 93% !important;
}

.u-min-w94p {
  min-width: 94% !important;
}

.u-min-w95p {
  min-width: 95% !important;
}

.u-min-w96p {
  min-width: 96% !important;
}

.u-min-w97p {
  min-width: 97% !important;
}

.u-min-w98p {
  min-width: 98% !important;
}

.u-min-w99p {
  min-width: 99% !important;
}

.u-min-w100p {
  min-width: 100% !important;
}

/*==================================
* max-width
==================================*/
.u-max-w0p {
  max-width: 0% !important;
}

.u-max-w1p {
  max-width: 1% !important;
}

.u-max-w2p {
  max-width: 2% !important;
}

.u-max-w3p {
  max-width: 3% !important;
}

.u-max-w4p {
  max-width: 4% !important;
}

.u-max-w5p {
  max-width: 5% !important;
}

.u-max-w6p {
  max-width: 6% !important;
}

.u-max-w7p {
  max-width: 7% !important;
}

.u-max-w8p {
  max-width: 8% !important;
}

.u-max-w9p {
  max-width: 9% !important;
}

.u-max-w10p {
  max-width: 10% !important;
}

.u-max-w11p {
  max-width: 11% !important;
}

.u-max-w12p {
  max-width: 12% !important;
}

.u-max-w13p {
  max-width: 13% !important;
}

.u-max-w14p {
  max-width: 14% !important;
}

.u-max-w15p {
  max-width: 15% !important;
}

.u-max-w16p {
  max-width: 16% !important;
}

.u-max-w17p {
  max-width: 17% !important;
}

.u-max-w18p {
  max-width: 18% !important;
}

.u-max-w19p {
  max-width: 19% !important;
}

.u-max-w20p {
  max-width: 20% !important;
}

.u-max-w21p {
  max-width: 21% !important;
}

.u-max-w22p {
  max-width: 22% !important;
}

.u-max-w23p {
  max-width: 23% !important;
}

.u-max-w24p {
  max-width: 24% !important;
}

.u-max-w25p {
  max-width: 25% !important;
}

.u-max-w26p {
  max-width: 26% !important;
}

.u-max-w27p {
  max-width: 27% !important;
}

.u-max-w28p {
  max-width: 28% !important;
}

.u-max-w29p {
  max-width: 29% !important;
}

.u-max-w30p {
  max-width: 30% !important;
}

.u-max-w31p {
  max-width: 31% !important;
}

.u-max-w32p {
  max-width: 32% !important;
}

.u-max-w33p {
  max-width: 33% !important;
}

.u-max-w34p {
  max-width: 34% !important;
}

.u-max-w35p {
  max-width: 35% !important;
}

.u-max-w36p {
  max-width: 36% !important;
}

.u-max-w37p {
  max-width: 37% !important;
}

.u-max-w38p {
  max-width: 38% !important;
}

.u-max-w39p {
  max-width: 39% !important;
}

.u-max-w40p {
  max-width: 40% !important;
}

.u-max-w41p {
  max-width: 41% !important;
}

.u-max-w42p {
  max-width: 42% !important;
}

.u-max-w43p {
  max-width: 43% !important;
}

.u-max-w44p {
  max-width: 44% !important;
}

.u-max-w45p {
  max-width: 45% !important;
}

.u-max-w46p {
  max-width: 46% !important;
}

.u-max-w47p {
  max-width: 47% !important;
}

.u-max-w48p {
  max-width: 48% !important;
}

.u-max-w49p {
  max-width: 49% !important;
}

.u-max-w50p {
  max-width: 50% !important;
}

.u-max-w51p {
  max-width: 51% !important;
}

.u-max-w52p {
  max-width: 52% !important;
}

.u-max-w53p {
  max-width: 53% !important;
}

.u-max-w54p {
  max-width: 54% !important;
}

.u-max-w55p {
  max-width: 55% !important;
}

.u-max-w56p {
  max-width: 56% !important;
}

.u-max-w57p {
  max-width: 57% !important;
}

.u-max-w58p {
  max-width: 58% !important;
}

.u-max-w59p {
  max-width: 59% !important;
}

.u-max-w60p {
  max-width: 60% !important;
}

.u-max-w61p {
  max-width: 61% !important;
}

.u-max-w62p {
  max-width: 62% !important;
}

.u-max-w63p {
  max-width: 63% !important;
}

.u-max-w64p {
  max-width: 64% !important;
}

.u-max-w65p {
  max-width: 65% !important;
}

.u-max-w66p {
  max-width: 66% !important;
}

.u-max-w67p {
  max-width: 67% !important;
}

.u-max-w68p {
  max-width: 68% !important;
}

.u-max-w69p {
  max-width: 69% !important;
}

.u-max-w70p {
  max-width: 70% !important;
}

.u-max-w71p {
  max-width: 71% !important;
}

.u-max-w72p {
  max-width: 72% !important;
}

.u-max-w73p {
  max-width: 73% !important;
}

.u-max-w74p {
  max-width: 74% !important;
}

.u-max-w75p {
  max-width: 75% !important;
}

.u-max-w76p {
  max-width: 76% !important;
}

.u-max-w77p {
  max-width: 77% !important;
}

.u-max-w78p {
  max-width: 78% !important;
}

.u-max-w79p {
  max-width: 79% !important;
}

.u-max-w80p {
  max-width: 80% !important;
}

.u-max-w81p {
  max-width: 81% !important;
}

.u-max-w82p {
  max-width: 82% !important;
}

.u-max-w83p {
  max-width: 83% !important;
}

.u-max-w84p {
  max-width: 84% !important;
}

.u-max-w85p {
  max-width: 85% !important;
}

.u-max-w86p {
  max-width: 86% !important;
}

.u-max-w87p {
  max-width: 87% !important;
}

.u-max-w88p {
  max-width: 88% !important;
}

.u-max-w89p {
  max-width: 89% !important;
}

.u-max-w90p {
  max-width: 90% !important;
}

.u-max-w91p {
  max-width: 91% !important;
}

.u-max-w92p {
  max-width: 92% !important;
}

.u-max-w93p {
  max-width: 93% !important;
}

.u-max-w94p {
  max-width: 94% !important;
}

.u-max-w95p {
  max-width: 95% !important;
}

.u-max-w96p {
  max-width: 96% !important;
}

.u-max-w97p {
  max-width: 97% !important;
}

.u-max-w98p {
  max-width: 98% !important;
}

.u-max-w99p {
  max-width: 99% !important;
}

.u-max-w100p {
  max-width: 100% !important;
}

@media print, screen and (min-width: 768px) {
  .u-w50p-pc {
    width: 50%;
  }
}

/**
 * Display
 */
/*==================================
* media
==================================*/
@media print, screen and (min-width: 768px) {
  .u-hidden-pc {
    display: none;
  }
}

@media print, screen and (max-width: 767px) {
  .u-hidden-sp {
    display: none;
  }
}

/**
 * Triangle
 */
/*==================================
* down primary
==================================*/
.u-triangle-down {
  width: 0;
  height: 0;
  margin: 20px auto;
  border-left: 55px solid transparent;
  border-right: 55px solid transparent;
  border-top: 40px solid #044E80;
}
@media print, screen and (min-width: 768px) {
  .u-triangle-down {
    margin: 40px auto;
    border-left: 80px solid transparent;
    border-right: 80px solid transparent;
    border-top: 60px solid #044E80;
  }
}

/* Component
----------------------------------------------------------------- */
/**
 * Button
 */
/*==================================
* btn
==================================*/
.c-button,
.c-button--dark,
.c-button--light,
.c-button--danger,
.c-button--warning,
.c-button--info,
.c-button--success,
.c-button--primary,
.c-button--secondary,
.c-button__square {
  display: inline-block;
  width: 100%;
  margin-bottom: 30px;
  padding: 10px;
  line-height: 1.5;
  border-radius: 50px;
  text-align: center;
  color: #333;
  font-size: 1.6rem;
  font-weight: bold;
  background: #fafafa;
  border: solid 1px #CCC;
  cursor: pointer;
  text-decoration: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: relative;
  box-sizing: border-box;
}
.c-button::after,
.c-button--dark::after,
.c-button--light::after,
.c-button--danger::after,
.c-button--warning::after,
.c-button--info::after,
.c-button--success::after,
.c-button--primary::after,
.c-button--secondary::after,
.c-button__square::after {
  content: "";
  display: block;
  position: absolute;
  top: calc(50% - 6px);
  right: 20px;
  width: 10px;
  height: 10px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
}
.c-button:hover, .c-button:active, .c-button:focus,
.c-button--dark:hover,
.c-button--light:hover,
.c-button--danger:hover,
.c-button--warning:hover,
.c-button--info:hover,
.c-button--success:hover,
.c-button--primary:hover,
.c-button--secondary:hover,
.c-button__square:hover,
.c-button--dark:active,
.c-button--light:active,
.c-button--danger:active,
.c-button--warning:active,
.c-button--info:active,
.c-button--success:active,
.c-button--primary:active,
.c-button--secondary:active,
.c-button__square:active,
.c-button--dark:focus,
.c-button--light:focus,
.c-button--danger:focus,
.c-button--warning:focus,
.c-button--info:focus,
.c-button--success:focus,
.c-button--primary:focus,
.c-button--secondary:focus,
.c-button__square:focus {
  text-decoration: none;
  color: #333;
  opacity: 0.8;
}
.c-button[disabled], .c-button.disabled,
[disabled].c-button--dark,
[disabled].c-button--light,
[disabled].c-button--danger,
[disabled].c-button--warning,
[disabled].c-button--info,
[disabled].c-button--success,
[disabled].c-button--primary,
[disabled].c-button--secondary,
[disabled].c-button__square,
.disabled.c-button--dark,
.disabled.c-button--light,
.disabled.c-button--danger,
.disabled.c-button--warning,
.disabled.c-button--info,
.disabled.c-button--success,
.disabled.c-button--primary,
.disabled.c-button--secondary,
.disabled.c-button__square {
  opacity: 0.5;
  pointer-events: none;
}
@media print, screen and (min-width: 768px) {
  .c-button,
  .c-button--dark,
  .c-button--light,
  .c-button--danger,
  .c-button--warning,
  .c-button--info,
  .c-button--success,
  .c-button--primary,
  .c-button--secondary,
  .c-button__square {
    max-width: 260px;
  }
}

.c-button__no-arrow {
  display: inline-block;
  width: 100%;
  margin-bottom: 30px;
  padding: 10px;
  line-height: 1.5;
  border-radius: 50px;
  text-align: center;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  background: #fafafa;
  border: solid 1px #CCC;
  cursor: pointer;
  text-decoration: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: relative;
  box-sizing: border-box;
}
.c-button__no-arrow:hover, .c-button__no-arrow:active, .c-button__no-arrow:focus {
  text-decoration: none;
  color: #fff;
  opacity: 0.8;
}
.c-button__no-arrow[disabled], .c-button__no-arrow.disabled {
  opacity: 0.5;
  pointer-events: none;
}
@media print, screen and (min-width: 768px) {
  .c-button__no-arrow {
    max-width: 260px;
  }
}

.c-button__square {
  border-color: transparent;
  border-radius: 4px;
}
.c-button__square::after {
  border-top: solid 2px #FFF;
  border-right: solid 2px #FFF;
}
.c-button__square:hover, .c-button__square:active, .c-button__square:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button__square__no-arrow {
  display: inline-block;
  width: 100%;
  margin-bottom: 30px;
  padding: 10px;
  line-height: 1.5;
  border-radius: 4px;
  text-align: center;
  color: #333;
  font-size: 1.6rem;
  font-weight: bold;
  background: #fafafa;
  border: solid 1px #CCC;
  cursor: pointer;
  text-decoration: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: relative;
  box-sizing: border-box;
  border-color: transparent;
}
.c-button__square__no-arrow:hover, .c-button__square__no-arrow:active, .c-button__square__no-arrow:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}
.c-button__square__no-arrow[disabled], .c-button__square__no-arrow.disabled {
  opacity: 0.5;
  pointer-events: none;
}
@media print, screen and (min-width: 768px) {
  .c-button__square__no-arrow {
    max-width: 260px;
  }
}

/*==================================
* カラー
==================================*/
.c-button--primary,
.c-button--secondary {
  color: #FFF;
  border-color: transparent;
}
.c-button--primary:hover, .c-button--primary:active, .c-button--primary:focus,
.c-button--secondary:hover,
.c-button--secondary:active,
.c-button--secondary:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--primary {
  background-color: #044E80;
}

.c-button--secondary {
  background-color: #FEB808;
}

.c-button--primary {
  background-color: #044E80 !important;
  color: #FFF;
  border: none;
}
.c-button--primary:hover, .c-button--primary:active, .c-button--primary:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--secondary {
  background-color: #FEB808 !important;
  color: #FFF;
  border: none;
}
.c-button--secondary:hover, .c-button--secondary:active, .c-button--secondary:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--success {
  background-color: #03967a !important;
  color: #FFF;
  border: none;
}
.c-button--success:hover, .c-button--success:active, .c-button--success:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--info {
  background-color: #17a2b8 !important;
  color: #FFF;
  border: none;
}
.c-button--info:hover, .c-button--info:active, .c-button--info:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--warning {
  background-color: #ffc107 !important;
  color: #FFF;
  border: none;
}
.c-button--warning:hover, .c-button--warning:active, .c-button--warning:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--danger {
  background-color: #dc3545 !important;
  color: #FFF;
  border: none;
}
.c-button--danger:hover, .c-button--danger:active, .c-button--danger:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--light {
  background-color: #adb5bd !important;
  color: #FFF;
  border: none;
}
.c-button--light:hover, .c-button--light:active, .c-button--light:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--dark {
  background-color: #343a40 !important;
  color: #FFF;
  border: none;
}
.c-button--dark:hover, .c-button--dark:active, .c-button--dark:focus {
  text-decoration: none;
  color: #FFF;
  opacity: 0.8;
}

.c-button--lg {
  padding: 15px;
  font-size: 2rem;
}
.c-button--lg::after {
  border-top-width: 4px;
  border-right-width: 4px;
}
@media print, screen and (min-width: 768px) {
  .c-button--lg {
    max-width: 550px;
    font-size: 2.2rem;
  }
  .c-button--lg::after {
    top: calc(50% - 8px);
    right: 40px;
    width: 12px;
    height: 12px;
  }
}

.c-button--xl {
  padding: 15px;
  width: 100%;
  font-size: 2rem;
  box-sizing: border-box;
}
@media print, screen and (min-width: 768px) {
  .c-button--xl {
    padding: 20px 50px;
    font-size: 2.5rem;
    max-width: 100%;
  }
}

.c-button--blue {
  background: #044E80;
  color: #FFF;
  border: none;
}
.c-button--blue:hover, .c-button--blue:focus {
  color: #FFF;
}

.c-button--red {
  background: #A1001B;
  color: #FFF;
  border: none;
}
.c-button--red:hover, .c-button--red:focus {
  color: #FFF;
}

/*==================================
* btn--radius
==================================*/
.c-button--radius {
  border-radius: 40px;
  -moz-border-radius: 40px;
  -webkit-border-radius: 40px;
}

/*==================================
* btn--block
==================================*/
.c-button--block {
  display: block;
  border-radius: 40px;
  -moz-border-radius: 40px;
  -webkit-border-radius: 40px;
  font-size: 2rem;
  line-height: 5.5rem;
}
@media print, screen and (min-width: 768px) {
  .c-button--block {
    font-size: 2.5rem;
    line-height: 7rem;
    max-width: 100%;
  }
}

/*==================================
* コンテナ（1カラム）
==================================*/
.c-button-container {
  padding: 30px 0 0 0;
  text-align: center;
}

/**
 * Grid
 */
/* c-grid
======================= */
.c-grid {
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.c-grid .c-grid__col--tit {
  text-align: center;
  margin-top: 20px;
  font-size: 2rem;
  font-weight: 500;
}
.c-grid .c-grid__col--text {
  margin: 20px auto auto 0;
  text-align: left;
}
.c-grid .c-grid-col2,
.c-grid .c-grid-col3 {
  box-sizing: border-box;
  margin-bottom: 50px;
}
.c-grid .c-grid-col2 img,
.c-grid .c-grid-col3 img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
.c-grid .c-grid-col2 {
  display: block;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .c-grid .c-grid-col2 {
    width: 46%;
  }
}
.c-grid .c-grid-col3 {
  display: block;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .c-grid .c-grid-col3 {
    width: 30%;
  }
}

/**
 * Label
 */
/**
 * Label
 */
.c-label,
.c-label--orange,
.c-label--dark,
.c-label--light,
.c-label--danger,
.c-label--warning,
.c-label--info,
.c-label--success,
.c-label--secondary,
.c-label--primary {
  margin: 0;
  padding: 5px 10px;
  display: inline-block;
  -webkit-appearance: none;
  -webkit-box-shadow: none;
  border-radius: 3px;
  background-color: #FFFFFF;
  text-align: center;
  font-size: 1.4rem;
  background: #fafafa;
  border: solid 1px #CCC;
  vertical-align: middle;
}

@media screen and (min-width: 768px) {
  .c-label,
  .c-label--orange,
  .c-label--dark,
  .c-label--light,
  .c-label--danger,
  .c-label--warning,
  .c-label--info,
  .c-label--success,
  .c-label--secondary,
  .c-label--primary {
    font-size: 1.6rem;
  }
}
.c-label--success {
  background-color: #03967a !important;
  color: #FFF;
  border: none;
}

.c-label--info {
  background-color: #17a2b8 !important;
  color: #FFF;
  border: none;
}

.c-lbl,
.c-lbl--dark,
.c-lbl--light,
.c-lbl--danger,
.c-lbl--warning,
.c-lbl--info,
.c-lbl--success,
.c-lbl--secondary,
.c-lbl--primary {
  margin: 0;
  padding: 3px 8px;
  display: inline-block;
  -webkit-appearance: none;
  -webkit-box-shadow: none;
  border-radius: 3px;
  background-color: #FFFFFF;
  text-align: center;
  font-size: 1.6rem;
  background: #fafafa;
  border: solid 1px #CCC;
}

.c-lbl--primary {
  background-color: #044E80 !important;
  color: #FFF;
  border: none;
}

.c-lbl--secondary {
  background-color: #FEB808 !important;
  color: #FFF;
  border: none;
}

.c-lbl--success {
  background-color: #03967a !important;
  color: #FFF;
  border: none;
}

.c-lbl--info {
  background-color: #17a2b8 !important;
  color: #FFF;
  border: none;
}

.c-lbl--warning {
  background-color: #ffc107 !important;
  color: #FFF;
  border: none;
}

.c-lbl--danger {
  background-color: #dc3545 !important;
  color: #FFF;
  border: none;
}

.c-lbl--light {
  background-color: #adb5bd !important;
  color: #FFF;
  border: none;
}

.c-lbl--dark {
  background-color: #343a40 !important;
  color: #FFF;
  border: none;
}

/**
 * List
 */
.c-list__check, .c-list__check--sm-black {
  margin: 0 auto;
  padding: 0;
}
.c-list__check li, .c-list__check--sm-black li {
  margin-bottom: 10px;
  padding: 0 0 0 35px;
  background-image: url(../img/icon__check.png);
  background-repeat: no-repeat;
  background-position: left center;
  font-size: 1.5rem;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .c-list__check li, .c-list__check--sm-black li {
    font-size: 1.8rem;
  }
}

.c-list__check--sm-black li {
  font-size: 1.8rem;
  color: #333;
  background-position: left top;
}
@media print, screen and (min-width: 768px) {
  .c-list__check--sm-black li {
    font-size: 2.2rem;
  }
}

/**
 * service-menu
 */
/* type01
======================= */
.c-service-menu-01 {
  width: 95%;
  margin: 0 auto;
  box-sizing: border-box;
}
.c-service-menu-01 li {
  max-width: 450px;
  margin: 0 auto 30px auto;
}
.c-service-menu-01 li:last-child {
  margin-bottom: 0;
}
.c-service-menu-01 li a {
  position: relative;
  display: flex;
  align-items: center;
  border: solid 3px #044E80;
  border-radius: 8px;
  background: #044E80;
}
.c-service-menu-01 li a::before {
  content: "";
  position: absolute;
  top: 90px;
  right: 5px;
  width: 25px;
  height: 25px;
  background: #fff;
  border: solid 3px #044E80;
  border-radius: 100px;
  z-index: 5;
}
.c-service-menu-01 li a::after {
  content: "\f054";
  position: absolute;
  top: 94px;
  right: 14px;
  font-family: "Font Awesome 5 Free";
  font-size: 2rem;
  font-weight: 900;
  color: #044E80;
  z-index: 10;
}
.c-service-menu-01 li a .c-service-menu-01__image {
  display: block;
  width: 32%;
}
.c-service-menu-01 li a .c-service-menu-01__image img {
  display: block;
  width: 100%;
  height: 125px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 8px 0 0 8px;
}
.c-service-menu-01 li a .c-service-menu-01__catchcopy {
  width: 68%;
  padding: 10px 5px;
  text-align: center;
  color: #fff;
}
.c-service-menu-01 li a .c-service-menu-01__catchcopy p {
  margin-bottom: 10px;
}
.c-service-menu-01 li a .c-service-menu-01__catchcopy h3 {
  font-size: 1.8rem;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .c-service-menu-01 {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 0 8px;
  }
  .c-service-menu-01 li {
    width: 32%;
    margin-bottom: 0;
  }
  .c-service-menu-01 li a::before {
    top: 126px;
  }
  .c-service-menu-01 li a::after {
    top: 130px;
    right: 13px;
  }
  .c-service-menu-01 li a .c-service-menu-01__image {
    width: 40%;
  }
  .c-service-menu-01 li a .c-service-menu-01__image img {
    height: 160px;
  }
  .c-service-menu-01 li a .c-service-menu-01__catchcopy p {
    margin-bottom: 15px;
    font-size: 1.6rem;
  }
  .c-service-menu-01 li a:hover {
    opacity: 1;
  }
  .c-service-menu-01 li a:hover::before {
    background: #ffb459;
  }
  .c-service-menu-01 li a:hover .c-service-menu-01__catchcopy {
    color: #fff3e5;
  }
}

/* type02
======================= */
.c-service-menu-02 {
  width: 95%;
  margin: 0 auto;
}
.c-service-menu-02 .c-service-menu-02__unit {
  margin-bottom: 50px;
  padding: 30px 20px;
  background: #fff;
  border-radius: 5px;
  box-sizing: border-box;
}
.c-service-menu-02 .c-service-menu-02__unit:last-child {
  margin-bottom: 0;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__image {
  margin-bottom: 20px;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__image img {
  display: block;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__title {
  margin-bottom: 20px;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__title span {
  margin-bottom: 10px;
  padding-bottom: 3px;
  font-size: 1.5rem;
  font-weight: normal;
  border-bottom: solid 1px #333;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__text {
  margin-bottom: 20px;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__text p {
  margin-bottom: 5px;
  font-size: 1.6rem;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__text p:last-child {
  margin-bottom: 0;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body__button a {
  display: block;
  margin: 0 auto;
  padding: 10px 10px 11px 10px;
  text-align: center;
  font-size: 1.6rem;
  font-weight: bold;
  color: #fff;
  background: #8eaad8;
  border: solid 2px #8eaad8;
  border-radius: 5px;
  transition: all 0.3s;
}
.c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body__button a:hover {
  color: #8eaad8;
  background: #fff;
  border: solid 2px #8eaad8;
  opacity: 1;
}
@media print, screen and (min-width: 768px) {
  .c-service-menu-02 .c-service-menu-02__unit {
    display: flex;
    justify-content: space-between;
    margin-bottom: 80px;
    padding: 40px 50px;
  }
  .c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__image {
    width: 35%;
    margin-bottom: 0;
  }
  .c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body {
    width: 55%;
  }
  .c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__title {
    margin-bottom: 30px;
    text-align: left;
    font-size: 3rem;
  }
  .c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__title span {
    margin-bottom: 15px;
    padding-bottom: 5px;
    font-size: 1.8rem;
    font-weight: bold;
  }
  .c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__text {
    margin-bottom: 40px;
  }
  .c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__text p {
    margin-bottom: 7px;
  }
  .c-service-menu-02 .c-service-menu-02__unit .c-service-menu-02__body .c-service-menu-02__body__button {
    width: 70%;
  }
  .c-service-menu-02 .c-service-menu-02__unit:nth-child(odd) .c-service-menu-02__image {
    order: 2;
  }
  .c-service-menu-02 .c-service-menu-02__unit:nth-child(odd) .c-service-menu-02__body {
    order: 1;
  }
}

/**
 * Title
 */
/* ページタイトル(H1)
 ======================= */
.c-page__tit {
  border-top: 1px solid #D9D9D9;
  border-bottom: 1px solid #D9D9D9;
  margin-bottom: 5rem;
}
@media print, screen and (min-width: 768px) {
  .c-page__tit {
    border-top: none;
  }
}

.c-page__tit__inner {
  margin: 0 auto;
  padding: 18px 0 18px 48px;
  position: relative;
  box-sizing: border-box;
}
@media print, screen and (min-width: 768px) {
  .c-page__tit__inner {
    width: 1100px;
    padding: 25px 0 25px 28px;
  }
}
.c-page__tit__inner:before {
  content: "";
  display: block;
  position: absolute;
  left: 20px;
  top: 20px;
  bottom: 20px;
  width: 8px;
  background: #044E80;
}
@media print, screen and (min-width: 768px) {
  .c-page__tit__inner:before {
    left: 0;
    top: 30px;
    bottom: 30px;
  }
}

.c-page__tit__text {
  padding: 0;
  font-size: 2rem;
  color: #333;
  line-height: 1.2;
}
@media print, screen and (min-width: 768px) {
  .c-page__tit__text {
    font-size: 3rem;
  }
}

/* 共通タイトル(H2)
 ======================= */
h2.tit {
  padding: 0 8px;
  font-size: 2.5rem;
  line-height: 2.7rem;
  font-weight: 500;
  color: #333;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  h2.tit {
    font-size: 3rem;
    line-height: 3.4rem;
  }
}

/* タイトルタイプ2
 ======================= */
.c-page__tit--type2 {
  margin: 0 0 15px 0;
  padding: 0;
  font-weight: bold;
  color: #044E80;
  line-height: 1.2;
}

/*
　H2タイトル（キャッチコピー）
================================*/
.c-title--catchcopy {
  margin: 0 auto 30px auto;
  padding: 0 8px;
  text-align: center;
}
.c-title--catchcopy h2 {
  margin-bottom: 20px;
  line-height: 1.4;
  font-weight: 700;
}
.c-title--catchcopy h2 strong {
  font-size: 3.2rem;
  color: #044E80;
}
.c-title--catchcopy h3 {
  margin-bottom: 20px;
  line-height: 1.4;
  font-size: 2.2rem;
  font-weight: 700;
}
.c-title--catchcopy p {
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .c-title--catchcopy {
    max-width: 1140px;
    margin: 0 auto 60px auto;
    padding: 0;
  }
  .c-title--catchcopy h2 {
    margin-bottom: 30px;
    line-height: 1.6;
    font-size: 3rem;
  }
  .c-title--catchcopy h2 strong {
    font-size: 4.8rem;
  }
  .c-title--catchcopy h3 {
    margin-bottom: 30px;
    line-height: 1.6;
    font-size: 32px;
  }
  .c-title--catchcopy p {
    font-size: 24px;
  }
}

/* H2
 ======================= */
.c-title, .c-title--border {
  margin: 0 0 5rem 0;
  padding: 0;
  font-size: 2.2rem;
  line-height: 3.2rem;
  font-weight: bold;
  color: #333;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .c-title, .c-title--border {
    font-size: 3.2rem;
    line-height: 4.5rem;
  }
}

/* H2（下線）
 ======================= */
.c-title--border {
  position: relative;
  padding-bottom: 20px;
  margin-bottom: 6rem;
}
.c-title--border::after {
  content: "";
  display: block;
  position: absolute;
  width: 60px;
  left: calc(50% - 30px);
  bottom: 0;
  border: solid 2px #044E80;
}
@media print, screen and (min-width: 768px) {
  .c-title--border {
    margin-bottom: 8rem;
  }
}

/* H3
 ======================= */
.c-title-h3 {
  font-weight: bold;
  margin: 0 0 20px 0;
  padding-left: 10px;
  font-size: 1.8rem;
  line-height: 1.5;
  border-left: solid 5px #044E80;
}
@media print, screen and (min-width: 768px) {
  .c-title-h3 {
    padding-left: 15px;
    font-size: 2.4rem;
  }
}

.c-title-h3--primary {
  margin: 0 0 20px 0;
  padding: 0;
  font-weight: bold;
  color: #044E80;
  font-size: 1.8rem;
  line-height: 1.5;
}
@media print, screen and (min-width: 768px) {
  .c-title-h3--primary {
    font-size: 2.4rem;
  }
}

/* H3（箇条書き）
 ======================= */
.c-title-h3--bullet {
  position: relative;
  margin: 0 0 20px 0;
  padding: 0 0 0 30px;
  color: #333;
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 1.5;
}
.c-title-h3--bullet::before {
  position: absolute;
  top: 50%;
  left: 0;
  content: "";
  width: 15px;
  height: 4px;
  background-color: #044E80;
  transform: translateY(-50%);
}
@media print, screen and (min-width: 768px) {
  .c-title-h3--bullet {
    font-size: 2.4rem;
  }
}

/* H4
 ======================= */
.c-title-h4 {
  margin: 0 0 15px 0;
  padding: 0;
  font-weight: bold;
  color: #044E80;
  font-size: 1.6rem;
  line-height: 1.5;
}
@media print, screen and (min-width: 768px) {
  .c-title-h4 {
    font-size: 2rem;
  }
}

.c-title-h4--base {
  margin: 0 0 15px 0;
  padding: 0;
  font-weight: bold;
  color: #333;
  font-size: 1.6rem;
  line-height: 1.5;
}
@media print, screen and (min-width: 768px) {
  .c-title-h4--base {
    font-size: 2rem;
  }
}

/**
 * Thumbnail
 */
.c-thumbnail,
.c-thumbnail--border {
  margin-bottom: 50px;
  padding: 0 5px;
}
@media print, screen and (min-width: 768px) {
  .c-thumbnail,
  .c-thumbnail--border {
    padding: 0;
  }
}
.c-thumbnail .c-thumbnail__list,
.c-thumbnail--border .c-thumbnail__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.c-thumbnail .c-thumbnail__list::after,
.c-thumbnail--border .c-thumbnail__list::after {
  content: "";
  display: block;
  width: 48%;
}
@media print, screen and (min-width: 768px) {
  .c-thumbnail .c-thumbnail__list::after,
  .c-thumbnail--border .c-thumbnail__list::after {
    width: 32%;
  }
}
.c-thumbnail .c-thumbnail__list .c-thumbnail__list--item,
.c-thumbnail--border .c-thumbnail__list .c-thumbnail__list--item {
  width: 48%;
  margin-bottom: 20px;
}
@media print, screen and (min-width: 768px) {
  .c-thumbnail .c-thumbnail__list .c-thumbnail__list--item,
  .c-thumbnail--border .c-thumbnail__list .c-thumbnail__list--item {
    width: 32%;
  }
}
.c-thumbnail .c-thumbnail__list .c-thumbnail__list--item > img,
.c-thumbnail--border .c-thumbnail__list .c-thumbnail__list--item > img {
  margin-right: auto;
  margin-left: auto;
  width: 100%;
}

.c-thumbnail--border .c-thumbnail__list--item {
  padding: 5px;
  box-sizing: border-box;
  border-radius: 3px;
  background-color: #FFF;
  border: solid 1px #ccc;
  box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.05);
}

/**
 * スライドメニュー
 */
.c-slide-menu {
  width: 250px;
  background: #f8f8f8;
  -webkit-box-shadow: inset 0 0 5px 5px #ebebeb;
  transform: translateX(0);
  transition: ease 0.3s;
  position: fixed;
  top: 0;
  left: -250px;
  z-index: 9999;
}
.c-slide-menu.open {
  transform: translateX(250px);
}
.c-slide-menu .c-slide-menu-inner {
  padding: 0 0 20px 0;
  overflow-y: auto;
}
.c-slide-menu.c-slide-menu-right {
  left: auto;
  right: -250px;
}
.c-slide-menu.c-slide-menu-right.open {
  transform: translateX(-250px);
}
.c-slide-menu h3 {
  padding: 10px 10px;
  -webkit-appearance: none;
  text-shadow: rgba(0, 0, 0, 0.4) 0px -1px 0px;
  background: #dfdfdf;
  color: #606060;
  text-shadow: 1px 1px 1px #FFFFFF;
  font-size: 16px;
  border-top: 1px solid #dddddd;
  border-bottom: 1px solid #dddddd;
}
.c-slide-menu ul {
  width: 100%;
  margin: 0;
  padding: 0;
  border-top: 1px solid #dfdfdf;
}
.c-slide-menu ul li {
  list-style: none;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #dfdfdf;
}
.c-slide-menu ul li a {
  text-decoration: none;
  display: block;
  padding: 12px 15px;
  position: relative;
  color: #333;
  font-size: 14px;
  /* リンクリスト（矢印） */
}
.c-slide-menu ul li a.arrow:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  width: 7px;
  height: 7px;
  margin-top: -4px;
  border-top: solid 2px #7f7f7f;
  border-right: solid 2px #7f7f7f;
  transform: rotate(45deg);
  content: "";
}

.c-slide-menu-overlay {
  position: absolute;
  top: 0px;
  bottom: 0px;
  right: 0px;
  left: 0px;
  z-index: 9998;
  opacity: 0;
  display: none;
  background: rgb(0, 0, 0);
}

@media print, screen and (min-width: 768px) {
  .c-slide-menu,
  .c-slide-menu-overlay {
    display: none;
  }
}
/**
 * Tip
 */
.c-tip-left {
  display: table;
  table-layout: fixed;
  width: 100%;
}

.c-tip-left__img {
  display: table-cell;
  vertical-align: top;
  padding-right: 10px;
}
.c-tip-left__img img {
  max-width: 100%;
}

.c-tip-left__tip {
  display: table-cell;
  vertical-align: top;
  background: #fff;
  padding: 1em;
  position: relative;
  border-radius: 5px;
  border: 1px solid #ccc;
}
.c-tip-left__tip:before {
  content: "";
  position: absolute;
  top: 10px;
  left: -9px;
  margin-left: 0;
  width: 0;
  height: 0;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  border-right: 9px solid #ccc;
}
.c-tip-left__tip :after {
  content: "";
  position: absolute;
  top: 10px;
  left: -9px;
  width: 0;
  height: 0;
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  margin-left: 1px;
  border-right: 9px solid #fff;
}

/**
 * Contentsbox
 */
/* 内部リンクメニュー
 ======================= */
.c-contentsbox__menu {
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu {
    max-width: 730px;
  }
}

@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu.c-contentsbox__menu-xs {
    max-width: 530px;
  }
}

@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu.c-contentsbox__menu-sm {
    max-width: 580px;
  }
}

@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu.c-contentsbox__menu-md {
    max-width: 650px;
  }
}

.c-contentsbox__menu li {
  width: 48%;
  float: left;
  display: inline-block;
  margin-right: 4%;
  margin-bottom: 4%;
  font-size: 12px;
  position: relative;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu li {
    width: auto;
    margin-right: 10px;
    margin-bottom: 10px;
    font-size: 14px;
  }
}

.c-contentsbox__menu li:nth-child(even) {
  margin-right: 0%;
}
@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu li:nth-child(even) {
    margin-right: 10px;
  }
}

.c-contentsbox__menu li a {
  text-decoration: none;
  color: #044E80;
  background: #E6EDF2;
  padding: 15px 10px 20px 10px;
  display: block;
  box-sizing: border-box;
}
@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu li a {
    padding: 15px;
  }
}

.c-contentsbox__menu li i.fa {
  display: block;
  position: absolute;
  bottom: 5px;
  left: 45%;
  margin: 5px 0 0 0;
}
@media print, screen and (min-width: 768px) {
  .c-contentsbox__menu li i.fa {
    display: inline-block;
    position: static;
    margin: 0 0 0 10px;
  }
}

/* type05
 ======================= */
.c-menu--type05 {
  margin: 0 auto;
  width: 95%;
}
.c-menu--type05 a {
  display: block;
  position: relative;
  color: #333;
  margin-bottom: 50px;
  border-radius: 5px;
  box-shadow: 0 0 15px 3px rgba(118, 118, 118, 0.5);
}
.c-menu--type05 a .c-menu__card-image {
  max-width: 100%;
  padding: 20px;
}
.c-menu--type05 a .c-menu__card-image img {
  width: 100%;
  height: 220px;
  -o-object-fit: contain;
     object-fit: contain;
}
.c-menu--type05 a .c-menu__card-textarea {
  padding: 20px 30px;
}
.c-menu--type05 a .c-menu__card-textarea p {
  font-size: 16px;
}
.c-menu--type05 a .c-menu__card-textarea .c-menu__card-header {
  margin-bottom: 20px;
  text-align: center;
  font-size: 22px;
  font-weight: bold;
}
.c-menu--type05 a .c-menu__card-textarea .c-menu__card-sub {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}
.c-menu--type05 a .c-menu__card-textarea .c-menu__card-sub i {
  margin-right: 5px;
  font-size: 26px;
  color: #ff8c00;
}
.c-menu--type05 a .c-menu__card-textarea .c-menu__card-body {
  margin-top: 20px;
  margin-bottom: 30px;
}
.c-menu--type05 a .c-menu__card-textarea .c-menu__card-body P {
  margin-bottom: 10px;
}
.c-menu--type05 a .c-menu__card-textarea .c-menu__card-bottom {
  position: absolute;
  display: block;
  bottom: 5px;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media print, screen and (min-width: 768px) {
  .c-menu--type05 {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    width: 100%;
    margin-top: 80px;
  }
  .c-menu--type05 a {
    width: 30%;
  }
  .c-menu--type05 a .c-menu__card-textarea .c-menu__card-header {
    font-size: 24px;
  }
}

/* 標準ページヘッダー
 ======================= */
.c-pc-heading {
  position: relative;
  background-image: url(../img/hp/pc-heading__bg.jpg);
  background-repeat: no-repeat;
  background-position: 50% 5%;
  background-size: cover;
  /* PC */
}
.c-pc-heading::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(34, 58, 87, 0.5);
  z-index: 10;
}
.c-pc-heading h1 {
  position: relative;
  padding: 5rem 0;
  font-size: 3rem;
  color: #fff;
  font-weight: 500;
  text-align: center;
  z-index: 20;
}
@media print, screen and (min-width: 768px) {
  .c-pc-heading h1 {
    padding: 7rem 0;
    font-size: 4rem;
  }
}

/**
 * Point
 */
/* point
 ======================= */
/* type01
 ======================= */
.c-point--type01 {
  /* PC */
}
.c-point--type01 .c-point__block {
  padding: 20px;
  box-sizing: border-box;
  border: solid 1px #ccc;
  margin-bottom: 50px;
}
.c-point--type01 .c-point__header {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}
.c-point--type01 .c-point__header h2 {
  font-size: 2.2rem;
  font-weight: bold;
  margin-left: 20px;
}
.c-point--type01 .c-point__cover {
  width: 60px;
  height: 60px;
  padding: 10px;
  border-radius: 100%;
  text-align: center;
  color: #fff;
  background-color: #044E80;
  box-sizing: border-box;
  line-height: 1.2;
  font-size: 1.3rem;
}
.c-point--type01 .c-point__no {
  font-size: 2rem;
}
@media print, screen and (min-width: 768px) {
  .c-point--type01 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .c-point--type01 .c-point__block {
    width: 32%;
  }
  .c-point--type01.c-point--col2 .c-point__block {
    width: 48%;
  }
}

/* type02
======================= */
.c-point--type02 {
  margin: 0 15px;
}
.c-point--type02 li {
  position: relative;
  margin-bottom: 50px;
  padding: 20px;
  border: solid 3px #044E80;
  border-radius: 10px;
}
.c-point--type02 li .c-point__strong {
  display: inline-block;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 10px 40px;
  text-align: center;
  font-size: 1.6rem;
  font-weight: bold;
  border-radius: 30px;
  color: #ffffff;
  background-color: #044E80;
  margin-right: -50%;
}
.c-point--type02 li .c-point__title {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  padding-top: 20px;
  color: #044E80;
}
.c-point--type02 li .c-point__image {
  max-width: 100%;
  margin: 25px auto;
  text-align: center;
}
.c-point--type02 li .c-point__image img {
  width: 80%;
}
.c-point--type02 li .c-point__text {
  text-align: center;
  font-size: 1.6rem;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .c-point--type02 {
    margin: 80px 0;
  }
  .c-point--type02 ul {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
  }
  .c-point--type02 ul li {
    width: 27%;
    margin-bottom: 0;
  }
  .c-point--type02 ul li .c-point__image img {
    width: 90%;
  }
  .c-point--type02 ul li .c-point__text {
    font-size: 2rem;
  }
}

/**
 * Feature
 */
.c-feature--type01 .c-feature__block {
  width: 100%;
  margin-bottom: 50px;
}
.c-feature--type01 .c-feature__block:last-child {
  margin-bottom: 30px;
}
.c-feature--type01 .c-feature__image {
  margin-bottom: 30px;
}
.c-feature--type01 .c-feature__image img {
  max-width: 100%;
  height: auto;
}

/* PC */
@media print, screen and (min-width: 768px) {
  .c-feature--type01 .c-feature__block {
    display: flex;
    margin-bottom: 80px;
  }
  .c-feature--type01 .c-feature__image {
    width: 50%;
    margin: 0;
    padding: 0 30px 0 0;
  }
  .c-feature--type01 .c-feature__text {
    width: 50%;
    padding: 0 0 0 30px;
  }
  .c-feature--type01 .c-feature--reverse {
    flex-direction: row-reverse;
  }
  .c-feature--type01 .c-feature--reverse .c-feature__image {
    padding: 0 0 0 30px;
    text-align: right;
  }
  .c-feature--type01 .c-feature--reverse .c-feature__text {
    padding: 0 30px 0 0;
  }
}
/*
　セクションタイトル
=================================*/
.pc-section-title--blue,
.pc-section-title--orange,
.pc-section-title--green,
.pc-section-title--gray {
  padding: 4rem 0;
}
.pc-section-title--blue h2,
.pc-section-title--orange h2,
.pc-section-title--green h2,
.pc-section-title--gray h2 {
  text-align: center;
  font-size: 2.4rem;
  font-weight: bold;
  color: #fff;
}
@media print, screen and (min-width: 768px) {
  .pc-section-title--blue,
  .pc-section-title--orange,
  .pc-section-title--green,
  .pc-section-title--gray {
    padding: 8rem 0;
  }
  .pc-section-title--blue h2,
  .pc-section-title--orange h2,
  .pc-section-title--green h2,
  .pc-section-title--gray h2 {
    max-width: 1140px;
    margin: 0 auto;
    font-size: 4rem;
  }
}

/* 青色 */
.pc-section-title--blue {
  background-color: #044E80;
}

/* オレンジ色 */
.pc-section-title--orange {
  background: #FEB808;
}

/* 緑色 */
.pc-section-title--green {
  background: #03967a;
}

/* 灰色 */
.pc-section-title--gray {
  background: #939598;
}

/**
 * entry-button
 */
/*
　申込みボタン（吹き出し付き）
=================================*/
.c-pc-entry-button__bubble--blue,
.c-pc-entry-button__bubble--orange,
.c-pc-entry-button__bubble--green,
.c-pc-entry-button__bubble--yellow,
.c-pc-entry-button__bubble--gray {
  position: relative;
  display: inline-block;
  padding: 5px 50px 25px 50px;
  transition: all 0.3s;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  font-size: 2.6rem;
  font-weight: 700;
  color: #fff;
  border-radius: 5px;
}
.c-pc-entry-button__bubble--blue span,
.c-pc-entry-button__bubble--orange span,
.c-pc-entry-button__bubble--green span,
.c-pc-entry-button__bubble--yellow span,
.c-pc-entry-button__bubble--gray span {
  position: absolute;
  top: -45px;
  left: calc(50% - 132px);
  display: block;
  width: 260px;
  padding: 8px 0;
  line-height: 1.2;
  font-size: 2rem;
  border-radius: 50px;
  background: #fff;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}
.c-pc-entry-button__bubble--blue span::before, .c-pc-entry-button__bubble--blue span::after,
.c-pc-entry-button__bubble--orange span::before,
.c-pc-entry-button__bubble--orange span::after,
.c-pc-entry-button__bubble--green span::before,
.c-pc-entry-button__bubble--green span::after,
.c-pc-entry-button__bubble--yellow span::before,
.c-pc-entry-button__bubble--yellow span::after,
.c-pc-entry-button__bubble--gray span::before,
.c-pc-entry-button__bubble--gray span::after {
  content: "";
  position: absolute;
  left: calc(50% - 10px);
}
.c-pc-entry-button__bubble--blue span::before,
.c-pc-entry-button__bubble--orange span::before,
.c-pc-entry-button__bubble--green span::before,
.c-pc-entry-button__bubble--yellow span::before,
.c-pc-entry-button__bubble--gray span::before {
  bottom: -10px;
  border-width: 10px 10px 0 10px;
  border-style: solid;
}
.c-pc-entry-button__bubble--blue span::after,
.c-pc-entry-button__bubble--orange span::after,
.c-pc-entry-button__bubble--green span::after,
.c-pc-entry-button__bubble--yellow span::after,
.c-pc-entry-button__bubble--gray span::after {
  bottom: -7px;
  border-width: 10px 10px 0 10px;
  border-style: solid;
  border-color: #fff transparent transparent transparent;
}
.c-pc-entry-button__bubble--blue i,
.c-pc-entry-button__bubble--orange i,
.c-pc-entry-button__bubble--green i,
.c-pc-entry-button__bubble--yellow i,
.c-pc-entry-button__bubble--gray i {
  margin-left: 10px;
}
.c-pc-entry-button__bubble--blue:hover,
.c-pc-entry-button__bubble--orange:hover,
.c-pc-entry-button__bubble--green:hover,
.c-pc-entry-button__bubble--yellow:hover,
.c-pc-entry-button__bubble--gray:hover {
  color: #fff;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__bubble--blue,
  .c-pc-entry-button__bubble--orange,
  .c-pc-entry-button__bubble--green,
  .c-pc-entry-button__bubble--yellow,
  .c-pc-entry-button__bubble--gray {
    padding: 5px 100px 30px 100px;
    font-size: 3.2rem;
    border-radius: 7px;
  }
  .c-pc-entry-button__bubble--blue span,
  .c-pc-entry-button__bubble--orange span,
  .c-pc-entry-button__bubble--green span,
  .c-pc-entry-button__bubble--yellow span,
  .c-pc-entry-button__bubble--gray span {
    top: -50px;
    left: calc(50% - 142px);
    width: 280px;
    font-size: 2.4rem;
  }
  .c-pc-entry-button__bubble--blue:hover,
  .c-pc-entry-button__bubble--orange:hover,
  .c-pc-entry-button__bubble--green:hover,
  .c-pc-entry-button__bubble--yellow:hover,
  .c-pc-entry-button__bubble--gray:hover {
    transform: translate(0, 3px);
  }
}

/* 青色 */
.c-pc-entry-button__bubble--blue {
  box-shadow: 0 6px 0 #213857;
  background: #044E80;
}
.c-pc-entry-button__bubble--blue span {
  color: #213857;
  border: 2px solid #213857;
}
.c-pc-entry-button__bubble--blue span::before {
  border-color: #213857 transparent transparent transparent;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__bubble--blue {
    box-shadow: 0 7px 0 #213857;
  }
  .c-pc-entry-button__bubble--blue:hover {
    background: #044E80;
    box-shadow: 0 2px 0 #213857;
  }
}

/* オレンジ色 */
.c-pc-entry-button__bubble--orange {
  box-shadow: 0 6px 0 #f96e0a;
  background: #FEB808;
}
.c-pc-entry-button__bubble--orange span {
  color: #f96e0a;
  border: 2px solid #f96e0a;
}
.c-pc-entry-button__bubble--orange span::before {
  border-color: #f96e0a transparent transparent transparent;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__bubble--orange {
    box-shadow: 0 7px 0 #f96e0a;
  }
  .c-pc-entry-button__bubble--orange:hover {
    background: #FEB808;
    box-shadow: 0 2px 0 #f96e0a;
  }
}

/* 緑色 */
.c-pc-entry-button__bubble--green {
  box-shadow: 0 6px 0 #026855;
  background: #03967a;
}
.c-pc-entry-button__bubble--green span {
  color: #026855;
  border: 2px solid #026855;
}
.c-pc-entry-button__bubble--green span::before {
  border-color: #026855 transparent transparent transparent;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__bubble--green {
    box-shadow: 0 7px 0 #026855;
  }
  .c-pc-entry-button__bubble--green:hover {
    background: #03967a;
    box-shadow: 0 2px 0 #026855;
  }
}

/* 黄色 */
.c-pc-entry-button__bubble--yellow {
  box-shadow: 0 6px 0 #d8a105;
  background: #fac530;
}
.c-pc-entry-button__bubble--yellow span {
  color: #fac530;
  border: 2px solid #fac530;
}
.c-pc-entry-button__bubble--yellow span::before {
  border-color: #fac530 transparent transparent transparent;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__bubble--yellow {
    padding: 0 100px 30px 100px;
    box-shadow: 0 7px 0 #d8a105;
  }
  .c-pc-entry-button__bubble--yellow span {
    top: -47px;
  }
  .c-pc-entry-button__bubble--yellow:hover {
    background: #fac530;
    box-shadow: 0 2px 0 #d8a105;
  }
}

/* 灰色 */
.c-pc-entry-button__bubble--gray {
  box-shadow: 0 6px 0 #747577;
  background: #939598;
}
.c-pc-entry-button__bubble--gray span {
  color: #939598;
  border: 2px solid #939598;
}
.c-pc-entry-button__bubble--gray span::before {
  border-color: #939598 transparent transparent transparent;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__bubble--gray {
    padding: 0 100px 30px 100px;
    box-shadow: 0 7px 0 #747577;
  }
  .c-pc-entry-button__bubble--gray span {
    top: -47px;
  }
  .c-pc-entry-button__bubble--gray:hover {
    background: #939598;
    box-shadow: 0 2px 0 #747577;
  }
}

/*
　申込みボタン（ラベル付き）
=================================*/
.c-pc-entry-button__label--blue,
.c-pc-entry-button__label--orange,
.c-pc-entry-button__label--green {
  position: relative;
  display: inline-block;
  padding: 0 50px 20px 50px;
  transition: all 0.3s;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  font-size: 2.6rem;
  font-weight: 700;
  color: #fff;
  border-radius: 5px;
}
.c-pc-entry-button__label--blue span,
.c-pc-entry-button__label--orange span,
.c-pc-entry-button__label--green span {
  position: absolute;
  top: -20px;
  left: calc(50% - 172px);
  display: block;
  width: 340px;
  padding: 8px 0;
  line-height: 1.2;
  font-size: 2rem;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}
.c-pc-entry-button__label--blue i,
.c-pc-entry-button__label--orange i,
.c-pc-entry-button__label--green i {
  margin-left: 10px;
}
.c-pc-entry-button__label--blue:hover,
.c-pc-entry-button__label--orange:hover,
.c-pc-entry-button__label--green:hover {
  color: #fff;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__label--blue,
  .c-pc-entry-button__label--orange,
  .c-pc-entry-button__label--green {
    padding: 0px 100px 25px 100px;
    font-size: 3.2rem;
    border-radius: 7px;
  }
  .c-pc-entry-button__label--blue span,
  .c-pc-entry-button__label--orange span,
  .c-pc-entry-button__label--green span {
    top: -22px;
    left: calc(50% - 202px);
    width: 400px;
    font-size: 2.4rem;
  }
  .c-pc-entry-button__label--blue:hover,
  .c-pc-entry-button__label--orange:hover,
  .c-pc-entry-button__label--green:hover {
    transform: translate(0, 3px);
  }
}

/* 青色 */
.c-pc-entry-button__label--blue {
  box-shadow: 0 6px 0 #213857;
  background: #044E80;
}
.c-pc-entry-button__label--blue span {
  color: #213857;
  border: 2px solid #213857;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__label--blue {
    box-shadow: 0 7px 0 #213857;
  }
  .c-pc-entry-button__label--blue:hover {
    background: #044E80;
    box-shadow: 0 2px 0 #213857;
  }
}

/* オレンジ色 */
.c-pc-entry-button__label--orange {
  box-shadow: 0 6px 0 #f96e0a;
  background: #FEB808;
}
.c-pc-entry-button__label--orange span {
  color: #f96e0a;
  border: 2px solid #f96e0a;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__label--orange {
    box-shadow: 0 7px 0 #f96e0a;
  }
  .c-pc-entry-button__label--orange:hover {
    background: #FEB808;
    box-shadow: 0 2px 0 #f96e0a;
  }
}

/* 緑色 */
.c-pc-entry-button__label--green {
  box-shadow: 0 6px 0 #026855;
  background: #03967a;
}
.c-pc-entry-button__label--green span {
  color: #026855;
  border: 2px solid #026855;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__label--green {
    box-shadow: 0 7px 0 #026855;
  }
  .c-pc-entry-button__label--green:hover {
    background: #03967a;
    box-shadow: 0 2px 0 #026855;
  }
}

/*
　申込みボタン（ノーマル）
=================================*/
.c-pc-entry-button__normal--blue,
.c-pc-entry-button__normal--orange,
.c-pc-entry-button__normal--green {
  position: relative;
  display: inline-block;
  padding: 15px 30px;
  transition: all 0.3s;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  border-radius: 5px;
}
.c-pc-entry-button__normal--blue i,
.c-pc-entry-button__normal--orange i,
.c-pc-entry-button__normal--green i {
  margin-left: 10px;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__normal--blue,
  .c-pc-entry-button__normal--orange,
  .c-pc-entry-button__normal--green {
    padding: 20px 50px 20px 50px;
    font-size: 2.6rem;
    border-radius: 7px;
  }
  .c-pc-entry-button__normal--blue:hover,
  .c-pc-entry-button__normal--orange:hover,
  .c-pc-entry-button__normal--green:hover {
    transform: translate(0, 3px);
    color: #fff;
  }
}

/* 青色 */
.c-pc-entry-button__normal--blue {
  box-shadow: 0 6px 0 #213857;
  background: #044E80;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__normal--blue {
    box-shadow: 0 7px 0 #213857;
  }
  .c-pc-entry-button__normal--blue:hover {
    background: #044E80;
    box-shadow: 0 2px 0 #213857;
  }
}

/* オレンジ色 */
.c-pc-entry-button__normal--orange {
  box-shadow: 0 6px 0 #f96e0a;
  background: #FEB808;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__normal--orange {
    box-shadow: 0 7px 0 #f96e0a;
  }
  .c-pc-entry-button__normal--orange:hover {
    background: #FEB808;
    box-shadow: 0 2px 0 #f96e0a;
  }
}

/* 緑色 */
.c-pc-entry-button__normal--green {
  box-shadow: 0 6px 0 #026855;
  background: #03967a;
}
@media print, screen and (min-width: 768px) {
  .c-pc-entry-button__normal--green {
    box-shadow: 0 7px 0 #026855;
  }
  .c-pc-entry-button__normal--green:hover {
    background: #03967a;
    box-shadow: 0 2px 0 #026855;
  }
}

/**
 * case
 */
/*==================================
* 導入事例
==================================*/
.c-pc-case {
  margin: 0 10px;
}
.c-pc-case li {
  padding: 20px;
  margin-bottom: 50px;
  border-radius: 5px;
  background: #fff;
  box-shadow: 0 0 15px 3px rgba(118, 118, 118, 0.4);
}
.c-pc-case li .c-button--primary {
  margin-bottom: 0;
}
.c-pc-case .c-pc-case__header {
  display: flex;
  margin-bottom: 20px;
}
.c-pc-case .c-pc-case__header img {
  width: 40px;
  height: 40px;
  border-radius: 100%;
}
.c-pc-case .c-pc-case__header .c-pc-case__title {
  padding-left: 20px;
}
.c-pc-case .c-pc-case__header .c-pc-case__title h3 {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 10px;
  line-height: 1.5;
}
.c-pc-case .c-pc-case__header .c-pc-case__title dl {
  display: block;
  margin: 0 0 10px 0;
}
.c-pc-case .c-pc-case__header .c-pc-case__title dl dt {
  display: inline;
  padding: 1px 5px;
  margin-right: 10px;
  font-size: 1.4rem;
  color: #044E80;
  border: solid 2px #044E80;
  border-radius: 4px;
}
.c-pc-case .c-pc-case__header .c-pc-case__title dl dd {
  display: inline;
  margin: 0;
  font-size: 1.8rem;
}
.c-pc-case .c-pc-case__body {
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .c-pc-case {
    max-width: 1140px;
    margin: 0 auto;
  }
  .c-pc-case li {
    padding: 40px;
    margin-bottom: 70px;
  }
  .c-pc-case .c-pc-case__header {
    margin-bottom: 30px;
  }
  .c-pc-case .c-pc-case__header img {
    width: 80px;
    height: 80px;
  }
  .c-pc-case .c-pc-case__header .c-pc-case__title {
    padding-left: 30px;
  }
  .c-pc-case .c-pc-case__header .c-pc-case__title h3 {
    font-size: 2.4rem;
  }
  .c-pc-case .c-pc-case__header .c-pc-case__title dl {
    display: inline-block;
    margin: 0;
  }
  .c-pc-case .c-pc-case__header .c-pc-case__title dl dt {
    margin-right: 15px;
    font-size: 1.6rem;
  }
  .c-pc-case .c-pc-case__header .c-pc-case__title dl dd {
    margin-right: 35px;
    font-size: 2rem;
  }
}

/**
 * Wizard
 */
.c-wizard {
  margin-bottom: 3rem;
}
@media print, screen and (min-width: 768px) {
  .c-wizard {
    margin-top: 3rem;
  }
}
.c-wizard .c-wizard__steps {
  display: table;
  list-style: none;
  position: relative;
  width: 100%;
  margin: 0 0 20px;
}
.c-wizard .c-wizard__steps li {
  display: table-cell;
  text-align: center;
}
.c-wizard .c-wizard__steps li a {
  display: block;
  position: relative;
  -moz-opacity: 1;
  filter: alpha(opacity=100);
  opacity: 1;
  color: #666;
  cursor: default;
}
.c-wizard .c-wizard__steps li a:before {
  content: "";
  position: absolute;
  height: 4px;
  background: #ccc;
  top: 13px;
  width: 100%;
  z-index: 4;
  left: 0;
}
.c-wizard .c-wizard__steps li a .c-wizard__step-no {
  width: 30px;
  height: 30px;
  line-height: 30px;
  border-radius: 100px;
  display: block;
  margin: 0 auto 5px;
  font-size: 14px;
  color: #fff;
  text-align: center;
  position: relative;
  z-index: 5;
}
.c-wizard .c-wizard__steps li a.c-wizard__step--disabled .c-wizard__step-no {
  background: #ccc;
}
.c-wizard .c-wizard__steps li a.c-wizard__step--selected:before, .c-wizard .c-wizard__steps li a.c-wizard__step--selected .c-wizard__step-no {
  background: #34495E;
}
.c-wizard .c-wizard__steps li a .c-wizard__step-nm {
  font-size: 85%;
}
.c-wizard .c-wizard__steps li:first-child a:before {
  left: 50%;
}
.c-wizard .c-wizard__steps li:last-child a:before {
  right: 50%;
  width: 50%;
  left: auto;
}
.c-wizard.c-wizard--col-3 li {
  width: 33.3%;
}

/**
 * slide
 */
/*==================================
* コンテナ
==================================*/
.c-slide__container {
  margin: 0 10px;
  padding: 0;
  background-color: #ffffff;
  border-radius: 5px;
  box-shadow: 0 0 15px 3px rgba(118, 118, 118, 0.5);
}
.c-slide__container .c-slide__container__title {
  padding: 10px 0;
  text-align: center;
  line-height: 1.4;
  font-size: 2rem;
  font-weight: bold;
  color: #ffffff;
  background-color: #044E80;
  border-radius: 5px 5px 0 0;
}
.c-slide__container .c-slide__container__body {
  padding: 50px 15px 20px 15px;
}
@media print, screen and (min-width: 768px) {
  .c-slide__container {
    max-width: 1140px;
    margin: 0 auto;
  }
  .c-slide__container .c-slide__container__title {
    padding: 25px 0;
    font-size: 3.2rem;
  }
  .c-slide__container .c-slide__container__body {
    padding: 80px 50px 50px 50px;
  }
}

/*==================================
* スライド（テキスト＋画像）
==================================*/
.c-slide--type01 .c-slide__inner {
  margin-bottom: 30px;
}
.c-slide--type01 .c-slide__image img {
  width: 100%;
  height: auto;
  margin-bottom: 30px;
}
.c-slide--type01 .c-slide__image--col-2 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}
.c-slide--type01 .c-slide__image--col-2 img {
  width: 48%;
  height: auto;
  margin-bottom: 30px;
}
.c-slide--type01 .c-slide__block .c-slide__title {
  margin: 20px auto;
  text-align: center;
  line-height: 1.4;
  font-size: 2.2rem;
  font-weight: bold;
  color: #044E80;
}
@media print, screen and (min-width: 768px) {
  .c-slide--type01 .c-slide__inner {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    margin-bottom: 50px;
  }
  .c-slide--type01 .c-slide__inner .c-slide__image,
  .c-slide--type01 .c-slide__inner .c-slide__image--col-2 {
    width: 45%;
  }
  .c-slide--type01 .c-slide__inner .c-slide__block {
    width: 55%;
  }
  .c-slide--type01 .c-slide__inner .c-slide__block .c-slide__title {
    margin: 0 0 30px 0;
    text-align: left;
    font-size: 2.6rem;
  }
}

/* block
----------------------------------------------------------------- */
/**
 * point
 */
/* type01
 ======================= */
.b-point--type01 {
  margin: 0 10px;
}
.b-point--type01 .b-point__card {
  padding: 20px 15px;
  margin-bottom: 50px;
  background-color: #ffffff;
  border-radius: 5px;
  box-shadow: 0 0 15px 3px rgba(118, 118, 118, 0.5);
}
.b-point--type01 .b-point__card:last-child {
  margin-bottom: 30px;
}
.b-point--type01 .b-point__card__header {
  margin-bottom: 30px;
}
.b-point--type01 .b-point__card__no {
  display: block;
  font-size: 5rem;
  font-weight: 900;
  letter-spacing: 0.3rem;
  color: #044E80;
}
.b-point--type01 .b-point__card__title {
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 1.5;
}
.b-point--type01 .b-point__card__about {
  margin-bottom: 50px;
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .b-point--type01 {
    max-width: 1140px;
    margin: 0 auto;
  }
  .b-point--type01 .b-point__card {
    padding: 70px 60px;
    margin-bottom: 80px;
  }
  .b-point--type01 .b-point__card__header {
    display: flex;
    margin-bottom: 40px;
  }
  .b-point--type01 .b-point__card__no {
    display: inline-block;
    font-size: 9rem;
    line-height: 1;
  }
  .b-point--type01 .b-point__card__title {
    font-size: 3rem;
    margin-left: 20px;
  }
  .b-point--type01 .b-point__card__about {
    font-size: 1.8rem;
  }
}

/* type02
 ======================= */
.b-point--type02 {
  margin: 0 10px;
}
.b-point--type02 .b-point__card {
  margin-bottom: 50px;
  background-color: #ffffff;
  border-radius: 5px;
  box-shadow: 0 0 15px 3px rgba(118, 118, 118, 0.5);
}
.b-point--type02 .b-point__card:last-child {
  margin-bottom: 30px;
}
.b-point--type02 .b-point__card__header {
  padding: 20px 0;
  text-align: center;
  background-color: #044E80;
  border-radius: 5px 5px 0 0;
}
.b-point--type02 .b-point__card__no {
  display: inline-block;
  padding: 10px 30px;
  background: #fff;
  border-radius: 30px;
  font-size: 1.8rem;
  font-weight: bold;
  color: #044E80;
  text-align: center;
  margin: 0 10px 10px 0;
}
.b-point--type02 .b-point__card__title {
  line-height: 1.4;
  font-size: 2rem;
  font-weight: bold;
  color: #ffffff;
}
.b-point--type02 .b-point__card__body {
  padding: 50px 15px 20px 15px;
}
@media print, screen and (min-width: 768px) {
  .b-point--type02 {
    max-width: 1140px;
    margin: 0 auto;
  }
  .b-point--type02 .b-point__card {
    margin-bottom: 80px;
  }
  .b-point--type02 .b-point__card__header {
    padding: 25px 0;
  }
  .b-point--type02 .b-point__card__no {
    font-size: 2rem;
    margin: 0 20px 0 0;
    vertical-align: middle;
  }
  .b-point--type02 .b-point__card__title {
    display: inline-block;
    font-size: 3.2rem;
    vertical-align: middle;
  }
  .b-point--type02 .b-point__card__body {
    padding: 80px 50px 50px 50px;
  }
}

/* Project
----------------------------------------------------------------- */
/* cms */
/**
 * TradeCore
 */
/*==================================
* パンくずリスト
==================================*/
._tc-breadcrumb {
  display: none;
}
@media print, screen and (min-width: 768px) {
  ._tc-breadcrumb {
    display: block;
    box-sizing: border-box;
    width: 1140px;
    margin: 0 auto;
    padding: 5px 0;
  }
}

/* contents */
/**
 * charge-initial
 */
/* ━━━━━━━━━━━━━━━━

 ■ プロジェクト

━━━━━━━━━━━━━━━━ */
/*=================================
* トップ
=================================*/
/*
　サンプルから選んで制作を依頼する
=================================*/
.p-charge-initial__sample {
  margin-bottom: 80px;
}
@media print, screen and (min-width: 768px) {
  .p-charge-initial__sample {
    margin-bottom: 100px;
  }
}

/*
　初期費用
=================================*/
.p-charge-initial__price {
  text-align: center;
  font-size: 20px;
  color: #333;
  margin: 25px 0;
}
.p-charge-initial__price span {
  font-size: 34px;
  font-weight: bold;
  margin-left: 10px;
}
@media print, screen and (min-width: 768px) {
  .p-charge-initial__price {
    margin: 25px auto 25px 80px;
    text-align: left;
    font-size: 34px;
  }
  .p-charge-initial__price span {
    font-size: 50px;
    margin-left: 15px;
  }
}

.p-charge-initial__guide .p-charge-initial__guide__title {
  font-size: 1.7rem;
  font-weight: bold;
  margin-bottom: 10px;
}

/*
　おすすめポイント
=================================*/
.p-charge-initial__point {
  text-align: center;
  margin-bottom: 30px;
}
.p-charge-initial__point .p-charge-initial__point__title {
  font-size: 2.6rem;
  font-weight: bold;
  margin-bottom: 15px;
}
.p-charge-initial__point .p-charge-initial__point__text {
  font-size: 1.8rem;
}
.p-charge-initial__point .p-charge-initial__point__text span {
  color: #dc3545;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-charge-initial__point .p-charge-initial__point__text {
    font-size: 2.2rem;
  }
}

/**
 * charge-price
 */
/* ━━━━━━━━━━━━━━━━

 ■ プロジェクト

━━━━━━━━━━━━━━━━ */
/*=================================
* トップ
=================================*/
/*
　最上部
=================================*/
.p-charge-price__top--info {
  margin-bottom: 50px;
  text-align: center;
  font-size: 2rem;
}

.p-charge-price__text--strong {
  font-size: 2.5rem;
  color: #dc3545;
  font-weight: bold;
}

/*
　月額
=================================*/
.p-charge-price__monthly--tbl table {
  width: 100%;
  border-collapse: collapse;
  border: none;
  box-sizing: border-box;
}
.p-charge-price__monthly--tbl th, .p-charge-price__monthly--tbl td {
  font-size: 1.5rem;
  padding: 10px 5px;
  text-align: center;
}
.p-charge-price__monthly--tbl th {
  background-color: #F9F9F9;
  border: 1px solid #666;
}
.p-charge-price__monthly--tbl td {
  border: 1px solid #666;
  background-color: #FFF;
}
.p-charge-price__monthly--tbl .p-charge-price__monthly--type1 {
  width: 38%;
  background-color: #deeaf7;
  font-weight: bold;
  color: #666;
}
.p-charge-price__monthly--tbl .p-charge-price__monthly--type2 {
  width: 38%;
  background-color: #fce2cc;
  font-weight: bold;
  color: #666;
}
@media print, screen and (min-width: 768px) {
  .p-charge-price__monthly--tbl th, .p-charge-price__monthly--tbl td {
    font-size: 1.7rem;
    padding: 15px 10px;
    text-align: center;
  }
  .p-charge-price__monthly--tbl .p-charge-price__monthly--type1,
  .p-charge-price__monthly--tbl .p-charge-price__monthly--type2 {
    font-size: 2.5rem;
  }
  .p-charge-price__monthly--tbl .p-charge-price__monthly--type2 {
    line-height: 1.1;
  }
}

/*
　月額料金の例
=================================*/
.p-charge-price__example .p-charge-price__example__unit {
  margin-bottom: 50px;
  text-align: center;
}
.p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__title {
  margin-bottom: 15px;
  font-size: 2rem;
  font-weight: bold;
  color: #044E80;
}
.p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__detail {
  margin-bottom: 20px;
}
.p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__detail h4 {
  margin-bottom: 15px;
  font-size: 1.8rem;
  font-weight: bold;
}
.p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__detail p {
  font-size: 1.6rem;
}
.p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__image img {
  display: block;
  width: 200px;
  height: auto;
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  .p-charge-price__example {
    display: flex;
    justify-content: space-around;
  }
  .p-charge-price__example .p-charge-price__example__unit {
    width: 45%;
  }
  .p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__title {
    margin-bottom: 20px;
    font-size: 2.2rem;
  }
  .p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__detail {
    margin-bottom: 30px;
  }
  .p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__detail h4 {
    margin-bottom: 20px;
    font-size: 2rem;
  }
  .p-charge-price__example .p-charge-price__example__unit .p-charge-price__example__image img {
    width: 250px;
  }
}

/**
 * pricing
 */
/* ━━━━━━━━━━━━━━━━

 ■ プロジェクト

━━━━━━━━━━━━━━━━ */
/*=================================
* トップ
=================================*/
/*
　顧客の声
=================================*/
@media print, screen and (min-width: 768px) {
  .p-charge-pricing__voice {
    width: 92%;
    margin: 0 auto;
  }
}

/**
 * Estate
 */
/* ━━━━━━━━━━━━━━━━

 ■ プロジェクト

━━━━━━━━━━━━━━━━ */
/*=================================
* トップ
=================================*/
/*
　背景あり注意書き
=================================*/
.p-estate__caution {
  padding: 10px;
  background-color: #E6EDF2;
  color: #044E80;
  font-weight: 600;
}
@media print, screen and (min-width: 768px) {
  .p-estate__caution {
    padding: 15px;
  }
}

/**
 * guide
 */
/* ━━━━━━━━━━━━━━━━

 ■ プロジェクト

━━━━━━━━━━━━━━━━ */
/*=================================
* トップ
=================================*/
/*
　目次
=================================*/
.p-guide__toc {
  padding: 20px 5px;
}
.p-guide__toc .p-guide__toc__inner {
  padding: 15px 10px 0 10px;
  border: solid 1px #d3d3d3;
}
.p-guide__toc .p-guide__toc__inner .p-guide__toc__title {
  margin-bottom: 10px;
  padding-bottom: 5px;
  padding-left: 5px;
  font-size: 1.8rem;
  font-weight: bold;
  border-bottom: solid 2px #5e5e5e;
}
.p-guide__toc .p-guide__toc__inner .p-guide__toc__list {
  padding: 10px;
}
.p-guide__toc .p-guide__toc__inner .p-guide__toc__list > li {
  margin-bottom: 15px;
  margin-left: 20px;
  list-style: auto;
  font-size: 1.8rem;
  font-weight: bold;
  color: #044E80;
}
.p-guide__toc .p-guide__toc__inner .p-guide__toc__list > li > a {
  padding-bottom: 1px;
  color: #044E80;
  border-bottom: solid 1px #044E80;
}
.p-guide__toc .p-guide__toc__inner .p-guide__toc__list > li .p-guide__toc__list__child > li {
  margin: 3px 10px 3px 20px;
  list-style: auto;
  color: #333;
  font-weight: normal;
}
.p-guide__toc .p-guide__toc__inner .p-guide__toc__list > li .p-guide__toc__list__child > li a {
  display: inline;
  font-size: 1.6rem;
  font-weight: bold;
  color: #333;
  border-bottom: solid 1px #333;
}
@media screen and (min-width: 768px) {
  .p-guide__toc {
    max-width: 900px;
    margin: 0 auto;
    padding: 30px 50px;
  }
  .p-guide__toc .p-guide__toc__inner {
    padding: 30px 40px;
  }
  .p-guide__toc .p-guide__toc__inner .p-guide__toc__title {
    font-size: 2rem;
  }
  .p-guide__toc .p-guide__toc__inner .p-guide__toc__list {
    padding: 10px 20px;
  }
  .p-guide__toc .p-guide__toc__inner .p-guide__toc__list > li {
    margin-bottom: 20px;
    font-size: 2rem;
  }
  .p-guide__toc .p-guide__toc__inner .p-guide__toc__list > li .p-guide__toc__list__child > li {
    margin: 7px 10px 7px 30px;
    font-size: 1.6rem;
  }
}

/*
　追従ボタン
=================================*/
.p-guide__follow-button {
  background: #03967a;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  text-align: center;
  position: fixed;
  bottom: 20px;
  right: -100%;
  z-index: 20000;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  transition-duration: 0.5s;
}
.p-guide__follow-button.is-show {
  right: 16px;
}
.p-guide__follow-button a {
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.7;
}
.p-guide__follow-button a:hover {
  opacity: 1;
}
.p-guide__follow-button a i {
  font-size: 26px;
}
@media print, screen and (min-width: 768px) {
  .p-guide__follow-button {
    bottom: 60px;
  }
}

/*
　分類用タイトル
=================================*/
.p-guide__category__title {
  padding: 70px 0 20px 0;
}
.p-guide__category__title h2 {
  text-align: center;
  line-height: 1.5;
  font-size: 2.4rem;
  font-weight: 900;
  color: #044E80;
}
@media print, screen and (min-width: 768px) {
  .p-guide__category__title {
    padding: 100px 0 20px 0;
  }
  .p-guide__category__title h2 {
    font-size: clamp(3rem, 2.8vw, 4rem);
  }
}

/*
　チェックリスト
=================================*/
.p-guide__renewal .c-list__check--sm-black,
.p-guide__transfer .c-list__check--sm-black,
.p-guide__self-build .c-list__check--sm-black,
.p-guide__design .c-list__check--sm-black,
.p-guide__startup-design .c-list__check--sm-black,
.p-guide__startup-self .c-list__check--sm-black {
  display: table;
  padding: 0 15px;
  text-align: left;
}
.p-guide__renewal .c-list__check--sm-black li,
.p-guide__transfer .c-list__check--sm-black li,
.p-guide__self-build .c-list__check--sm-black li,
.p-guide__design .c-list__check--sm-black li,
.p-guide__startup-design .c-list__check--sm-black li,
.p-guide__startup-self .c-list__check--sm-black li {
  font-size: 2rem;
}
@media print, screen and (min-width: 768px) {
  .p-guide__renewal .c-list__check--sm-black li,
  .p-guide__transfer .c-list__check--sm-black li,
  .p-guide__self-build .c-list__check--sm-black li,
  .p-guide__design .c-list__check--sm-black li,
  .p-guide__startup-design .c-list__check--sm-black li,
  .p-guide__startup-self .c-list__check--sm-black li {
    font-size: 2.6rem;
    background-position: left;
  }
}

/*
　サービス説明
=================================*/
.p-guide__service__unit {
  margin: 0 0 50px 0;
  padding: 0;
  background-color: #ffffff;
  border-radius: 5px;
  box-shadow: 0 0 15px 3px rgba(118, 118, 118, 0.5);
}
.p-guide__service__unit .p-guide__service__title {
  padding: 10px;
  text-align: center;
  line-height: 1.5;
  font-size: 2rem;
  font-weight: bold;
  color: #ffffff;
  background-color: #044E80;
  border-radius: 5px 5px 0 0;
}
.p-guide__service__unit .p-guide__service__body {
  padding: 30px 15px;
}
@media print, screen and (min-width: 768px) {
  .p-guide__service__unit {
    margin: 0;
  }
  .p-guide__service__unit .p-guide__service__title {
    padding: 20px;
  }
}

/*
　2column
=================================*/
@media print, screen and (min-width: 768px) {
  .p-guide__service--col2 {
    display: flex;
    justify-content: space-between;
    max-width: 1140px;
  }
  .p-guide__service--col2 .p-guide__service__unit {
    width: 48%;
  }
  .p-guide__service--col2 .p-guide__service__unit .p-guide__service__title {
    font-size: 2.6rem;
  }
  .p-guide__service--col2 .p-guide__service__unit .p-guide__service__body {
    padding: 60px 40px;
  }
}

/*
　3column
=================================*/
@media print, screen and (min-width: 768px) {
  .p-guide__service--col3 {
    display: flex;
    justify-content: space-between;
    max-width: 1140px;
  }
  .p-guide__service--col3 .p-guide__service__unit {
    width: 31%;
  }
  .p-guide__service--col3 .p-guide__service__unit .p-guide__service__title {
    padding: 20px;
    font-size: 2.2rem;
  }
  .p-guide__service--col3 .p-guide__service__unit .p-guide__service__body {
    padding: 40px 20px;
  }
}

/*
　活用例
=================================*/
.p-guide__renewal__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title,
.p-guide__transfer__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title,
.p-guide__self-build__usage-example--introduction .c-pc-case li .c-pc-case__header .c-pc-case__title,
.p-guide__design__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title {
  padding-left: 0;
}
@media print, screen and (min-width: 768px) {
  .p-guide__renewal__usage-example .c-pc-case,
  .p-guide__transfer__usage-example .c-pc-case,
  .p-guide__self-build__usage-example--introduction .c-pc-case,
  .p-guide__design__usage-example .c-pc-case {
    display: flex;
    justify-content: space-between;
    padding: 0 8px;
  }
  .p-guide__renewal__usage-example .c-pc-case li,
  .p-guide__transfer__usage-example .c-pc-case li,
  .p-guide__self-build__usage-example--introduction .c-pc-case li,
  .p-guide__design__usage-example .c-pc-case li {
    width: 41%;
    margin-bottom: 0;
  }
  .p-guide__renewal__usage-example .c-pc-case li .c-pc-case__header,
  .p-guide__transfer__usage-example .c-pc-case li .c-pc-case__header,
  .p-guide__self-build__usage-example--introduction .c-pc-case li .c-pc-case__header,
  .p-guide__design__usage-example .c-pc-case li .c-pc-case__header {
    margin-bottom: 20px;
  }
  .p-guide__renewal__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title dl,
  .p-guide__transfer__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title dl,
  .p-guide__self-build__usage-example--introduction .c-pc-case li .c-pc-case__header .c-pc-case__title dl,
  .p-guide__design__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title dl {
    margin-bottom: 10px;
  }
  .p-guide__renewal__usage-example .c-pc-case li:nth-child(2),
  .p-guide__transfer__usage-example .c-pc-case li:nth-child(2),
  .p-guide__self-build__usage-example--introduction .c-pc-case li:nth-child(2),
  .p-guide__design__usage-example .c-pc-case li:nth-child(2) {
    margin-left: 20px;
  }
}

.p-guide__self-build__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title {
  padding-left: 0;
}
@media print, screen and (min-width: 768px) {
  .p-guide__self-build__usage-example .c-pc-case {
    display: flex;
    justify-content: center;
    padding: 0 8px;
  }
  .p-guide__self-build__usage-example .c-pc-case li {
    width: 100%;
    margin-bottom: 0;
  }
  .p-guide__self-build__usage-example .c-pc-case li .c-pc-case__header {
    margin-bottom: 20px;
  }
  .p-guide__self-build__usage-example .c-pc-case li .c-pc-case__header .c-pc-case__title dl {
    margin-bottom: 10px;
  }
}

.p-guide__self-build__usage-example--introduction .c-pc-case li {
  width: unset;
}

/*
　提言タイトル
=================================*/
.p-guide__proposal__title {
  margin-bottom: 20px;
  text-align: center;
  line-height: 1.5;
  font-size: 2.2rem;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-guide__proposal__title {
    font-size: 3rem;
  }
}

/*
　エントリーボタン
=================================*/
.p-guide__renewal .c-button-container,
.p-guide__self-build .c-button-container {
  padding: 35px 0 50px 0;
}
.p-guide__renewal .c-button-container .c-pc-entry-button__bubble--orange,
.p-guide__self-build .c-button-container .c-pc-entry-button__bubble--orange {
  padding: 30px 70px 25px 70px;
}
.p-guide__renewal .c-button-container .c-pc-entry-button__bubble--orange span,
.p-guide__self-build .c-button-container .c-pc-entry-button__bubble--orange span {
  top: -35px;
  left: calc(50% - 122px);
  width: 240px;
}
@media print, screen and (min-width: 768px) {
  .p-guide__renewal .c-button-container,
  .p-guide__self-build .c-button-container {
    padding: 80px 0;
  }
}

/*
　デザインサンプル
=================================*/
.p-guide__renewal__sample__design h3 {
  margin-bottom: 30px;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
}
.p-guide__renewal__sample__design .p-guide__renewal__sample__design__group {
  margin-bottom: 45px;
}
.p-guide__renewal__sample__design .p-guide__renewal__sample__design__group .p-guide__renewal__sample__design__unit {
  margin-bottom: 40px;
  text-align: center;
}
.p-guide__renewal__sample__design .p-guide__renewal__sample__design__group .p-guide__renewal__sample__design__unit:last-child {
  margin-bottom: 0;
}
.p-guide__renewal__sample__design .p-guide__renewal__sample__design__group .p-guide__renewal__sample__design__unit .p-guide__renewal__sample__design__label {
  display: inline-block;
  margin-bottom: 15px;
  padding: 5px 10px;
  font-size: 1.6rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: #044E80;
}
.p-guide__renewal__sample__design .p-guide__renewal__sample__design__group .p-guide__renewal__sample__design__unit .p-guide__renewal__sample__design__image img {
  display: block;
  margin: 0 auto;
  border: solid 1px #d8d8d8;
}
.p-guide__renewal__sample__design p {
  line-height: 1.75;
  text-align: center;
  font-size: 1.8rem;
}
.p-guide__renewal__sample__design p span {
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-guide__renewal__sample__design h3 {
    margin-bottom: 40px;
    font-size: 2.4rem;
  }
  .p-guide__renewal__sample__design .p-guide__renewal__sample__design__group {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 0;
  }
  .p-guide__renewal__sample__design .p-guide__renewal__sample__design__group .p-guide__renewal__sample__design__unit {
    width: 47%;
  }
  .p-guide__renewal__sample__design .p-guide__renewal__sample__design__group .p-guide__renewal__sample__design__unit .p-guide__renewal__sample__design__label {
    font-size: 1.8rem;
  }
  .p-guide__renewal__sample__design p {
    font-size: 2rem;
  }
}

/*
　集客専用ページ
=================================*/
.p-guide__renewal__lp {
  text-align: center;
}
.p-guide__renewal__lp .p-guide__renewal__lp__text {
  margin-bottom: 20px;
}
.p-guide__renewal__lp .p-guide__renewal__lp__text h3 {
  margin-bottom: 15px;
  font-size: 2rem;
  font-weight: bold;
}
.p-guide__renewal__lp .p-guide__renewal__lp__text p {
  line-height: 1.75;
  font-size: 1.8rem;
}
.p-guide__renewal__lp .p-guide__renewal__lp__text p span {
  font-weight: bold;
}
.p-guide__renewal__lp .p-guide__renewal__lp__image img {
  display: block;
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  .p-guide__renewal__lp .p-guide__renewal__lp__text {
    margin-bottom: 50px;
  }
  .p-guide__renewal__lp .p-guide__renewal__lp__text h3 {
    margin-bottom: 20px;
    font-size: 2.4rem;
  }
  .p-guide__renewal__lp .p-guide__renewal__lp__text p {
    font-size: 2rem;
  }
}

/*
　導入事例
=================================*/
.p-guide__case .p-guide__case__unit {
  margin: 0 0 50px 0;
  padding: 30px 20px;
  border-radius: 5px;
  background: #fff;
  box-shadow: 0 0 15px 3px rgba(118, 118, 118, 0.4);
}
.p-guide__case .p-guide__case__unit .p-guide__case__title {
  margin-bottom: 20px;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
}
.p-guide__case .p-guide__case__unit .p-guide__case__body .p-guide__case__image {
  margin-bottom: 20px;
}
.p-guide__case .p-guide__case__unit .p-guide__case__body .p-guide__case__image img {
  display: block;
  margin: 0 auto;
}
.p-guide__case .p-guide__case__unit .p-guide__case__body .p-guide__case__text {
  margin-bottom: 20px;
}
.p-guide__case .p-guide__case__unit .p-guide__case__body .p-guide__case__text p {
  font-size: 1.6rem;
}
.p-guide__case .p-guide__case__unit .p-guide__case__foot {
  text-align: right;
}
.p-guide__case .p-guide__case__unit .p-guide__case__foot a {
  text-decoration: none;
  font-size: 1.6rem;
  font-weight: bold;
  color: #044E80;
}
@media print, screen and (min-width: 768px) {
  .p-guide__case {
    display: flex;
    justify-content: space-between;
  }
  .p-guide__case .p-guide__case__unit {
    width: 41%;
    margin: 0;
    padding: 50px 40px;
  }
  .p-guide__case .p-guide__case__unit .p-guide__case__title {
    margin-bottom: 30px;
    font-size: 2.4rem;
  }
  .p-guide__case .p-guide__case__unit .p-guide__case__body .p-guide__case__image {
    width: 80%;
    margin: 0 auto 30px auto;
  }
  .p-guide__case .p-guide__case__unit .p-guide__case__body .p-guide__case__text {
    margin-bottom: 30px;
  }
  .p-guide__case .p-guide__case__unit .p-guide__case__body .p-guide__case__text p {
    font-size: 1.8rem;
  }
  .p-guide__case .p-guide__case__unit:nth-child(2) {
    margin-left: 32px;
  }
}

/*
　乗り換えのポイント
=================================*/
.p-guide__transfer__point .p-guide__transfer__point__image {
  margin-bottom: 20px;
}
.p-guide__transfer__point .p-guide__transfer__point__image img {
  display: block;
  margin: 0 auto;
}
.p-guide__transfer__point .p-guide__transfer__point__text {
  line-height: 1.75;
  font-size: 1.8rem;
}
.p-guide__transfer__point .p-guide__transfer__point__text span {
  display: inline;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-guide__transfer__point .p-guide__transfer__point__image {
    margin-bottom: 30px;
  }
  .p-guide__transfer__point .p-guide__transfer__point__text {
    font-size: 2rem;
  }
}

/*
　エントリーボタン
=================================*/
.p-guide__transfer__entry .p-guide__transfer__entry__unit {
  width: 100%;
  margin: 0 auto 50px auto;
  background: #fff;
}
.p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__title h2 {
  padding: 15px 10px;
  text-align: center;
  font-size: 2.2rem;
  font-weight: bold;
  color: #fff;
  background-color: #044E80;
}
.p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__body {
  padding: 30px 35px;
}
.p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__body p {
  margin-bottom: 10px;
  text-align: center;
  font-size: 1.8rem;
}
.p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__body .c-list__check--sm-black {
  margin-bottom: 30px;
}
.p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__body .c-list__check--sm-black li {
  font-size: 1.8rem;
}
.p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__button a {
  display: block;
  margin: 0 auto;
  padding: 15px 10px;
  text-align: center;
  font-size: 1.8rem;
  font-weight: bold;
  color: #fff;
  border-radius: 5px;
  background: #FEB808;
}
@media print, screen and (min-width: 768px) {
  .p-guide__transfer__entry {
    display: flex;
    justify-content: space-between;
  }
  .p-guide__transfer__entry .p-guide__transfer__entry__unit {
    width: 48%;
    margin: 0;
  }
  .p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__title h2 {
    padding: 20px 10px;
    font-size: 2.6rem;
  }
  .p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__body p {
    font-size: 2.2rem;
  }
  .p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__body .c-list__check--sm-black {
    margin-top: 30px;
  }
  .p-guide__transfer__entry .p-guide__transfer__entry__unit .p-guide__transfer__entry__body .c-list__check--sm-black li {
    font-size: 2rem;
  }
}

/*
　制作を依頼するポイント
=================================*/
.p-guide__design__point .p-guide__design__point__image {
  margin-bottom: 20px;
}
.p-guide__design__point .p-guide__design__point__image img {
  display: block;
  margin: 0 auto;
}
.p-guide__design__point .p-guide__design__point__text {
  line-height: 1.75;
  font-size: 1.8rem;
}
.p-guide__design__point .p-guide__design__point__text span {
  display: inline;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-guide__design__point .p-guide__design__point__image {
    margin-bottom: 30px;
  }
  .p-guide__design__point .p-guide__design__point__text {
    font-size: 2rem;
  }
}

/*
　エントリーボタン
=================================*/
.p-guide__design .c-button-container {
  padding: 35px 0 100px 0;
}
.p-guide__design .c-button-container .c-pc-entry-button__bubble--orange {
  padding: 30px 70px 25px 70px;
}
.p-guide__design .c-button-container .c-pc-entry-button__bubble--orange span {
  top: -35px;
  left: calc(50% - 122px);
  width: 240px;
}

/*
　自分で作成するポイント
=================================*/
.p-guide__self-build__point .p-guide__self-build__point__image {
  margin-bottom: 20px;
}
.p-guide__self-build__point .p-guide__self-build__point__image img {
  display: block;
  margin: 0 auto;
}
.p-guide__self-build__point .p-guide__self-build__point__text {
  line-height: 1.75;
  font-size: 1.8rem;
}
.p-guide__self-build__point .p-guide__self-build__point__text span {
  display: inline;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-guide__self-build__point .p-guide__self-build__point__image {
    margin-bottom: 30px;
  }
  .p-guide__self-build__point .p-guide__self-build__point__text {
    font-size: 2rem;
  }
}

/*
　開業の制作を依頼するポイント
=================================*/
.p-guide__startup-design__point .p-guide__startup-design__point__image {
  margin-bottom: 20px;
}
.p-guide__startup-design__point .p-guide__startup-design__point__image img {
  display: block;
  height: 170px;
  margin: 0 auto;
}
.p-guide__startup-design__point .p-guide__startup-design__point__text {
  line-height: 1.75;
  font-size: 1.8rem;
}
.p-guide__startup-design__point .p-guide__startup-design__point__text span {
  display: inline;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-guide__startup-design__point .p-guide__startup-design__point__image {
    margin-bottom: 30px;
  }
  .p-guide__startup-design__point .p-guide__startup-design__point__image img {
    height: 250px;
  }
  .p-guide__startup-design__point .p-guide__startup-design__point__text {
    font-size: 2rem;
  }
}

/*
　エントリーボタン
=================================*/
.p-guide__startup-design .c-button-container {
  padding: 60px 0 50px 0;
}
.p-guide__startup-design .c-button-container .c-pc-entry-button__bubble--orange {
  padding: 30px 90px 25px 90px;
}
.p-guide__startup-design .c-button-container .c-pc-entry-button__bubble--orange span {
  top: -60px;
  left: calc(50% - 159px);
  width: 315px;
}
@media print, screen and (min-width: 768px) {
  .p-guide__startup-design .c-button-container {
    padding: 60px 0 0 0;
  }
}

/*
　印象付けタイトル
=================================*/
.p-guide__impress__title {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 40px;
  text-align: center;
  font-size: 2.6rem;
  font-weight: bold;
}
.p-guide__impress__title::before, .p-guide__impress__title::after {
  content: "";
  width: 5px;
  height: 35px;
  background-color: #044E80;
}
.p-guide__impress__title::before {
  margin-right: 25px;
  transform: rotate(-25deg);
}
.p-guide__impress__title::after {
  margin-left: 25px;
  transform: rotate(25deg);
}
@media print, screen and (min-width: 768px) {
  .p-guide__impress__title {
    margin-bottom: 60px;
    font-size: 4rem;
  }
  .p-guide__impress__title::before, .p-guide__impress__title::after {
    height: 50px;
  }
}

/*
　開業者（自分で作成する）
=================================*/
.l-section.p-guide__startup-self {
  padding-top: 0;
}
@media print, screen and (min-width: 768px) {
  .l-section.p-guide__startup-self {
    padding-bottom: 120px;
  }
}

/* ポイント */
.p-guide__startup-self__point .p-guide__startup-self__point__image {
  margin-bottom: 20px;
}
.p-guide__startup-self__point .p-guide__startup-self__point__image img {
  display: block;
  margin: 0 auto;
}
.p-guide__startup-self__point .p-guide__startup-self__point__text {
  line-height: 1.75;
  font-size: 1.8rem;
}
.p-guide__startup-self__point .p-guide__startup-self__point__text span {
  display: inline;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-guide__startup-self__point .p-guide__startup-self__point__image {
    margin-bottom: 30px;
  }
  .p-guide__startup-self__point .p-guide__startup-self__point__text {
    font-size: 2rem;
  }
}

/* エントリーボタン */
.p-guide__startup-self .c-button-container {
  padding: 35px 0 100px 0;
}
.p-guide__startup-self .c-button-container .c-pc-entry-button__bubble--orange {
  padding: 30px 70px 25px 70px;
}
.p-guide__startup-self .c-button-container .c-pc-entry-button__bubble--orange span {
  top: -35px;
  left: calc(50% - 122px);
  width: 240px;
}

/* ━━━━━━━━━━━━━━━━

 ■hp_function

━━━━━━━━━━━━━━━━ */
/*==================================
* 機能
==================================*/
.p-main__function ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  margin-bottom: 30px;
}
.p-main__function ul li {
  width: 30%;
  margin-bottom: 20px;
  text-align: center;
}
.p-main__function ul li img {
  margin-bottom: 5px;
}
@media print, screen and (min-width: 768px) {
  .p-main__function ul {
    max-width: 1140px;
    margin-bottom: 80px;
  }
  .p-main__function ul li {
    width: 13%;
    font-size: 16px;
    margin-bottom: 0;
  }
  .p-main__function ul li img {
    margin-bottom: 10px;
  }
}

/* seo
 ======================= */
.p-seo__block {
  margin-bottom: 30px;
}
.p-seo__block .p-seo__block__point {
  margin-bottom: 30px;
}
.p-seo__block .p-seo__block__point h3 {
  margin-bottom: 20px;
  font-size: 1.8rem;
  font-weight: bold;
  color: #044E80;
}
.p-seo__block .p-seo__block__point p {
  margin-bottom: 5px;
  font-size: 1.6rem;
}
.p-seo__block .p-seo__image {
  margin-bottom: 30PX;
  text-align: center;
}
.p-seo__block .p-seo__example {
  margin-bottom: 30px;
  padding: 15px 10px;
  border: solid 1px #cccccc;
  font-size: 1.6rem;
}
.p-seo__block .p-seo__example .p-seo__example__title {
  margin-bottom: 10px;
}
.p-seo__block .p-seo__example .p-seo__example__text p {
  margin-bottom: 5px;
}
.p-seo__block .p-seo__block__text {
  margin-bottom: 20px;
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .p-seo__block .p-seo__block__point {
    margin-bottom: 50px;
  }
  .p-seo__block .p-seo__block__point h3 {
    margin-bottom: 30px;
    text-align: center;
    font-size: 2.8rem;
  }
  .p-seo__block .p-seo__block__point p {
    margin-bottom: 10px;
    text-align: center;
    font-size: 2.2rem;
  }
  .p-seo__block .p-seo__image {
    margin-bottom: 50px;
  }
  .p-seo__block .p-seo__example {
    width: 65%;
    margin: 0 auto 50px auto;
    padding: 30px 50px;
    font-size: 1.8rem;
  }
  .p-seo__block .p-seo__example .p-seo__example__title {
    margin-bottom: 20px;
  }
  .p-seo__block .p-seo__block__text {
    margin-bottom: 30px;
    text-align: center;
    font-size: 1.8rem;
  }
  .p-seo__block .p-seo__block__text p {
    margin-bottom: 5px;
  }
}

/* article type02
======================= */
.p-pc-article__list--type02 li {
  margin-bottom: 30px;
}
.p-pc-article__list--type02 li a {
  display: block;
  box-shadow: 0 1px 8px rgba(0, 0, 0, 0.2);
  transition: box-shadow 0.1s ease-in;
  border-radius: 7px;
  box-sizing: border-box;
}
.p-pc-article__list--type02 li a .p-pc-article__list__image img {
  display: block;
  width: 100%;
  height: 200px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 7px 7px 0 0;
}
.p-pc-article__list--type02 li a .p-pc-article__list__content {
  padding: 20px 15px;
}
.p-pc-article__list--type02 li a .p-pc-article__list__content h3 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin-bottom: 10px;
  font-weight: bold;
  color: #333;
}
.p-pc-article__list--type02 li a .p-pc-article__list__content p {
  color: #777;
}
@media print, screen and (min-width: 768px) {
  .p-pc-article__list--type02 li a {
    display: flex;
  }
  .p-pc-article__list--type02 li a .pc-article__list__image {
    width: 250px;
    padding: 20px 0 20px 20px;
  }
  .p-pc-article__list--type02 li a .pc-article__list__image img {
    border-radius: 0;
    height: 180px;
  }
  .p-pc-article__list--type02 li a .p-pc-article__list__content {
    width: calc(100% - 330px);
    padding: 30px;
  }
  .p-pc-article__list--type02 li a .p-pc-article__list__content h3 {
    margin-bottom: 20px;
    font-size: 2rem;
  }
  .p-pc-article__list--type02 li a:hover {
    opacity: 1;
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.2);
    border-radius: 7px;
  }
}

/* ━━━━━━━━━━━━━━━━

 ■hp

━━━━━━━━━━━━━━━━ */
/*==================================
* main visual hp
==================================*/
.p-hp__main-visual {
  padding: 30px 8px;
  background: #f6f7f7;
}
.p-hp__main-visual .p-hp__main-visual__textarea {
  text-align: center;
}
.p-hp__main-visual .p-hp__main-visual__textarea h1 {
  margin-bottom: 30px;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.3;
  color: #044E80;
}
.p-hp__main-visual .p-hp__main-visual__textarea a {
  display: block;
  width: 75%;
  margin: 0 auto 20px auto;
  padding: 10px 20px;
  font-size: 2.4rem;
  font-weight: bold;
  color: #ffffff;
  border-radius: 5px;
  background-color: #FEB808;
}
.p-hp__main-visual .p-hp__main-visual__textarea p {
  font-size: 1.8rem;
}
.p-hp__main-visual .p-hp__main-visual__image {
  max-width: 100%;
}
.p-hp__main-visual .p-hp__main-visual__image img {
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .p-hp__main-visual {
    padding: 50px 0;
  }
  .p-hp__main-visual .p-hp__main-visual__inner {
    display: flex;
    box-sizing: border-box;
    align-items: center;
    max-width: 1140px;
    margin: 0 auto;
  }
  .p-hp__main-visual .p-hp__main-visual__inner .p-hp__main-visual__textarea {
    width: 50%;
  }
  .p-hp__main-visual .p-hp__main-visual__inner .p-hp__main-visual__textarea h1 {
    margin-bottom: 40px;
    font-size: 4.2rem;
  }
  .p-hp__main-visual .p-hp__main-visual__inner .p-hp__main-visual__textarea a {
    width: 320px;
    margin-bottom: 40px;
    font-size: 3rem;
  }
  .p-hp__main-visual .p-hp__main-visual__inner .p-hp__main-visual__textarea p {
    font-size: 2.4rem;
  }
  .p-hp__main-visual .p-hp__main-visual__inner .p-hp__main-visual__image {
    width: 50%;
  }
}

/*==================================
* HP制作キャンペーンバナー
==================================*/
.p-hp__banner {
  display: block;
  width: 90%;
  padding: 30px 10px;
  margin: 0 auto;
  background-color: #3d70bb;
  box-shadow: 0 10px 7px 7px rgba(0, 0, 0, 0.2);
}
@media print, screen and (min-width: 768px) {
  .p-hp__banner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: calc(100% - 80px);
    padding: 30px 30px 40px 30px;
  }
}

.p-hp__banner__contents {
  margin-bottom: 30px;
  text-align: center;
}
.p-hp__banner__contents strong {
  line-height: 1.3;
  font-size: 3rem;
  text-shadow: 2px 2px 0 #000;
  color: #fff100;
}
.p-hp__banner__contents .p-hp__banner__contents__text {
  margin-top: 20px;
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain {
  position: relative;
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__caption {
  padding-left: 110px;
  text-align: left;
  font-size: 1.4rem;
  color: #fff;
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period {
  position: absolute;
  top: 10px;
  left: 15px;
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst {
  display: inline-block;
  position: relative;
  width: 70px;
  height: 70px;
  text-align: center;
  background-color: #ed287b;
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst::before, .p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst::after {
  content: "";
  position: absolute;
  width: 70px;
  height: 70px;
  top: 0;
  left: 0;
  background-color: #ed287b;
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst::before {
  transform: rotate(30deg);
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst::after {
  transform: rotate(60deg);
}
.p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst p {
  position: relative;
  margin-top: 8px;
  line-height: 1.2;
  font-size: 1.6rem;
  color: #ffffff;
  z-index: 10;
}
@media print, screen and (min-width: 768px) {
  .p-hp__banner__contents {
    text-align: left;
  }
  .p-hp__banner__contents strong {
    padding: 0;
    text-align: left;
    font-size: 5.5rem;
  }
  .p-hp__banner__contents .p-hp__banner__contents__text {
    padding: 0 30px;
  }
  .p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__caption {
    padding: 25px 0 0 150px;
    font-size: 2rem;
  }
  .p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst {
    width: 100px;
    height: 100px;
  }
  .p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst::before, .p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst::after {
    width: 100px;
    height: 100px;
  }
  .p-hp__banner__contents .p-hp__banner__contents__text .p-hp__banner__contents__explain .p-hp__banner__contents__explain__period .p-hp__banner__pointburst p {
    margin-top: 10px;
    font-size: 2.2rem;
  }
}

.p-hp__banner__image {
  text-align: center;
}
.p-hp__banner__image img {
  max-width: 150px;
}
@media print, screen and (min-width: 768px) {
  .p-hp__banner__image {
    width: 30%;
    padding-bottom: 0;
  }
  .p-hp__banner__image img {
    max-width: 200px;
  }
}

/*==================================
* 無料診断キャンペーンバナー
==================================*/
.p-hp__check__banner {
  display: block;
  width: 90%;
  padding: 30px 10px;
  margin: 0 auto;
  background-color: #41acf4;
  box-shadow: 0 10px 7px 7px rgba(0, 0, 0, 0.2);
}
@media print, screen and (min-width: 768px) {
  .p-hp__check__banner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: calc(100% - 80px);
    padding: 30px 30px 40px 30px;
  }
}

.p-hp__check__banner__contents {
  margin-bottom: 30px;
  text-align: center;
}
.p-hp__check__banner__contents h2 {
  line-height: 1.3;
  font-size: 3rem;
  font-weight: bold;
  text-shadow: 2px 2px 0 #000;
  color: #fac530;
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text {
  margin-top: 20px;
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain {
  position: relative;
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__caption {
  padding-left: 110px;
  text-align: left;
  font-size: 1.4rem;
  color: #fff;
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period {
  position: absolute;
  top: 10px;
  left: 15px;
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst {
  display: inline-block;
  position: relative;
  width: 70px;
  height: 70px;
  text-align: center;
  background-color: #dc3545;
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst::before, .p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst::after {
  content: "";
  position: absolute;
  width: 70px;
  height: 70px;
  top: 0;
  left: 0;
  background-color: #dc3545;
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst::before {
  transform: rotate(30deg);
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst::after {
  transform: rotate(60deg);
}
.p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst p {
  position: relative;
  margin-top: 8px;
  line-height: 1.2;
  font-size: 1.6rem;
  color: #ffffff;
  z-index: 10;
}
@media print, screen and (min-width: 768px) {
  .p-hp__check__banner__contents {
    margin-right: 20px;
    text-align: left;
  }
  .p-hp__check__banner__contents h2 {
    padding: 0;
    text-align: left;
    font-size: 5.5rem;
  }
  .p-hp__check__banner__contents .p-hp__check__banner__contents__text {
    padding: 0 30px;
  }
  .p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__caption {
    padding: 25px 0 0 150px;
    font-size: 2rem;
  }
  .p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst {
    width: 100px;
    height: 100px;
  }
  .p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst::before, .p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst::after {
    width: 100px;
    height: 100px;
  }
  .p-hp__check__banner__contents .p-hp__check__banner__contents__text .p-hp__check__banner__contents__explain .p-hp__check__banner__contents__explain__period .p-hp__check__banner__pointburst p {
    margin-top: 10px;
    font-size: 2.2rem;
  }
}

.p-hp__check__banner__image {
  text-align: center;
}
.p-hp__check__banner__image img {
  max-width: 180px;
}
@media print, screen and (min-width: 768px) {
  .p-hp__check__banner__image {
    width: 30%;
    padding-bottom: 0;
  }
  .p-hp__check__banner__image img {
    max-width: 250px;
  }
}

/*==================================
* 機能
==================================*/
.p-hp__main__function ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  margin-bottom: 30px;
}
.p-hp__main__function ul li {
  width: 30%;
  margin-bottom: 20px;
  text-align: center;
}
.p-hp__main__function ul li img {
  margin-bottom: 5px;
}
@media print, screen and (min-width: 768px) {
  .p-hp__main__function ul {
    max-width: 1140px;
    margin-bottom: 80px;
  }
  .p-hp__main__function ul li {
    width: 13%;
    font-size: 16px;
    margin-bottom: 0;
  }
  .p-hp__main__function ul li img {
    margin-bottom: 10px;
  }
}

.p-hp__sub__function ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  margin-bottom: 50px;
}
.p-hp__sub__function ul li {
  width: 18%;
  margin-bottom: 20px;
  text-align: center;
}
.p-hp__sub__function ul li img {
  margin-bottom: 5px;
}
@media print, screen and (min-width: 768px) {
  .p-hp__sub__function ul {
    max-width: 1140px;
    margin-bottom: 80px;
  }
  .p-hp__sub__function ul li {
    width: 8%;
    font-size: 16px;
    margin-bottom: 0;
  }
  .p-hp__sub__function ul li img {
    margin-bottom: 10px;
  }
}

/*==================================
* 選ばれる理由
==================================*/
.p-hp__reason .p-hp__reason__block,
.p-hp__reason .p-hp__reason__block--reverse {
  margin-bottom: 60px;
}
.p-hp__reason .p-hp__reason__block .p-hp__reason__image,
.p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__image {
  max-width: 100%;
}
.p-hp__reason .p-hp__reason__block .p-hp__reason__image img,
.p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__image img {
  width: 100%;
  height: 250px;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-hp__reason .p-hp__reason__block .p-hp__reason__panel,
.p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel {
  position: relative;
  box-sizing: border-box;
  width: 90%;
  margin: -40px auto 0 auto;
  padding: 0 20px 20px 20px;
  background-color: #ffffff;
  box-shadow: 0 7px 20px 0 rgba(0, 0, 0, 0.2);
  border-radius: 6px;
  z-index: 50;
}
.p-hp__reason .p-hp__reason__block .p-hp__reason__panel .p-hp__reason__strong,
.p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel .p-hp__reason__strong {
  font-size: 54px;
  font-weight: 900;
  color: #044E80;
}
.p-hp__reason .p-hp__reason__block .p-hp__reason__panel .p-hp__reason__title,
.p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel .p-hp__reason__title {
  margin-bottom: 15px;
  line-height: 1.2;
  font-size: 24px;
  font-weight: 700;
}
.p-hp__reason .p-hp__reason__block .p-hp__reason__panel .p-hp__reason__text,
.p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel .p-hp__reason__text {
  margin-bottom: 20px;
  font-size: 16px;
  line-height: 1.8;
}
.p-hp__reason .p-hp__reason__block .p-hp__reason__panel .c-button--primary,
.p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel .c-button--primary {
  margin-bottom: 0;
}
@media print, screen and (min-width: 768px) {
  .p-hp__reason {
    max-width: 1140px;
    margin: 0 auto;
  }
  .p-hp__reason .p-hp__reason__block,
  .p-hp__reason .p-hp__reason__block--reverse {
    position: relative;
    height: 500px;
    margin-bottom: 100px;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__image,
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__image {
    position: absolute;
    top: 0;
    width: 80%;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__image img,
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__image img {
    height: 500px;
    -o-object-position: right;
       object-position: right;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__panel,
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    width: 55%;
    margin: 0;
    padding: 0 50px 50px 50px;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__panel .p-hp__reason__strong,
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel .p-hp__reason__strong {
    font-size: 74px;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__panel .p-hp__reason__title,
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel .p-hp__reason__title {
    font-size: 34px;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__panel .p-hp__reason__text,
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel .p-hp__reason__text {
    margin-bottom: 30px;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__image {
    right: 0;
  }
  .p-hp__reason .p-hp__reason__block .p-hp__reason__panel {
    left: 0;
  }
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__image {
    left: 0;
  }
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__image img {
    -o-object-position: left;
       object-position: left;
  }
  .p-hp__reason .p-hp__reason__block--reverse .p-hp__reason__panel {
    right: 0;
  }
}

/*=================================
　申込の流れ
=================================*/
.p-hp__flow {
  width: 90%;
  margin: 0 auto 50px auto;
  box-sizing: border-box;
}
.p-hp__flow .p-hp__flow__body {
  margin-bottom: 40px;
}
.p-hp__flow .p-hp__flow__body .p-hp__flow__image {
  position: relative;
  width: 60%;
  margin: 0 auto 10px auto;
}
.p-hp__flow .p-hp__flow__body .p-hp__flow__image .p-hp__flow__image__number {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 45px;
  height: 45px;
  border-radius: 50%;
  line-height: 45px;
  text-align: center;
  font-family: "Arial", "Century Gothic", sans-serif;
  font-size: 2.6rem;
  font-weight: bold;
  background: #044E80;
  color: #fff;
}
.p-hp__flow .p-hp__flow__body .p-hp__flow__image img {
  display: block;
  width: 100%;
  height: auto;
}
.p-hp__flow .p-hp__flow__body .p-hp__flow__text h3 {
  margin-bottom: 10px;
  text-align: center;
  font-size: 1.8rem;
  font-weight: bold;
}
.p-hp__flow .p-hp__flow__body .p-hp__flow__text p {
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .p-hp__flow {
    width: 100%;
    max-width: 1140px;
    margin-bottom: 0;
    padding: 0 8px;
  }
  .p-hp__flow ul {
    display: flex;
    justify-content: space-between;
    box-sizing: border-box;
  }
  .p-hp__flow ul .p-hp__flow__body {
    width: 30%;
  }
  .p-hp__flow ul .p-hp__flow__body .p-hp__flow__image {
    margin-bottom: 15px;
  }
  .p-hp__flow ul .p-hp__flow__body .p-hp__flow__text h3 {
    margin-bottom: 15px;
    font-size: 2rem;
    height: 3.5em;
    line-height: 1.4;
    display: flex;
    align-items: flex-start;
    justify-content: center;
  }
  .p-hp__flow ul .p-hp__flow__body .p-hp__flow__text p {
    font-size: 1.8rem;
  }
}

/**
 * index
 */
/*==================================
* main-visual
==================================*/
.l-main-visual {
  background: #044E80;
}
@media print, screen and (min-width: 768px) {
  .l-main-visual {
    padding: 0;
  }
}

.l-main-visual__inner {
  margin: 0 auto;
  padding: 0 10px;
}
.l-main-visual__inner .l-main-visual__title {
  margin-bottom: 30px;
  text-align: center;
}
.l-main-visual__inner .l-main-visual__title h1 {
  margin-bottom: 30px;
  text-align: left;
  font-size: 1.4rem;
  color: #fff;
}
.l-main-visual__inner .l-main-visual__title strong {
  text-align: center;
  line-height: 1.25;
  font-size: 1.8rem;
  color: #fff;
}
.l-main-visual__inner .l-main-visual__title strong span {
  font-size: 3rem;
  font-weight: 900;
}
.l-main-visual__inner .l-main-visual__entry {
  width: 90%;
  margin: 0 auto;
  text-align: center;
}
.l-main-visual__inner .l-main-visual__entry .l-main-visual__entry__button {
  display: block;
  padding: 10px;
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
  background: #FEB808;
}
.l-main-visual__inner .l-main-visual__image {
  display: none;
}
@media print, screen and (min-width: 768px) {
  .l-main-visual__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1140px;
    padding: 0 10px;
  }
  .l-main-visual__inner > div {
    width: 45%;
  }
  .l-main-visual__inner > div .l-main-visual__title h1 {
    line-height: 1.5;
    font-size: clamp(14px, 1.4035087719vw, 16px);
  }
  .l-main-visual__inner > div .l-main-visual__title strong {
    font-size: clamp(18px, 2.4561403509vw, 28px);
  }
  .l-main-visual__inner > div .l-main-visual__title strong span {
    font-size: clamp(30px, 4.2105263158vw, 48px);
  }
  .l-main-visual__inner > div .l-main-visual__entry {
    width: 80%;
  }
  .l-main-visual__inner > div .l-main-visual__entry .l-main-visual__entry__button:hover {
    opacity: 1;
    color: #044E80;
    background: #fff;
  }
  .l-main-visual__inner .l-main-visual__image {
    display: block;
    width: 50%;
  }
}

/*==================================
* キャンペーンページへの誘導バナー
==================================*/
.p-banner {
  width: 90%;
  margin: 0 auto;
  background: #fff;
  border-radius: 10px;
  box-sizing: border-box;
}
.p-banner a {
  position: relative;
  display: block;
  padding: 20px;
  border: 2px solid #345887;
  border-radius: 10px;
  text-align: center;
  background: #edf6ff;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.p-banner a::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
  pointer-events: none;
}
.p-banner a:hover {
  opacity: 1;
  background: #d4eafd;
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}
.p-banner a:focus-visible {
  outline: 3px solid rgba(52, 88, 135, 0.35);
  outline-offset: 3px;
}
.p-banner a .p-banner__wrapper .p-banner__text p {
  display: inline-block;
  margin-bottom: 10px;
  padding: 2px 10px 4px;
  font-size: 1.6rem;
  font-weight: 700;
  color: #fff;
  background: #005bac;
  border-radius: 5px;
}
.p-banner a .p-banner__wrapper .p-banner__text p span {
  font-size: 2.4rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
}
.p-banner a .p-banner__wrapper .p-banner__text h2 {
  margin: 10px 0 14px;
  font-size: 2.6rem;
  font-weight: 900;
  color: #222;
  letter-spacing: 0.01em;
  line-height: 1.3;
}
.p-banner a .p-banner__wrapper .p-banner__text .p-banner__text__button {
  display: none;
}
.p-banner a .p-banner__wrapper .p-banner__image {
  width: 80%;
  margin: 0 auto 15px auto;
}
.p-banner a .p-banner__wrapper .p-banner__image img {
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: auto;
  filter: drop-shadow(0 8px 18px rgba(0, 0, 0, 0.12));
}
.p-banner a .p-banner__button {
  display: inline-block;
  padding: 8px 18px;
  font-size: 1.6rem;
  font-weight: bold;
  color: #fff;
  background: #ff6b00;
  border-radius: 3px;
}
@media print, screen and (min-width: 768px) {
  .p-banner {
    max-width: 825px;
  }
  .p-banner a {
    padding: 20px 30px;
  }
  .p-banner a .p-banner__wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
  }
  .p-banner a .p-banner__wrapper .p-banner__text {
    width: 63%;
    text-align: left;
  }
  .p-banner a .p-banner__wrapper .p-banner__text p {
    margin-bottom: 14px;
    padding: 2px 12px 4px;
    font-size: 1.8rem;
  }
  .p-banner a .p-banner__wrapper .p-banner__text p span {
    font-size: 2.8rem;
  }
  .p-banner a .p-banner__wrapper .p-banner__text h2 {
    margin-bottom: 18px;
    font-size: 2.8rem;
  }
  .p-banner a .p-banner__wrapper .p-banner__text .p-banner__text__button {
    display: inline-block;
    padding: 8px 18px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    background: #FF6B00;
    border-radius: 3px;
  }
  .p-banner a .p-banner__wrapper .p-banner__image {
    width: 31%;
    margin: 0;
  }
  .p-banner a .p-banner__button {
    display: none;
  }
}

/*==================================
* メニュー一覧
==================================*/
.p-service-menu {
  background: #eaf0fa;
}

.p-service-menu .c-service-menu-02 .p-service-menu__tag {
  margin-bottom: 20px;
}
.p-service-menu .c-service-menu-02 .p-service-menu__tag p {
  margin-bottom: 5px;
  font-size: 1.6rem;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .p-service-menu .c-service-menu-02 .p-service-menu__tag {
    margin-bottom: 30px;
  }
  .p-service-menu .c-service-menu-02 .p-service-menu__tag p {
    margin-bottom: 7px;
    font-size: 1.8rem;
  }
}

/*==================================
* 無料で試す
==================================*/
.p-entry {
  background: #044E80;
}

.p-entry__inner {
  width: 95%;
  margin: 0 auto;
  box-sizing: border-box;
}
.p-entry__inner .p-entry__image {
  margin-bottom: 25px;
}
.p-entry__inner .p-entry__image img {
  display: block;
  width: 130px;
  height: auto;
  margin: 0 auto;
}
.p-entry__inner .p-entry__body .p-entry__body__text {
  color: #fff;
}
.p-entry__inner .p-entry__body .p-entry__body__text p {
  margin-bottom: 7px;
  font-size: 1.6rem;
  line-height: 1.5;
}
.p-entry__inner .p-entry__body .p-entry__body__text h2 {
  margin: 30px 0;
  line-height: 1.4;
  text-align: center;
  font-size: 2.4rem;
  font-weight: bold;
}
.p-entry__inner .p-entry__body .p-entry__body__button a {
  display: block;
  padding: 10px;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
  color: #044E80;
  background: #fff;
  border-radius: 100px;
}
.p-entry__inner .p-entry__body .p-entry__body__button a:hover {
  opacity: 1;
  color: #fff;
  background: #FEB808;
}
@media print, screen and (min-width: 768px) {
  .p-entry__inner {
    width: 100%;
    padding: 0 8px;
  }
  .p-entry__inner .p-entry__image {
    margin-bottom: 30px;
  }
  .p-entry__inner .p-entry__image img {
    width: 170px;
  }
  .p-entry__inner .p-entry__body .p-entry__body__text p {
    text-align: center;
    margin-bottom: 10px;
    font-size: 2.2rem;
  }
  .p-entry__inner .p-entry__body .p-entry__body__text h2 {
    margin: 30px 0 40px 0;
    font-size: 3rem;
  }
  .p-entry__inner .p-entry__body .p-entry__body__button a {
    width: 50%;
    margin: 0 auto;
    padding: 15px;
    font-size: 2.4rem;
  }
}

/**
 * Inquiry
 */
/* お問合せ
 ======================= */
.p-inquiry__box {
  border: 1px solid #999;
  box-sizing: border-box;
  background-color: #f9f9f9;
  padding: 10px 10px 20px 10px;
}
@media print, screen and (min-width: 768px) {
  .p-inquiry__box {
    padding: 25px 20px 35px 20px;
  }
}

/**
 * Portal
 */
/* マイショップ
 ======================= */
.p-portal__my-shop li {
  width: 100%;
  border: 2px solid #044E80;
  box-sizing: border-box;
  margin-bottom: 30px;
}
@media print, screen and (min-width: 768px) {
  .p-portal__my-shop li {
    width: 500px;
    float: left;
    display: inline-block;
    margin-bottom: 50px;
  }
}
@media print, screen and (min-width: 768px) {
  .p-portal__my-shop li:nth-child(even) {
    float: right;
  }
}

.p-portal__my-shop--image {
  padding: 15px 10px 0 10px;
}
@media print, screen and (min-width: 768px) {
  .p-portal__my-shop--image {
    padding: 20px 20px 0 20px;
  }
}
@media print, screen and (min-width: 768px) {
  .p-portal__my-shop--image img {
    height: 194px;
  }
}

.p-portal__my-shop--detail {
  background: #044E80;
  padding: 15px;
  color: #FFF;
}
@media print, screen and (min-width: 768px) {
  .p-portal__my-shop--detail {
    padding: 20px;
  }
}
.p-portal__my-shop--detail h3 {
  margin-bottom: 5px;
}
.p-portal__my-shop--detail p {
  line-height: 1.3;
}

/**
 * Price
 */
/*==================================
* 共通
==================================*/
.p-price__text--strong {
  font-size: 2.5rem;
  color: #dc3545;
  font-weight: bold;
}

/*==================================
* 最上部
==================================*/
.p-price__top--info {
  margin-bottom: 30px;
  font-size: 2rem;
}

/*==================================
* 初期費用
==================================*/
.p-price__initial--box {
  display: table;
  width: 100%;
  margin: 0 auto;
  font-weight: bold;
  font-size: 2.5rem;
  border: 1px solid #666;
  border-bottom: none;
  box-sizing: border-box;
}
@media print, screen and (min-width: 768px) {
  .p-price__initial--box {
    width: 85%;
    font-size: 5rem;
  }
}
.p-price__initial--box dt, .p-price__initial--box dd {
  display: table-cell;
  text-align: center;
  box-sizing: border-box;
  padding: 15px 0;
  border-bottom: 1px solid #666;
}
.p-price__initial--box dt {
  width: 40%;
  background: #F9F9F9;
  border-right: 1px solid #666;
  color: #666;
}
.p-price__initial--box dd {
  width: 60%;
  margin: 0;
  background: #FFF;
  color: #dc3545;
}

/**
 * reason
 */
.p-reason__grid {
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.p-reason__grid .p-reason__grid__col2 {
  box-sizing: border-box;
  margin-bottom: 50px;
}
.p-reason__grid .p-reason__grid__col2 img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
.p-reason__grid .p-reason__grid__col2 {
  display: block;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .p-reason__grid .p-reason__grid__col2 {
    width: 46%;
  }
}

@media print, screen and (min-width: 768px) {
  .p-reason__continue .c-feature__image img {
    max-width: 430px;
  }
}

.p-reason__continue-result {
  margin-bottom: 80px;
  text-align: center;
}
.p-reason__continue-result .p-reason__continue-result__title {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 20px;
}
.p-reason__continue-result .p-reason__continue-result__no {
  color: #03967a;
  font-size: 3rem;
  font-weight: bold;
  line-height: 1;
  margin-left: 30px;
}
.p-reason__continue-result .p-reason__continue-result__no span {
  font-size: 8rem;
  margin-right: 10px;
}
.p-reason__continue-result .p-reason__continue-result__date {
  margin-left: 130px;
  font-size: 1.4rem;
}
@media print, screen and (min-width: 768px) {
  .p-reason__continue-result {
    margin-bottom: 100px;
  }
  .p-reason__continue-result .p-reason__continue-result__no {
    font-size: 5rem;
    margin-left: 50px;
  }
  .p-reason__continue-result .p-reason__continue-result__no span {
    font-size: 10rem;
  }
  .p-reason__continue-result .p-reason__continue-result__date {
    margin-left: 210px;
    font-size: 1.4rem;
  }
}

/**
 * select-layout
 */
/*==================================
* レイアウトを選択
==================================*/
.p-select-layout__block .p-select-layout__text {
  margin-bottom: 20px;
  text-align: center;
  font-size: 1.6rem;
}
.p-select-layout__block .p-select-layout__text span {
  font-size: 2rem;
}
.p-select-layout__block .p-select-layout__list {
  margin-bottom: 20px;
}
.p-select-layout__block .p-select-layout__list li a {
  display: block;
  position: relative;
  padding: 10px 20px 10px 10px;
  text-decoration: none;
  font-size: 1.6rem;
  color: #333;
  border-top: solid 1px #333;
  border-right: solid 1px #333;
  border-left: solid 1px #333;
}
.p-select-layout__block .p-select-layout__list li a::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 15px;
  width: 7px;
  height: 7px;
  margin-top: -4px;
  border-top: solid 2px #7f7f7f;
  border-right: solid 2px #7f7f7f;
  transform: rotate(45deg);
}
.p-select-layout__block .p-select-layout__list li .p-select-layout__list__last {
  border-bottom: solid 1px #333;
}
.p-select-layout__block .p-select-layout__bottom {
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .p-select-layout__block .p-select-layout__text {
    margin-bottom: 30px;
    font-size: 2rem;
  }
  .p-select-layout__block .p-select-layout__text span {
    font-size: 2.4rem;
  }
  .p-select-layout__block .p-select-layout__list ul {
    display: flex;
    justify-content: space-around;
  }
  .p-select-layout__block .p-select-layout__list ul li a {
    padding: 10px 40px;
    border-bottom: solid 1px #333;
  }
  .p-select-layout__block .p-select-layout__list ul li a::after {
    margin-top: -6px;
    border-top: none;
    border-bottom: solid 2px #7f7f7f;
  }
  .p-select-layout__block .p-select-layout__list ul li a:hover {
    border-color: #247abe;
    color: #ffffff;
    background-color: #247abe;
  }
  .p-select-layout__block .p-select-layout__list ul li a:hover::after {
    border-right: solid 2px #ffffff;
    border-bottom: solid 2px #ffffff;
  }
}

/*==================================
* レイアウトリスト
==================================*/
.p-select-layout__sample__list ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
.p-select-layout__sample__list ul li {
  width: 45%;
  margin-bottom: 30px;
  text-align: center;
}
.p-select-layout__sample__list ul li .p-select-layout__sample {
  position: relative;
}
.p-select-layout__sample__list ul li .p-select-layout__sample a {
  display: block;
}
.p-select-layout__sample__list ul li .p-select-layout__sample a .p-select-layout__sample__text {
  position: absolute;
  display: block;
  width: 50%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 5px 20px;
  color: #ffffff;
  background-color: #565656;
  border-radius: 20px;
  opacity: 0.8;
}
.p-select-layout__sample__list ul li .p-select-layout__sample a img {
  margin-bottom: 15px;
}
.p-select-layout__sample__list ul li .c-button--primary {
  margin-bottom: 10px;
  font-size: 1.2rem;
}
.p-select-layout__sample__list ul li .c-button--primary::after {
  right: 15px;
}
@media print, screen and (min-width: 768px) {
  .p-select-layout__sample__list ul li {
    width: 30%;
    margin-bottom: 50px;
  }
  .p-select-layout__sample__list ul li .p-select-layout__sample a .p-select-layout__sample__text {
    display: none;
  }
  .p-select-layout__sample__list ul li .p-select-layout__sample a:hover .p-select-layout__sample__text {
    display: block;
    opacity: 1;
  }
  .p-select-layout__sample__list ul li .c-button--primary {
    font-size: 1.6rem;
  }
  .p-select-layout__sample__list ul li .c-button--primary::after {
    right: 20px;
  }
}

/**
 * self-build
 */
/*==================================
* 自分で作る
==================================*/
.p-self-build__flow {
  width: 90%;
  margin: 0 auto;
  box-sizing: border-box;
}
@media print, screen and (min-width: 768px) {
  .p-self-build__flow {
    max-width: 1140px;
    width: 100%;
    padding: 0 8px;
  }
}

.p-self-build__flow__block {
  padding: 20px;
  background-color: #fff;
  border-radius: 7px;
  border: solid 2px #044E80;
  box-sizing: border-box;
}
.p-self-build__flow__block .p-self-build__flow__content {
  margin-bottom: 50px;
}
.p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__no {
  display: inline-block;
  margin-bottom: 10px;
  padding: 0 20px 2px 20px;
  font-size: 2rem;
  font-weight: 900;
  color: #fff;
  background: #044E80;
  border-radius: 100px;
}
.p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__title {
  margin-bottom: 10px;
  font-size: 2.2rem;
  font-weight: bold;
}
.p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__text {
  margin-bottom: 20px;
  line-height: 1.6;
  font-size: 1.6rem;
}
.p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__text span {
  font-size: 1.8rem;
  color: #dc3545;
}
.p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__button {
  width: 100%;
  margin: 0 auto 30px auto;
}
.p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__button a {
  display: block;
  padding: 10px 20px;
  text-align: center;
  text-decoration: none;
  font-size: 1.8rem;
  font-weight: bold;
  color: #fff;
  background: #FEB808;
  border: solid 2px #FEB808;
  border-radius: 5px;
  transition: all 0.3s;
}
.p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__button a:hover {
  opacity: 1;
  color: #FEB808;
  background: #fff;
  border: solid 2px #FEB808;
}
.p-self-build__flow__block .p-self-build__flow__item li {
  margin-bottom: 25px;
}
.p-self-build__flow__block .p-self-build__flow__item li:last-child {
  margin-bottom: 0;
}
.p-self-build__flow__block .p-self-build__flow__item li .p-self-build__flow__item__title {
  margin-bottom: 5px;
  font-size: 1.6rem;
  font-weight: bold;
}
.p-self-build__flow__block .p-self-build__flow__item li .p-self-build__flow__item__text {
  font-size: 1.6rem;
}
.p-self-build__flow__block .p-self-build__flow__item p {
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .p-self-build__flow__block {
    padding: 40px 45px;
  }
  .p-self-build__flow__block .p-self-build__flow__content {
    margin-bottom: 50px;
    display: flex;
    justify-content: space-between;
    box-sizing: border-box;
  }
  .p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text {
    width: 50%;
  }
  .p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__no {
    margin-bottom: 20px;
    padding: 3px 30px 5px 30px;
    font-size: 2.4rem;
  }
  .p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__title {
    margin-bottom: 30px;
    font-size: 3rem;
  }
  .p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__text {
    margin-bottom: 20px;
    font-size: 1.8rem;
  }
  .p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__text span {
    font-size: 2rem;
  }
  .p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__text .p-self-build__flow__button {
    width: 80%;
    margin: 0 auto 0 0;
  }
  .p-self-build__flow__block .p-self-build__flow__content .p-self-build__flow__content__image {
    width: 48%;
  }
}

/**
 * Simulation
 */
/*==================================
* 入力
==================================*/
.p-simulation__input table {
  width: 100%;
  border-collapse: collapse;
  box-sizing: border-box;
  border-bottom: 1px solid #666;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__input table {
    border-bottom: none;
  }
}
.p-simulation__input th, .p-simulation__input td {
  padding: 20px 10px;
  display: block;
  border: 1px solid #666;
  border-bottom: none;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__input th, .p-simulation__input td {
    padding: 15px 20px;
    display: table-cell;
    border-bottom: 1px solid #666;
  }
}
.p-simulation__input th {
  background-color: #F9F9F9;
  font-size: 2rem;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__input th {
    width: 25%;
  }
}
.p-simulation__input td {
  background-color: #FFF;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__input td {
    width: 75%;
  }
}
.p-simulation__input .p-simulation__input__select {
  font-size: 2rem;
  vertical-align: middle;
}
.p-simulation__input .p-simulation__input__radio {
  display: inline-block;
  padding: 3px 10px;
  border: solid 1px #ccc;
  margin-right: 20px;
  cursor: pointer;
  font-size: 2rem;
}

/*==================================
* 結果
==================================*/
.p-simulation__result table {
  width: 100%;
  border-collapse: collapse;
  box-sizing: border-box;
  border-bottom: 1px solid #666;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__result table {
    width: 700px;
    margin: 0 auto;
    border-bottom: none;
  }
}
.p-simulation__result th, .p-simulation__result td {
  padding: 20px 10px;
  display: block;
  border: 1px solid #666;
  border-bottom: none;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__result th, .p-simulation__result td {
    padding: 15px 20px;
    display: table-cell;
    border-bottom: 1px solid #666;
  }
}
.p-simulation__result th {
  background-color: #F9F9F9;
  font-size: 2rem;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__result th {
    width: 25%;
  }
}
.p-simulation__result td {
  background-color: #FFF;
  text-align: right;
}
@media print, screen and (min-width: 768px) {
  .p-simulation__result td {
    width: 25%;
  }
}

/**
 * smart
 */
/*==================================
* PC・スマホ同時更新
==================================*/
.p-smart__update__inner .p-smart__update__box {
  text-align: center;
}
.p-smart__update__inner .p-smart__update__box img {
  margin-bottom: 10px;
}
.p-smart__update__inner .p-smart__update__box p {
  font-size: 1.8rem;
}
.p-smart__update__inner .p-smart__update__triangle {
  width: 0;
  height: 0;
  margin: 20px auto;
  border-left: 40px solid transparent;
  border-right: 40px solid transparent;
  border-top: 30px solid #044E80;
}
@media print, screen and (min-width: 768px) {
  .p-smart__update__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 80px;
  }
  .p-smart__update__inner .p-smart__update__box {
    width: 45%;
  }
  .p-smart__update__inner .p-smart__update__triangle {
    width: 0;
    height: 0;
    margin: 0 auto;
    border-top: 50px solid transparent;
    border-bottom: 50px solid transparent;
    border-left: 50px solid #044E80;
  }
}

/*==================================
* スマホ対応の必要性
==================================*/
.p-smart__need li {
  margin-bottom: 20px;
}
.p-smart__need li h3 {
  margin-bottom: 5px;
  padding: 0 0 0 35px;
  font-size: 2rem;
  font-weight: bold;
  color: #bf1015;
  background-image: url(../img/hp/icon_check.png);
  background-repeat: no-repeat;
  background-position: left center;
}
.p-smart__need li p {
  padding: 0 0 0 35px;
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .p-smart__need li {
    margin-bottom: 30px;
  }
  .p-smart__need li h3 {
    margin-bottom: 10px;
    font-size: 2.8rem;
  }
  .p-smart__need li p {
    font-size: 1.8rem;
  }
}

/*==================================
* 導入事例
==================================*/
.p-smart__example .p-smart__example__block {
  margin-bottom: 50px;
  text-align: center;
}
.p-smart__example .p-smart__example__block p {
  margin-bottom: 20px;
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .p-smart__example {
    display: flex;
    justify-content: space-around;
  }
  .p-smart__example .p-smart__example__block {
    width: 50%;
  }
  .p-smart__example .p-smart__example__block p {
    margin-bottom: 30px;
    font-size: 2rem;
  }
  .p-smart__example .p-smart__example__block a {
    display: block;
    margin: 0 auto 30px auto;
  }
}

/*==================================
* 無料で導入
==================================*/
.p-smart__intro p {
  margin-bottom: 30px;
  font-size: 2rem;
}
@media print, screen and (min-width: 768px) {
  .p-smart__intro p {
    margin-bottom: 40px;
    font-size: 3rem;
  }
  .p-smart__intro a {
    display: block;
    margin: 0 auto;
  }
}

/**
 * Top Page
 */
/*==================================
* HP制作キャンペーンバナー
==================================*/
.p-cp__banner {
  display: block;
  width: 90%;
  padding: 30px 10px;
  margin: 0 auto;
  background-color: #3d70bb;
  box-shadow: 0 10px 7px 7px rgba(0, 0, 0, 0.2);
}
@media print, screen and (min-width: 768px) {
  .p-cp__banner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: calc(100% - 80px);
    padding: 30px 30px 40px 30px;
  }
}

.p-cp__banner__contents {
  margin-bottom: 30px;
  text-align: center;
}
.p-cp__banner__contents strong {
  line-height: 1.3;
  font-size: 3rem;
  text-shadow: 2px 2px 0 #000;
  color: #fff100;
}
.p-cp__banner__contents .p-cp__banner__contents__text {
  margin-top: 20px;
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain {
  position: relative;
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__caption {
  padding-left: 110px;
  text-align: left;
  font-size: 1.4rem;
  color: #fff;
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period {
  position: absolute;
  top: 10px;
  left: 15px;
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst {
  display: inline-block;
  position: relative;
  width: 70px;
  height: 70px;
  text-align: center;
  background-color: #ed287b;
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst::before, .p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst::after {
  content: "";
  position: absolute;
  width: 70px;
  height: 70px;
  top: 0;
  left: 0;
  background-color: #ed287b;
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst::before {
  transform: rotate(30deg);
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst::after {
  transform: rotate(60deg);
}
.p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst p {
  position: relative;
  margin-top: 8px;
  line-height: 1.2;
  font-size: 1.6rem;
  color: #ffffff;
  z-index: 10;
}
@media print, screen and (min-width: 768px) {
  .p-cp__banner__contents {
    margin-right: 20px;
    text-align: left;
  }
  .p-cp__banner__contents strong {
    padding: 0;
    text-align: left;
    font-size: 5.5rem;
  }
  .p-cp__banner__contents .p-cp__banner__contents__text {
    padding: 0 30px;
  }
  .p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__caption {
    padding: 25px 0 0 150px;
    font-size: 2rem;
  }
  .p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst {
    width: 100px;
    height: 100px;
  }
  .p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst::before, .p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst::after {
    width: 100px;
    height: 100px;
  }
  .p-cp__banner__contents .p-cp__banner__contents__text .p-cp__banner__contents__explain .p-cp__banner__contents__explain__period .p-cp__banner__point-burst p {
    margin-top: 10px;
    font-size: 2.2rem;
  }
}

.p-cp__banner__image {
  text-align: center;
}
.p-cp__banner__image img {
  max-width: 150px;
}
@media print, screen and (min-width: 768px) {
  .p-cp__banner__image {
    width: 30%;
    padding-bottom: 0;
  }
  .p-cp__banner__image img {
    max-width: 200px;
  }
}

/*==================================
* 申込み流れ
==================================*/
@media print, screen and (min-width: 768px) {
  .p-top__flow:after {
    content: "";
    display: table;
    clear: both;
  }
}
.p-top__flow li {
  width: 100%;
  display: inline-block;
}
@media print, screen and (min-width: 768px) {
  .p-top__flow li {
    width: 16%;
    float: left;
  }
}
.p-top__flow li img {
  width: 70%;
}
@media print, screen and (min-width: 768px) {
  .p-top__flow li img {
    width: 90%;
  }
}
.p-top__flow li.p-top__flow__arrow:before {
  content: "";
  width: 0;
  height: 0;
  border-left: 30px solid transparent;
  border-right: 30px solid transparent;
  border-top: 30px solid #044E80;
  display: block;
  margin: 0 auto 20px auto;
}
@media print, screen and (min-width: 768px) {
  .p-top__flow li.p-top__flow__arrow {
    width: 5%;
    padding-top: 100px;
  }
  .p-top__flow li.p-top__flow__arrow:before {
    border-left: 20px solid #044E80;
    border-right: 0px solid transparent;
    border-top: 20px solid transparent;
    border-bottom: 20px solid transparent;
    margin-top: 20px;
  }
}

/*==================================
* リンク下線
==================================*/
.p-top__link {
  text-decoration: underline;
  font-size: 1.4rem;
}/*# sourceMappingURL=app.css.map */