@charset 'UTF-8';
/*****************************************************
  Foundation
*****************************************************/
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
* 1. Set default font family to sans-serif.
* 2. Prevent iOS text size adjust after 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/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 when focused and also mouse hovered in all browsers.
*/
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: .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: -.5em;
}

sub {
  bottom: -.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
*    (include `-moz` to future-proof).
*/
input[type='search'] {
  -webkit-appearance: textfield;
  /* 1 */
  /* 2 */
  box-sizing: content-box;
}

/**
* 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: .35em .625em .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;
}

html {
  font-size: 62.5%;
}

body {
  font: 1.6em/1.8 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'Noto Sans Japanese', Roboto, 'Droid Sans', 'メイリオ', Meiryo, '游ゴシック体', 'YuGothic', '游ゴシック', 'Yu Gothic', sans-serif;
  color: #141414;
  min-width: 100%;
  background: #f7f7fa;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: unset;
  word-wrap: break-word;
  word-break: break-word;
  overflow-x: hidden;
}
body.isOpen {
  overflow-y: hidden;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2), (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}
* {
  box-sizing: border-box;
}

ul, ol, li, dd {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

em {
  font-style: normal;
}

p {
  margin: 0;
}
p + p {
  margin-top: 1.5em;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-transition: .1s linear;
  transition: .1s linear;
}

select {
  white-space: nowrap;
}

a {
  text-decoration: none;
  color: #141414;
  opacity: 1;
  -webkit-transition: .1s linear;
  transition: .1s linear;
}
a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 1.5em;
  }
  body.isOpen::after {
    display: none;
  }

  html.isOpen body {
    overflow-y: hidden;
  }

  a:hover {
    text-decoration: none;
  }
}
/*****************************************************
  Layout
*****************************************************/
/* =================================================
  Frame
================================================= */
.l-main {
  position: relative;
  z-index: 1;
  background: #f7f7fa;
}
.l-main_contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
}
.l-main_contents.l-main_contents--single {
  display: block;
  margin-top: 30px;
  padding: 60px 30px;
  background: #fff;
}
.l-main_contents.l-main_contents--single02 {
  display: block;
  margin-top: 30px;
  padding: 60px 80px;
  background: #fff;
}
.l-main_contents.l-main_contents--single03 {
  display: block;
  margin-top: 30px;
  padding: 60px 40px;
  background: #fff;
}
.l-main_contents.l-main_contents--category {
  display: block;
  margin-top: 30px;
  padding: 30px;
  background: #fff;
}
.l-main_contents_primary {
  position: relative;
  width: calc(100% - 240px);
  margin-top: 30px;
  padding: 50px 40px 60px;
  background: #fff;
}
.l-main_contents_primary::before {
  position: absolute;
  content: '';
  display: block;
  top: -30px;
  left: 0;
  width: 100%;
  height: 30px;
  background: #eff0f6;
}
.l-main_contents_primary::after {
  position: absolute;
  content: '';
  display: block;
  top: -30px;
  left: -215px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 215px 215px 0;
  border-color: transparent #eff0f6 transparent transparent;
}
.l-main_contents_secondary {
  width: 240px;
}

.l-container {
  position: relative;
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
}

@media screen and (max-width: 1024px) {
  .l-main_contents {
    display: block;
  }
  .l-main_contents_primary {
    width: auto;
  }
  .l-main_contents_secondary {
    width: auto;
    margin: 0;
  }
}
@media screen and (max-width: 768px) {
  .l-main {
    padding: 0 15px;
  }
  .l-main_contents {
    display: block;
  }
  .l-main_contents.l-main_contents--single {
    width: auto;
    margin: 0 -15px;
    padding: 30px 15px 50px;
  }
  .l-main_contents.l-main_contents--single02 {
    width: auto;
    margin: 0 -15px;
    padding: 30px 15px 50px;
  }
  .l-main_contents.l-main_contents--single03 {
    width: auto;
    margin: 0 -15px;
    padding: 30px 15px 50px;
  }
  .l-main_contents.l-main_contents--category {
    margin-top: 30px;
    padding: 0 0 20px;
    background: transparent;
  }
  .l-main_contents_primary {
    width: auto;
    margin: 0 -15px;
    padding: 30px 15px;
  }
  .l-main_contents_primary::before {
    display: none;
  }
  .l-main_contents_primary::after {
    display: none;
  }
  .l-main_contents_secondary {
    width: auto;
    padding: 50px 0;
  }

  .isFixed .l-main {
    margin-top: 50px;
  }
}
/* =================================================
  Header
================================================= */
.l-header {
  position: relative;
  z-index: 2;
  width: 100%;
  background: #fff;
  line-height: 1.5;
}
.l-header_inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 100%;
  margin: 0 auto;
  padding: 10px 30px;
  background-color: rgba(255, 255, 255, .7);
}
.l-header_logo {
  width: 280px;
  margin: 0;
}
.l-header_logo_image {
  width: 100%;
}
.l-header_logo a {
  display: block;
  text-decoration: none;
}
.l-header_info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-left: 20px;
  font-size: 13px;
  font-size: 1.3rem;
}
.l-header_utility_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
.l-header_utility_nav + .l-header_utility_nav {
  margin-top: 12px;
}
.l-header_utility_nav_item + .l-header_utility_nav_item {
  margin: 0 0 0 20px;
  padding: 0 0 0 20px;
  border-left: 1px solid #e2e6ef;
}
.l-header_utility_nav_link.student::after {
  content: url('/assets/images/common/ico_student.svg');
  display: inline-block;
  margin-left: 4px;
  vertical-align: middle;
}
.l-header_utility_nav_link.access::after {
  content: url('/assets/images/common/ico_access.svg');
  display: inline-block;
  margin-left: 4px;
  vertical-align: middle;
}
.l-header_utility_nav_link.contact::after {
  content: url('/assets/images/common/ico_contact.svg');
  display: inline-block;
  margin-left: 4px;
  vertical-align: middle;
}
.l-header_utility--sp {
  display: none;
}
.l-header_cta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  min-height: 68px;
  margin: 0 0 0 40px;
  text-align: center;
}
.l-header_cta_btn + .l-header_cta_btn {
  margin-left: 1px;
}
.l-header_cta_btn_link {
  display: block;
  height: 100%;
  min-width: 90px;
  padding: 42px 10px 7px;
  background-color: #ffcd05;
  background-repeat: no-repeat;
  background-position: 50% 12px;
}
.l-header_cta_btn_link.brochure {
  background-image: url('/assets/images/common/ico_brochure.svg');
}
.l-header_cta_btn_link.meeting {
  background-image: url('/assets/images/common/ico_meeting.svg');
}
.l-header_cta_btn_link:hover {
  background-color: rgba(255, 205, 5, .7);
  text-decoration: none;
}
.l-header_siteSearch {
  position: absolute;
  top: 15px;
  right: 86px;
  width: 230px;
}
.l-header_siteSearch_form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 30px;
  border: 1px solid #f7f7fa;
}
.l-header_siteSearch_field {
  width: calc(100% - 28px);
  padding: 5px 10px;
  border: none;
  border-radius: 0;
  line-height: 1;
}
.l-header_siteSearch_btn {
  width: 28px;
  background: #999 url('/assets/images/common/ico_search_02.svg') 50% 50% no-repeat;
  background-size: 14px auto;
}
.l-header_siteSearch_btn_label {
  opacity: 0;
}
.l-header_spMenu {
  display: none;
}

.isHome .l-header {
  position: absolute;
  background-color: transparent;
}
.isHome .l-gnav {
  background-color: rgba(0, 0, 0, .3);
}
.isHome .l-gnav_menu_item--search .l-gnav_menu_link {
  background-color: rgba(38, 38, 43, .3);
}

@media screen and (max-width: 1024px) {
  .l-header_utility_nav_item + .l-header_utility_nav_item {
    margin-left: 10px;
    padding-left: 10px;
  }
  .l-header_cta {
    margin-left: 15px;
  }
}
@media screen and (max-width: 930px) {
  .l-header_logo {
    width: 175px;
  }
  .l-header_info {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .l-header_utility_nav_item + .l-header_utility_nav_item {
    margin: 0 0 0 5px;
    padding: 0 0 0 5px;
  }
  .l-header_cta_btn_link {
    min-width: 80px;
    padding-left: 0;
    padding-right: 0;
  }
}
@media screen and (max-width: 768px) {
  .l-header_inner {
    display: block;
    padding: 0;
    background: #fff;
  }
  .l-header_logo {
    width: auto;
    padding: 12px 15px 11px;
    background: #fff;
    border-top: 2px solid #000;
  }
  .l-header_logo img {
    display: block;
    height: 17px;
    margin: 0 auto;
  }
  .l-header_info {
    display: none;
  }
  .l-header_utility--sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
  }
  .l-header_utility--sp_item {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    text-align: center;
    font-size: 10px;
    font-size: 1rem;
    font-weight: 700;
  }
  .l-header_utility--sp_link {
    display: block;
    width: 100%;
    height: 50px;
    padding: 13px 0 0;
    line-height: 50px;
  }
  .l-header_utility--sp_link.access {
    background: #ffe682 url('/assets/images/common/ico_access_02.svg') 50% 10px no-repeat;
    background-size: auto 18px;
  }
  .l-header_utility--sp_link.brochure {
    background: #ffcd05 url('/assets/images/common/ico_brochure.svg') 50% 9px no-repeat;
    background-size: auto 20px;
    border-left: 1px solid #f0b500;
  }
  .l-header_utility--sp_link.meeting {
    background: #ffcd05 url('/assets/images/common/ico_meeting.svg') 50% 9px no-repeat;
    background-size: auto 20px;
    border-left: 1px solid #f0b500;
  }
  .l-header_utility--sp_link.menu {
    position: relative;
    background-color: #000;
    color: #fff;
  }
  .l-header_utility--sp_link.menu::after {
    content: 'メニュー';
    display: inline;
  }
  .l-header_utility--sp_link.menu.isOpen::after {
    content: '閉じる';
  }
  .l-header_utility--sp_link.menu span {
    position: absolute;
    left: 0;
    right: 0;
    display: block;
    width: 14px;
    height: 2px;
    margin: 0 auto;
    background: #fff;
    -webkit-transition: all .3s ease-out;
    transition: all .3s ease-out;
  }
  .l-header_utility--sp_link.menu span:nth-child(1) {
    top: 12px;
  }
  .l-header_utility--sp_link.menu span:nth-child(2) {
    top: 18px;
  }
  .l-header_utility--sp_link.menu span:nth-child(3) {
    top: 24px;
  }
  .l-header_utility--sp_link.menu.isOpen span {
    width: 18px;
  }
  .l-header_utility--sp_link.menu.isOpen span:nth-child(1) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .l-header_utility--sp_link.menu.isOpen span:nth-child(2) {
    opacity: 0;
  }
  .l-header_utility--sp_link.menu.isOpen span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg);
  }
  .l-header_utility--sp_link.menu.isOpen + .l-header_nav {
    -webkit-transform: translateY(0%);
    -ms-transform: translateY(0%);
    transform: translateY(0%);
    opacity: 1;
  }

  .isFixed .l-header_utility--sp {
    position: fixed;
    top: 0;
  }
}
/* =================================================
  Footer
================================================= */
.l-footer {
  position: relative;
  z-index: 1;
  padding: 0 30px 30px;
  background: #000;
  line-height: 1.5;
}
.l-footer_cta {
  margin: 0 -30px;
  padding: 30px;
  background: #edf5fc;
}
.l-footer_cta_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.l-footer_cta_box {
  width: calc(100%/2 - 15px);
  padding: 37px 40px 44px;
  background: #fff;
  text-align: center;
}
.l-footer_cta_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 0 15px;
  font-size: 24px;
  font-size: 2.4rem;
  text-align: center;
}
.l-footer_cta_title::before, .l-footer_cta_title::after {
  content: '';
  display: inline-block;
  width: 80px;
  height: 1px;
  background: #141414;
}
.l-footer_cta_title::before {
  margin-right: 9px;
}
.l-footer_cta_title::after {
  margin-left: 9px;
}
.l-footer_cta_btn {
  position: relative;
  display: block;
  max-width: 370px;
  padding: 14px 35px;
  margin: 15px auto 0;
  background: #ffcd05;
  border-radius: 25px;
  font-size: 15px;
  font-size: 1.5rem;
  text-align: center;
  font-weight: 700;
}
.l-footer_cta_btn:hover {
  text-decoration: none;
  background-color: rgba(255, 205, 5, .7);
}
.l-footer_cta_btn::after {
  position: absolute;
  content: '';
  display: block;
  top: 0;
  bottom: 0;
  right: 23px;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #000;
}
.l-footer_upper {
  margin: 0 -30px;
  padding: 30px 30px 0;
  background: #fff;
}
.l-footer_banner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: -30px;
}
.l-footer_banner_item {
  width: calc(100%/6 - 30px);
  margin: 0 0 30px 30px;
}
.l-footer_banner_item a:hover {
  opacity: .7;
}
.l-footer_contents {
  margin: 0 -30px;
  padding: 60px 30px;
  background: #26262b;
}
.l-footer_contents a {
  color: #fff;
}
.l-footer_nav {
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
  font-size: 12px;
  font-size: 1.2rem;
}
.l-footer_nav_menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.l-footer_nav_cat {
  width: calc(100%/6 - 30px);
}
.l-footer_nav_cat_title {
  font-weight: 700;
}
.l-footer_nav_cat_menu {
  margin-top: 20px;
}
.l-footer_nav_cat_item + .l-footer_nav_cat_item {
  margin-top: 12px;
}
.l-footer_nav_cat_item_toggle {
  display: none;
}
.l-footer_nav_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 55px;
  line-height: 1.3;
}
.l-footer_nav_link_item {
  padding: 0 20px;
}
.l-footer_nav_link_item + .l-footer_nav_link_item {
  border-left: 1px solid #525457;
}
.l-footer_bottom {
  width: 100%;
  max-width: 1170px;
  margin: 30px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
}
.l-footer_info_logo {
  margin: 0;
}
.l-footer_info_logo img {
  width: 220px;
}
.l-footer_info_address {
  margin: 17px 0 0;
}
.l-footer_pagetop {
  position: fixed;
  right: 30px;
  bottom: 30px;
  z-index: 2;
  width: 40px;
  height: 40px;
}

@media screen and (max-width: 900px) {
  .l-footer_cta_inner {
    display: block;
  }
  .l-footer_cta_box {
    width: auto;
  }
  .l-footer_cta_box + .l-footer_cta_box {
    margin-top: 30px;
  }
  .l-footer_cta_btn {
    max-width: none;
  }
}
@media screen and (max-width: 768px) {
  .l-footer {
    padding: 0 15px 55px;
  }
  .l-footer_cta {
    margin: 0 -15px;
    padding: 50px 15px;
  }
  .l-footer_cta_inner {
    display: block;
  }
  .l-footer_cta_box {
    width: auto;
    padding: 20px;
  }
  .l-footer_cta_box + .l-footer_cta_box {
    margin-top: 15px;
  }
  .l-footer_cta_title {
    margin: 0 0 10px;
    white-space: nowrap;
    font-size: 21px;
    font-size: 2.1rem;
  }
  .l-footer_cta_title::before, .l-footer_cta_title::after {
    width: 100%;
  }
  .l-footer_cta_btn {
    max-width: none;
    padding: 14px 24px;
    border-radius: 25px;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .l-footer_cta_btn::after {
    right: 17px;
  }
  .l-footer_upper {
    margin: 0 -15px;
    padding: 30px 15px 15px;
  }
  .l-footer_banner {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -15px;
  }
  .l-footer_banner_item {
    width: calc(100%/2 - 15px);
    margin: 0 0 15px 15px;
  }
  .l-footer_banner_item img {
    width: 100%;
  }
  .l-footer_contents {
    margin: 0 -15px;
    padding: 0;
    background: #484852;
  }
  .l-footer_nav {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .l-footer_nav_menu {
    display: block;
  }
  .l-footer_nav_cat {
    position: relative;
    width: auto;
  }
  .l-footer_nav_cat_title {
    position: relative;
    z-index: 1;
    display: block;
    padding: 11px 65px 11px 15px;
    border-top: 1px solid #313138;
  }
  .l-footer_nav_cat_menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 0 -1px;
    background: #53535e;
    border-top: 1px solid #313138;
  }
  .l-footer_nav_cat_menu_wrap {
    position: relative;
    z-index: 1;
  }
  .l-footer_nav_cat_item {
    width: 50%;
  }
  .l-footer_nav_cat_item + .l-footer_nav_cat_item {
    margin-top: 0;
  }
  .l-footer_nav_cat_item:nth-child(odd) {
    border-right: 1px solid #313138;
  }
  .l-footer_nav_cat_item_toggle {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    display: block;
    width: 50px;
    height: 100%;
    background: #3d3d45;
    border-top: 1px solid #313138;
    border-left: 1px solid #313138;
    text-indent: -100vh;
    white-space: nowrap;
    overflow: hidden;
  }
  .l-footer_nav_cat_item_toggle::before {
    position: absolute;
    content: '';
    display: block;
    top: 21px;
    right: 0;
    left: 0;
    width: 16px;
    height: 2px;
    margin: 0 auto;
    background: #fff;
  }
  .l-footer_nav_cat_item_toggle::after {
    position: absolute;
    content: '';
    display: block;
    top: 14px;
    right: 0;
    left: 0;
    width: 2px;
    height: 16px;
    margin: 0 auto;
    background: #fff;
    -webkit-transition: all .3s ease-out;
    transition: all .3s ease-out;
  }
  .l-footer_nav_cat_item_toggle.isOpen::after {
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
  }
  .l-footer_nav_cat_item a {
    position: relative;
    display: block;
    height: 100%;
    padding: 11px 15px 11px 26px;
    border-bottom: 1px solid #313138;
  }
  .l-footer_nav_cat_item a::before {
    position: absolute;
    content: '';
    display: block;
    top: 1.2em;
    left: 15px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 4px;
    border-color: transparent transparent transparent #ffcd05;
  }
  .l-footer_nav_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0;
    border-top: 1px solid #313138;
    line-height: 1.5;
  }
  .l-footer_nav_link_item {
    width: 50%;
    padding: 0;
  }
  .l-footer_nav_link_item + .l-footer_nav_link_item {
    border-left: none;
  }
  .l-footer_nav_link_item:nth-child(odd) {
    border-right: 1px solid #313138;
  }
  .l-footer_nav_link_item a {
    position: relative;
    display: block;
    height: 100%;
    padding: 11px 15px 11px 26px;
    border-bottom: 1px solid #313138;
  }
  .l-footer_nav_link_item a::before {
    position: absolute;
    content: '';
    display: block;
    top: 1.2em;
    left: 15px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 4px;
    border-color: transparent transparent transparent #ffcd05;
  }
  .l-footer_bottom {
    display: block;
    text-align: center;
  }
  .l-footer_info_logo img {
    width: 165px;
  }
  .l-footer_info_address {
    margin: 15px 0 25px;
  }
  .l-footer_pagetop {
    right: 15px;
    bottom: 15px;
  }
}
/* =================================================
  .l-gnav
================================================= */
.l-gnav {
  padding: 0 30px;
  background: #000;
}
.l-gnav_menu {
  display: table;
  margin-left: auto;
}
.l-gnav_menu_item {
  display: table-cell;
  vertical-align: middle;
}
.l-gnav_menu_item--search {
  padding-left: 20px;
  text-align: center;
}
.l-gnav_menu_item--search .l-gnav_menu_link {
  width: 50px;
  padding: 14px 0;
  background: #26262b;
}
.l-gnav_menu_link {
  position: relative;
  z-index: 2;
  display: block;
  padding: 14px 20px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
}
.l-gnav_menu_link::before {
  position: absolute;
  content: '';
  display: block;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #ffcd05;
  opacity: 0;
  -webkit-transition: .1s linear;
  transition: .1s linear;
}
.l-gnav_menu_link.isActive::before {
  opacity: 1;
}
.l-gnav_menu_link:hover, .l-gnav_menu_link.isOpen {
  background: #222;
  text-decoration: none;
}

.isHome .l-gnav_menu_link:hover, .isHome .l-gnav_menu_link.isOpen {
  background: #1b1b1f;
  background: rgba(27, 27, 31, .7);
}

@media screen and (max-width: 1024px) {
  .l-gnav_menu_link {
    padding: 14px 15px;
  }
}
@media screen and (max-width: 768px) {
  .l-gnav {
    display: none;
  }
}
/* =================================================
  .l-gnav--sp
================================================= */
.l-gnav--sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .l-gnav--sp {
    position: absolute;
    display: block;
    width: 100%;
    height: calc(100vh - 92px);
    overflow-y: auto;
    background: #000;
    background: rgba(0, 0, 0, .8);
    opacity: 0;
    visibility: hidden;
    -webkit-transform: translateY(-30px);
    -ms-transform: translateY(-30px);
    transform: translateY(-30px);
    -webkit-transition: all .2s;
    transition: all .2s;
  }
  .l-gnav--sp a {
    color: #fff;
  }
  .l-gnav--sp a:hover {
    text-decoration: none;
  }
  .l-gnav--sp_inner {
    background: #53535e;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .l-gnav--sp_subMenu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 0 -1px;
    background: #53535e;
    border-top: 1px solid #313138;
  }
  .l-gnav--sp_subMenu_item {
    width: 50%;
  }
  .l-gnav--sp_subMenu_item.home {
    width: 100%;
  }
  .l-gnav--sp_subMenu_item a {
    position: relative;
    display: block;
    height: 100%;
    padding: 11px 15px 11px 26px;
    border-bottom: 1px solid #313138;
  }
  .l-gnav--sp_subMenu_item a::before {
    position: absolute;
    content: '';
    display: block;
    top: 1.2em;
    left: 15px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 4px;
    border-color: transparent transparent transparent #ffcd05;
  }
  .l-gnav--sp_subMenu_item:nth-child(even) a {
    border-right: 1px solid #313138;
  }
  .l-gnav--sp_subMenu_label {
    position: relative;
  }
  .l-gnav--sp_subMenu_label.student::after {
    content: url('/assets/images/common/ico_student.svg');
    display: inline-block;
    width: 12px;
    height: 18px;
    margin-left: 4px;
    vertical-align: middle;
  }
  .l-gnav--sp_menu {
    display: block;
  }
  .l-gnav--sp_cat {
    position: relative;
    width: auto;
  }
  .l-gnav--sp_cat_title {
    position: relative;
    z-index: 1;
    display: block;
    padding: 11px 65px 11px 15px;
    background: #484852;
    border-top: 1px solid #313138;
    font-weight: 700;
  }
  .l-gnav--sp_cat_menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 0 -1px;
    background: #53535e;
    border-top: 1px solid #313138;
  }
  .l-gnav--sp_cat_menu_wrap {
    position: relative;
    z-index: 1;
  }
  .l-gnav--sp_cat_item {
    width: 50%;
  }
  .l-gnav--sp_cat_item + .l-gnav--sp_cat_item {
    margin-top: 0;
  }
  .l-gnav--sp_cat_item:nth-child(odd) {
    border-right: 1px solid #313138;
  }
  .l-gnav--sp_cat_item_toggle {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    display: block;
    width: 50px;
    height: 100%;
    background: #000;
    border-top: 1px solid #313138;
    border-left: 1px solid #313138;
    text-indent: -100vh;
    white-space: nowrap;
    overflow: hidden;
  }
  .l-gnav--sp_cat_item_toggle::before {
    position: absolute;
    content: '';
    display: block;
    top: 21px;
    right: 0;
    left: 0;
    width: 16px;
    height: 2px;
    margin: 0 auto;
    background: #fff;
  }
  .l-gnav--sp_cat_item_toggle::after {
    position: absolute;
    content: '';
    display: block;
    top: 14px;
    right: 0;
    left: 0;
    width: 2px;
    height: 16px;
    margin: 0 auto;
    background: #fff;
    -webkit-transition: all .3s ease-out;
    transition: all .3s ease-out;
  }
  .l-gnav--sp_cat_item_toggle.isOpen::after {
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
  }
  .l-gnav--sp_cat_item a {
    position: relative;
    display: block;
    height: 100%;
    padding: 11px 15px 11px 26px;
    border-bottom: 1px solid #313138;
  }
  .l-gnav--sp_cat_item a::before {
    position: absolute;
    content: '';
    display: block;
    top: 1.2em;
    left: 15px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 4px;
    border-color: transparent transparent transparent #ffcd05;
  }
  .l-gnav--sp_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0;
    border-top: 1px solid #313138;
    line-height: 1.5;
  }
  .l-gnav--sp_link_item {
    width: 50%;
    padding: 0;
  }
  .l-gnav--sp_link_item + .l-gnav--sp_link_item {
    border-left: none;
  }
  .l-gnav--sp_link_item:nth-child(odd) {
    border-right: 1px solid #313138;
  }
  .l-gnav--sp_link_item a {
    position: relative;
    display: block;
    height: 100%;
    padding: 11px 15px 11px 26px;
    border-bottom: 1px solid #313138;
  }
  .l-gnav--sp_link_item a::before {
    position: absolute;
    content: '';
    display: block;
    top: 1.2em;
    left: 15px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 4px;
    border-color: transparent transparent transparent #ffcd05;
  }
  .l-gnav--sp_close {
    display: block;
    padding: 12px 15px 11px;
    background: #000;
    text-align: center;
  }
  .l-gnav--sp_close_label {
    position: relative;
    display: inline-block;
    padding-right: 22px;
  }
  .l-gnav--sp_close_label::before, .l-gnav--sp_close_label::after {
    position: absolute;
    content: '';
    display: block;
    top: 0;
    right: 1px;
    width: 13px;
    height: 2px;
    margin: auto 0;
    background: #fff;
    bottom: 0;
  }
  .l-gnav--sp_close_label::before {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  .l-gnav--sp_close_label::after {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
  }

  .isFixed .l-gnav--sp {
    position: fixed;
    left: 0;
    top: 50px;
    height: calc(100vh - 50px);
  }

  html.isOpen .l-gnav--sp {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
/* =================================================
  .l-dropDownMenu
================================================= */
.l-dropDownMenu {
  position: absolute;
  top: 100%;
  left: 0;
  display: block;
  visibility: hidden;
  width: 100%;
  padding: 0 30px;
  background: rgba(27, 27, 31, .8);
  text-align: left;
  opacity: 0;
  -webkit-transition: all .2s;
  transition: all .2s;
  -webkit-transform: translateY(-30px);
  -ms-transform: translateY(-30px);
  transform: translateY(-30px);
}
.l-dropDownMenu a {
  color: #fff;
}
.l-dropDownMenu.isOpen {
  visibility: visible;
  opacity: 1;
  -webkit-transform: translateY(0%);
  -ms-transform: translateY(0%);
  transform: translateY(0%);
}
.l-dropDownMenu_inner {
  position: relative;
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
  padding: 30px 0 20px;
}
.l-dropDownMenu_title {
  padding: 0 0 0 38px;
  background: url('/assets/images/common/ico_arrow_next.svg') 10px 50% no-repeat;
  font-weight: 700;
  font-size: 18px;
  font-size: 1.8rem;
}
.l-dropDownMenu_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 25px 0 0 -30px;
}
.l-dropDownMenu_item {
  width: calc(100%/3 - 30px);
  margin: 0 0 0 30px;
}
.l-dropDownMenu_item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 10px;
  font-weight: 700;
  font-size: 15px;
  font-size: 1.5rem;
}
.l-dropDownMenu_item a:hover {
  text-decoration: none;
  background: rgba(255, 255, 255, .2);
}
.l-dropDownMenu_item_thumb {
  margin: 0 20px 0 0;
}
.l-dropDownMenu_item_label {
  width: calc(100% - 180px);
}
.l-dropDownMenu_close {
  position: absolute;
  top: 35px;
  right: 10px;
  width: 21px;
  height: 21px;
}
.l-dropDownMenu_close_btn {
  position: relative;
  display: block;
  width: 21px;
  height: 21px;
}
.l-dropDownMenu_close_btn::before, .l-dropDownMenu_close_btn::after {
  position: absolute;
  content: '';
  display: block;
  top: 9px;
  right: -2px;
  width: 25px;
  height: 2px;
  background: #fff;
}
.l-dropDownMenu_close_btn::before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.l-dropDownMenu_close_btn::after {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

@media screen and (max-width: 1024px) {
  .l-dropDownMenu_item {
    width: calc(100%/2 - 30px);
  }
}
/* =================================================
  .l-siteSearch
================================================= */
.l-siteSearch {
  padding: 20px 50px;
}
.l-siteSearch_form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 970px;
  margin: 0 auto;
  border-radius: 25px;
  overflow: hidden;
}
.l-siteSearch_field {
  padding: 13px 20px 13px 30px;
  background: #fff;
  width: calc(100% - 6.7em);
  border: none;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-size: 15px;
  font-size: 1.5rem;
}
.l-siteSearch_btn {
  width: 6.7em;
  background: #ffcd05;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .l-siteSearch {
    padding: 20px 15px;
    border-top: 1px solid #313138;
    border-bottom: 1px solid #313138;
  }
  .l-siteSearch_form {
    border-radius: 15px;
  }
  .l-siteSearch_field {
    padding: 5px 15px;
    width: calc(100% - 60px);
    font-size: 13px;
    font-size: 1.3rem;
  }
  .l-siteSearch_btn {
    width: 60px;
    font-size: 13px;
    font-size: 1.3rem;
  }
}
/* =================================================
  .l-localnav
================================================= */
.l-localnav {
  position: relative;
  width: 240px;
  margin: -86px 0 0;
  line-height: 1.5;
}
.l-localnav_title {
  display: table;
  width: 100%;
  height: 116px;
  margin: 0;
  background: #000;
}
.l-localnav_title a {
  display: table-cell;
  height: 100%;
  padding: 20px 20px 20px 50px;
  background: url('/assets/images/common/ico_arrow_next.svg') 20px 50% no-repeat;
  vertical-align: middle;
  color: #fff;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
}
.l-localnav_title a:hover {
  text-decoration: none;
}
.l-localnav_list {
  width: 100%;
}
.l-localnav_list .l-localnav_list .l-localnav_list {
  position: relative;
  z-index: 1;
  padding: 10px 0;
  background: #f4f9fd;
}
.l-localnav_item {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  border-bottom: 1px solid #fff;
}
.l-localnav_item_link {
  position: relative;
  display: block;
  width: 100%;
  padding: 20px 20px 20px 30px;
  font-size: 15px;
  font-size: 1.5rem;
}
.l-localnav_item_link:hover {
  text-decoration: none;
  background: #fff;
}
.l-localnav_item_link::after {
  position: absolute;
  content: '';
  display: block;
  top: 1.8em;
  left: 20px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #ffcd05;
}
.l-localnav_item_link.isActive {
  background: #fff;
}

@media screen and (max-width: 1024px) {
  .l-localnav {
    width: auto;
    margin: 0;
  }
}
@media screen and (max-width: 768px) {
  .l-localnav {
    margin: 0;
  }
  .l-localnav_title {
    height: auto;
    margin: 0;
  }
  .l-localnav_title a {
    height: auto;
    padding: 18px 15px 18px 37px;
    background: url('/assets/images/common/ico_arrow_next.svg') 10px 50% no-repeat;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .l-localnav_item_link {
    position: relative;
    display: block;
    width: 100%;
    padding: 15px 15px 15px 26px;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .l-localnav_item_link::after {
    top: 1.5em;
    left: 15px;
  }
}
/* -----------------------------------------------
  .l-topicsPath
----------------------------------------------- */
.l-topicsPath {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
}
.l-topicsPath_inner {
  padding: 15px 30px;
}
.l-topicsPath_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
}
.l-topicsPath_list_item {
  position: relative;
  font-size: 12px;
  font-size: 1.2rem;
}
.l-topicsPath_list_item a {
  color: #fff;
}
.l-topicsPath_list_item + .l-topicsPath_list_item::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  margin: 0 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  vertical-align: .1em;
}

@media screen and (max-width: 768px) {
  .l-topicsPath_inner {
    position: relative;
    padding: 10px 15px;
  }
  .l-topicsPath_list_item {
    font-size: 10px;
    font-size: 1rem;
  }
}
/* =================================================
  .l-category
================================================= */
.l-category_header {
  padding: 100px 30px 145px;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
}
.l-category_header.about {
  background-image: url('/assets/images/about/bg_category.jpg');
}
.l-category_header.j-highschool {
  background-image: url('/assets/images/j-highschool/bg_category.jpg');
}
.l-category_header.highschool {
  background-image: url('/assets/images/highschool/bg_category.jpg');
}
.l-category_header.guidance {
  background-image: url('/assets/images/guidance/bg_category.jpg');
}
.l-category_header.schoollife {
  background-image: url('/assets/images/schoollife/bg_category.jpg');
}
.l-category_header.exam {
  background-image: url('/assets/images/exam/bg_category.jpg');
}
.l-category_header_inner {
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
  color: #fff;
}
.l-category_header_title {
  position: relative;
  margin: 0 0 35px;
  padding: 0 0 25px;
  text-align: center;
  font-size: 30px;
  font-size: 3rem;
  line-height: 1.3;
}
.l-category_header_title::after {
  position: absolute;
  content: '';
  display: block;
  left: 0;
  right: 0;
  bottom: 0;
  width: 70px;
  height: 2px;
  margin: 0 auto;
  background: #ffcd05;
}
.l-category_header_copy {
  margin: 0 0 20px;
  text-align: center;
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.3;
}
.l-category_header_text {
  margin: 0;
}
.l-category_header_text + .l-category_header_text {
  margin-top: 20px;
}
.l-category_header_text--division2 {
  text-align: center;
}
.l-category_body {
  width: 100%;
  max-width: 1170px;
  margin: -90px auto 0;
  padding: 30px;
  background: #f7f7fa;
}

@media screen and (max-width: 768px) {
  .l-category_header {
    padding: 0;
    background: none !important;
  }
  .l-category_header_inner {
    width: 100%;
    max-width: 1170px;
    margin: 0 auto;
    color: #141414;
  }
  .l-category_header_title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin: 0 -15px 25px;
    min-height: 140px;
    padding: 55px 15px 20px;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: cover;
    text-align: left;
    font-size: 19px;
    font-size: 1.9rem;
    color: #fff;
  }
  .l-category_header_title::after {
    display: none;
  }
  .l-category_header_text--division2 {
    text-align: left;
  }
  .l-category_header_text--division2 br {
    display: none;
  }
  .l-category_header_copy {
    text-align: left;
    font-size: 21px;
    font-size: 2.1rem;
  }
  .l-category_header.about .l-category_header_title {
    background-image: url('/assets/images/about/bg_category.jpg');
  }
  .l-category_header.j-highschool .l-category_header_title {
    background-image: url('/assets/images/j-highschool/bg_category.jpg');
  }
  .l-category_header.highschool .l-category_header_title {
    background-image: url('/assets/images/highschool/bg_category.jpg');
  }
  .l-category_header.guidance .l-category_header_title {
    background-image: url('/assets/images/guidance/bg_category.jpg');
  }
  .l-category_header.schoollife .l-category_header_title {
    background-image: url('/assets/images/schoollife/bg_category.jpg');
  }
  .l-category_header.exam .l-category_header_title {
    background-image: url('/assets/images/exam/bg_category.jpg');
  }
  .l-category_body {
    margin: 0;
    padding: 50px 0 20px;
  }
}
/* =================================================
  .l-pageHeader
================================================= */
.l-pageHeader {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 260px;
  padding: 50px 30px;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
}
.l-pageHeader.topics {
  background-image: url('/assets/images/topics/bg_category.jpg');
}
.l-pageHeader.about {
  background-image: url('/assets/images/about/bg_category.jpg');
}
.l-pageHeader.j-highschool {
  background-image: url('/assets/images/j-highschool/bg_category.jpg');
}
.l-pageHeader.highschool {
  background-image: url('/assets/images/highschool/bg_category.jpg');
}
.l-pageHeader.guidance {
  background-image: url('/assets/images/guidance/bg_category.jpg');
}
.l-pageHeader.schoollife {
  background-image: url('/assets/images/schoollife/bg_category.jpg');
}
.l-pageHeader.exam {
  background-image: url('/assets/images/exam/bg_category.jpg');
}
.l-pageHeader.examniee {
  background-image: url('/assets/images/examniee/bg_category.jpg');
}
.l-pageHeader.alumni {
  background-image: url('/assets/images/alumni/bg_category.jpg');
}
.l-pageHeader.student {
  background-image: url('/assets/images/student/bg_category.jpg');
}
.l-pageHeader.privacy {
  background-image: url('/assets/images/privacy/bg_category.jpg');
}
.l-pageHeader.access {
  background-image: url('/assets/images/access/bg_category.jpg');
}
.l-pageHeader.brochure {
  background-image: url('/assets/images/brochure/bg_category.jpg');
}
.l-pageHeader.sitemap {
  background-image: url('/assets/images/sitemap/bg_category.jpg');
}
.l-pageHeader.recruit {
  background-image: url('/assets/images/recruit/bg_category.jpg');
}
.l-pageHeader.seiritz-tv {
  background-image: url('/assets/images/seiritz-tv/bg_category.jpg');
}
.l-pageHeader.earthproject {
  background-image: url('/assets/images/earthproject/bg_category.jpg');
}
.l-pageHeader.calendar {
  background-image: url('/assets/images/calendar/bg_category.jpg');
}
.l-pageHeader.football-entry {
  background-image: url('/assets/images/football-entry/bg_category.jpg');
}
.l-pageHeader.search {
  background-image: url('/assets/images/search/bg_category.jpg');
}
.l-pageHeader.notfound {
  background-image: url('/assets/images/notfound/bg_category.jpg');
}
.l-pageHeader_title {
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
  padding: 30px 0;
  color: #fff;
  font-size: 30px;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.4;
}

@media screen and (max-width: 768px) {
  .l-pageHeader {
    height: 140px;
    margin: 0 -15px;
    padding: 35px 15px;
  }
  .l-pageHeader_title {
    padding: 20px 0;
    font-size: 19px;
    font-size: 1.9rem;
  }
}
/* =================================================
  .l-subContents
================================================= */
.l-subContents {
  margin: 50px 0 0;
}
.l-subContents + .l-subContents {
  margin-top: 30px;
}
.l-subContents_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 0 30px;
  text-align: center;
  white-space: nowrap;
  font-size: 20px;
  font-size: 2rem;
  font-weight: 700;
}
.l-subContents_title::before, .l-subContents_title::after {
  content: '';
  display: inline-block;
  width: 100%;
  height: 2px;
  background: #ffcd05;
}
.l-subContents_title::before {
  margin-right: 9px;
}
.l-subContents_title::after {
  margin-left: 9px;
}
.l-subContents_title.schoollife::before, .l-subContents_title.schoollife::after {
  background: #4796d9;
}

@media screen and (max-width: 768px) {
  .l-subContents {
    margin: 40px 0 0;
  }
  .l-subContents_title {
    font-size: 19px;
    font-size: 1.9rem;
    font-weight: 700;
  }
}
/*****************************************************
  Object
*****************************************************/
.u-mt0 {
  margin-top: 0 !important;
}

.u-mr0 {
  margin-right: 0 !important;
}

.u-mb0 {
  margin-bottom: 0 !important;
}

.u-ml0 {
  margin-left: 0 !important;
}

.u-mt5 {
  margin-top: 5px !important;
}

.u-mr5 {
  margin-right: 5px !important;
}

.u-mb5 {
  margin-bottom: 5px !important;
}

.u-ml5 {
  margin-left: 5px !important;
}

.u-mt10 {
  margin-top: 10px !important;
}

.u-mr10 {
  margin-right: 10px !important;
}

.u-mb10 {
  margin-bottom: 10px !important;
}

.u-ml10 {
  margin-left: 10px !important;
}

.u-mt15 {
  margin-top: 15px !important;
}

.u-mr15 {
  margin-right: 15px !important;
}

.u-mb15 {
  margin-bottom: 15px !important;
}

.u-ml15 {
  margin-left: 15px !important;
}

.u-mt20 {
  margin-top: 20px !important;
}

.u-mr20 {
  margin-right: 20px !important;
}

.u-mb20 {
  margin-bottom: 20px !important;
}

.u-ml20 {
  margin-left: 20px !important;
}

.u-mt25 {
  margin-top: 25px !important;
}

.u-mr25 {
  margin-right: 25px !important;
}

.u-mb25 {
  margin-bottom: 25px !important;
}

.u-ml25 {
  margin-left: 25px !important;
}

.u-mt30 {
  margin-top: 30px !important;
}

.u-mr30 {
  margin-right: 30px !important;
}

.u-mb30 {
  margin-bottom: 30px !important;
}

.u-ml30 {
  margin-left: 30px !important;
}

.u-mt35 {
  margin-top: 35px !important;
}

.u-mr35 {
  margin-right: 35px !important;
}

.u-mb35 {
  margin-bottom: 35px !important;
}

.u-ml35 {
  margin-left: 35px !important;
}

.u-mt40 {
  margin-top: 40px !important;
}

.u-mr40 {
  margin-right: 40px !important;
}

.u-mb40 {
  margin-bottom: 40px !important;
}

.u-ml40 {
  margin-left: 40px !important;
}

.u-mt45 {
  margin-top: 45px !important;
}

.u-mr45 {
  margin-right: 45px !important;
}

.u-mb45 {
  margin-bottom: 45px !important;
}

.u-ml45 {
  margin-left: 45px !important;
}

.u-mt50 {
  margin-top: 50px !important;
}

.u-mr50 {
  margin-right: 50px !important;
}

.u-mb50 {
  margin-bottom: 50px !important;
}

.u-ml50 {
  margin-left: 50px !important;
}

.u-mt55 {
  margin-top: 55px !important;
}

.u-mr55 {
  margin-right: 55px !important;
}

.u-mb55 {
  margin-bottom: 55px !important;
}

.u-ml55 {
  margin-left: 55px !important;
}

.u-mt60 {
  margin-top: 60px !important;
}

.u-mr60 {
  margin-right: 60px !important;
}

.u-mb60 {
  margin-bottom: 60px !important;
}

.u-ml60 {
  margin-left: 60px !important;
}

.u-mt65 {
  margin-top: 65px !important;
}

.u-mr65 {
  margin-right: 65px !important;
}

.u-mb65 {
  margin-bottom: 65px !important;
}

.u-ml65 {
  margin-left: 65px !important;
}

.u-mt70 {
  margin-top: 70px !important;
}

.u-mr70 {
  margin-right: 70px !important;
}

.u-mb70 {
  margin-bottom: 70px !important;
}

.u-ml70 {
  margin-left: 70px !important;
}

.u-mt75 {
  margin-top: 75px !important;
}

.u-mr75 {
  margin-right: 75px !important;
}

.u-mb75 {
  margin-bottom: 75px !important;
}

.u-ml75 {
  margin-left: 75px !important;
}

.u-mt80 {
  margin-top: 80px !important;
}

.u-mr80 {
  margin-right: 80px !important;
}

.u-mb80 {
  margin-bottom: 80px !important;
}

.u-ml80 {
  margin-left: 80px !important;
}

.u-mt85 {
  margin-top: 85px !important;
}

.u-mr85 {
  margin-right: 85px !important;
}

.u-mb85 {
  margin-bottom: 85px !important;
}

.u-ml85 {
  margin-left: 85px !important;
}

.u-mt90 {
  margin-top: 90px !important;
}

.u-mr90 {
  margin-right: 90px !important;
}

.u-mb90 {
  margin-bottom: 90px !important;
}

.u-ml90 {
  margin-left: 90px !important;
}

.u-mt95 {
  margin-top: 95px !important;
}

.u-mr95 {
  margin-right: 95px !important;
}

.u-mb95 {
  margin-bottom: 95px !important;
}

.u-ml95 {
  margin-left: 95px !important;
}

.u-mt100 {
  margin-top: 100px !important;
}

.u-mr100 {
  margin-right: 100px !important;
}

.u-mb100 {
  margin-bottom: 100px !important;
}

.u-ml100 {
  margin-left: 100px !important;
}

.u-objCenter {
  margin-left: auto !important;
  margin-right: auto !important;
}

.u-pt0 {
  padding-top: 0 !important;
}

.u-pr0 {
  padding-right: 0 !important;
}

.u-pb0 {
  padding-bottom: 0 !important;
}

.u-pl0 {
  padding-left: 0 !important;
}

.u-pt5 {
  padding-top: 5px !important;
}

.u-pr5 {
  padding-right: 5px !important;
}

.u-pb5 {
  padding-bottom: 5px !important;
}

.u-pl5 {
  padding-left: 5px !important;
}

.u-pt10 {
  padding-top: 10px !important;
}

.u-pr10 {
  padding-right: 10px !important;
}

.u-pb10 {
  padding-bottom: 10px !important;
}

.u-pl10 {
  padding-left: 10px !important;
}

.u-pt15 {
  padding-top: 15px !important;
}

.u-pr15 {
  padding-right: 15px !important;
}

.u-pb15 {
  padding-bottom: 15px !important;
}

.u-pl15 {
  padding-left: 15px !important;
}

.u-pt20 {
  padding-top: 20px !important;
}

.u-pr20 {
  padding-right: 20px !important;
}

.u-pb20 {
  padding-bottom: 20px !important;
}

.u-pl20 {
  padding-left: 20px !important;
}

.u-pt25 {
  padding-top: 25px !important;
}

.u-pr25 {
  padding-right: 25px !important;
}

.u-pb25 {
  padding-bottom: 25px !important;
}

.u-pl25 {
  padding-left: 25px !important;
}

.u-pt30 {
  padding-top: 30px !important;
}

.u-pr30 {
  padding-right: 30px !important;
}

.u-pb30 {
  padding-bottom: 30px !important;
}

.u-pl30 {
  padding-left: 30px !important;
}

.u-pt35 {
  padding-top: 35px !important;
}

.u-pr35 {
  padding-right: 35px !important;
}

.u-pb35 {
  padding-bottom: 35px !important;
}

.u-pl35 {
  padding-left: 35px !important;
}

.u-pt40 {
  padding-top: 40px !important;
}

.u-pr40 {
  padding-right: 40px !important;
}

.u-pb40 {
  padding-bottom: 40px !important;
}

.u-pl40 {
  padding-left: 40px !important;
}

.u-pt45 {
  padding-top: 45px !important;
}

.u-pr45 {
  padding-right: 45px !important;
}

.u-pb45 {
  padding-bottom: 45px !important;
}

.u-pl45 {
  padding-left: 45px !important;
}

.u-pt50 {
  padding-top: 50px !important;
}

.u-pr50 {
  padding-right: 50px !important;
}

.u-pb50 {
  padding-bottom: 50px !important;
}

.u-pl50 {
  padding-left: 50px !important;
}

.u-pt55 {
  padding-top: 55px !important;
}

.u-pr55 {
  padding-right: 55px !important;
}

.u-pb55 {
  padding-bottom: 55px !important;
}

.u-pl55 {
  padding-left: 55px !important;
}

.u-pt60 {
  padding-top: 60px !important;
}

.u-pr60 {
  padding-right: 60px !important;
}

.u-pb60 {
  padding-bottom: 60px !important;
}

.u-pl60 {
  padding-left: 60px !important;
}

.u-pt65 {
  padding-top: 65px !important;
}

.u-pr65 {
  padding-right: 65px !important;
}

.u-pb65 {
  padding-bottom: 65px !important;
}

.u-pl65 {
  padding-left: 65px !important;
}

.u-pt70 {
  padding-top: 70px !important;
}

.u-pr70 {
  padding-right: 70px !important;
}

.u-pb70 {
  padding-bottom: 70px !important;
}

.u-pl70 {
  padding-left: 70px !important;
}

.u-pt75 {
  padding-top: 75px !important;
}

.u-pr75 {
  padding-right: 75px !important;
}

.u-pb75 {
  padding-bottom: 75px !important;
}

.u-pl75 {
  padding-left: 75px !important;
}

.u-pt80 {
  padding-top: 80px !important;
}

.u-pr80 {
  padding-right: 80px !important;
}

.u-pb80 {
  padding-bottom: 80px !important;
}

.u-pl80 {
  padding-left: 80px !important;
}

.u-pt85 {
  padding-top: 85px !important;
}

.u-pr85 {
  padding-right: 85px !important;
}

.u-pb85 {
  padding-bottom: 85px !important;
}

.u-pl85 {
  padding-left: 85px !important;
}

.u-pt90 {
  padding-top: 90px !important;
}

.u-pr90 {
  padding-right: 90px !important;
}

.u-pb90 {
  padding-bottom: 90px !important;
}

.u-pl90 {
  padding-left: 90px !important;
}

.u-pt95 {
  padding-top: 95px !important;
}

.u-pr95 {
  padding-right: 95px !important;
}

.u-pb95 {
  padding-bottom: 95px !important;
}

.u-pl95 {
  padding-left: 95px !important;
}

.u-pt100 {
  padding-top: 100px !important;
}

.u-pr100 {
  padding-right: 100px !important;
}

.u-pb100 {
  padding-bottom: 100px !important;
}

.u-pl100 {
  padding-left: 100px !important;
}

.u-wAuto {
  width: auto !important;
}

.u-w5 {
  width: 5% !important;
}

.u-w10 {
  width: 10% !important;
}

.u-w15 {
  width: 15% !important;
}

.u-w20 {
  width: 20% !important;
}

.u-w25 {
  width: 25% !important;
}

.u-w30 {
  width: 30% !important;
}

.u-w35 {
  width: 35% !important;
}

.u-w40 {
  width: 40% !important;
}

.u-w45 {
  width: 45% !important;
}

.u-w50 {
  width: 50% !important;
}

.u-w55 {
  width: 55% !important;
}

.u-w60 {
  width: 60% !important;
}

.u-w65 {
  width: 65% !important;
}

.u-w70 {
  width: 70% !important;
}

.u-w75 {
  width: 75% !important;
}

.u-w80 {
  width: 80% !important;
}

.u-w85 {
  width: 85% !important;
}

.u-w90 {
  width: 90% !important;
}

.u-w95 {
  width: 95% !important;
}

.u-w100 {
  width: 100% !important;
}

.u-fs11 {
  font-size: 11px !important;
  font-size: 1.1rem;
}

.u-fs12 {
  font-size: 12px !important;
  font-size: 1.2rem;
}

.u-fs13 {
  font-size: 13px !important;
  font-size: 1.3rem;
}

.u-fs14 {
  font-size: 14px !important;
  font-size: 1.4rem;
}

.u-fs15 {
  font-size: 15px !important;
  font-size: 1.5rem;
}

.u-fs16 {
  font-size: 16px !important;
  font-size: 1.6rem;
}

.u-fs17 {
  font-size: 17px !important;
  font-size: 1.7rem;
}

.u-fs18 {
  font-size: 18px !important;
  font-size: 1.8rem;
}

.u-fs19 {
  font-size: 19px !important;
  font-size: 1.9rem;
}

.u-fs20 {
  font-size: 20px !important;
  font-size: 2rem;
}

.u-fs21 {
  font-size: 21px !important;
  font-size: 2.1rem;
}

.u-fs22 {
  font-size: 22px !important;
  font-size: 2.2rem;
}

.u-fs23 {
  font-size: 23px !important;
  font-size: 2.3rem;
}

.u-fs24 {
  font-size: 24px !important;
  font-size: 2.4rem;
}

.u-fs25 {
  font-size: 25px !important;
  font-size: 2.5rem;
}

.u-fs26 {
  font-size: 26px !important;
  font-size: 2.6rem;
}

.u-fs27 {
  font-size: 27px !important;
  font-size: 2.7rem;
}

.u-fs28 {
  font-size: 28px !important;
  font-size: 2.8rem;
}

.u-fs29 {
  font-size: 29px !important;
  font-size: 2.9rem;
}

.u-fs30 {
  font-size: 30px !important;
  font-size: 3rem;
}

.u-fs31 {
  font-size: 31px !important;
  font-size: 3.1rem;
}

.u-fs32 {
  font-size: 32px !important;
  font-size: 3.2rem;
}

.u-fs33 {
  font-size: 33px !important;
  font-size: 3.3rem;
}

.u-fs34 {
  font-size: 34px !important;
  font-size: 3.4rem;
}

.u-fs35 {
  font-size: 35px !important;
  font-size: 3.5rem;
}

.u-fsBig {
  font-size: 20px !important;
  font-size: 2rem;
}

.u-fsSmall {
  font-size: 13px !important;
  font-size: 1.3rem;
}

@media screen and (max-width: 768px) {
  .u-fsBig {
    font-size: 18px !important;
    font-size: 1.8rem;
  }

  .u-fsSmall {
    font-size: 12px !important;
    font-size: 1.2rem;
  }
}
.u-textbold {
  font-weight: 700 !important;
}

.u-textnormal {
  font-weight: 200 !important;
}

.u-emp {
  color: #d92121 !important;
}

.u-pink {
  color: #ed7980 !important;
}

.u-orange {
  color: #f4960d !important;
}

.u-green {
  color: #028658 !important;
}

.u-yellow {
  color: #ffcd05 !important;
}

.u-blue {
  color: #0071a1 !important;
}

.u-clear {
  clear: both !important;
}

.u-ac {
  text-align: center !important;
}

.u-ar {
  text-align: right !important;
}

.u-al {
  text-align: left !important;
}

.u-vm {
  vertical-align: middle !important;
}

.u-vt {
  vertical-align: top !important;
}

.u-vb {
  vertical-align: bottom !important;
}

.u-isSP {
  display: none !important;
}

@media screen and (max-width: 768px) {
  .u-isPC {
    display: none !important;
  }

  .u-isSP {
    display: inherit !important;
  }
}
/* -----------------------------------------------
  .c-btn
----------------------------------------------- */
.c-btn {
  position: relative;
  display: block;
  margin-top: 30px;
  padding: 14px 15px;
  border: 1px solid #000;
  text-decoration: none;
  text-align: center;
  color: #000;
  line-height: 1.3;
  -webkit-transition: .2s linear;
  transition: .2s linear;
  outline: none;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
}
.c-btn.c-grid_col {
  margin-top: 0;
}
.c-btn:hover {
  text-decoration: none;
}
.c-btn:not(.c-btn--theme):hover {
  background: #000;
  color: #fff;
}
.c-btn--inline {
  display: inline-table;
  margin-top: 0;
  margin-left: 20px;
  min-width: 0;
  min-height: 51px;
}
.c-btn--flex {
  display: table;
  min-width: 270px;
}
.c-btn--small {
  min-width: 40%;
}
.c-btn--medium {
  min-width: 50%;
}
.c-btn--large {
  min-width: 75%;
}
.c-btn--center {
  margin-left: auto;
  margin-right: auto;
}
.c-btn--right {
  margin-left: auto;
}
.c-btn--next {
  padding-right: 30px;
  padding-left: 30px;
}
.c-btn--next::after {
  position: absolute;
  content: '';
  display: block;
  top: 0;
  bottom: 0;
  right: 22px;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #000;
  -webkit-transition: .1s linear;
  transition: .1s linear;
}
.c-btn--next:not(.c-btn--theme):hover::after {
  border-color: transparent transparent transparent #fff;
}
.c-btn--prev {
  padding-right: 30px;
  padding-left: 30px;
}
.c-btn--prev::before {
  position: absolute;
  content: '';
  display: block;
  top: 0;
  bottom: 0;
  left: 22px;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-width: 4px 4px 4px 0;
  border-color: transparent #000 transparent transparent;
  -webkit-transition: .1s linear;
  transition: .1s linear;
}
.c-btn--prev:not(.c-btn--theme):hover::before {
  border-color: transparent #fff transparent transparent;
}
.c-btn--theme {
  background: #ffcd05;
  border-color: transparent;
}
.c-btn--theme:hover {
  background-color: rgba(255, 205, 5, .7);
}
.c-btn_ico {
  position: relative;
  display: inline-block;
}
.c-btn_ico--external {
  padding-right: 20px;
  background: url('/assets/images/common/ico_external.svg') 100% 50% no-repeat;
}

@media screen and (max-width: 768px) {
  .c-btn {
    min-width: 0;
    margin-top: 15px;
    padding: 13px;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .c-btn--inline {
    display: block;
    width: 100%;
    margin-left: 0;
    min-height: 0;
  }
  .c-btn--flex {
    display: block;
    width: 100%;
    min-width: 0;
  }
  .c-btn--small {
    min-width: 0;
  }
  .c-btn--medium {
    min-width: 0;
  }
}
/* -----------------------------------------------
  title
----------------------------------------------- */
.c-pageTitle {
  position: relative;
  margin: 0 0 30px;
  padding: 0 0 25px;
  font-size: 36px;
  font-size: 3.6rem;
  font-weight: 400;
  text-align: center;
  line-height: 1.3;
}
.c-pageTitle::after {
  position: absolute;
  content: '';
  display: block;
  left: 0;
  right: 0;
  bottom: 0;
  width: 70px;
  height: 2px;
  margin: 0 auto;
  background: #ffcd05;
}

.c-subTitle_lv02 {
  position: relative;
  margin-bottom: 30px;
  padding-bottom: 15px;
  font-size: 28px;
  font-size: 2.8rem;
  line-height: 1.5;
  border-bottom: 3px solid #e2e6ef;
}
.c-subTitle_lv02:before {
  content: ' ';
  position: absolute;
  left: 0;
  bottom: -3px;
  display: block;
  width: 70px;
  height: 3px;
  background: #008cd6;
}
.c-subTitle_lv02--division2 {
  font-weight: 400;
  font-size: 20px;
  font-size: 2rem;
}
.c-subTitle_lv02--division2 em {
  display: block;
  font-weight: 700;
  font-size: 28px;
  font-size: 2.8rem;
}
.c-subTitle_lv03 {
  position: relative;
  margin: 0 0 40px;
  padding: 0 0 3px 20px;
  line-height: 1.5;
  font-size: 24px;
  font-size: 2.4rem;
}
.c-subTitle_lv03:before {
  content: ' ';
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 3px;
  height: 100%;
  background: -webkit-linear-gradient(top, #00afe2 0%, #00afe2 50%, #008cd6 51%, #008cd6 100%);
  background: linear-gradient(to bottom, #00afe2 0%, #00afe2 50%, #008cd6 51%, #008cd6 100%);
}
.c-subTitle_lv03--division2 {
  font-weight: 400;
  font-size: 20px;
  font-size: 2rem;
}
.c-subTitle_lv03--division2 em {
  display: block;
  font-weight: 700;
  font-size: 24px;
  font-size: 2.4rem;
}
.c-subTitle_lv04 {
  margin: 0 0 30px;
  padding-bottom: 10px;
  font-size: 20px;
  font-size: 2rem;
  border-bottom: 2px solid #008cd6;
}
.c-subTitle_lv04--division2 {
  font-weight: 400;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5;
}
.c-subTitle_lv04--division2 em {
  display: block;
  font-weight: 700;
  font-size: 20px;
  font-size: 2rem;
}
.c-subTitle_lv04--isIcon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.c-subTitle_lv04--yellow {
  border-color: #ffcd05;
}
.c-subTitle_lv05 {
  margin: 0 0 20px;
  padding: 0 0 17px;
  border-bottom: 1px solid #e2e6ef;
  line-height: 1.5;
  font-size: 18px;
  font-size: 1.8rem;
}
.c-subTitle_lv06 {
  margin: 0 0 10px;
  line-height: 1.5;
  font-size: 16px;
  font-size: 1.6rem;
}

@media screen and (max-width: 768px) {
  .c-pageTitle {
    font-size: 30px;
    font-size: 3rem;
  }

  .c-subTitle_lv02 {
    margin-bottom: 25px;
    font-size: 25px;
    font-size: 2.5rem;
  }
  .c-subTitle_lv02--division2 {
    font-size: 18px;
    font-size: 1.8rem;
  }
  .c-subTitle_lv02--division2 em {
    font-size: 25px;
    font-size: 2.5rem;
  }
  .c-subTitle_lv03 {
    margin-bottom: 30px;
    padding: 0 0 2px 15px;
    font-size: 21px;
    font-size: 2.1rem;
  }
  .c-subTitle_lv03--division2 {
    font-size: 18px;
    font-size: 1.8rem;
  }
  .c-subTitle_lv03--division2 em {
    font-size: 21px;
    font-size: 2.1rem;
  }
  .c-subTitle_lv04 {
    margin: 0 0 25px;
    padding-bottom: 15px;
    font-size: 19px;
    font-size: 1.9rem;
  }
  .c-subTitle_lv04--division2 {
    font-size: 15px;
    font-size: 1.5rem;
  }
  .c-subTitle_lv04--division2 em {
    font-size: 19px;
    font-size: 1.9rem;
  }
  .c-subTitle_lv05 {
    font-size: 17px;
    font-size: 1.7rem;
  }
  .c-subTitle_lv06 {
    font-size: 15px;
    font-size: 1.5rem;
  }
}
/* -----------------------------------------------
  .c-crossTitle
----------------------------------------------- */
.c-crossTitle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 42px;
  font-size: 4.2rem;
  font-weight: 400;
}
.c-crossTitle_icon {
  width: 83px;
  height: 83px;
  background: url('/assets/images/common/ico_cross.svg') no-repeat;
  background-size: cover;
}

@media screen and (max-width: 768px) {
  .c-crossTitle {
    margin: 0 0 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    font-size: 40px;
    font-size: 4rem;
    line-height: 1.5;
  }
  .c-crossTitle_icon {
    width: 45px;
    height: 45px;
  }
}
/* -----------------------------------------------
  .c-titleIcon
----------------------------------------------- */
.c-titleIcon {
  min-width: 60px;
  margin-right: 8px;
}
.c-titleIconLabel {
  display: block;
  padding: 6px 0 8px;
  text-align: center;
  border: 2px solid #141414;
  border-radius: 4px;
  line-height: 1;
}

/* -----------------------------------------------
  .c-sec
----------------------------------------------- */
.c-sec {
  margin-top: 50px;
}
.c-secText {
  margin-bottom: 50px;
}
.c-secText--mSmall {
  margin-bottom: 35px;
}
.c-sec_news {
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
  padding: 60px 30px;
  background: #fff;
}
.c-sec_news .c-subTitle_lv02 {
  margin: 0 0 30px;
}

@media screen and (max-width: 768px) {
  .c-sec {
    margin-top: 40px;
  }
  .c-secText {
    margin-bottom: 40px;
  }
  .c-sec_news {
    margin: 0 -15px;
    padding: 50px 15px;
    width: auto;
  }
  .c-sec_news .c-subTitle_lv02 {
    margin-bottom: 25px;
  }
}
/* -----------------------------------------------
  .c-def
----------------------------------------------- */
.c-def {
  margin: 0;
}
.c-def_title {
  margin: -5px 0 10px;
  font-weight: 700;
}

/* -----------------------------------------------
  .c-lead
----------------------------------------------- */
.c-lead {
  margin: 0 0 15px;
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.8;
}

@media screen and (max-width: 768px) {
  .c-lead {
    font-size: 15px;
    font-size: 1.5rem;
  }
}
/* -----------------------------------------------
  .c-telNum
----------------------------------------------- */
.c-telNum {
  font-size: 42px;
  font-size: 4.2rem;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .c-telNum {
    font-size: 32px;
    font-size: 3.2rem;
  }
  .c-telNum a {
    color: #0099e2;
  }
}
/* -----------------------------------------------
  .c-figure
----------------------------------------------- */
.c-figure {
  margin: 0 auto;
  text-align: center;
}
.c-figure_caption {
  margin: 15px 0 10px;
  font-size: 13px;
  font-size: 1.3rem;
}
.c-figure + .c-figure {
  margin-top: 40px;
}

@media screen and (max-width: 768px) {
  .c-figure img {
    width: auto;
    max-width: 100%;
  }
}
/* -----------------------------------------------
  .c-imgList
----------------------------------------------- */
.c-imgList--column2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -30px 0 0 -30px;
}
.c-imgList--column2 .c-imgList_item {
  width: calc(50% - 30px);
  margin: 30px 0 0 30px;
  text-align: center;
}
.c-imgList_item a:hover {
  opacity: .7;
}
.c-imgList_item img {
  width: 100%;
}
.c-imgList_caption {
  margin: 10px 0 0;
  font-size: 13px;
  font-size: 1.3rem;
}
.c-imgList_block {
  margin-bottom: 60px;
}
.c-imgList_block:last-child {
  margin-bottom: 0;
}
.c-imgList_block .c-imgList_block_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.c-imgList_block img {
  width: 100%;
}
.c-imgList_block--btmCol02 li {
  width: calc(100% / 2 - 11px);
  margin-left: 11px;
}
.c-imgList_block--btmCol02 li:first-child {
  width: 100%;
  margin-bottom: 11px;
}
.c-imgList_block--btmCol02 .c-imgList_block_list {
  margin-left: -11px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-imgList_block--btmCol03 li {
  width: calc(100% / 3 - 11px);
  margin-left: 11px;
}
.c-imgList_block--btmCol03 li:first-child {
  width: 100%;
  margin-bottom: 11px;
}
.c-imgList_block--btmCol03 .c-imgList_block_list {
  margin-left: -11px;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-imgList_block--rightRow02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.c-imgList_block--rightRow02 .c-imgList_block_main {
  width: 66.2352%;
}
.c-imgList_block--rightRow02 .c-imgList_block_list {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 32.4705%;
}
.c-imgList_block--rightRow02 li {
  margin-top: 11px;
}
.c-imgList_block--rightRow02 li:first-child {
  margin-top: 0;
}
.c-imgList_block--rev .c-imgList_block_main {
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
}

@media screen and (max-width: 768px) {
  .c-imgList--column2 {
    margin: -10px 0 0 -10px;
  }
  .c-imgList--column2 .c-imgList_item {
    width: calc(50% - 10px);
    margin: 10px 0 0 10px;
    text-align: center;
  }
  .c-imgList--column2[data-spgrid='false'] {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: -15px 0 0 0;
  }
  .c-imgList--column2[data-spgrid='false'] .c-imgList_item {
    width: 100%;
    margin: 15px 0 0 0;
  }
  .c-imgList_caption {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .c-imgList_block {
    margin-bottom: 50px;
  }
  .c-imgList_block .c-imgList_block_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .c-imgList_block--btmCol02 li, .c-imgList_block--btmCol03 li {
    width: 100%;
    margin: 15px 0 0;
  }
  .c-imgList_block--btmCol02 li:first-child, .c-imgList_block--btmCol03 li:first-child {
    margin: 0;
  }
  .c-imgList_block--btmCol02 .c-imgList_block_list, .c-imgList_block--btmCol03 .c-imgList_block_list {
    margin-left: 0;
  }
  .c-imgList_block--rightRow02 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .c-imgList_block--rightRow02 .c-imgList_block_main {
    width: 100%;
  }
  .c-imgList_block--rightRow02 .c-imgList_block_list {
    width: 100%;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }
  .c-imgList_block--rightRow02 li {
    margin-top: 15px;
  }
  .c-imgList_block--rightRow02 li:first-child {
    margin-top: 15px;
  }
  .c-imgList_block--rev .c-imgList_block_main {
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }
}
/* -----------------------------------------------
  .c-imageUnit
----------------------------------------------- */
.c-imageUnit {
  overflow: hidden;
  zoom: 1;
}
.c-imageUnit_text {
  overflow: hidden;
  zoom: 1;
}
.c-imageUnit_image {
  margin: 0;
  text-align: center;
}
.c-imageUnit_image_caption {
  margin: 10px 0 0;
  font-size: 13px;
  font-size: 1.3rem;
}
.c-imageUnit--parallel .c-imageUnit_text {
  overflow: visible;
}
.c-imageUnit--parallel .c-imageUnit_image {
  margin-bottom: 30px;
}
.c-imageUnit--imageL .c-imageUnit_image {
  float: left;
  margin-right: 20px;
}
.c-imageUnit--imageR .c-imageUnit_image {
  float: right;
  margin-left: 20px;
}

@media screen and (max-width: 768px) {
  .c-imageUnit[data-spgrid='false'] .c-imageUnit_image {
    float: none;
    margin: 0 0 20px;
  }
  .c-imageUnit[data-spgrid='false'] .c-imageUnit_image img {
    width: auto;
  }
  .c-imageUnit--rtl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
  }
  .c-imageUnit--rtl.c-imageUnit--imageL .c-imageUnit_image {
    margin-top: 20px;
    margin-bottom: 0;
  }
  .c-imageUnit--rtl.c-imageUnit--imageR .c-imageUnit_image {
    margin-top: 0;
    margin-bottom: 20px;
  }
  .c-imageUnit--rtl[data-spgrid='false'] .c-imageUnit_image {
    margin-top: 20px;
    margin-bottom: 0;
  }
}
/* -----------------------------------------------
  .c-pickupBox
----------------------------------------------- */
.c-pickupBox {
  padding: 30px;
  border: 3px solid #008cd6;
}
.c-pickupBox--yellow {
  border-color: #ffcd05;
}
.c-pickupBox--gray {
  border-color: #e2e6ef;
}
.c-pickupBox--pd27 {
  padding: 27px;
}

@media screen and (max-width: 768px) {
  .c-pickupBox {
    padding: 15px;
  }
  .c-pickupBox--pd27 {
    padding: 12px;
  }
}
/* -----------------------------------------------
  .c-btnList
----------------------------------------------- */
.c-btnList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 -15px;
}
.c-btnList_item {
  padding: 0 15px;
}
.c-btnList_item .c-btn {
  min-width: 240px;
  margin: 0;
}

@media screen and (max-width: 768px) {
  .c-btnList {
    display: block;
    margin: 0;
  }
  .c-btnList_item {
    padding: 0;
  }
  .c-btnList_item + .c-btnList_item {
    margin-top: 15px;
  }
}
/* -----------------------------------------------
  .c-grid
----------------------------------------------- */
.c-grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -30px;
}
.c-grid--center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.c-grid_col {
  margin-left: 29.9px;
  margin-bottom: 30px;
}
.c-grid_col--1 {
  width: calc(((100% / 12) * 1) - 30px);
}
.c-grid_col--2 {
  width: calc(((100% / 12) * 2) - 30px);
}
.c-grid_col--3 {
  width: calc(((100% / 12) * 3) - 30px);
}
.c-grid_col--4 {
  width: calc(((100% / 12) * 4) - 30px);
}
.c-grid_col--5 {
  width: calc(((100% / 12) * 5) - 30px);
}
.c-grid_col--6 {
  width: calc(((100% / 12) * 6) - 30px);
}
.c-grid_col--7 {
  width: calc(((100% / 12) * 7) - 30px);
}
.c-grid_col--8 {
  width: calc(((100% / 12) * 8) - 30px);
}
.c-grid_col--9 {
  width: calc(((100% / 12) * 9) - 30px);
}
.c-grid_col--10 {
  width: calc(((100% / 12) * 10) - 30px);
}
.c-grid_col--11 {
  width: calc(((100% / 12) * 11) - 30px);
}
.c-grid_col--12 {
  width: calc(((100% / 12) * 12) - 30px);
}
.c-grid--division2 .c-grid_col {
  width: calc((100% / 2) - 30px);
}
.c-grid--division3 .c-grid_col {
  width: calc((100% / 3) - 30px);
}
.c-grid--division4 .c-grid_col {
  width: calc((100% / 4) - 30px);
}

.l-main_contents_primary .c-grid_col--1 {
  width: calc(((100% / 8) * 1) - 30px);
}
.l-main_contents_primary .c-grid_col--2 {
  width: calc(((100% / 8) * 2) - 30px);
}
.l-main_contents_primary .c-grid_col--3 {
  width: calc(((100% / 8) * 3) - 30px);
}
.l-main_contents_primary .c-grid_col--4 {
  width: calc(((100% / 8) * 4) - 30px);
}
.l-main_contents_primary .c-grid_col--5 {
  width: calc(((100% / 8) * 5) - 30px);
}
.l-main_contents_primary .c-grid_col--6 {
  width: calc(((100% / 8) * 6) - 30px);
}
.l-main_contents_primary .c-grid_col--7 {
  width: calc(((100% / 8) * 7) - 30px);
}
.l-main_contents_primary .c-grid_col--8 {
  width: calc(((100% / 8) * 8) - 30px);
}

@media screen and (max-width: 768px) {
  .c-grid {
    margin-left: -15px;
  }
  .c-grid_col {
    margin-left: 14.9px;
    margin-bottom: 15px;
  }
  .c-grid_col--1 {
    width: calc(((100% / 12) * 1) - 15px);
  }
  .c-grid_col--2 {
    width: calc(((100% / 12) * 2) - 15px);
  }
  .c-grid_col--3 {
    width: calc(((100% / 12) * 3) - 15px);
  }
  .c-grid_col--4 {
    width: calc(((100% / 12) * 4) - 15px);
  }
  .c-grid_col--5 {
    width: calc(((100% / 12) * 5) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid_col--6 {
    width: calc(((100% / 12) * 6) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid_col--7 {
    width: calc(((100% / 12) * 7) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid_col--8 {
    width: calc(((100% / 12) * 8) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid_col--9 {
    width: calc(((100% / 12) * 9) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid_col--10 {
    width: calc(((100% / 12) * 10) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid_col--11 {
    width: calc(((100% / 12) * 11) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid_col--12 {
    width: calc(((100% / 12) * 12) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .c-grid--division2:not([data-spgrid='false']) .c-grid_col {
    width: calc((100% / 2) - 15px);
  }
  .c-grid--division3:not([data-spgrid='false']) .c-grid_col {
    width: calc((100% / 3) - 15px);
  }
  .c-grid--division4:not([data-spgrid='false']) .c-grid_col {
    width: calc((100% / 4) - 15px);
  }
  .c-grid[data-spgrid='false'] {
    display: block;
  }
  .c-grid[data-spgrid='false'] > .c-grid_col {
    float: none;
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--1 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--2 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--3 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--4 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--5 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--6 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--7 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--8 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--9 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--10 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--11 {
    width: auto;
  }
  .c-grid[data-spgrid='false'] .c-grid_col--12 {
    width: auto;
  }
  .c-grid[data-spgrid='2'] > .c-grid_col {
    width: calc((100% / 2) - 15px);
  }

  .l-main_primary .c-grid_col--1 {
    width: calc(((100% / 8) * 1) - 15px);
  }
  .l-main_primary .c-grid_col--2 {
    width: calc(((100% / 8) * 2) - 15px);
  }
  .l-main_primary .c-grid_col--3 {
    width: calc(((100% / 8) * 3) - 15px);
  }
  .l-main_primary .c-grid_col--4 {
    width: calc(((100% / 8) * 4) - 15px);
  }
  .l-main_primary .c-grid_col--5 {
    width: calc(((100% / 8) * 5) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .l-main_primary .c-grid_col--6 {
    width: calc(((100% / 8) * 6) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .l-main_primary .c-grid_col--7 {
    width: calc(((100% / 8) * 7) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .l-main_primary .c-grid_col--8 {
    width: calc(((100% / 8) * 8) - 15px);
    width: calc((100% / 2) - 15px);
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--1 {
    width: auto;
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--2 {
    width: auto;
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--3 {
    width: auto;
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--4 {
    width: auto;
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--5 {
    width: auto;
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--6 {
    width: auto;
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--7 {
    width: auto;
  }
  .l-main_primary .c-grid[data-spgrid='false'] .c-grid_col--8 {
    width: auto;
  }
}
/* -----------------------------------------------
  .c-textList
----------------------------------------------- */
.c-textList--col2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.c-textList--col2 .c-textList_item {
  width: calc((100% / 2) - 30px);
}
.c-textList_item {
  position: relative;
  margin-top: 15px;
  padding-left: 1em;
}
.c-textList_item:first-child {
  margin-top: 0;
}
.c-textList_item:before {
  content: ' ';
  position: absolute;
  top: .6em;
  left: 0;
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #008cd6;
}
.c-textList_item--mtSml {
  margin-top: 0;
}
.c-textList--inr {
  margin-top: 15px;
}

@media screen and (max-width: 768px) {
  .c-textList--col2 {
    display: block;
  }
  .c-textList--col2 .c-textList_item {
    width: 100%;
  }
}
/* -----------------------------------------------
  .c-defList
----------------------------------------------- */
.c-defList_title {
  font-weight: 700;
  margin-bottom: 5px;
}

/* -----------------------------------------------
  .c-notice
----------------------------------------------- */
.c-notice_item {
  position: relative;
  padding-left: 1.5em;
  font-size: 13px;
  font-size: 1.3rem;
  color: #6a6a6a;
}
.c-notice_item + .c-notice_item {
  margin-top: 10px;
}
.c-notice_mark {
  position: absolute;
  left: 0;
}
.c-notice--numeric .c-notice_item {
  padding-left: 2em;
}

/* -----------------------------------------------
  .c-media
----------------------------------------------- */
.c-media {
  position: relative;
  width: 100%;
  height: 0;
  padding: 0 0 56.25%;
  overflow: hidden;
}
.c-media iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* -----------------------------------------------
  .c-link
----------------------------------------------- */
.c-link {
  color: #008cd6;
}
.c-link_size {
  font-weight: 400;
  color: #949494;
  font-size: 16px;
  font-size: 1.6rem;
}
.c-link::after {
  position: relative;
  top: 2px;
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-left: 8px;
  margin-right: 5px;
  background-repeat: no-repeat;
  background-size: cover;
}
.c-link--external::after {
  content: ' ';
  width: 14px;
  height: 10px;
  top: 0;
  background-image: url('/assets/images/common/ico_external.svg');
}
.c-link--pdf::after {
  content: ' ';
  background-image: url('/assets/images/common/ico_pdf.svg');
}
.c-link--xls::after {
  content: ' ';
  background-image: url('/assets/images/common/ico_xls.svg');
}
.c-link--doc::after {
  content: ' ';
  background-image: url('/assets/images/common/ico_doc.svg');
}

@media screen and (max-width: 768px) {
  .c-link_size {
    font-size: 15px;
    font-size: 1.5rem;
  }
}
/* -----------------------------------------------
  .c-linkList
----------------------------------------------- */
.c-linkList_item {
  position: relative;
}
.c-linkList_item a {
  color: #008cd6;
}
.c-linkList_item + .c-linkList_item {
  margin-top: 10px;
}

/* -----------------------------------------------
  .c-linkArrow
----------------------------------------------- */
.c-linkArrow {
  position: relative;
  display: inline-block;
  padding: 0 0 0 12px;
}
.c-linkArrow::before {
  position: absolute;
  content: '';
  display: block;
  top: .55em;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #ffcd05;
}
.c-linkArrow_size {
  font-weight: 400;
  color: #949494;
  font-size: 16px;
  font-size: 1.6rem;
}
.c-linkArrow_link::after {
  position: relative;
  top: 2px;
  content: ' ';
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-left: 8px;
  background-repeat: no-repeat;
  background-size: cover;
}
.c-linkArrow_link--external::after {
  top: 0;
  width: 14px;
  height: 10px;
  background-image: url('/assets/images/common/ico_external.svg');
}
.c-linkArrow_link--pdf::after {
  background-image: url('/assets/images/common/ico_pdf.svg');
}
.c-linkArrow_link--xls::after {
  background-image: url('/assets/images/common/ico_xls.svg');
}
.c-linkArrow_link--doc::after {
  background-image: url('/assets/images/common/ico_doc.svg');
}
.c-linkArrow--large {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 700;
  padding: 0 0 0 27px;
  background: url('/assets/images/common/ico_arrow.svg') 0 7px no-repeat;
}
.c-linkArrow--large::before {
  display: none;
}

@media screen and (max-width: 768px) {
  .c-linkArrow_size {
    font-size: 15px;
    font-size: 1.5rem;
  }
}
/* -----------------------------------------------
  .c-linkArrowList
----------------------------------------------- */
[class^='c-linkArrowList']:not([class*='_item']) [class^='c-linkArrowList']:not([class*='_item']) {
  margin-top: 15px;
  padding: 0 0 8px;
}

@media screen and (max-width: 768px) {
  [class^='c-linkArrowList']:not([class*='_item']) [class^='c-linkArrowList']:not([class*='_item']) {
    margin-top: 15px;
  }
  [class^='c-linkArrowList']:not([class*='_item']) [class^='c-linkArrowList']:not([class*='_item']) {
    padding-left: 9px;
  }
}
.c-linkArrowList_item {
  position: relative;
  padding-left: 12px;
}
.c-linkArrowList_item + .c-linkArrowList_item {
  margin-top: 10px;
}
.c-linkArrowList_item::before {
  position: absolute;
  content: '';
  display: block;
  top: .55em;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #ffcd05;
}
.c-linkArrowList_item.c-grid_col + .c-linkArrowList_item.c-grid_col {
  margin-top: 0;
}
.c-linkArrowList_item--large {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 700;
  padding: 0 0 0 27px;
  background: url('/assets/images/common/ico_arrow.svg') 0 7px no-repeat;
}
.c-linkArrowList_item--large::before {
  display: none;
}
.c-linkArrowList_item_link::after {
  position: relative;
  top: 2px;
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-left: 8px;
  background-repeat: no-repeat;
  background-size: cover;
}
.c-linkArrowList_item_link--external::after {
  content: '';
  top: 0;
  width: 14px;
  height: 10px;
  background-image: url('/assets/images/common/ico_external.svg');
}

@media screen and (max-width: 768px) {
  .c-linkArrowList_item.c-grid_col {
    margin-bottom: 0;
  }
  .c-linkArrowList_item.c-grid_col + .c-linkArrowList_item.c-grid_col {
    margin-top: 10px;
  }
}
/* -----------------------------------------------
  .c-ancherList
----------------------------------------------- */
.c-ancherList {
  margin: 0 0 40px;
}
.c-ancherList_title {
  margin: 0 0 7px;
  font-weight: 700;
  font-size: 16px;
  font-size: 1.6rem;
}
.c-ancherList_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding-top: 1px;
  border-left: 1px solid #e2e6ef;
}
.c-ancherList_item {
  width: 25%;
  margin-top: -1px;
  border-top: 1px solid #e2e6ef;
  border-bottom: 1px solid #e2e6ef;
  border-right: 1px solid #e2e6ef;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1.5;
}
.c-ancherList_item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 100%;
  padding: 10px 20px 10px;
}
.c-ancherList_item a:hover {
  background: #f7f7fa;
  text-decoration: none;
}
.c-ancherList_item_label {
  position: relative;
  display: inline-block;
  padding-left: 15px;
}
.c-ancherList_item_label::before {
  position: absolute;
  content: '';
  display: block;
  top: .6em;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 4px 0 4px;
  border-color: #ffcd05 transparent transparent transparent;
}
.c-ancherList--division2 .c-ancherList_item {
  width: 50%;
}

@media screen and (max-width: 768px) {
  .c-ancherList {
    margin: 0 0 20px;
  }
  .c-ancherList_title {
    font-size: 15px;
    font-size: 1.5rem;
  }
  .c-ancherList_item {
    width: 50%;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .c-ancherList_item a {
    padding: 10px 15px 10px;
  }
}
/* -----------------------------------------------
  .c-numericList
----------------------------------------------- */
[class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']) [class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']), [class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']) [class^='c-linkArrowList']:not([class*='_item']) {
  margin-top: 15px;
  padding: 0 0 8px;
}
[class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']) [class^='c-textList']:not([class*='_item']):not([class*='_title']):not([class*='_data']) {
  margin-top: 15px;
  padding: 0 0 5px 7px;
}

@media screen and (max-width: 768px) {
  [class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']) [class^='c-textList']:not([class*='_item']):not([class*='_title']):not([class*='_data']), [class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']) [class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']), [class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']) [class^='c-linkArrowList']:not([class*='_item']) {
    margin-top: 15px;
  }
  [class^='c-numericList']:not([class*='_item']):not([class*='_title']):not([class*='_data']):not([class*='_number']) [class^='c-textList']:not([class*='_item']):not([class*='_title']):not([class*='_data']) {
    padding-left: 9px;
  }
}
.c-numericList {
  margin: 0;
  counter-reset: number 0;
}
.c-numericList_item {
  padding: 0 0 0 1.8em;
  position: relative;
}
.c-numericList_item:before {
  position: absolute;
  left: 0;
  counter-increment: number 1;
  content: counter(number) '.';
  font-weight: 700;
}
.c-numericList_item + .c-numericList_item {
  margin-top: 10px;
}

.c-numericList02 {
  margin: 0;
  counter-reset: number 0;
}
.c-numericList02_title {
  padding: 0 0 10px 1.8em;
  position: relative;
  font-weight: 700;
}
.c-numericList02_title:before {
  position: absolute;
  left: 0;
  counter-increment: number 1;
  content: counter(number) '.';
}
.c-numericList02_data {
  padding-left: 1.8em;
}
.c-numericList02_data + .c-numericList02_title {
  margin-top: 10px;
}

.c-numericList03 {
  margin: 0;
  counter-reset: number 0;
}
.c-numericList03_item {
  padding: 0 0 0 1.8em;
  position: relative;
}
.c-numericList03_item + .c-numericList03_item {
  margin-top: 10px;
}
.c-numericList03_number {
  position: absolute;
  left: 0;
  font-weight: 700;
}

/* -----------------------------------------------
  .c-definition
----------------------------------------------- */
.c-definition {
  margin: 0;
}
.c-definition_title {
  font-weight: 700;
}
.c-definition_detail {
  margin: 7px 0 0;
}
.c-definition_detail + .c-definition_title {
  margin-top: 10px;
}

.c-definition02 {
  margin: 0;
}
.c-definition02_detail {
  margin: -1.8em 0 0 7em;
}
.c-definition02_detail + .c-definition02_title {
  margin-top: 20px;
}

@media screen and (max-width: 768px) {
  .c-definition02_title {
    margin: 0 0 5px;
    font-weight: 700;
  }
  .c-definition02_detail {
    margin: 0;
  }
  .c-definition02_detail + .c-definition02_title {
    margin-top: 20px;
  }
}
/* -----------------------------------------------
  .c-box
----------------------------------------------- */
.c-box {
  padding: 25px 30px;
  font-size: 20px;
  font-size: 2rem;
  background: #f5f5f6;
}
.c-box--normal {
  font-size: 16px;
  font-size: 1.6rem;
}
.c-box--pink {
  background: #fef6f0;
}
.c-box--transparent {
  padding: 0 30px;
  background: transparent;
}
.c-box--nopd {
  padding: 0;
}

@media screen and (max-width: 768px) {
  .c-box {
    padding: 15px;
    font-size: 15px;
    font-size: 1.5rem;
  }
  .c-box--normal {
    font-size: 15px;
    font-size: 1.5rem;
  }
  .c-box--transparent {
    padding: 0 15px;
    font-size: 15px;
    font-size: 1.5rem;
  }
}
/* -----------------------------------------------
  .c-boxLine
----------------------------------------------- */
.c-boxLine_wrap {
  border-bottom: 1px solid #ccc;
}
.c-boxLine_link {
  display: block;
  padding: 20px;
}
.c-boxLine_link:hover {
  text-decoration: none;
  background: #eee;
}

@media screen and (max-width: 768px) {
  .c-boxLine_link {
    padding: 10px;
  }
}
/* -----------------------------------------------
  .c-table
----------------------------------------------- */
.c-table table {
  width: 100%;
  text-align: left;
  table-layout: fixed;
  border-top: 1px solid #e2e6ef;
}
.c-table th, .c-table td {
  padding: 10px 0;
  border-bottom: 1px solid #e2e6ef;
}
.c-table th {
  padding-left: 15px;
  font-weight: 400;
}
.c-table--auto table {
  table-layout: inherit;
}
.c-table_grid_col--2 {
  width: 17.6470%;
}
.c-table_grid_col--3 {
  width: 35.2941%;
}
.c-table_grid_col--4 {
  width: 52.9411%;
}
.c-table_grid_col--5 {
  width: 70.5882%;
}
.c-table_grid_col_type02--3 {
  width: 300px;
}
.c-table_grid_col_type02--3 + td {
  padding: 30px !important;
}

@media screen and (max-width: 768px) {
  .c-table th, .c-table td {
    display: block;
    width: 100%;
  }
  .c-table th {
    padding: 10px 13px 0;
    font-weight: 700;
    border-bottom: none;
  }
  .c-table th + td {
    padding-top: 0;
  }
  .c-table td {
    padding: 10px 13px;
  }
  .c-table_grid_col--2, .c-table_grid_col--3, .c-table_grid_col--4, .c-table_grid_col--5 {
    width: 100%;
  }
  .c-table_grid_col_type02--3 {
    width: 100%;
  }
  .c-table_grid_col_type02--3 + td {
    padding: 20px 0 !important;
  }
}
.c-table02 table {
  width: 100%;
  text-align: left;
  table-layout: fixed;
  border-top: 1px solid #d1d5de;
}
.c-table02 th, .c-table02 td {
  padding: 20px 30px;
  border-bottom: 1px solid #d1d5de;
}
.c-table02 th {
  font-weight: 400;
  background: #f0f2f7;
}
.c-table02--auto table {
  table-layout: inherit;
}
.c-table02_grid_col--2 {
  width: 17.6470%;
}
.c-table02_grid_col--3 {
  width: 35.2941%;
}
.c-table02_grid_col--4 {
  width: 52.9411%;
}
.c-table02_grid_col--5 {
  width: 70.5882%;
}

@media screen and (max-width: 768px) {
  .c-table02 table tr:last-child th, .c-table02 table tr:last-child td {
    border-bottom: none;
  }
  .c-table02 table tr:last-child td {
    padding-bottom: 0;
  }
  .c-table02 table th, .c-table02 table td {
    display: block;
    width: 100%;
  }
  .c-table02 table th {
    padding: 10px 15px;
  }
  .c-table02 table td {
    padding: 25px 15px;
  }
  .c-table02 table_grid_col--2, .c-table02 table_grid_col--3, .c-table02 table_grid_col--4, .c-table02 table_grid_col--5 {
    width: 100%;
  }
}
.c-table03 table {
  width: 100%;
  text-align: left;
  table-layout: fixed;
  border: solid #d1d5de;
  border-width: 1px 1px 0 0;
}
.c-table03 th, .c-table03 td {
  padding: 10px 15px;
  border: solid #d1d5de;
  border-width: 0 0 1px 1px;
}
.c-table03 th {
  font-weight: 400;
  background: #ebedf4;
}
.c-table03--auto table {
  table-layout: inherit;
}
.c-table03_grid_col--2 {
  width: 17.6470%;
}
.c-table03_grid_col--3 {
  width: 35.2941%;
}
.c-table03_grid_col--4 {
  width: 52.9411%;
}
.c-table03_grid_col--5 {
  width: 70.5882%;
}

@media screen and (max-width: 768px) {
  .c-table03 th, .c-table03 td {
    display: block;
    width: 100%;
    padding: 10px 13px;
    border-bottom: 1px solid #d1d5de;
  }
  .c-table03_grid_col--2, .c-table03_grid_col--3, .c-table03_grid_col--4, .c-table03_grid_col--5 {
    width: 100%;
  }
}
.c-table04 table {
  width: 100%;
  text-align: center;
  table-layout: fixed;
  border: solid #d1d5de;
  border-width: 1px 1px 0 0;
}
.c-table04 tbody th {
  text-align: left;
}
.c-table04 th, .c-table04 td {
  padding: 10px 15px;
  border: solid #d1d5de;
  border-width: 0 0 1px 1px;
}
.c-table04 th {
  font-weight: 400;
  background: #ebedf4;
}
.c-table04_cell--darkblue {
  background: #e5f6ff !important;
}
.c-table04_cell--blue {
  background: #f2fbff !important;
}
.c-table04_cell--yellow {
  background: #ffffe9 !important;
}
.c-table04--auto table {
  table-layout: inherit;
}

@media screen and (max-width: 768px) {
  .c-table04 th, .c-table04 td {
    padding: 5px 10px;
  }
  .c-table04[data-spswipe='true'] {
    width: 100%;
    padding: 7px 0;
    overflow-x: auto;
  }
  .c-table04[data-spswipe='true'] table {
    table-layout: fixed;
    width: 850px;
  }
}
/* -----------------------------------------------
  form flow
----------------------------------------------- */
.c-frmFlow {
  margin: 35px 0 60px;
}
.c-frmFlow_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  font-weight: 700;
}
.c-frmFlow_item {
  position: relative;
  width: calc(100% / 3 - 20px);
  height: 48px;
  line-height: 48px;
  background: #e2e6ef;
  counter-increment: itemNum;
}
.c-frmFlow_item:before {
  content: ' ';
  position: absolute;
  top: 0;
  right: -24px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 24px 0 24px 24px;
  border-color: transparent transparent transparent #e2e6ef;
}
.c-frmFlow_item:last-child:before {
  display: none;
}
.c-frmFlow_item--current {
  color: #fff;
  background: #000;
}
.c-frmFlow_item--current:before {
  border-color: transparent transparent transparent #000;
}
.c-frmFlow_item--current .c-frmFlow_number:before {
  color: #000;
}
.c-frmFlow_number {
  position: relative;
  padding-left: 34px;
}
.c-frmFlow_number:before {
  content: counter(itemNum);
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  display: block;
  width: 24px;
  height: 24px;
  line-height: 22px;
  border-radius: 50%;
  background: #fff;
}

@media screen and (max-width: 768px) {
  .c-frmFlow {
    margin: 25px 0 50px;
  }
  .c-frmFlow_item {
    width: calc(100% / 3 - 15px);
    height: 54px;
    padding-top: 30px;
    line-height: 1;
  }
  .c-frmFlow_item:before {
    right: -15px;
    border-width: 27px 0 27px 15px;
  }
  .c-frmFlow_number {
    padding: 30px 0 0;
  }
  .c-frmFlow_number:before {
    top: 10px;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    width: 16px;
    height: 16px;
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.2;
  }
}
/* -----------------------------------------------
  .c-tab
----------------------------------------------- */
.c-tabCnt_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 50px;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
}
.c-tabCnt_item {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  text-align: center;
}
.c-tabCnt_item:first-child .c-tab_trigger {
  border-left: 1px solid #e2e6ef;
}
.c-tabCnt_item:first-child .c-tab_trigger.isActive {
  border-color: #ffcd05;
}
.c-tabCnt_trigger {
  display: block;
  padding: 10px 20px;
  border: solid #e2e6ef;
  border-width: 1px 1px 1px 0;
}
.c-tabCnt_trigger:hover {
  text-decoration: none;
}
.c-tabCnt_trigger.isActive {
  position: relative;
  border-color: #ffcd05;
  background: #ffcd05;
}
.c-tabCnt_trigger.isActive:before {
  content: ' ';
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 8px 0 8px;
  border-color: #ffcd05 transparent transparent transparent;
}

@media screen and (max-width: 768px) {
  .c-tabCnt_list {
    margin-bottom: 30px;
  }
}
/* -----------------------------------------------
  form parts
----------------------------------------------- */
.c-frmText, .c-frmTextArea {
  font-family: 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'Noto Sans Japanese', Roboto, 'Droid Sans', 'メイリオ', Meiryo, '游ゴシック体', 'YuGothic', '游ゴシック', 'Yu Gothic', sans-serif;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  border: 1px solid #b4b7bf;
  border-radius: 3px;
}

.c-frmSelect {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  min-width: 100px;
  height: 40px;
  padding: 0 30px 0 10px;
  border: 1px solid #b4b7bf;
  border-radius: 3px;
  cursor: pointer;
  background: url('/assets/images/common/ico_arrow_bottom.svg') top 50% right 10px no-repeat;
}
.c-frmSelect--err {
  border-color: #d92121;
  background-color: #fff2f2;
}

.c-frmSelect::-ms-expand {
  display: none;
}

.c-frmButton {
  outline: none;
}

.c-frmText {
  height: 40px;
  padding: 0 10px;
  line-height: 38px;
}
.c-frmText:first-child {
  margin: 0;
}
.c-frmText:placeholder-shown {
  color: #b4b7bf;
}
.c-frmText::-webkit-input-placeholder {
  color: #b4b7bf;
}
.c-frmText:-moz-placeholder, .c-frmText::-moz-placeholder {
  color: #b4b7bf;
  opacity: 1;
}
.c-frmText:-ms-input-placeholder {
  color: #b4b7bf;
}
.c-frmText--full {
  max-width: 570px;
}
.c-frmText--long {
  max-width: 370px;
}
.c-frmText--middle {
  max-width: 140px;
}
.c-frmText--small {
  max-width: 100px;
}
.c-frmText--err {
  border-color: #d92121;
  background: #fff2f2;
}

@media screen and (max-width: 768px) {
  .c-frmText--full {
    max-width: initial;
    max-width: auto;
  }
  .c-frmText--long {
    max-width: initial;
    max-width: auto;
  }
  .c-frmText--middle {
    max-width: 100px;
  }
  .c-frmText--small {
    max-width: 80px;
  }
}
.c-frmText:disabled, .c-frmRadio:disabled, .c-frmSelect:disabled, .c-frmTextArea:disabled {
  color: #bdbdbd;
  cursor: default;
}

.c-frmTextArea {
  height: 12em;
  font-size: 90%;
}

.c-frmRadio, .c-frmCheckBox {
  display: inline-block;
  margin-right: 6px;
}

.c-frmRadio + .c-frmChk, .c-frmCheckBox + .c-frmChk {
  position: relative;
  display: inline-block;
  cursor: pointer;
  white-space: nowrap;
}

@media (min-width: 1px) {
  .c-frmRadio, .c-frmCheckBox {
    display: none;
    margin: 0;
  }

  .c-frmRadio + .c-frmChk, .c-frmCheckBox + .c-frmChk {
    padding: 0 0 0 24px;
  }

  .c-frmRadio + .c-frmChk:before, .c-frmCheckBox + .c-frmChk:before {
    content: ' ';
    position: absolute;
    top: 50%;
    left: 0;
    box-sizing: border-box;
    display: block;
    width: 16px;
    height: 16px;
    margin-top: -7px;
    background: #fff;
    border-radius: 3px;
  }

  .c-frmRadio + .c-frmChk:before {
    border: 1px solid #b4b7bf;
    border-radius: 30px;
  }

  .c-frmCheckBox + .c-frmChk:before {
    border: 1px solid #b4b7bf;
  }

  .c-frmRadio:checked + .c-frmChk:after, .c-frmCheckBox:checked + .c-frmChk:after {
    content: ' ';
    position: absolute;
    top: 50%;
    box-sizing: border-box;
    display: block;
  }

  .c-frmRadio:checked + .c-frmChk:after {
    left: 4px;
    width: 8px;
    height: 8px;
    margin-top: -3px;
    background: #ffcd05;
    border-radius: 8px;
  }

  .c-frmCheckBox:checked + .c-frmChk:after {
    left: 3px;
    width: 12px;
    height: 8px;
    margin-top: -5px;
    border-left: 3px solid #ffcd05;
    border-bottom: 3px solid #ffcd05;
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }

  .c-frmRadio.c-frmRadio--err + .c-frmChk:before, .c-frmCheckBox.c-frmCheckBox--err + .c-frmChk:before {
    border: 1px solid #d92121;
  }

  .c-frmRadio.c-frmRadio--err + .c-frmChk:before, .c-frmCheckBox.c-frmCheckBox--err + .c-frmChk:before {
    background: #fff2f2;
  }
}
.c-frmLead {
  text-align: center;
}

@media screen and (max-width: 768px) {
  .c-frmLead {
    text-align: left;
  }
}
.c-frmList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.c-frmListItem {
  margin-right: 30px;
}
.c-frmListItem:last-child {
  margin-right: 0;
}

@media screen and (max-width: 768px) {
  .c-frmListItem {
    margin-right: 15px;
  }
}
.c-frmLabel {
  margin: 0 25px 0 10px;
}
.c-frmLabel--uniform {
  margin: 0 10px;
}
.c-frmLabel--left {
  margin: 0 10px 0 0;
}
.c-frmLabel:last-child {
  margin-right: 0;
}

@media screen and (max-width: 768px) {
  .c-frmLabel {
    margin: 0 13px 0 8px;
  }
  .c-frmLabel--uniform {
    margin: 0 10px;
  }
  .c-frmLabel--left {
    margin: 0 10px 0 0;
  }
}
.c-frmSelectList {
  margin-top: -20px;
}
.c-frmSelectListItem {
  margin-top: 20px;
}

.c-frmAddress {
  margin-top: 20px;
}
.c-frmAddress:first-child {
  margin-top: 0;
}

@media screen and (max-width: 768px) {
  .c-frmAddress {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .c-frmAddress .c-frmLabel {
    width: 80px;
    margin: 0;
  }
  .c-frmAddress .c-frmLabel + .c-frmText, .c-frmAddress .c-frmLabel + .c-frmSelect {
    width: calc(100% - 80px);
  }
}
.c-frmCaution {
  margin: 15px 0 5px;
}

.c-frmRequired {
  position: relative;
  display: block;
}
.c-frmRequired:after {
  content: '必須';
  position: absolute;
  top: 3px;
  right: 0;
  display: inline-block;
  padding: 4px 10px 5px;
  color: #fff;
  font-weight: 400;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  border-radius: 3px;
  background: #d92121;
}

@media screen and (max-width: 768px) {
  .c-frmRequired {
    display: inline-block;
  }
  .c-frmRequired:after {
    position: relative;
    top: -1px;
    margin-left: 10px;
    font-size: 12px;
    font-size: 1.2rem;
  }
}
.c-frmBtnList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 30px;
}
.c-frmBtnListItem {
  margin-left: 30px;
}
.c-frmBtnListItem:first-child {
  margin-left: 0;
}

@media screen and (max-width: 768px) {
  .c-frmBtnList {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 10px;
  }
  .c-frmBtnListItem {
    margin-left: 0;
  }
}
.c-frmErrMain {
  margin-bottom: 60px;
  padding: 25px 30px;
  text-align: center;
  color: #d92121;
  font-weight: 700;
  border: 2px solid #d92121;
}

.c-frmErrText {
  margin-bottom: 10px;
  color: #d92121;
  font-weight: 700;
}

.c-checkPosition {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.c-checkPosition_inner .c-frmCaution {
  line-height: 1;
  font-weight: 700;
  margin-bottom: 20px;
}
@media screen and (min-width: 769px) {
  .c-checkPosition_inner:first-of-type {
    margin: 0 40px 30px 0;
  }
}
.c-checkPosition_inner:first-of-type .c-frmCaution {
  text-align: center;
}
.c-checkPosition_inner .c-checkPosition_img {
  margin: 0;
}
.c-checkPosition_inner_desc .c-frmList {
  border-left: 4px solid;
  margin-bottom: 20px;
  padding: 3px 0 4px 20px;
}
.c-checkPosition_inner_desc .c-frmList:nth-of-type(1) {
  border-left-color: #c73645;
}
.c-checkPosition_inner_desc .c-frmList:nth-of-type(2) {
  border-left-color: #df9609;
}
.c-checkPosition_inner_desc .c-frmList:nth-of-type(3) {
  border-left-color: #0275c5;
}
.c-checkPosition_inner_desc .c-frmList:nth-of-type(4) {
  border-left-color: #985ca2;
  margin-bottom: 0;
}
.c-checkPosition_inner_desc .c-frmListItem {
  min-width: 96px;
  margin-right: 20px;
}
.c-checkPosition_inner_desc .c-frmListItem:nth-child(4n) {
  margin-right: 0;
}
.c-checkPosition_inner_desc .c-frmListItem .c-frmCheckBox + .c-frmChk:before {
  border-radius: 0;
}
.c-checkPosition_inner_desc .c-frmListItem .c-frmCheckBox:checked + .c-frmChk:after {
  background: #ffcd05;
  border: none;
  width: 10px;
  height: 10px;
  -webkit-transform: rotate(0);
  -ms-transform: rotate(0);
  transform: rotate(0);
  margin-top: -4px;
}

@media screen and (max-width: 768px) {
  .c-checkPosition {
    display: block;
  }
  .c-checkPosition_inner .c-frmCaution {
    margin-bottom: 15px;
    font-size: 1.4rem;
  }
  .c-checkPosition_inner:first-of-type {
    margin: 0 0 23px;
  }
  .c-checkPosition_inner_desc .c-frmList {
    padding: 4px 0 4px 20px;
    margin-bottom: 10px;
  }
  .c-checkPosition_inner_desc .c-frmListItem {
    line-height: 2;
  }
  .c-checkPosition_inner .c-checkPosition_img {
    margin: 0;
    text-align: center;
  }
}
.c-radioRecord {
  display: inline-block;
}
.c-radioRecord_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0;
  padding: 10px 28px;
}
.c-radioRecord_list:nth-child(odd) {
  background: #f7f8fb;
}
.c-radioRecord_list_ttl {
  font-weight: bold;
  margin-right: 33px;
}
.c-radioRecord_list .c-frmRadio + .c-frmChk {
  padding: 0 0 0 25px;
}

@media screen and (max-width: 768px) {
  .c-radioRecord {
    display: block;
  }
  .c-radioRecord_list {
    padding: 15px;
  }
  .c-radioRecord_list_ttl {
    margin-right: 25px;
  }
  .c-radioRecord_list_desc {
    min-width: 160px;
    max-width: 200px;
  }
  .c-radioRecord_list_desc .c-frmListItem {
    margin-right: 30px;
  }
  .c-radioRecord_list_desc .c-frmListItem:nth-child(3) {
    margin-right: 0;
  }
}
/* -----------------------------------------------
  .js-spAccordion
----------------------------------------------- */
@media screen and (max-width: 768px) {
  .js-spAccordion + * {
    display: none;
  }
}
/* -----------------------------------------------
  for develop
----------------------------------------------- */
.dev-toggle {
  position: fixed;
  bottom: 20px;
  left: 20px;
  z-index: 999999;
  display: inline-block;
  padding: 5px 10px;
  background: #000;
  opacity: .7;
  color: #fff;
  border-radius: 5px;
  font-size: 13px;
  font-size: 1.3rem;
  font-family: sans-serif;
  font-weight: bold;
  text-decoration: none;
}
.dev-toggle:hover {
  text-decoration: none;
  color: #fff;
}

.dev-section + .dev-section {
  margin-top: 40px;
}

.dev-title {
  margin: 0 0 30px;
  padding: 8px;
  background: rosybrown;
  color: #fff;
  font-size: 15px;
  font-size: 1.5rem;
  font-family: sans-serif;
  font-weight: 700;
}

.dev-title02 {
  margin: 30px 0 15px;
  padding-bottom: 5px;
  border-bottom: 3px solid rosybrown;
  font-size: 14px;
  font-size: 1.4rem;
  font-family: sans-serif;
  font-weight: bold;
  color: rosybrown;
}

.dev-memo {
  position: relative;
  margin-bottom: 15px;
  padding: 5px 5px 5px 30px;
  background: antiquewhite;
  border-radius: 5px;
  font-size: 12px;
  font-size: 1.2rem;
  font-family: sans-serif;
}
.dev-memo:before {
  position: absolute;
  top: .5em;
  left: 10px;
  content: '\f040';
  font-family: 'FontAwesome';
}
.dev-memo code {
  display: inline-block;
  margin: 0 3px;
  padding: 0 5px;
  background: rosybrown;
  border-radius: 2px;
  color: #fff;
  font-weight: 700;
}

.dev-code {
  margin: 30px 0;
}
.dev-code-label {
  font-family: sans-serif;
  font-weight: bold;
}
.dev-code-label:before {
  content: '\f013';
  display: inline-block;
  margin-right: 10px;
  font-family: 'FontAwesome';
}
.dev-code .prettyprint {
  width: 100%;
  max-height: 300px;
  padding: 1em;
  overflow: auto;
  border: none;
  font-size: 12px;
  font-size: 1.2rem;
}

.dev-grid {
  display: table;
  width: 100%;
  margin-top: 50px;
  table-layout: fixed;
  font-size: 10px;
  font-size: 1rem;
}
.dev-grid_col {
  display: table-cell;
  padding: 10px 0;
  background: #ebeff7;
  text-align: center;
  vertical-align: middle;
}
.dev-grid_gutter {
  display: table-cell;
  width: 30px;
  padding: 10px 0;
  background: #d9e0ef;
  text-align: center;
  vertical-align: middle;
}

.dev-colorScheme {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -30px;
}
.dev-colorScheme_item {
  width: calc(100%/6 - 30px);
  margin: 0 0 30px 30px;
  font-size: 12px;
  font-size: 1.2rem;
}
.dev-colorScheme_code {
  height: 85px;
  padding: 5px;
}
.dev-colorScheme_desc {
  margin: 5px 0 0;
}

@media screen and (max-width: 1024px) {
  .dev-colorScheme {
    margin-left: -15px;
  }
  .dev-colorScheme_item {
    width: calc(100%/4 - 15px);
    margin: 0 0 15px 15px;
  }
}
@media screen and (max-width: 768px) {
  .dev-colorScheme_item {
    width: calc(100%/2 - 15px);
  }
}
pre .str, code .str {
  color: #fec243;
}

pre .kwd, code .kwd {
  color: #8470ff;
}

pre .com, code .com {
  color: #32cd32;
  font-style: italic;
}

pre .typ, code .typ {
  color: #6ecbcc;
}

pre .lit, code .lit {
  color: #d06;
}

pre .pun, code .pun {
  color: #8b8970;
}

pre .pln, code .pln {
  color: #f0f0f0;
}

pre .tag, code .tag {
  color: #9c9cff;
}

pre .htm, code .htm {
  color: #dda0dd;
}

pre .xsl, code .xsl {
  color: #d0a0d0;
}

pre .atn, code .atn {
  color: #46eeee;
  font-weight: normal;
}

pre .atv, code .atv {
  color: #eeb4b4;
}

pre .dec, code .dec {
  color: #3387cc;
}

pre.prettyprint, code.prettyprint {
  font-family: 'Droid Sans Mono', 'CPMono_v07 Bold', 'Droid Sans', monospace;
  font-weight: bold;
  font-size: 9pt;
  background-color: #0f0f0f;
  -khtml-border-radius: 8px;
  border-radius: 8px;
}

pre.prettyprint {
  width: 95%;
  margin: 1em auto;
  white-space: pre-wrap;
}

pre.prettyprint a, code.prettyprint a {
  text-decoration: none;
}

ol.linenums {
  margin-top: 0;
  margin-bottom: 0;
  color: #8b8970;
}

li.L0, li.L1, li.L2, li.L3, li.L5, li.L6, li.L7, li.L8 {
  list-style-type: none;
}

@media print {
  pre.prettyprint, code.prettyprint {
    background-color: #fff;
  }

  pre .str, code .str {
    color: #088;
  }

  pre .kwd, code .kwd {
    color: #006;
    font-weight: bold;
  }

  pre .com, code .com {
    color: #oc3;
    font-style: italic;
  }

  pre .typ, code .typ {
    color: #404;
    font-weight: bold;
  }

  pre .lit, code .lit {
    color: #044;
  }

  pre .pun, code .pun {
    color: #440;
  }

  pre .pln, code .pln {
    color: #000;
  }

  pre .tag, code .tag {
    color: #b66ff7;
    font-weight: bold;
  }

  pre .htm, code .htm {
    color: #606;
    font-weight: bold;
  }

  pre .xsl, code .xsl {
    color: #606;
    font-weight: bold;
  }

  pre .atn, code .atn {
    color: #c71585;
    font-weight: normal;
  }

  pre .atv, code .atv {
    color: #088;
    font-weight: normal;
  }
}
/* -----------------------------------------------
  .p-hero
----------------------------------------------- */
.p-hero {
  position: relative;
  height: 100vh;
  overflow: hidden;
}
.p-hero_screen {
  position: fixed;
  width: 100%;
  height: 100%;
}
.p-hero_title {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  width: 722px;
  height: 227px;
  margin: auto;
}
.p-hero_slide_image {
  position: relative;
  overflow: hidden;
  width: 100%;
  text-align: center;
}
.p-hero_slide_image img {
  max-width: none;
  min-width: 100%;
  min-height: 100vh;
}
.p-hero_scroll {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 30px;
  width: 60px;
  margin: 0 auto;
}
.p-hero_scroll_btn {
  position: relative;
  display: block;
  padding: 0 0 65px;
}
.p-hero_scroll_btn::before {
  position: absolute;
  content: '';
  display: block;
  bottom: 0;
  left: 0;
  right: 0;
  width: 54px;
  height: 54px;
  margin: 0 auto;
  box-sizing: border-box;
  border: 3px solid #fff;
  border-radius: 100%;
}
.p-hero_scroll_btn::after {
  position: absolute;
  content: '';
  display: block;
  display: block;
  left: 0;
  right: 0;
  bottom: 30%;
  width: 7px;
  height: 7px;
  margin: 0 auto;
  border-bottom: 3px solid #fff;
  border-left: 3px solid #fff;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  -webkit-animation: arrowDown 1.5s infinite;
  animation: arrowDown 1.5s infinite;
}
.p-hero_scroll_btn img {
  display: block;
  width: 60px;
  margin: 0 auto;
}
.p-hero_notice {
  position: absolute;
  top: 160px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 1;
  width: 100%;
  padding: 0 30px;
  max-width: 1170px;
}
.p-hero_notice_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  background: rgba(255, 255, 255, .7);
}
.p-hero_notice_title {
  min-width: 165px;
  padding: 15px;
  color: #fff;
  text-align: center;
  font-size: 1.5rem;
  font-weight: 700;
  background: #3da4dd;
}
.p-hero_notice_main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0;
  padding: 15px 0;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.p-hero_notice_date {
  margin: 0 30px;
  font-weight: 700;
}
.p-hero_notice_text {
  padding-right: 30px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@-webkit-keyframes arrowDown {
  0% {
    bottom: 40%;
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    bottom: 30%;
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

@keyframes arrowDown {
  0% {
    bottom: 40%;
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    bottom: 30%;
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@media screen and (max-width: 768px) {
  .p-hero_title {
    width: 302px;
    height: 97px;
  }
  .p-hero_slide img {
    min-height: 0;
  }
  .p-hero_scroll {
    bottom: 20px;
    width: 42px;
  }
  .p-hero_scroll_btn {
    padding: 0 0 52px;
  }
  .p-hero_scroll_btn::before {
    width: 40px;
    height: 40px;
  }
  .p-hero_scroll_btn img {
    width: 42px;
  }
  .p-hero_notice {
    top: 105px;
    padding: 0 15px;
  }
  .p-hero_notice_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .p-hero_notice_title {
    width: 100%;
    min-width: initial;
    padding: 10px;
    font-size: 1.4rem;
    background: rgba(0, 140, 214, .7);
  }
  .p-hero_notice_main {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 15px 20px 20px;
  }
  .p-hero_notice_date {
    margin: 0;
  }
  .p-hero_notice_text {
    padding-right: 0;
  }
}
/* =================================================
  .p-topSection
================================================= */
.p-topSection {
  padding: 60px 30px;
}
.p-topSection:nth-child(2n) {
  background: #fff;
}
.p-topSection_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 0 55px;
  font-size: 30px;
  font-size: 3rem;
  text-align: center;
  line-height: 1.5;
}
.p-topSection_title::before, .p-topSection_title::after {
  content: '';
  display: inline-block;
  width: 80px;
  height: 1px;
  background: #141414;
}
.p-topSection_title::before {
  margin-right: 9px;
}
.p-topSection_title::after {
  margin-left: 9px;
}

.isHome .p-topSection--schoollife .l-subContents {
  margin: 0 0 -30px;
}
.isHome .p-topSection--schoollife .l-subContents_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 0 55px;
  font-size: 30px;
  font-size: 3rem;
  text-align: center;
  line-height: 1.5;
}
.isHome .p-topSection--schoollife .l-subContents_title::before, .isHome .p-topSection--schoollife .l-subContents_title::after {
  content: '';
  display: inline-block;
  width: 80px;
  height: 1px;
  background: #141414;
}
.isHome .p-topSection--schoollife .l-subContents_title::before {
  margin-right: 9px;
}
.isHome .p-topSection--schoollife .l-subContents_title::after {
  margin-left: 9px;
}

@media screen and (max-width: 768px) {
  .p-topSection {
    margin: 0 -15px;
    padding: 50px 15px;
  }
  .p-topSection_title {
    margin: 0 0 30px;
    white-space: nowrap;
    font-size: 27px;
    font-size: 2.7rem;
  }
  .p-topSection_title::before, .p-topSection_title::after {
    width: 100%;
  }

  .isHome .p-topSection--schoollife .l-subContents {
    margin: 0 0 -15px;
  }
  .isHome .p-topSection--schoollife .l-subContents_title {
    margin: 0 0 30px;
    white-space: nowrap;
    font-size: 27px;
    font-size: 2.7rem;
  }
  .isHome .p-topSection--schoollife .l-subContents_title::before, .isHome .p-topSection--schoollife .l-subContents_title::after {
    width: 100%;
  }
}
/* -----------------------------------------------
  .p-topTopics
----------------------------------------------- */
.p-topTopics {
  margin: 0 -30px;
  overflow-x: hidden;
}
.p-topTopics_link {
  position: relative;
  display: block;
  overflow: hidden;
  background: #000;
}
.p-topTopics_link_text {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 8px 15px;
  background: rgba(0, 0, 0, .4);
  color: #fff;
  font-weight: 700;
}
.p-topTopics_link img {
  width: 100%;
  -webkit-transition-duration: .3s;
  transition-duration: .3s;
}
.p-topTopics_link:hover img {
  opacity: .6;
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}

@media screen and (max-width: 768px) {
  .p-topTopics {
    margin: 0 -15px;
  }
}
/* -----------------------------------------------
  .p-topNews
----------------------------------------------- */
.p-topNews {
  margin: 0 0 60px;
}
.p-topNews_tab {
  margin: 0 -30px 40px;
  padding: 0 30px;
  border-bottom: 1px solid #e2e6ef;
}
.p-topNews_tab_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
}
.p-topNews_tab_nav_item {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  text-align: center;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.5;
}
.p-topNews_tab_nav_item a {
  position: relative;
  display: block;
  padding: 0 10px 20px;
}
.p-topNews_tab_nav_item a:hover {
  text-decoration: none;
}
.p-topNews_tab_nav_item a::before {
  position: absolute;
  content: '';
  display: block;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: #ffcd05;
  opacity: 0;
  -webkit-transition: .1s linear;
  transition: .1s linear;
}
.p-topNews_tab_nav_item a.isActive::before {
  opacity: 1;
}
.p-topNews_tab--cntIn {
  margin: 0 0 40px;
}
.p-topNews_tabPanels {
  width: 100%;
  max-width: 1170px;
  margin: 0 auto;
}

@media screen and (max-width: 1024px) {
  .p-topNews_tab_nav_item {
    -webkit-box-flex: 1;
    -ms-flex: auto;
    flex: auto;
  }
}
@media screen and (max-width: 768px) {
  .p-topNews {
    margin: 0 0 30px;
  }
  .p-topNews_tab {
    margin: 0 0 30px;
    padding: 0;
    border-bottom: none;
  }
  .p-topNews_tab_nav {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .p-topNews_tab_nav_item {
    -webkit-box-flex: 1;
    -ms-flex: auto;
    flex: auto;
    width: calc(100%/3);
    font-size: 14px;
    font-size: 1.4rem;
  }
  .p-topNews_tab_nav_item:first-child {
    width: 100%;
  }
  .p-topNews_tab_nav_item:first-child a {
    border: 1px solid #e2e6ef;
  }
  .p-topNews_tab_nav_item:nth-child(4), .p-topNews_tab_nav_item:last-child {
    border-right: 1px solid #e2e6ef;
  }
  .p-topNews_tab_nav_item a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
    padding: 11px;
    border-bottom: 1px solid #e2e6ef;
    border-left: 1px solid #e2e6ef;
  }
  .p-topNews_tab_nav_item a::before {
    display: none;
  }
  .p-topNews_tab_nav_item a.isActive {
    background: #ffcd05;
    border-color: transparent;
  }
  .p-topNews_tab--cntIn {
    margin: 0 0 30px;
  }
  .p-topNews_tabPanels {
    width: 100%;
    max-width: 1170px;
    margin: 0 auto;
  }
}
/* -----------------------------------------------
  .p-topAbout
----------------------------------------------- */
.p-topAbout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 -30px 60px;
}
.p-topAbout_item {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  background: #fff;
  text-align: center;
}
.p-topAbout_item + .p-topAbout_item {
  margin-left: 1px;
}
.p-topAbout_item_link:hover {
  text-decoration: none;
}
.p-topAbout_item_link:hover .p-topAbout_item_thumb img {
  opacity: .6;
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
.p-topAbout_item_thumb {
  background: #000;
  overflow: hidden;
}
.p-topAbout_item_thumb img {
  width: 100%;
  -webkit-transition-duration: .3s;
  transition-duration: .3s;
}
.p-topAbout_item_text {
  padding: 25px;
}
.p-topAbout_item_title {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.5;
}
.p-topAbout_item_desc {
  margin: 10px 0 0;
  font-size: 14px;
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .p-topAbout {
    display: block;
    margin: 0 0 30px;
  }
  .p-topAbout_item + .p-topAbout_item {
    margin: 15px 0 0;
  }
  .p-topAbout_item_text {
    padding: 25px;
  }
  .p-topAbout_item_title {
    font-size: 21px;
    font-size: 2.1rem;
  }
  .p-topAbout_item_desc {
    text-align: left;
  }
}
/* -----------------------------------------------
  .p-topSchool
----------------------------------------------- */
.p-topSchool {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-topSchool_area {
  width: calc(50% - 30px);
}
.p-topSchool_area + .p-topSchool_area {
  position: relative;
}
.p-topSchool_area + .p-topSchool_area::before {
  position: absolute;
  content: '';
  display: block;
  top: -60px;
  left: -30px;
  width: 1px;
  height: calc(100% + 120px);
  background: #e2e6ef;
}
.p-topSchool_area--highschool {
  margin-left: 30px;
}
.p-topSchool_area--j-highschool {
  margin-right: 30px;
}
.p-topSchool_menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.p-topSchool_menu_item {
  width: 50%;
  padding: 0 15px 30px;
  text-align: center;
}
.p-topSchool_menu_item_link:hover {
  text-decoration: none;
}
.p-topSchool_menu_item_link:hover .p-topSchool_menu_item_thumb img {
  opacity: .6;
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
.p-topSchool_menu_item_thumb {
  max-width: 220px;
  max-height: 220px;
  margin: 0 auto 20px;
  background: #000;
  border-radius: 100%;
  overflow: hidden;
}
.p-topSchool_menu_item_thumb img {
  width: 100%;
  -webkit-transition-duration: .3s;
  transition-duration: .3s;
}
.p-topSchool_menu_item_title {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 700;
}
.p-topSchool_menu_item_desc {
  margin: 0;
  font-size: 14px;
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .p-topSchool {
    display: block;
  }
  .p-topSchool_area {
    width: auto;
  }
  .p-topSchool_area--highschool {
    margin-left: 0;
  }
  .p-topSchool_area--j-highschool {
    margin-right: 0;
  }
  .p-topSchool_area + .p-topSchool_area {
    margin-top: 45px;
  }
  .p-topSchool_menu {
    display: block;
    width: auto;
    margin-bottom: 30px;
  }
  .p-topSchool_menu_item {
    width: auto;
    padding: 0;
    text-align: left;
  }
  .p-topSchool_menu_item + .p-topSchool_menu_item {
    margin-top: 15px;
  }
  .p-topSchool_menu_item_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .p-topSchool_menu_item:nth-child(even) .p-topSchool_menu_item_link {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  .p-topSchool_menu_item_thumb {
    width: 50%;
    max-width: none;
    max-height: none;
    margin: 0;
  }
  .p-topSchool_menu_item_text {
    width: calc(50% - 15px);
  }
  .p-topSchool_menu_item_title {
    font-size: 15px;
    font-size: 1.5rem;
  }
  .p-topSchool_menu_item_desc {
    margin: 0;
    font-size: 12px;
    font-size: 1.2rem;
  }
}
/* -----------------------------------------------
  .p-topSchoollife
----------------------------------------------- */
.p-topSchoollife {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -30px;
}
.p-topSchoollife_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 33%;
  flex: 1 1 33%;
  min-height: 360px;
  -webkit-transform: translateY(-20px);
  -ms-transform: translateY(-20px);
  transform: translateY(-20px);
}
.p-topSchoollife_item:nth-child(3n+2) {
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}
.p-topSchoollife_item_link {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  padding: 20px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
  color: #fff;
}
.p-topSchoollife_item_link:hover {
  text-decoration: none;
}
.p-topSchoollife_item_link:hover::before {
  opacity: .5;
}
.p-topSchoollife_item_link:hover::after {
  opacity: 1;
}
.p-topSchoollife_item_link:hover .p-topSchoollife_item_inner {
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
.p-topSchoollife_item_link::before {
  position: absolute;
  content: '';
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: .2;
  -webkit-transition: .3s linear;
  transition: .3s linear;
}
.p-topSchoollife_item_link::after {
  position: absolute;
  content: '';
  display: block;
  top: -5px;
  right: -5px;
  background: inherit;
  filter: blur(5px);
  bottom: -5px;
  left: -5px;
  z-index: -1;
  opacity: 0;
  -webkit-transition: .3s linear;
  transition: .3s linear;
}
.p-topSchoollife_item_inner {
  position: relative;
  width: 100%;
  -webkit-transition: .3s linear;
  transition: .3s linear;
}
.p-topSchoollife_item_num {
  display: block;
  height: 50px;
  margin: 0 auto;
}
.p-topSchoollife_item_text {
  margin: 10px 0 0;
  letter-spacing: .1em;
  text-align: center;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
}
.p-topSchoollife_item.uniform .p-topSchoollife_item_link {
  background-image: url(/assets/images/top/bg_schoollife_uniform.jpg);
}
.p-topSchoollife_item.day .p-topSchoollife_item_link {
  background-image: url(/assets/images/top/bg_schoollife_day.jpg);
}
.p-topSchoollife_item.event .p-topSchoollife_item_link {
  background-image: url(/assets/images/top/bg_schoollife_event.jpg);
}
.p-topSchoollife_item.environment .p-topSchoollife_item_link {
  background-image: url(/assets/images/top/bg_schoollife_environment.jpg);
}
.p-topSchoollife_item.club .p-topSchoollife_item_link {
  background-image: url(/assets/images/top/bg_schoollife_club.jpg);
}
.p-topSchoollife_item.sgc .p-topSchoollife_item_link {
  background-image: url(/assets/images/top/bg_schoollife_sgc.jpg);
}

@media screen and (max-width: 768px) {
  .p-topSchoollife {
    margin: 0 -15px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .p-topSchoollife_item {
    -webkit-box-flex: initial;
    -ms-flex: initial;
    flex: initial;
    width: 50%;
    min-height: 180px;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
  .p-topSchoollife_item_num {
    display: block;
    height: 50px;
    margin: 0 auto;
  }
  .p-topSchoollife_item_text {
    font-size: 15px;
    font-size: 1.5rem;
  }
}
/* -----------------------------------------------
  .p-topSns
----------------------------------------------- */
.p-topSns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 100%;
  max-width: 970px;
  margin: 0 auto;
}
.p-topSns_area {
  width: calc(50% - 15px);
}
.p-topSns_area--twitter {
  padding: 20px;
  background: #f5f5f7;
  line-height: 0;
}

@media screen and (max-width: 1024px) {
  .p-topSns {
    display: block;
  }
  .p-topSns_area {
    width: 470px;
    margin-left: auto;
    margin-right: auto;
  }
  .p-topSns_area + .p-topSns_area {
    margin-top: 30px;
  }
}
@media screen and (max-width: 768px) {
  .p-topSns_area {
    width: auto;
  }
  .p-topSns_area--twitter {
    padding: 10px;
  }
}
/* -----------------------------------------------
  .p-newsList
----------------------------------------------- */
.p-newsList_item {
  display: table;
  width: 100%;
}
.p-newsList_item + .p-newsList_item {
  margin-top: 20px;
}
.p-newsList_item_date {
  position: relative;
  display: table-cell;
  width: 7.5em;
  font-weight: 700;
}
.p-newsList_item_cat {
  position: absolute;
  top: 1px;
  right: 30px;
  display: inline-block;
  width: 170px;
  padding: 5px 5px 6px;
  border: 1px solid #e2e6ef;
  border-radius: 13px;
  text-align: center;
  font-weight: 400;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
}
.p-newsList_item_text {
  position: relative;
  display: table-cell;
  padding: 0 0 0 11px;
}
.p-newsList_item_text::before {
  position: absolute;
  content: '';
  display: block;
  top: .55em;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #ffcd05;
  -webkit-transition: .1s linear;
  transition: .1s linear;
}
.p-newsList.isCategory .p-newsList_item_date {
  /*width: 18.5em;*/
  width: 20em;
}

@media screen and (max-width: 768px) {
  .p-newsList_item {
    display: block;
  }
  .p-newsList_item + .p-newsList_item {
    margin-top: 25px;
  }
  .p-newsList_item_date {
    position: relative;
    display: block;
    width: auto;
    margin: 0 0 10px;
    font-weight: 700;
  }
  .p-newsList_item_cat {
    position: static;
    margin-left: 20px;
  }
  .p-newsList_item_text {
    display: block;
  }
  .p-newsList_item_text::before {
    top: .6em;
  }
  .p-newsList.isCategory .p-newsList_item_date {
    width: auto;
  }
}
/* -----------------------------------------------
  .p-panel
----------------------------------------------- */
.p-panel_item_link:hover {
  text-decoration: none;
}
.p-panel_item_link:hover .p-panel_item_thumb img {
  opacity: .6;
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
.p-panel_item_thumb {
  margin: 0 0 15px;
  background: #000;
  overflow: hidden;
}
.p-panel_item_thumb img {
  width: 100%;
  -webkit-transition-duration: .3s;
  transition-duration: .3s;
}
.p-panel_item_title {
  position: relative;
  margin: 0 0 10px;
  padding: 0 0 0 26px;
  background: url('/assets/images/common/ico_arrow_next_02.svg') 0 .1em no-repeat;
  font-weight: 700;
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.4;
}

@media screen and (max-width: 768px) {
  .p-panel_item_desc {
    font-size: 15px;
    font-size: 1.5rem;
  }
}
.p-panel02_item_link {
  display: block;
}
.p-panel02_item_link:hover {
  opacity: .7;
  text-decoration: none;
}
.p-panel02_item_thumb {
  margin: 0 0 10px;
}
.p-panel02_item_thumb img {
  width: 100%;
}
.p-panel02_item_title {
  position: relative;
  padding: 0 0 0 12px;
  line-height: 1.4;
}
.p-panel02_item_title::before {
  position: absolute;
  content: '';
  display: block;
  top: .45em;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #ffcd05;
}

/* -----------------------------------------------
  .p-message
----------------------------------------------- */
.p-message_main {
  margin: 0 0 50px;
}
.p-message_main img {
  width: 100%;
}
.p-message_sign {
  margin: 35px 0 0;
  text-align: right;
}
.p-message_sign img {
  width: 160px;
}

@media screen and (max-width: 768px) {
  .p-message_main {
    margin: 0 0 30px;
  }
  .p-message_sign {
    margin: 30px 0 0;
  }
  .p-message_sign img {
    width: 120px;
  }
}
/* -----------------------------------------------
  .p-pagenation
----------------------------------------------- */
.p-pagenation {
  margin: 50px 0;
  text-align: center;
  font-size: 0;
  font-size: 0rem;
}
.p-pagenation_item {
  display: inline-block;
  margin: 0 5px;
  font-size: 15px;
  font-size: 1.5rem;
  line-height: 1.4;
}
.p-pagenation_item_label {
  font-size: 0;
  font-size: 0rem;
}
.p-pagenation_item a {
  position: relative;
  display: block;
  padding: 5px 10px;
  background: #fff;
  border: 1px solid #000;
}
.p-pagenation_item a:hover {
  text-decoration: none;
}
.p-pagenation_item.isActive span, .p-pagenation_item.isActive a {
  position: relative;
  display: block;
  padding: 5px 10px;
  cursor: default;
  border: 1px solid #000;
  background: #fff5cd;
}
.p-pagenation_item.isHidden {
  display: none;
}
.p-pagenation_item--prev {
  margin-right: 5px;
}
.p-pagenation_item--prev a {
  padding: 5px 12px;
  background: #000;
}
.p-pagenation_item--prev a::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff;
  vertical-align: 1px;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.p-pagenation_item--next {
  margin-left: 5px;
}
.p-pagenation_item--next a {
  padding: 5px 12px;
  background: #000;
}
.p-pagenation_item--next a::after {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  vertical-align: 1px;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media screen and (max-width: 768px) {
  .p-pagenation {
    margin: 50px 0 30px;
  }
  .p-pagenation_item:not([class*='isActive']):not([class*='p-pagenation_item--prev']):not([class*='p-pagenation_item--next']) {
    display: none;
  }
  .p-pagenation_item.isActive {
    font-weight: 700;
  }
  .p-pagenation_item.isActive::after {
    content: 'ページ目';
    display: inline-block;
  }
  .p-pagenation_item.isActive a {
    display: inline-block;
    padding: 0;
    background: none;
    border: none;
    pointer-events: none;
  }
}
/* -----------------------------------------------
  .p-article 記事投稿専用モジュール
----------------------------------------------- */
.p-article a {
  color: #008cd6;
}
.p-article p {
  margin: 1em 0;
}
.p-article table {
  max-width: 100%;
  table-layout: fixed;
  margin: 30px 0;
}
.p-article table th, .p-article table td {
  padding: 10px;
  vertical-align: top;
}
.p-article table th > :nth-child(1), .p-article table td > :nth-child(1) {
  margin-top: 0;
}
.p-article dl {
  margin: 20px 0;
}
.p-article dl > dt {
  font-weight: 700;
}
.p-article dl > dd {
  margin: 7px 0 0;
}
.p-article dl > dd + dt {
  margin-top: 10px;
}
.p-article ol {
  margin: 20px 0;
  counter-reset: number 0;
}
.p-article ol > li {
  padding: 0 0 0 1.8em;
  position: relative;
}
.p-article ol > li::before {
  position: absolute;
  left: 0;
  counter-increment: number 1;
  content: counter(number) '.';
  font-weight: 700;
}
.p-article ol > li + li {
  margin-top: 10px;
}
.p-article ul {
  margin: 20px 0;
}
.p-article ul > li {
  position: relative;
  margin-top: 15px;
  padding-left: 1em;
}
.p-article ul > li ul {
  margin: 15px 0;
}
.p-article ul > li:first-child {
  margin-top: 0;
}
.p-article ul > li:before {
  content: ' ';
  position: absolute;
  top: .6em;
  left: 0;
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #008cd6;
}
.p-article h2 {
  position: relative;
  margin-bottom: 30px;
  padding-bottom: 15px;
  font-size: 28px;
  font-size: 2.8rem;
  line-height: 1.5;
  border-bottom: 3px solid #e2e6ef;
}
.p-article h2:before {
  content: ' ';
  position: absolute;
  left: 0;
  bottom: -3px;
  display: block;
  width: 70px;
  height: 3px;
  background: #008cd6;
}
.p-article h3 {
  position: relative;
  margin: 0 0 40px;
  padding: 0 0 3px 20px;
  line-height: 1.5;
  font-size: 24px;
  font-size: 2.4rem;
}
.p-article h3:before {
  content: ' ';
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 3px;
  height: 100%;
  background: -webkit-linear-gradient(top, #00afe2 0%, #00afe2 50%, #008cd6 51%, #008cd6 100%);
  background: linear-gradient(to bottom, #00afe2 0%, #00afe2 50%, #008cd6 51%, #008cd6 100%);
}
.p-article h4 {
  margin: 0 0 30px;
  padding-bottom: 10px;
  font-size: 20px;
  font-size: 2rem;
  border-bottom: 2px solid #008cd6;
}
.p-article h5 {
  margin: 0 0 20px;
  padding: 0 0 17px;
  border-bottom: 1px solid #e2e6ef;
  line-height: 1.5;
  font-size: 18px;
  font-size: 1.8rem;
}
.p-article h6 {
  margin: 0 0 10px;
  line-height: 1.5;
  font-size: 16px;
  font-size: 1.6rem;
}
.p-article .btn01, .p-article .btn02 {
  position: relative;
  display: table;
  min-width: 270px;
  margin: 30px auto 0;
  padding: 14px 30px;
  border: 1px solid #000;
  text-decoration: none;
  text-align: center;
  color: #000;
  line-height: 1.3;
  -webkit-transition: .2s linear;
  transition: .2s linear;
  outline: none;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
}
.p-article .btn01:hover, .p-article .btn02:hover {
  text-decoration: none;
}
.p-article .btn01::after, .p-article .btn02::after {
  position: absolute;
  content: '';
  display: block;
  top: 0;
  bottom: 0;
  right: 22px;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-width: 4px 0 4px 4px;
  border-color: transparent transparent transparent #000;
}
.p-article .btn01:hover {
  background: #000;
  color: #fff;
}
.p-article .btn01:hover::after {
  border-color: transparent transparent transparent #fff;
}
.p-article .btn02 {
  background: #ffcd05;
  border-color: transparent;
}
.p-article .btn02:hover {
  background-color: rgba(255, 205, 5, .7);
}
.p-article .table {
  width: 100%;
  text-align: left;
  table-layout: fixed;
  border: solid #d1d5de;
  border-width: 1px 1px 0 0;
}
.p-article .table th, .p-article .table td {
  padding: 10px 15px;
  border: solid #d1d5de;
  border-width: 0 0 1px 1px;
}
.p-article .table th {
  font-weight: 400;
  background: #ebedf4;
}
.p-article .table2 {
  width: auto;
  text-align: left;
  table-layout: auto;
}
.p-article .table2 th, .p-article .table2 td {
  padding: 10px 15px;
}
.p-article .table2 th {
  font-weight: 400;
}
.p-article .table3 {
  width: auto;
  text-align: left;
  table-layout: auto;
  border: solid #d1d5de;
  border-width: 1px 1px 0 0;
}
.p-article .table3 th, .p-article .table3 td {
  padding: 10px 15px;
  border: solid #d1d5de;
  border-width: 0 0 1px 1px;
}
.p-article .table3 th {
  font-weight: 400;
  background: #ebedf4;
}
.p-article .table-sc td {
  vertical-align: middle;
}
.p-article .table-sc td:nth-child(1), .p-article .table-sc td:nth-child(5) {
  padding: 10px 40px;
}
.p-article .table-sc td:nth-child(2) {
  padding: 10px 40px 10px 0;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}
.p-article .table-sc td:nth-child(3) {
  padding: 10px 40px;
  border-left: 1px solid #ccc;
  border-right: 1px solid #ccc;
  text-align: center;
  white-space: nowrap;
}
.p-article .table-sc td:nth-child(4) {
  padding: 10px 0 10px 40px;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}
.p-article .table-bb {
  width: auto;
  text-align: left;
  table-layout: auto;
  border: solid #d1d5de;
  border-width: 1px 1px 0 0;
}
.p-article .table-bb td {
  padding: 5px;
  border: solid #d1d5de;
  border-width: 0 0 1px 1px;
  text-align: center;
  vertical-align: middle;
}
.p-article .table-bb td:nth-child(1) {
  text-align: left;
}
.p-article .table-bb th {
  padding: 5px;
  background: #ebedf4;
  border: solid #d1d5de;
  border-width: 0 0 1px 1px;
  font-weight: 400;
  text-align: center;
  vertical-align: middle;
}
.p-article iframe {
  display: block;
  width: 640px;
  height: 360px;
  margin: 1em auto;
}

@media screen and (max-width: 768px) {
  .p-article dl > dt {
    margin: 0 0 10px;
    padding-left: 14px;
  }
  .p-article dl > dd {
    padding-left: 14px;
  }
  .p-article dl > dd + dt {
    margin-top: 20px;
  }
  .p-article h2 {
    margin-bottom: 25px;
    font-size: 25px;
    font-size: 2.5rem;
  }
  .p-article h3 {
    margin-bottom: 30px;
    padding: 0 0 2px 15px;
    font-size: 21px;
    font-size: 2.1rem;
  }
  .p-article h4 {
    margin: 0 0 25px;
    padding-bottom: 15px;
    font-size: 19px;
    font-size: 1.9rem;
  }
  .p-article h5 {
    font-size: 17px;
    font-size: 1.7rem;
  }
  .p-article h6 {
    font-size: 15px;
    font-size: 1.5rem;
  }
  .p-article .btn01, .p-article .btn02 {
    display: block;
    width: 100%;
    min-width: 0;
    margin-top: 15px;
    padding: 13px;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .p-article iframe {
    width: 100%;
    height: 300px;
  }
  .p-article .table th, .p-article .table td {
    display: block;
    width: 100%;
    padding: 10px 13px;
    border-bottom: 1px solid #d1d5de;
  }
  .p-article .table2 th, .p-article .table2 td, .p-article .table3 th, .p-article .table3 td {
    padding: 10px 13px;
  }
  .p-article .table-sc td {
    font-size: 85%;
  }
  .p-article .table-sc td:nth-child(1), .p-article .table-sc td:nth-child(5) {
    width: 35%;
    padding: 10px;
    text-align: center;
  }
  .p-article .table-sc td:nth-child(2) {
    width: 10%;
    padding: 10px 10px 10px 0;
    font-size: 18px;
  }
  .p-article .table-sc td:nth-child(3) {
    width: 10%;
    padding: 10px;
  }
  .p-article .table-sc td:nth-child(4) {
    width: 10%;
    padding: 10px 0 10px 10px;
    font-size: 18px;
  }
  .p-article .table-bb {
    font-size: 85%;
  }
  .p-article .table-bb td {
    padding: 3px;
    vertical-align: middle;
  }
  .p-article .table-bb th {
    padding: 3px;
    vertical-align: middle;
    font-size: 75%;
  }
}
/* =================================================
  .p-projHeader
================================================= */
.p-projHeader {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 30px;
}
.p-projHeader_icon {
  width: 80px;
  height: 80px;
  margin-right: 15px;
  color: #008cd6;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  line-height: 74px;
  border: 3px solid #008cd6;
  border-radius: 50%;
  background: #fff100;
}
.p-projHeader_icon--square {
  width: auto;
  height: auto;
  margin-top: 2px;
  padding: 2px 15px;
  line-height: inherit;
  border-width: 2px;
  border-radius: 4px;
}
.p-projHeader_title {
  margin: 0;
  font-weight: 400;
  line-height: 1.4;
  font-size: 20px;
  font-size: 2rem;
}
.p-projHeader_title em {
  display: block;
  font-weight: 700;
  font-size: 24px;
  font-size: 2.4rem;
}

@media screen and (max-width: 768px) {
  .p-projHeader {
    margin-bottom: 25px;
  }
  .p-projHeader_icon {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .p-projHeader_title {
    font-size: 18px;
    font-size: 1.8rem;
  }
  .p-projHeader_title em {
    font-size: 21px;
    font-size: 2.1rem;
  }
}
/* =================================================
  .p-flow
================================================= */
.p-flow dl {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  border-radius: 4px;
  background: #f39700;
}
.p-flow dl:before {
  content: ' ';
  position: absolute;
  left: 83px;
  bottom: -12px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12px 12px 0 12px;
  border-color: #f39600 transparent transparent transparent;
}
.p-flow dl:last-child:before {
  display: none;
}
.p-flow dt {
  width: 193px;
  color: #fff;
  text-align: center;
  font-weight: 700;
  font-size: 20px;
  font-size: 2rem;
}
.p-flow dd {
  margin: 3px 3px 3px 0;
  padding: 25px 30px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  font-size: 14px;
  font-size: 1.4rem;
  border-radius: 0 2px 2px 0;
  background: #fffae5;
}

@media screen and (max-width: 768px) {
  .p-flow dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 18px;
  }
  .p-flow dl:before {
    left: 50%;
    margin-left: -12px;
  }
  .p-flow dl:first-child {
    margin-top: 0;
  }
  .p-flow dt {
    width: 100%;
    font-size: 19px;
    font-size: 1.9rem;
  }
  .p-flow dd {
    margin: 3px;
    padding: 10px 15px;
    border-radius: 0 0 2px 2px;
  }
}
/* =================================================
  .p-cycle
================================================= */
.p-cycle_unit {
  margin-top: 20px;
  border: solid #008cd6;
  border-width: 0 3px 3px;
}
.p-cycle_unit:first-child {
  margin-top: 0;
}
.p-cycle_unit dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0;
  background: #008cd6;
}
.p-cycle_unit dt {
  width: 220px;
  color: #fff;
  font-weight: 700;
  text-align: center;
}
.p-cycle_unit dd {
  margin: 3px 0;
  padding: 7px 15px 9px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  background: #fff100;
}
.p-cycle_text {
  padding: 25px 30px;
}

@media screen and (max-width: 768px) {
  .p-cycle_unit {
    margin-top: 15px;
  }
  .p-cycle_unit dt {
    width: 127px;
  }
  .p-cycle_text {
    padding: 10px 15px;
  }
}
/* =================================================
  .p-point
================================================= */
.p-point {
  padding-top: 55px;
}
.p-point_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -75px 0 0 -6.2%;
}
.p-point_unit {
  position: relative;
  width: 42%;
  margin: 75px 0 0 6.2%;
}
.p-point_unit dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  min-height: 100%;
  margin: 0;
  font-weight: 700;
  border: 3px solid #008cd6;
  background: #fff100;
}
.p-point_unit dt, .p-point_unit dd {
  line-height: 1.4;
}
.p-point_unit dt span, .p-point_unit dd span {
  position: relative;
  top: 50%;
  left: 0;
  display: block;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  padding: 10px 15px;
}
.p-point_unit dt {
  width: 100%;
  max-width: 114px;
  text-align: center;
  color: #008cd6;
}
.p-point_unit dd {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  border-left: 3px solid #008cd6;
  background: #fff;
}
.p-point_unit p {
  position: absolute;
  top: -58px;
  right: -33px;
  width: 80px;
  height: 80px;
  text-align: center;
  font-size: 12px;
  font-size: 1.2rem;
  color: #008cd6;
  line-height: 1.4;
  border: 3px solid #fff;
  border-radius: 50%;
  background: #fff100;
}
.p-point_unit p span {
  display: block;
  position: relative;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}

@media screen and (max-width: 768px) {
  .p-point_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: 0;
  }
  .p-point_unit {
    width: 100%;
    margin: 76px 0 0;
  }
  .p-point_unit:first-child {
    margin-top: 0;
  }
  .p-point_unit dt {
    max-width: 90px;
  }
  .p-point_unit p {
    width: 70px;
    height: 70px;
    right: inherit;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    font-size: 11px;
    font-size: 1.1rem;
  }
}
/* =================================================
  .p-clubList
================================================= */
.p-clubList_item {
  margin-top: 0;
  padding: 25px 20px 30px;
}
.p-clubList_item--sports {
  background: #f7fcff;
  border-top: 1px solid #008cd6;
}
.p-clubList_item--culture {
  background: #fbf9fd;
  border-top: 1px solid #9070af;
}
.p-clubList_item--club {
  background: #f7fdfd;
  border-top: 1px solid #00a496;
}
.p-clubList_item_title {
  margin: 0 0 10px;
  font-weight: 700;
  line-height: 1.5;
}
.p-clubList_item_desc {
  font-size: 13px;
  font-size: 1.3rem;
}

@media screen and (max-width: 768px) {
  .p-clubList_item {
    padding: 15px;
  }
  .p-clubList_item_title {
    font-size: 15px;
    font-size: 1.5rem;
  }
  .p-clubList_item_desc {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
/* =================================================
  .p-sitemap
================================================= */
.p-sitemap_group_title {
  margin: 0;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
}
.p-sitemap_group_title_link {
  position: relative;
  display: block;
  padding: 12px 14px 11px 40px;
  background: url('/assets/images/common/ico_arrow_next_02.svg') 14px .8em no-repeat;
  border: 1px solid #e2e6ef;
}
.p-sitemap_group_title_link:hover {
  background-color: #f7f7fa;
  text-decoration: none;
}
.p-sitemap_group_list {
  padding: 25px 10px 30px;
}

@media screen and (max-width: 768px) {
  .p-sitemap_group_title_link {
    padding: 9px 14px 8px 40px;
    background: url('/assets/images/common/ico_arrow_next_02.svg') 14px .65em no-repeat;
  }
  .p-sitemap_group_list {
    padding: 25px 8px 30px;
  }
}
/* =================================================
  .p-pickupVis
================================================= */
.p-pickupVis {
  position: relative;
}
.p-pickupVis_detail {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 410px;
  margin: 0;
  padding: 30px;
  color: #fff;
  background: #008cd6;
}
.p-pickupVis_title {
  margin-bottom: 10px;
  padding-left: 20px;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: 700;
  border-left: 3px solid #fff;
}
.p-pickupVis_image {
  margin: 0;
  text-align: right;
}
.p-pickupVis_item {
  max-width: 520px;
}

@media screen and (max-width: 768px) {
  .p-pickupVis {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .p-pickupVis_main {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
  .p-pickupVis_detail {
    position: relative;
    top: 0;
    -webkit-transform: translate(0);
    -ms-transform: translate(0);
    transform: translate(0);
    width: 100%;
    margin-top: -20px;
    padding: 15px;
  }
  .p-pickupVis_title {
    padding-left: 15px;
    font-size: 21px;
    font-size: 2.1rem;
  }
  .p-pickupVis_image {
    margin: 0 -15px;
  }
  .p-pickupVis_item {
    max-width: initial;
    max-width: auto;
    width: 100%;
  }
}
/* =================================================
  .p-pickupVis02
================================================= */
.p-pickupVis02 {
  position: relative;
  margin-bottom: 60px;
}
.p-pickupVis02_main {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 440px;
  margin: 0;
  padding: 30px;
  text-align: center;
  background: #fff;
}
.p-pickupVis02_image {
  margin: 0;
}
.p-pickupVis02_item {
  max-width: 740px;
}
.p-pickupVis02_btn {
  display: inline-block;
  margin: 0 auto;
}
.p-pickupVis02--imageL .p-pickupVis02_main {
  right: 0;
}
.p-pickupVis02--imageL .p-pickupVis02_image {
  text-align: left;
}
.p-pickupVis02--imageR .p-pickupVis02_main {
  left: 0;
}
.p-pickupVis02--imageR .p-pickupVis02_image {
  text-align: right;
}

@media screen and (max-width: 768px) {
  .p-pickupVis02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 50px;
  }
  .p-pickupVis02_main {
    position: relative;
    top: 0;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    width: 100%;
    margin-top: -15px;
    padding: 15px;
    text-align: left;
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
  .p-pickupVis02_main br {
    display: none;
  }
  .p-pickupVis02_image {
    margin: 0 -15px;
  }
  .p-pickupVis02_item {
    max-width: 100%;
  }
  .p-pickupVis02_btn {
    display: block;
    margin: 0 auto;
  }
}
/* =================================================
  .p-openList
================================================= */
.p-openList {
  counter-reset: openNum;
}
.p-openList_item {
  counter-increment: openNum;
  margin: 0;
}
.p-openList_title {
  position: relative;
  padding: 15px 45px 15px 20px;
  font-weight: 700;
  border-top: 1px solid #008cd6;
  cursor: pointer;
  background: #f7fcff;
}
.p-openList_title:after {
  content: ' ';
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  display: block;
  width: 28px;
  height: 28px;
  background: url('/assets/images/common/ico_plus.svg') no-repeat;
  background-size: cover;
}
.p-openList_title.isOpen:after {
  background-image: url('/assets/images/common/ico_minus.svg');
}
.p-openList_detail {
  padding: 30px 20px;
}
.p-openList--qa .p-openList_title:before {
  content: 'Q' counter(openNum) '. ';
}

@media screen and (max-width: 768px) {
  .p-openList_title {
    padding: 10px 50px 10px 15px;
  }
  .p-openList_title:after {
    right: 15px;
  }
  .p-openList_detail {
    padding: 25px 15px;
  }
}
/* =================================================
  .p-scroll_balloon
================================================= */
.p-scroll_balloon {
  display: none;
  position: relative;
  padding: 7px 10px;
  background: #a3abbe;
  color: #fff;
  font-size: 10px;
  font-size: 1rem;
}
.p-scroll_balloon--top:after, .p-scroll_balloon--bottom:before {
  content: ' ';
  position: absolute;
  display: block;
  left: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
}
.p-scroll_balloon--top {
  margin-bottom: 7px;
}
.p-scroll_balloon--top:after {
  bottom: -7px;
  margin: 0 auto;
  border-width: 7px 5.5px 0;
  border-color: #a3abbe transparent transparent;
}
.p-scroll_balloon--bottom {
  margin-top: 7px;
}
.p-scroll_balloon--bottom:before {
  top: -7px;
  margin: 0 auto;
  border-width: 0 5.5px 7px;
  border-color: transparent transparent #a3abbe;
}

@media screen and (max-width: 768px) {
  .p-scroll_balloon {
    display: block;
  }
}
/* =================================================
  .p-dayTime
================================================= */
.p-dayTime {
  position: relative;
  padding-bottom: 40px;
}
.p-dayTime:before {
  content: ' ';
  position: absolute;
  top: 0;
  left: 40px;
  width: 0;
  height: 100%;
  border-left: 1px solid #008cd6;
}
.p-dayTime:last-child {
  padding-bottom: 0;
}
.p-dayTime:last-child:before {
  display: none;
}
.p-dayTime_schedule {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.p-dayTime_time {
  position: relative;
  z-index: 1;
  width: 80px;
  padding-top: 90px;
  color: #008cd6;
  text-align: center;
  font-size: 20px;
  font-size: 2rem;
  font-weight: 700;
  background-color: #fff;
  background-position: 0 10px;
  background-repeat: no-repeat;
  background-size: 100% auto;
  font-family: 'Roboto', sans-serif;
}
.p-dayTime_time--8_20 {
  background-image: url('/assets/images/schoollife/day/ico_time_8_20.svg');
}
.p-dayTime_time--8_40 {
  background-image: url('/assets/images/schoollife/day/ico_time_8_40.svg');
}
.p-dayTime_time--12_30 {
  background-image: url('/assets/images/schoollife/day/ico_time_12_30.svg');
}
.p-dayTime_time--13_15 {
  background-image: url('/assets/images/schoollife/day/ico_time_13_15.svg');
}
.p-dayTime_time--15_15 {
  background-image: url('/assets/images/schoollife/day/ico_time_15_15.svg');
}
.p-dayTime_time--18_00 {
  background-image: url('/assets/images/schoollife/day/ico_time_18_00.svg');
}
.p-dayTime_time--20_00 {
  background-image: url('/assets/images/schoollife/day/ico_time_20_00.svg');
}
.p-dayTime_main {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-left: 30px;
}
.p-dayTime_detail {
  margin: 0;
  padding-top: 35px;
}
.p-dayTime_title {
  margin-bottom: 28px;
  font-size: 20px;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .p-dayTime {
    padding-bottom: 50px;
  }
  .p-dayTime:before {
    display: none;
  }
  .p-dayTime:last-child .p-dayTime_schedule {
    padding-bottom: 0;
  }
  .p-dayTime:last-child .p-dayTime_schedule:before {
    display: none;
  }
  .p-dayTime_schedule {
    position: relative;
    padding-bottom: 15px;
  }
  .p-dayTime_schedule:before {
    content: ' ';
    position: absolute;
    top: 0;
    left: 30px;
    width: 0;
    height: 100%;
    border-left: 1px solid #008cd6;
  }
  .p-dayTime_time {
    width: 60px;
    padding-top: 60px;
    font-size: 17px;
    font-size: 1.7rem;
    background-position: 0 0;
  }
  .p-dayTime_detail {
    padding-top: 15px;
  }
  .p-dayTime_title {
    margin-bottom: 18px;
    font-size: 19px;
    font-size: 1.9rem;
  }
  .p-dayTime_image {
    margin-top: 20px;
  }
}
/* =================================================
  .p-annualEvent
================================================= */
.p-annualEvent {
  position: relative;
  padding-bottom: 60px;
}
.p-annualEvent:before {
  content: ' ';
  position: absolute;
  top: 0;
  left: 45px;
  width: 0;
  height: 100%;
  border-left: 1px solid #008cd6;
}
.p-annualEvent:last-child {
  padding-bottom: 0;
}
.p-annualEvent_schedule {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.p-annualEvent_month {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  padding: 15px 0 15px 20px;
  font-size: 28px;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1;
  background: #fff;
}
.p-annualEvent_month span {
  font-size: 56px;
  font-size: 5.6rem;
}
.p-annualEvent_main {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.p-annualEvent_detail {
  margin: 0;
  padding: 90px 0 0 80px;
}
.p-annualEvent_detail--composite {
  padding-bottom: 50px;
}
.p-annualEvent_title {
  margin-bottom: 28px;
  font-size: 20px;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .p-annualEvent {
    padding-bottom: 30px;
  }
  .p-annualEvent:before {
    display: none;
  }
  .p-annualEvent:last-child .p-dayTime_schedule {
    padding-bottom: 0;
  }
  .p-annualEvent:last-child .p-dayTime_schedule:before {
    display: none;
  }
  .p-annualEvent_schedule {
    position: relative;
    padding-bottom: 15px;
  }
  .p-annualEvent_schedule:before {
    content: ' ';
    position: absolute;
    top: 0;
    left: 25px;
    width: 0;
    height: 100%;
    border-left: 1px solid #008cd6;
  }
  .p-annualEvent_month {
    padding: 15px 0;
    font-size: 25px;
    font-size: 2.5rem;
  }
  .p-annualEvent_month span {
    font-size: 50px;
    font-size: 5rem;
  }
  .p-annualEvent_detail {
    position: relative;
    left: -15px;
    padding: 90px 0 0 65px;
  }
  .p-annualEvent_title {
    margin-bottom: 18px;
    font-size: 19px;
    font-size: 1.9rem;
  }
  .p-annualEvent_image {
    margin-top: 20px;
  }
}
/* =================================================
  .p-icoList
================================================= */
.p-icoList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  border-top: 1px solid #e2e6ef;
}
.p-icoList:last-child {
  border-bottom: 1px solid #e2e6ef;
}
.p-icoList_item {
  width: calc(100% / 3);
  padding: 8px 0;
}
.p-icoList_unit {
  margin-top: 35px;
}

@media screen and (max-width: 768px) {
  .p-icoList {
    display: block;
    border-top: none;
  }
  .p-icoList_item {
    width: 100%;
    border-top: 1px solid #e2e6ef;
  }
}
/* =================================================
  .p-adobeReader
================================================= */
.p-adobeReader {
  padding: 20px 30px;
  margin-top: 40px;
  background: #f5f5f6;
}
.p-adobeReader_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.p-adobeReader_img {
  margin: 0 30px 0 0;
}
.p-adobeReader_txt {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@media screen and (max-width: 768px) {
  .p-adobeReader {
    padding: 15px;
  }
  .p-adobeReader_item {
    display: block;
  }
  .p-adobeReader_img {
    margin: 0 0 25px;
  }
}
/* -----------------------------------------------
  .p-zoom
----------------------------------------------- */
.p-zoom_balloon {
  display: none;
}

@media screen and (max-width: 768px) {
  .p-zoom_balloon {
    position: relative;
    display: block;
    padding: 7px 10px;
    background: #a3abbe;
    text-align: center;
    color: #fff;
    font-size: 10px;
    font-size: 1rem;
  }
  .p-zoom_balloon::before {
    content: '';
    display: inline-block;
    width: 15px;
    height: 13px;
    margin-right: 7px;
    background: url(/assets/images/common/ico_zoom.svg) 0 0 no-repeat;
    background-size: auto 13px;
    vertical-align: -2px;
  }
  .p-zoom_balloon--top {
    margin-bottom: 15px;
  }
  .p-zoom_balloon--top::after {
    position: absolute;
    content: '';
    display: block;
    left: 0;
    right: 0;
    bottom: -7px;
    width: 0;
    height: 0;
    margin: 0 auto;
    border-style: solid;
    border-width: 7px 5.5px 0 5.5px;
    border-color: #a3abbe transparent transparent transparent;
  }
  .p-zoom_balloon--bottom {
    margin-top: 15px;
  }
  .p-zoom_balloon--bottom::after {
    position: absolute;
    content: '';
    display: block;
    left: 0;
    right: 0;
    top: -7px;
    width: 0;
    height: 0;
    margin: 0 auto;
    border-style: solid;
    border-width: 0 5.5px 7px 5.5px;
    border-color: transparent transparent #a3abbe transparent;
  }
}
/* -----------------------------------------------
  .p-paging
----------------------------------------------- */
.p-paging {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 50px 0 0;
  /* MT出力用 */
}
.p-paging_prev_arrow, .p-paging_next_arrow {
  position: relative;
  display: block;
  width: 60px;
  height: 32px;
  background: #000;
}
.p-paging_prev_arrow:before, .p-paging_next_arrow:before {
  content: ' ';
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border: 2px solid #fff;
  border-width: 2px 2px 0 0;
}
.p-paging_prev_arrow:hover, .p-paging_next_arrow:hover {
  background: rgba(0, 0, 0, .7);
}
.p-paging_prev {
  margin-right: 5px;
}
.p-paging_prev_arrow:before {
  -webkit-transform: rotate(-135deg);
  -ms-transform: rotate(-135deg);
  transform: rotate(-135deg);
  margin: -5px 0 0 -3px;
}
.p-paging_next {
  margin-left: 5px;
}
.p-paging_next_arrow:before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  margin: -5px 0 0 -6px;
}
.p-paging_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.p-paging_num {
  margin: 0 5px;
  text-align: center;
  font-size: 1.5rem;
  border: 1px solid #000;
}
.p-paging_num_link {
  display: block;
  width: 30px;
  height: 30px;
  line-height: 30px;
}
.p-paging_num_link:hover {
  text-decoration: none;
  background: #fff5cd;
}
.p-paging_num--nobdr {
  border: none;
}
.p-paging_num--cur {
  font-weight: 700;
  background: #fff5cd;
}
.p-paging_sep {
  width: 30px;
  height: 30px;
  line-height: 30px;
}
.p-paging_first, .p-paging_last, .p-paging_text {
  display: none;
}
.p-paging p {
  margin: 0;
}
.p-paging div {
  letter-spacing: -.40em;
}
.p-paging .link_first, .p-paging .link_last, .p-paging_text {
  display: none;
}
.p-paging .link_page, .p-paging .current_page {
  display: inline-block;
  letter-spacing: normal;
  vertical-align: top;
  width: 32px;
  height: 32px;
  line-height: 30px;
  margin: 0 5px;
  text-align: center;
  font-size: 1.5rem;
  border: 1px solid #000;
}
.p-paging .link_page:hover, .p-paging .current_page:hover {
  text-decoration: none;
  background: #fff5cd;
}
.p-paging .current_page {
  font-weight: 700;
  background: #fff5cd;
}
.p-paging .link_before, .p-paging .link_next {
  position: relative;
  display: block;
  width: 60px;
  height: 32px;
  overflow: hidden;
  text-indent: -9999px;
  background: #000;
}
.p-paging .link_before:before, .p-paging .link_next:before {
  content: ' ';
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 8px;
  height: 8px;
  border: 2px solid #fff;
  border-width: 2px 2px 0 0;
}
.p-paging .link_before:hover, .p-paging .link_next:hover {
  background: rgba(0, 0, 0, .7);
}
.p-paging .link_before {
  margin-right: 5px;
}
.p-paging .link_before:before {
  -webkit-transform: rotate(-135deg);
  -ms-transform: rotate(-135deg);
  transform: rotate(-135deg);
  margin: -5px 0 0 -3px;
}
.p-paging .link_next {
  margin-left: 5px;
}
.p-paging .link_next:before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  margin: -5px 0 0 -6px;
}

@media screen and (max-width: 768px) {
  .p-paging {
    margin: 45px 0 0;
    /* MT出力用 */
  }
  .p-paging_num {
    display: none;
  }
  .p-paging_num_link {
    width: 45px;
    height: 43px;
    line-height: 43px;
  }
  .p-paging_first, .p-paging_last, .p-paging_text {
    display: block;
  }
  .p-paging_prev_arrow, .p-paging_next_arrow {
    width: 45px;
    height: 45px;
  }
  .p-paging_first, .p-paging_last {
    text-align: center;
    border: 1px solid #000;
  }
  .p-paging_first {
    margin-right: 7px;
  }
  .p-paging_last {
    margin-left: 7px;
  }
  .p-paging_text {
    width: calc(100% - 194px);
    height: 45px;
    line-height: 45px;
    font-weight: bold;
    text-align: center;
  }
  .p-paging .link_first, .p-paging .link_last, .p-paging_text {
    display: block;
  }
  .p-paging .link_page, .p-paging .current_page {
    display: none;
  }
  .p-paging .link_before, .p-paging .link_next {
    width: 45px;
    height: 43px;
  }
  .p-paging .link_first, .p-paging .link_last {
    display: inline-block;
    width: 45px;
    height: 43px;
    line-height: 43px;
    text-align: center;
    border: 1px solid #000;
  }
  .p-paging .link_first {
    margin-right: 7px;
  }
  .p-paging .link_last {
    margin-left: 7px;
  }
  .p-paging_text {
    width: calc(100% - 194px);
    height: 45px;
    line-height: 45px;
    font-weight: bold;
    text-align: center;
  }
}
/* -----------------------------------------------
  .p-subcat
----------------------------------------------- */
.p-subcat_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -10px 0 0 -10px;
  font-size: 1.5rem;
}
.p-subcat_cat {
  margin: 10px 0 0 10px;
  border: 1px solid #e2e6ef;
}
.p-subcat_link {
  display: block;
  padding: 5px 20px;
  color: #008cd6;
}
.p-subcat_link:hover {
  text-decoration: none;
  background: #e2e6ef;
}
.p-subcat_arrowlist {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -5px;
}
.p-subcat_arrowcat {
  width: calc(100% / 3);
  margin-top: 5px;
  padding-right: 15px;
}

@media screen and (max-width: 768px) {
  .p-subcat_list {
    font-size: 1.4rem;
  }
  .p-subcat_arrowcat {
    width: calc(100% / 2);
  }
}
/* -----------------------------------------------
  .p-artlabel
----------------------------------------------- */
.p-artlabel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.p-artlabel_date {
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
  margin: 0;
  line-height: 1;
}
.p-artlabel_cat {
  display: inline-block;
  width: 170px;
  margin-top: .2em;
  padding: 5px 5px 6px;
  border: 1px solid #e2e6ef;
  border-radius: 13px;
  text-align: center;
  font-weight: 400;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .p-artlabel_date {
    -ms-flex-item-align: end;
    align-self: flex-end;
    margin-bottom: 20px;
  }
  .p-artlabel_cat {
    -ms-flex-item-align: start;
    align-self: flex-start;
    margin-top: -.3em;
  }
}
/* -----------------------------------------------
  .p-thumbList
----------------------------------------------- */
.p-thumbList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -30px 0 0 -40px;
}
.p-thumbList_wrap {
  width: calc(100% / 2 - 40px);
  margin: 30px 0 0 40px;
}
.p-thumbList_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.p-thumbList_image {
  position: relative;
  margin: 0;
}
.p-thumbList_image img {
  width: 210px;
  height: 118px;
  object-fit: cover;
}
.p-thumbList_image:before {
  content: ' ';
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 1;
  width: 54px;
  height: 54px;
  opacity: .7;
  background: url('/assets/images/common/ico_play.svg');
  background-size: cover;
}
.p-thumbList_main {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin: -.5em 0 0 20px;
}
.p-thumbList_label {
  margin-top: 10px;
  font-size: 1.2rem;
  color: #999;
  line-height: 1;
  letter-spacing: -.40em;
}
.p-thumbList_label_date, .p-thumbList_label_cat {
  display: inline-block;
  letter-spacing: normal;
  vertical-align: middle;
}
.p-thumbList_label_cat {
  margin-left: 10px;
  padding-left: 10px;
  border-left: 1px solid #999;
}

@media screen and (max-width: 768px) {
  .p-thumbList {
    margin: -25px 0 0 -15px;
  }
  .p-thumbList_wrap {
    width: calc(100% / 2 - 15px);
    margin: 25px 0 0 15px;
  }
  .p-thumbList_link {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .p-thumbList_main {
    -webkit-box-flex: 1;
    -ms-flex: auto;
    flex: auto;
    width: 100%;
    margin: 8px 0 0 0;
  }
  .p-thumbList_image {
    position: relative;
    width: 100%;
    padding-top: 56%;
  }
  .p-thumbList_image img {
    position: absolute;
    top: 0;
    left: 0;
    width: auto;
    height: 100%;
  }
  .p-thumbList_image:before {
    width: 35px;
    height: 35px;
  }
  .p-thumbList_label {
    margin-top: 5px;
    text-align: right;
  }
  .p-thumbList_label_cat {
    margin-top: 3px;
    margin-left: 0;
    padding-left: 0;
    border-left: none;
  }
}
/*!
 * Swiper 4.3.5
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * http://www.idangero.us/swiper/
 *
 * Copyright 2014-2018 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: July 31, 2018
 */
.swiper-container {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
}

.swiper-container-no-flexbox .swiper-slide {
  float: left;
}

.swiper-container-vertical > .swiper-wrapper {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  -webkit-transition-property: -webkit-transform, -webkit-transform;
  transition-property: transform, -webkit-transform;
  box-sizing: content-box;
}

.swiper-container-android .swiper-slide, .swiper-wrapper {
  -webkit-transform: translate3d(0px, 0, 0);
  transform: translate3d(0px, 0, 0);
}

.swiper-container-multirow > .swiper-wrapper {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.swiper-container-free-mode > .swiper-wrapper {
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-slide {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  -webkit-transition-property: -webkit-transform, -webkit-transform;
  transition-property: transform, -webkit-transform;
}

.swiper-invisible-blank-slide {
  visibility: hidden;
}

/* Auto Height */
.swiper-container-autoheight, .swiper-container-autoheight .swiper-slide {
  height: auto;
}

.swiper-container-autoheight .swiper-wrapper {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-transition-property: height, -webkit-transform;
  transition-property: height, -webkit-transform;
  transition-property: transform, height;
  -webkit-transition-property: -webkit-transform, height, -webkit-transform;
  transition-property: transform, height, -webkit-transform;
}

/* 3D Effects */
.swiper-container-3d {
  -webkit-perspective: 1200px;
  perspective: 1200px;
}

.swiper-container-3d .swiper-wrapper, .swiper-container-3d .swiper-slide, .swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top, .swiper-container-3d .swiper-slide-shadow-bottom, .swiper-container-3d .swiper-cube-shadow {
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
}

.swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top, .swiper-container-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-container-3d .swiper-slide-shadow-left {
  background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, .5)), to(transparent));
  background-image: -webkit-linear-gradient(right, rgba(0, 0, 0, .5), transparent);
  background-image: -webkit-linear-gradient(right, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to left, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-right {
  background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, .5)), to(transparent));
  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, .5), transparent);
  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to right, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-top {
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, .5)), to(transparent));
  background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, .5), transparent);
  background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to top, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, .5)), to(transparent));
  background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, .5), transparent);
  background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, .5), rgba(0, 0, 0, 0));
}

/* IE10 Windows Phone 8 Fixes */
.swiper-container-wp8-horizontal, .swiper-container-wp8-horizontal > .swiper-wrapper {
  -ms-touch-action: pan-y;
  touch-action: pan-y;
}

.swiper-container-wp8-vertical, .swiper-container-wp8-vertical > .swiper-wrapper {
  -ms-touch-action: pan-x;
  touch-action: pan-x;
}

.swiper-button-prev, .swiper-button-next {
  position: absolute;
  top: 50%;
  width: 50px;
  height: 50px;
  margin-top: -25px;
  z-index: 10;
  cursor: pointer;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: cover;
}

.swiper-button-prev.swiper-button-disabled, .swiper-button-next.swiper-button-disabled {
  opacity: .35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-prev, .swiper-container-rtl .swiper-button-next {
  left: 30px;
  right: auto;
  background-image: url('/assets/images/common/btn_slide_prev.svg');
}

.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  right: 30px;
  left: auto;
  background-image: url('/assets/images/common/btn_slide_next.svg');
}

.swiper-button-prev.swiper-button-white, .swiper-container-rtl .swiper-button-next.swiper-button-white {
  background-image: url('/assets/images/common/btn_slide_prev.svg');
}

.swiper-button-next.swiper-button-white, .swiper-container-rtl .swiper-button-prev.swiper-button-white {
  background-image: url('/assets/images/common/btn_slide_next.svg');
}

.swiper-button-prev.swiper-button-black, .swiper-container-rtl .swiper-button-next.swiper-button-black {
  background-image: url('/assets/images/common/btn_slide_prev.svg');
}

.swiper-button-next.swiper-button-black, .swiper-container-rtl .swiper-button-prev.swiper-button-black {
  background-image: url('/assets/images/common/btn_slide_next.svg');
}

.swiper-button-lock {
  display: none;
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  -webkit-transition: 300ms opacity;
  transition: 300ms opacity;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

/* Common Styles */
.swiper-pagination-fraction, .swiper-pagination-custom, .swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 10px;
  left: 0;
  width: 100%;
}

/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transform: scale(.33);
  -ms-transform: scale(.33);
  transform: scale(.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  -webkit-transform: scale(.66);
  -ms-transform: scale(.66);
  transform: scale(.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  -webkit-transform: scale(.33);
  -ms-transform: scale(.33);
  transform: scale(.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  -webkit-transform: scale(.66);
  -ms-transform: scale(.66);
  transform: scale(.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  -webkit-transform: scale(.33);
  -ms-transform: scale(.33);
  transform: scale(.33);
}

.swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  display: inline-block;
  border-radius: 100%;
  background: #000;
  opacity: .2;
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background: #007aff;
}

.swiper-container-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  -webkit-transform: translate3d(0px, -50%, 0);
  transform: translate3d(0px, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 6px 0;
  display: block;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 8px;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  -webkit-transition: 200ms top, 200ms -webkit-transform;
  transition: 200ms top, 200ms -webkit-transform;
  transition: 200ms transform, 200ms top;
  -webkit-transition: 200ms -webkit-transform, 200ms top, 200ms -webkit-transform;
  transition: 200ms transform, 200ms top, 200ms -webkit-transform;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 4px;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 200ms left, 200ms -webkit-transform;
  transition: 200ms left, 200ms -webkit-transform;
  transition: 200ms transform, 200ms left;
  -webkit-transition: 200ms -webkit-transform, 200ms left, 200ms -webkit-transform;
  transition: 200ms transform, 200ms left, 200ms -webkit-transform;
}

.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 200ms right, 200ms -webkit-transform;
  transition: 200ms right, 200ms -webkit-transform;
  transition: 200ms transform, 200ms right;
  -webkit-transition: 200ms -webkit-transform, 200ms right, 200ms -webkit-transform;
  transition: 200ms transform, 200ms right, 200ms -webkit-transform;
}

/* Progress */
.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, .25);
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #007aff;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-transform: scale(0);
  -ms-transform: scale(0);
  transform: scale(0);
  -webkit-transform-origin: left top;
  -ms-transform-origin: left top;
  transform-origin: left top;
}

.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  -webkit-transform-origin: right top;
  -ms-transform-origin: right top;
  transform-origin: right top;
}

.swiper-container-horizontal > .swiper-pagination-progressbar, .swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}

.swiper-container-vertical > .swiper-pagination-progressbar, .swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-white .swiper-pagination-bullet-active {
  background: #fff;
}

.swiper-pagination-progressbar.swiper-pagination-white {
  background: rgba(255, 255, 255, .25);
}

.swiper-pagination-progressbar.swiper-pagination-white .swiper-pagination-progressbar-fill {
  background: #fff;
}

.swiper-pagination-black .swiper-pagination-bullet-active {
  background: #000;
}

.swiper-pagination-progressbar.swiper-pagination-black {
  background: rgba(0, 0, 0, .25);
}

.swiper-pagination-progressbar.swiper-pagination-black .swiper-pagination-progressbar-fill {
  background: #000;
}

.swiper-pagination-lock {
  display: none;
}

/* Scrollbar */
.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, .1);
}

.swiper-container-horizontal > .swiper-scrollbar {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%;
}

.swiper-container-vertical > .swiper-scrollbar {
  position: absolute;
  right: 3px;
  top: 1%;
  z-index: 50;
  width: 5px;
  height: 98%;
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: rgba(0, 0, 0, .5);
  border-radius: 10px;
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
}

.swiper-zoom-container > img, .swiper-zoom-container > svg, .swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
}

/* Preloader */
.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  -webkit-transform-origin: 50%;
  -ms-transform-origin: 50%;
  transform-origin: 50%;
  -webkit-animation: swiper-preloader-spin 1s steps(12, end) infinite;
  animation: swiper-preloader-spin 1s steps(12, end) infinite;
}

.swiper-lazy-preloader:after {
  display: block;
  content: '';
  width: 100%;
  height: 100%;
  background-image: url('data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D\'0%200%20120%20120\'%20xmlns%3D\'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg\'%20xmlns%3Axlink%3D\'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink\'%3E%3Cdefs%3E%3Cline%20id%3D\'l\'%20x1%3D\'60\'%20x2%3D\'60\'%20y1%3D\'7\'%20y2%3D\'27\'%20stroke%3D\'%236c6c6c\'%20stroke-width%3D\'11\'%20stroke-linecap%3D\'round\'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(30%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(60%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(90%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(120%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(150%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.37\'%20transform%3D\'rotate(180%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.46\'%20transform%3D\'rotate(210%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.56\'%20transform%3D\'rotate(240%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.66\'%20transform%3D\'rotate(270%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.75\'%20transform%3D\'rotate(300%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.85\'%20transform%3D\'rotate(330%2060%2C60)\'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E');
  background-position: 50%;
  background-size: 100%;
  background-repeat: no-repeat;
}

.swiper-lazy-preloader-white:after {
  background-image: url('data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D\'0%200%20120%20120\'%20xmlns%3D\'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg\'%20xmlns%3Axlink%3D\'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink\'%3E%3Cdefs%3E%3Cline%20id%3D\'l\'%20x1%3D\'60\'%20x2%3D\'60\'%20y1%3D\'7\'%20y2%3D\'27\'%20stroke%3D\'%23fff\'%20stroke-width%3D\'11\'%20stroke-linecap%3D\'round\'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(30%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(60%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(90%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(120%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.27\'%20transform%3D\'rotate(150%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.37\'%20transform%3D\'rotate(180%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.46\'%20transform%3D\'rotate(210%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.56\'%20transform%3D\'rotate(240%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.66\'%20transform%3D\'rotate(270%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.75\'%20transform%3D\'rotate(300%2060%2C60)\'%2F%3E%3Cuse%20xlink%3Ahref%3D\'%23l\'%20opacity%3D\'.85\'%20transform%3D\'rotate(330%2060%2C60)\'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E');
}

@-webkit-keyframes swiper-preloader-spin {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes swiper-preloader-spin {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
/* a11y */
.swiper-container .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}

.swiper-container-fade .swiper-slide {
  pointer-events: none;
  -webkit-transition-property: opacity;
  transition-property: opacity;
}

.swiper-container-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-fade .swiper-slide-active, .swiper-container-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube {
  overflow: visible;
}

.swiper-container-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  -webkit-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-container-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-cube.swiper-container-rtl .swiper-slide {
  -webkit-transform-origin: 100% 0;
  -ms-transform-origin: 100% 0;
  transform-origin: 100% 0;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-next, .swiper-container-cube .swiper-slide-prev, .swiper-container-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible;
}

.swiper-container-cube .swiper-slide-shadow-top, .swiper-container-cube .swiper-slide-shadow-bottom, .swiper-container-cube .swiper-slide-shadow-left, .swiper-container-cube .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-container-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: .6;
  filter: blur(50px);
  z-index: 0;
}

.swiper-container-flip {
  overflow: visible;
}

.swiper-container-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
}

.swiper-container-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-flip .swiper-slide-active, .swiper-container-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-flip .swiper-slide-shadow-top, .swiper-container-flip .swiper-slide-shadow-bottom, .swiper-container-flip .swiper-slide-shadow-left, .swiper-container-flip .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-container-coverflow .swiper-wrapper {
  /* Windows 8 IE 10 fix */
  -ms-perspective: 1200px;
}

@media screen and (max-width: 768px) {
  .swiper-container {
    width: calc(100% - 30px);
    overflow: visible;
  }

  .swiper-button-prev, .swiper-button-next {
    width: 40px;
    height: 40px;
  }

  .swiper-button-prev, .swiper-container-rtl .swiper-button-next {
    left: -10px;
  }

  .swiper-button-next, .swiper-container-rtl .swiper-button-prev {
    right: -10px;
  }
}
/*****************************************************
  Print
*****************************************************/
/*****************************************************
  Clears
*****************************************************/
.l-container:after, .p-article:after {
  content: '';
  display: block;
  clear: both;
}